Le blog de Jean David TECHER, un Réunionnais à Saint-Priest/Lyon

Aller au contenu | Aller au menu | Aller à la recherche


< 1 2 3 4 5 6 7 8 >

samedi 20 décembre 2008

[Apache - OpenLDAP] Authentification Apache 1.3 et LDAP

Pour utiliser, l'authentification, il suffit de recourir en premier à l'installation du module ldap pour apache

wget http://www.rudedog.org/auth_ldap/auth_ldap-1.6.0.tar.gz
tar xvzf auth_ldap-1.6.0.tar.gz 
cd auth_ldap-1.6.0
./configure
make

On copie ensuite la librairie à l'endroit prévue à cet effet

cp auth_ldap.so /usr/lib/apache/1.3/

On active le module pour apache en ajoutant la ligne suivante dans /etc/apache/modules.conf

LoadModule auth_ldap_module /usr/lib/apache/1.3//auth_ldap.so

Pour l'accès à un répertoire, on spécifie ceci dans le fichier de configuration d'apache

<Directory "/chemin/vers/le/repertoire/">
	Options Indexes FollowSymLinks MultiViews Includes
	AllowOverride None
	Order allow,deny
	Allow from all
	AuthType basic
	AuthName "??? sur DavidGIS.fr: Acces reserve!"
	AuthLDAPEnabled on 
	AuthLDAPURL ldap://localhost:389/dc=chezdavid,dc=local?uid
	require valid-user
</Directory>

[FFMPEG] Conversion de fichiers .mpeg au format .flv

1. Documentation personnelle pour compilation - libmp3lame pour le son

Profitant de mon congé, j'en profite pour mettre à jour quelques unes des docs que j'ai. C'est vrai que parfois ffmpeg est très utile pour ce genre de conversion. malheureusement, parfois on ignore que c'est lipmp3lame qu'il faut pour obtenir le son. C'est ce que je propose dans cet article. J'ai commencé aujourd'hui en proposant un document aux formats suivants

2. Téléchargement de binaires et librairies personnelles pour Ubuntu

Mes binaires sont disponibles à http://www.davidgis.fr/download/mpeg2flv.tar.bz2

On télécharge et on vérifie les dépendances

david@bremko:/var/lib/david$ wget -q http://www.davidgis.fr:/download/mpeg2flv.tar.bz2
david@bremko:/var/lib/david$ tar xjf mpeg2flv.tar.bz2 
david@bremko:/var/lib/david$ cd mpeg2flv/
david@bremko:/var/lib/david/mpeg2flv$ LD_LIBRARY_PATH=${LD_LIBRARY_PATH}:$PWD ldd ffmpeg
	linux-gate.so.1 =>  (0xb7f0c000)
	libavdevice.so.52 (0xb7f03000)
	libavformat.so.52 (0xb7e1a000)
	libavcodec.so.52 (0xb76b5000)
	libavutil.so.49 (0xb76a6000)
	libm.so.6 => /lib/tls/i686/cmov/libm.so.6 (0xb765e000)
	libpthread.so.0 => /lib/tls/i686/cmov/libpthread.so.0 (0xb7646000)
	libc.so.6 => /lib/tls/i686/cmov/libc.so.6 (0xb74f7000)
	libz.so.1 => /usr/lib/libz.so.1 (0xb74e1000)
	libbz2.so.1.0 => /lib/libbz2.so.1.0 (0xb74d1000)
	libdl.so.2 => /lib/tls/i686/cmov/libdl.so.2 (0xb74cd000)
	libgsm.so.1 => /usr/lib/libgsm.so.1 (0xb74c0000)
	libmp3lame.so.0 (0xb7447000)
	/lib/ld-linux.so.2 (0xb7f0d000)

3. FrontEnd avec gtkdialog pour la conversion

Si on dispose de gtkdialog, j'ai fait un petit script à base de gtkdialog servant de frontend pour la conversion

Il suffit de taper ./convert.sh. La fenêtre suivante devrait apparaître


FrontEnd de conversion à base de GtkDialog

On peut ensuite utiliser un outil comme totem pour visualiser le résultat totem ~/clip1.flv


Visualisation avec Totem

Code de retour de wget

Supposons que j'ai le fichier urls.txt dont le contenu est le suivant

