« Installation et mise en place de trac » : différence entre les versions

Aller à la navigation Aller à la recherche
aucun résumé des modifications
Aucun résumé des modifications
Aucun résumé des modifications
Ligne 6 : Ligne 6 :


Ce howto va vous montrer comment mettre en place ce système de tracking.
Ce howto va vous montrer comment mettre en place ce système de tracking.
Le domaine utilisé est <code>trac.pfoo.csnu.org</code> qui est un alias pour <code>core.csnu.org</code>.<br />
Le domaine utilisé est <code>trac.pfoo.domain.tld</code> qui est un alias pour <code>srv.domain.tld</code>.<br />
<code>core.csnu.org</code> est le domaine identifiant le serveur sur lequel se trouvera le trac. Il possède l'adresse ipv4 <code>213.186.47.110</code> et l'adresse ipv6 <code>2001:41d0:1:d6e::110</code>.
<code>srv.domain.tld</code> est le domaine identifiant le serveur sur lequel se trouvera le trac. Il possède l'adresse ipv4 <code>213.186.47.110</code> et l'adresse ipv6 <code>2001:41d0:1:d6e::110</code>.


Ce howto est construit de manière à respecter mon howto sur apache 2 ainsi que celui sur svn. Les changements de permissions effectués dans ce howto supposent que vous êtes en umask 0027
Ce howto est construit de manière à respecter mon howto sur apache 2 ainsi que celui sur svn. Les changements de permissions effectués dans ce howto supposent que vous êtes en umask 0027
Ligne 13 : Ligne 13 :
=Champs dns=
=Champs dns=


Éditez le fichier de la zone dns de votre domaine (<code>/srv/bind/csnu.org.hosts</code> dans mon cas) et ajoutez les lignes suivantes si elles ne sont pas présentent :
Éditez le fichier de la zone dns de votre domaine (<code>/srv/bind/domain.tld.hosts</code> dans mon cas) et ajoutez les lignes suivantes si elles ne sont pas présentent :
<pre>
<pre>
core.csnu.org.  IN      A      213.186.47.110
srv.domain.tld.  IN      A      213.186.47.110
core.csnu.org.  IN      AAAA    2001:41d0:1:d6e::110
srv.domain.tld.  IN      AAAA    2001:41d0:1:d6e::110
trac.pfoo      IN      CNAME  core.csnu.org.
trac.pfoo      IN      CNAME  srv.domain.tld.
</pre>
</pre>


Ligne 32 : Ligne 32 :
=Création de l'environnement trac=
=Création de l'environnement trac=


Nous allons créer un environnement trac nommé "trac" dans <code>/srv/http/csnu.org/pfoo.csnu.org/trac/</code> :
Nous allons créer un environnement trac nommé "trac" dans <code>/srv/http/domain.tld/pfoo.domain.tld/trac/</code> :
<pre>trac-admin /srv/http/csnu.org/pfoo.csnu.org/trac initenv</pre>
<pre>trac-admin /srv/http/domain.tld/pfoo.domain.tld/trac initenv</pre>


Il va falloir répondre à une série de questions:
Il va falloir répondre à une série de questions:
Ligne 40 : Ligne 40 :
Database connection string [sqlite:db/trac.db]> appuyez sur enter
Database connection string [sqlite:db/trac.db]> appuyez sur enter
Repository type [svn]> appuyez sur enter
Repository type [svn]> appuyez sur enter
Path to repository [/var/svn/test]> /srv/http/csnu.org/pfoo.csnu.org/svn/
Path to repository [/var/svn/test]> /srv/http/domain.tld/pfoo.domain.tld/svn/
Templates directory [/usr/share/trac/templates]> appuyez sur enter
Templates directory [/usr/share/trac/templates]> appuyez sur enter
</pre>
</pre>


Comme vous pouvez le voir, je couple trac avec mon dépôt subversion situé dans <code>/srv/http/csnu.org/pfoo.csnu.org/svn/</code>.
Comme vous pouvez le voir, je couple trac avec mon dépôt subversion situé dans <code>/srv/http/domain.tld/pfoo.domain.tld/svn/</code>.


Pour fonctionner, il faut que l'environnement trac soit accessible en lecture et en écriture par apache. Modifiez donc les droits d'accès :
Pour fonctionner, il faut que l'environnement trac soit accessible en lecture et en écriture par apache. Modifiez donc les droits d'accès :
<pre>
<pre>
chown -R root:www-data /srv/http/csnu.org/pfoo.csnu.org/trac/
chown -R root:www-data /srv/http/domain.tld/pfoo.domain.tld/trac/
chmod -R g+w /srv/http/csnu.org/pfoo.csnu.org/trac/
chmod -R g+w /srv/http/domain.tld/pfoo.domain.tld/trac/
</pre>
</pre>


Ligne 56 : Ligne 56 :
Nous allons maintenant créer deux utilisateurs ayant accès à trac. On préfèrera crypter les mots-de-passes en SHA (option -s)
Nous allons maintenant créer deux utilisateurs ayant accès à trac. On préfèrera crypter les mots-de-passes en SHA (option -s)
<pre>
<pre>
htpasswd -cs /srv/http/csnu.org/pfoo.csnu.org/trac.htpasswd pfoo
htpasswd -cs /srv/http/domain.tld/pfoo.domain.tld/trac.htpasswd pfoo
htpasswd -s /srv/http/csnu.org/pfoo.csnu.org/trac.htpasswd jonass
htpasswd -s /srv/http/domain.tld/pfoo.domain.tld/trac.htpasswd jonass
</pre>
</pre>


Bien-sur, il faut que ce fichier soit accessible par apache :
Bien-sur, il faut que ce fichier soit accessible par apache :
<pre>chown root:www-data /srv/http/csnu.org/pfoo.csnu.org/trac.htpasswd</pre>
<pre>chown root:www-data /srv/http/domain.tld/pfoo.domain.tld/trac.htpasswd</pre>


=Configuration de apache2=
=Configuration de apache2=


Créez le fichier <code>/etc/apache2/vhosts/trac.pfoo.csnu.org.conf</code> et ajoutez y les lignes suivantes :
Créez le fichier <code>/etc/apache2/vhosts/trac.pfoo.domain.tld.conf</code> et ajoutez y les lignes suivantes :
<pre><nowiki>
<pre><nowiki>
<VirtualHost 213.186.47.110:80>
<VirtualHost 213.186.47.110:80>
         ServerName trac.pfoo.csnu.org
         ServerName trac.pfoo.domain.tld
         Include sites/trac.pfoo.csnu.org.conf
         Include sites/trac.pfoo.domain.tld.conf
</VirtualHost>
</VirtualHost>
<VirtualHost [2001:41d0:1:d6e::110]:80>
<VirtualHost [2001:41d0:1:d6e::110]:80>
         ServerName trac.pfoo.csnu.org
         ServerName trac.pfoo.domain.tld
         Include sites/trac.pfoo.csnu.org.conf
         Include sites/trac.pfoo.domain.tld.conf
</VirtualHost>
</VirtualHost>
</nowiki></pre>
</nowiki></pre>
Ligne 83 : Ligne 83 :
==Avec CGI==
==Avec CGI==


Créez le fichier <code>/etc/apache2/sites/trac.pfoo.csnu.org.conf</code> et ajoutez y les lignes suivantes :
Créez le fichier <code>/etc/apache2/sites/trac.pfoo.domain.tld.conf</code> et ajoutez y les lignes suivantes :
<pre>
<pre>
ScriptAlias /trac /usr/share/trac/cgi-bin/trac.cgi
ScriptAlias /trac /usr/share/trac/cgi-bin/trac.cgi
<Location "/trac">
<Location "/trac">
   SetEnv TRAC_ENV "/srv/http/csnu.org/pfoo.csnu.org/trac/"
   SetEnv TRAC_ENV "/srv/http/domain.tld/pfoo.domain.tld/trac/"
</Location>
</Location>
<Location "/trac/login">
<Location "/trac/login">
   AuthType Basic
   AuthType Basic
   AuthName "Trac"
   AuthName "Trac"
   AuthUserFile /srv/http/csnu.org/pfoo.csnu.org/trac.htpasswd
   AuthUserFile /srv/http/domain.tld/pfoo.domain.tld/trac.htpasswd
   Require valid-user
   Require valid-user
</Location>
</Location>
Ligne 109 : Ligne 109 :
</pre>
</pre>