root@olivia:~# cat urls.txt
http://www.davidgis.fr
http://www.free.fr
http://www.zebigboss.fr
http://www.google.fr
http://www.google.frz
http://lame.sourceforge.net

Le code de retour avec wget pour une url est 0 en cas d'échec et 1 en cas de succès. Sous cette condition comme pour les booléens en C, on peut recourir à l'exemple suivant:

cat urls.txt
while read url;
do
 if wget -q "${url}";
 then
     echo "${url}";
  fi;
 done

Ou plus simplement

cat urls.txt|while read url; do wget -q "${url}" && echo "${url}";done

Ce qui donnera donc

http://www.davidgis.fr
http://www.free.fr
http://www.google.fr
http://lame.sourceforge.net

mercredi 17 décembre 2008

[PostGIS] PostGIS 1.3.5 is out! Tests avec MapServer 5.2.1 et PgRouting 1.03 pour le support de type LINE

Lundi 15 décembre 2008, PostGIS 1.3.5 est enfin sorti. Il s'agit une release mineur ayant pour but de rectifier des bugs notamment pour le TYPE LINESTRING avec MapServer, i.e. pour les layers de type LINE.

Conformément à l'un des mails relayés par Paul RAMSEY sur la mailing-list, Marc CAVE-AYLAND a fourni un sacré travail pour la correction de 3 bugs. N'ayons pas peur de lâcher les mots: il a déchiré sa race sur ce coup qui était un gros frein ces derniers mois pour MapServer...Et je pèse mes mots car depuis que la 5.2.0 de MapServer est sorti, parfois il fallait ruser en ayant recours à la fonction buffer() de PostGIS lorsque les données étaient de type LINE pour les convertir en POLYGON...Peut-être une petite ruse mais un mauvais plan dans le sens où le calcul debuffer impose des calculs géométriques assez important. Le calcul de buffer à la volée peut-être tolérable si la volumétrie en base est négligeable mais peut se révèler très pénalisant pour un serveur de production. Pour des données statiques, seul le stockage de buffer peut être envisagé mais peut aussi devenir contraignant si le stockage est aussi un frein (encombrement sur disque...)

En tentant de rendre hommage à MCA, je vais au travers de ce billet profiter du moment poru passer en revue de bonnes vieilles lignes de commandes à l'ancienne toujours à l'ancienne, comme toujours, histoire de lui rendre hommage

Let's go for ze tests!

Compilation de PostGIS 1.3.5

Comme à l'accoutumée.

wget http://www.postgis.org/download/postgis-1.3.5.tar.gz
tar xvzf postgis-1.3.5.tar.gz 
cd postgis-1.3.5
./configure 
make
make install
ldconfig

Compilation de MapServer 5.2.1

 wget http://download.osgeo.org/mapserver/mapserver-5.2.1.tar.gz
 tar xzf mapserver-5.2.1.tar.gz 
 cd mapserver-5.2.1
./configure --with-wms-client --with-wfsclient --with-wfs --with-postgis=/usr/local/pgsql/bin/pg_config --with-proj=/usr/local/ --with-geos=/usr/local/bin/geos-config --with-curl-config=/usr/bin/curl-config --with-fastcgi=/usr/lib/cgi-bin/ --with-proj=/usr/local --with-wfs --with-gd=/usr/local/ --with-ming=/usr/local/ --with-ogr=/usr/local/bin/gdal-config --with-gdal=/usr/local/bin/gdal-config --with-php=/root/php-5.2.1 --with-png --with-xml2-config=/usr/bin
make
cp mapscript/php3/php_mapscript.so  $(php-config --extension-dir)/

On vérifie juste que l'extension MapScript est bien prise en compte dans le php.ini

root@olivia:/mnt/sources/mapserver-5.2.1# grep php_mapscript.so /usr/lib/cgi-bin/php.ini 
extension=php_mapscript.so

Compilation de PgRouting 1.0.3

La pareil, j'ai tellement a flemme que rien ne vaut de belles captures d'écran. Donc on télécharge, on décompresse, et on fait un beau cmake

Et maintenant, on installe

Création d'une base de données PostGIS + PgRouting et d'un mini jeu de données

Comme toujours à l'ancienne, on crée la base avec les fonctionnalités de PostGIS et on vérifie grâce à postgis_full_version() que c'est bon.