Créez le fichier <code>/etc/apache2/sites/trac.pfoo.csnu.org.conf</code> et ajoutez y les lignes suivantes :
Créez le fichier <code>/etc/apache2/sites/trac.pfoo.domain.tld.conf</code> et ajoutez y les lignes suivantes :
<pre><nowiki>
<pre><nowiki>
<Location /trac>
<Location /trac>
Ligne 115 : Ligne 115 :
   PythonInterpreter main_interpreter
   PythonInterpreter main_interpreter
   PythonHandler trac.web.modpython_frontend  
   PythonHandler trac.web.modpython_frontend  
   PythonOption TracEnv /srv/http/csnu.org/pfoo.csnu.org/trac/
   PythonOption TracEnv /srv/http/domain.tld/pfoo.domain.tld/trac/
   PythonOption TracUriRoot /trac
   PythonOption TracUriRoot /trac
   SetEnv PYTHON_EGG_CACHE /srv/http/csnu.org/pfoo.csnu.org/trac/cache/
   SetEnv PYTHON_EGG_CACHE /srv/http/domain.tld/pfoo.domain.tld/trac/cache/
</Location>
</Location>
<Location "/trac/login">
<Location "/trac/login">
   AuthType Basic
   AuthType Basic
   AuthName "Trac"
   AuthName "Trac"
   AuthUserFile /srv/http/csnu.org/pfoo.csnu.org/trac.htpasswd
   AuthUserFile /srv/http/domain.tld/pfoo.domain.tld/trac.htpasswd
   Require valid-user
   Require valid-user
</Location>
</Location>
Ligne 133 : Ligne 133 :
=Configuration de trac.ini=
=Configuration de trac.ini=


Le fichier de configuration de votre trac est <code>/srv/http/csnu.org/pfoo.csnu.org/trac/conf/trac.ini</code>.
Le fichier de configuration de votre trac est <code>/srv/http/domain.tld/pfoo.domain.tld/trac/conf/trac.ini</code>.
Vous pouvez le modifier à votre guise. Si vous souhaitez coupler votre trac avec un dépôt svn, il faut modifier la directive <code>repository_dir</code> afin qu'elle corresponde au chemin de votre dépôt subersion. Normalement, ceci est déjà fait étant donné que vous avez entré le chemin de votre dépôt lors de la création de l'environnement trac.
Vous pouvez le modifier à votre guise. Si vous souhaitez coupler votre trac avec un dépôt svn, il faut modifier la directive <code>repository_dir</code> afin qu'elle corresponde au chemin de votre dépôt subersion. Normalement, ceci est déjà fait étant donné que vous avez entré le chemin de votre dépôt lors de la création de l'environnement trac.


Ligne 139 : Ligne 139 :


Depuis <code>Trac 0.11</code> le plugin Webadmin est inclut par défaut avec Trac. Pour qu'un utilisateur puisse y accéder il suffit de lui ajouter la permission <code>TRAC_ADMIN</code>. Par exemple :
Depuis <code>Trac 0.11</code> le plugin Webadmin est inclut par défaut avec Trac. Pour qu'un utilisateur puisse y accéder il suffit de lui ajouter la permission <code>TRAC_ADMIN</code>. Par exemple :
<pre>trac-admin /srv/http/csnu.org/pfoo.csnu.org/trac/ permission add pfoo TRAC_ADMIN</pre>
<pre>trac-admin /srv/http/domain.tld/pfoo.domain.tld/trac/ permission add pfoo TRAC_ADMIN</pre>


En rechargeant la page de Trac vous verrez apparaître un bouton admin.
En rechargeant la page de Trac vous verrez apparaître un bouton admin.
Ligne 145 : Ligne 145 :
=Ajouter une feuille de style CSS=
=Ajouter une feuille de style CSS=


Vous pouvez embellir votre page trac avec une feuille de style CSS. Pour cela, rendez dans votre dossier trac (<code>/srv/http/csnu.org/pfoo.csnu.org/trac/</code> dans mon cas) et modifiez le fichier <code>templates/site.html</code> :
Vous pouvez embellir votre page trac avec une feuille de style CSS. Pour cela, rendez dans votre dossier trac (<code>/srv/http/domain.tld/pfoo.domain.tld/trac/</code> dans mon cas) et modifiez le fichier <code>templates/site.html</code> :
<pre><nowiki>
<pre><nowiki>
   <head py:match="head" py:attrs="select('@*')">
   <head py:match="head" py:attrs="select('@*')">
4 231

modifications

Menu de navigation