createdb testrouting
createlang plpgsql testrouting
psql -d testrouting -f /usr/local/pgsql/share/lwpostgis.sql 
psql -d testrouting -f /usr/local/pgsql/share/spatial_ref_sys.sql 
psql -d testrouting -c "SELECT postgis_full_version()"
root@olivia:~# psql -d testrouting -c "SELECT postgis_full_version()"
                               postgis_full_version                               
----------------------------------------------------------------------------------
 POSTGIS="1.3.5" GEOS="3.0.0-CAPI-1.4.1" PROJ="Rel. 4.6.0, 21 Dec 2007" USE_STATS
(1 ligne)

Ok super!!!Maintenant on charge les fonctionnalités de PgRouting

for file in $(ls /usr/share/postlbs/*);do psql -d testrouting -f $file;done

On charge maintenant un petit jeu de données (voir l'article ici

 wget http://www.davidgis.fr/download/pgrouting_wr.sql
 psql -d testrouting -f pgrouting_wr.sql

MapServer: création de la MapFile et affichage en SVG

Conformément à l'article, on prendra la Mapfile suivante

Remarque: Conformément à la doc de PostgreSQL 8.2 pour le tuning, on prendra en considération ici que mes données sont très peu nombreuses donc je m'autorise pour le layer de nommé path de laisser mon ORDER BY sans reconfigurer mon serveur mais pour une mise en production , il est bon d'agir sur des paramètres comme work_mem de PostgreSQL - pour limiter l'écriture de fichiers temporaires sur disque - afin de fournir le meilleur tuning de base au niveau perf'...

MAP
  EXTENT 65.8612518310547 -88.3858108520508 300.999877929688 126.77375793457
  IMAGECOLOR 255 255 255
  FONTSET "/var/www/demo_routing/map/fonts.txt"
  SYMBOLSET "/var/www/demo_routing/map/symbols.sym"
  SIZE 500 457.336021282363



  IMAGETYPE svg

  OUTPUTFORMAT
    NAME svg
    MIMETYPE "image/svg+xml"
    DRIVER svg
    FORMATOPTION  "COMPRESSED_OUTPUT=FALSE"
    FORMATOPTION  "FULL_RESOLUTION=TRUE"        
  END

  STATUS ON
  NAME "wr"

  WEB
    IMAGEPATH "/var/www/tmp/"
    IMAGEURL "/tmp/"

    LOG /var/www/tmp/mapserver.log 
  END



LAYER
NAME "network"
    CONNECTION "user=postgres dbname=testrouting host=localhost"
    CONNECTIONTYPE POSTGIS
    DATA "the_geom from (select the_geom,gid from wr) as foo USING UNIQUE gid USING SRID=-1"
    TYPE LINE
    STATUS ON
    CLASS
	STYLE
          COLOR 0 123 0
          OUTLINECOLOR 255 255 0
        END
    END
END

LAYER
NAME "restrictions"
    CONNECTION "user=postgres dbname=testrouting host=localhost"
    CONNECTIONTYPE POSTGIS
    DATA "the_geom from (SELECT  the_geom,gid FROM wr  WHERE NOT (nullvalue(rule) AND nullvalue(to_cost)) ) as foo USING UNIQUE gid USING SRID=-1"
    TYPE LINE
    STATUS ON
    CLASS
        STYLE
          COLOR 255 0 0
          OUTLINECOLOR 255 255 0
        END
    END
END



LAYER
NAME "path"
    CONNECTION "user=postgres dbname=testrouting host=localhost"
    CONNECTIONTYPE POSTGIS
    DATA "the_geom FROM (SELECT the_geom,gid FROM wr RIGHT JOIN (SELECT edge_id FROM shortest_path_shooting_star('SELECT gid as id, source, target, cost, reverse_cost,x1, y1,x2, y2, rule, to_cost FROM wr order by id',20,8,true,true)) AS x(e) ON (x.e=wr.gid)) as foo USING UNIQUE gid USING SRID=-1"
    TYPE LINE
    STATUS ON
    CLASS
        STYLE
          COLOR 0 0 189
          OUTLINECOLOR 255 255 0
        END
    END
END


END

Et on aura donc


En vert le réseau, en rouge les tronçons inaccessibles, en bleu le plus court chemin pour joindre les deux extrémités du réseau tout en prenant en compte les tronçons inaccessibles

Tout ça pour ca!!