Projet

Général

Profil

Doc-geting-started » Historique » Version 30

Emmanuel GARETTE, 04/02/2013 12:02

1 1 Philippe Caseiro
h1. Premiers pas
2 1 Philippe Caseiro
3 6 Lionel Morin
Dans ce document vous trouverez toutes les étapes pour utiliser le dépôt standard Eole pour le packaging.
4 1 Philippe Caseiro
5 6 Lionel Morin
L'idée de départ de ce dépôt est de fournir un outil qui vous permet de disposer d'un environnement prêt à l'emploi
6 1 Philippe Caseiro
pour construire un paquet "Eole".
7 1 Philippe Caseiro
8 1 Philippe Caseiro
Il suffit de mettre les fichiers dans les bons répertoires.
9 1 Philippe Caseiro
10 1 Philippe Caseiro
h2. Le dépôt
11 1 Philippe Caseiro
12 7 Lionel Morin
Voici l’arborescence type d'un dépôt "standardisé" :
13 1 Philippe Caseiro
14 2 Philippe Caseiro
* */src/*
15 1 Philippe Caseiro
** *<appli>-<version>/*
16 1 Philippe Caseiro
** *plugins-<version>/nom/*
17 1 Philippe Caseiro
** *lang-<version>/nom/*
18 1 Philippe Caseiro
* */tmpl/*
19 1 Philippe Caseiro
* */dicos/*
20 1 Philippe Caseiro
* */pretemplate/*
21 1 Philippe Caseiro
* */posttemplate/*
22 1 Philippe Caseiro
* */postservice/*
23 20 Joël Cuissinat
* */diagnose/*
24 20 Joël Cuissinat
* */firewall/*
25 28 Emmanuel GARETTE
* */schedule/*
26 28 Emmanuel GARETTE
** *pre/*
27 28 Emmanuel GARETTE
** *post/*
28 28 Emmanuel GARETTE
* */bacula/*
29 28 Emmanuel GARETTE
** *fichier/*
30 28 Emmanuel GARETTE
** *restore/*
31 30 Emmanuel GARETTE
* */scripts/*
32 1 Philippe Caseiro
* */sql/*
33 1 Philippe Caseiro
** *gen/*
34 1 Philippe Caseiro
** *updates/*
35 1 Philippe Caseiro
** *conf/*
36 1 Philippe Caseiro
*** *gen/*
37 1 Philippe Caseiro
*** *updates/*
38 1 Philippe Caseiro
*** *pwd/*
39 1 Philippe Caseiro
* */sso/*
40 1 Philippe Caseiro
** *filtres/*
41 1 Philippe Caseiro
** *user-info/*
42 1 Philippe Caseiro
* */ldap/*
43 29 Joël Cuissinat
** *passwords/*
44 19 Joël Cuissinat
* */ead/*
45 21 Joël Cuissinat
** *actions/*
46 21 Joël Cuissinat
** *perms/*
47 21 Joël Cuissinat
** *roles/*
48 22 Joël Cuissinat
* */zephir/*
49 22 Joël Cuissinat
** *configs/*
50 22 Joël Cuissinat
** *srv/*
51 20 Joël Cuissinat
* */lib/*
52 20 Joël Cuissinat
** *eole/*
53 20 Joël Cuissinat
** *<source>/*
54 1 Philippe Caseiro
* */sharenvole/*
55 3 Philippe Caseiro
* _Makefile_
56 3 Philippe Caseiro
* _eole.mk_
57 3 Philippe Caseiro
* _apps.mk_
58 24 Daniel Dehennin
* *<appli>.mk*
59 1 Philippe Caseiro
60 1 Philippe Caseiro
Commentaires :
61 1 Philippe Caseiro
62 1 Philippe Caseiro
table{border:1px solid black}.
63 9 Philippe Caseiro
| */src/*                   | _Répertoire de destination des sources de l'application_                                                                                      |
64 2 Philippe Caseiro
| */src/<appli>-<version>/* | _Code source de l'application avec la possibilité de faire cohabiter plusieurs versions lors des mises à jour_                                |
65 1 Philippe Caseiro
| */src/plugins-<version>/* | _Répertoire contenant les plugins externes et ceux développés en interne pour cette version de l'application (un sous-répertoire par plugin)_ |
66 2 Philippe Caseiro
| */src/lang-<version>/*    | _Répertoire des traductions pour cette version (un sous-répertoire par langue)_                                                               |
67 1 Philippe Caseiro
| */tmpl/*                  | _Répertoire des templates eole_                                                                                                               |
68 1 Philippe Caseiro
| */dicos/*                 | _Répertoire des dictionnaires eole (XX_<appli>.xml[1])                                                                                        |
69 2 Philippe Caseiro
| */pretemplate/*           | _Répertoire des scripts (shell ou python) de pretemplate_                                                                                     |
70 1 Philippe Caseiro
| */posttemplate/*          | _Répertoire des scripts (shell ou python) de posttemplate_                                                                                    |
71 1 Philippe Caseiro
| */postservice/*           | _Répertoire des scripts (shell ou python) de postservice_                                                                                     |
72 22 Joël Cuissinat
| */diagnose/*              | _Répertoire des scripts de tests diagnose_                                                                                                    |
73 22 Joël Cuissinat
| */firewall/*              | _Répertoire des fichiers eole-firewall (.fw) statiques_                                                                                       |
74 27 Emmanuel GARETTE
| */schedule/pre/*          | _Répertoire des scripts schedule "pre" _                                                                                                      |
75 27 Emmanuel GARETTE
| */schedule/post/*         | _Répertoire des scripts schedule "post"_                                                                                                      |
76 1 Philippe Caseiro
| */bacula/fichier/*        | _Répertoire de description des fichiers à sauvegarder par Bacula_                                                                             |
77 30 Emmanuel GARETTE
| */bacula/restore/*        | _Répertoire des scripts de restauration Bacula_                                                                                               |
78 30 Emmanuel GARETTE
| */scripts/*               | _Répertoire des scripts exécutables par les utilisateurs_                                                                                     |
79 2 Philippe Caseiro
| */sql/*                   | _Répertoire des configurations pour la génération et la gestion des mise à jours des bases de données_                                        |
80 6 Lionel Morin
| */sql/gen/*               | _Répertoire des scripts sql à exécuter lors de la génération de la base de données_                                                           |
81 6 Lionel Morin
| */sql/updates*            | _Répertoire des scripts sql à exécuter lors de mise à jour de la base de données_                                                             |
82 2 Philippe Caseiro
| */sql/conf/*              | _Répertoire des configurations pour la gestion de la bases de données_                                                                        |
83 2 Philippe Caseiro
| */sql/conf/gen*           | _Répertoire du fichier de configuration de génération de la base de données_                                                                  |
84 9 Philippe Caseiro
| */sql/conf/updates*       | _Répertoire du fichier de configuration des mises à jour de la base de données_                                                               |
85 1 Philippe Caseiro
| */sql/conf/passwords*     | _Répertoire du fichier de configuration pour la gestion de mots de passe d'accès à la base de données_                                        |
86 1 Philippe Caseiro
| */sso/*                   | _Répertoire des configurations pour la gestion du SSO_                                                                                        |
87 1 Philippe Caseiro
| */sso/filtres/*           | _Répertoire des filtres sso (<appli>.ini, <appli>_apps.ini)_                                                                                  |
88 1 Philippe Caseiro
| */sso/user-info/*         | _Répertoire du profil sso (profil_<appli>.py)                                                                                                 |
89 1 Philippe Caseiro
| */ldap/*                  | _Répertoire des configurations pour la gestion des mots de passe d'accès au serveur ldap_                                                     |
90 22 Joël Cuissinat
| */ldap/passwords/*        | _Répertoire du fichier de  configuration du mot de passe ldap (<appli>.ini)_                                                                  |
91 22 Joël Cuissinat
| */ead/*                   | _Répertoire des configurations pour la gestion des actions EAD_                                                                               |
92 22 Joël Cuissinat
| */ead/actions/*           | _Répertoire des configurations pour la gestion des actions de l'EAD_                                                                          |
93 22 Joël Cuissinat
| */ead/perms/*             | _Répertoire des configurations pour la gestion des rôles de l'EAD_                                                                            |
94 22 Joël Cuissinat
| */ead/roles/*             | _Répertoire des configurations pour la gestion des associations de rôle de l'EAD_                                                             |
95 22 Joël Cuissinat
| */zephir/*                | _Répertoire des configurations pour la gestion des agents Zéphir_                                                                             |
96 22 Joël Cuissinat
| */zephir/configs*         | _Répertoire des configurations pour la gestion des configuration d'agents Zéphir_                                                             |
97 22 Joël Cuissinat
| */zephir/srv*             | _Répertoire des configurations pour la gestion des configuration d'agents de service Zéphir_                                                  |
98 22 Joël Cuissinat
| */lib/*                   | _Répertoire pour les fichiers de librairie (/usr/lib)_                                                                                        |
99 22 Joël Cuissinat
| */lib/eole/*              | _Répertoire pour les fichiers de librairie EOLE_                                                                                              |
100 22 Joël Cuissinat
| */lib/<source>/*          | _Répertoire pour les fichiers de librairie spécifiques à l'application_                                                                       |
101 2 Philippe Caseiro
| */sharenvole/*            | _Répertoire des scripts historiques d'aide à l'installation des applications envole (à éviter si possible)_                                   |
102 6 Lionel Morin
| Makefile                  | _Fichier de règles de "compilation"_                                                                                                          |
103 9 Philippe Caseiro
| eole.mk                   | _Règles standard Eole ! ne pas changer ce fichier_                                                                                            |
104 9 Philippe Caseiro
| apps.mk                   | _Règles pour l'installation de l'application web._                                                                                            |
105 25 Daniel Dehennin
| <appli>.mk                | _Règles pour supplémentaire du développeur à inclure dans Makefile_                                                                           |
106 1 Philippe Caseiro
107 1 Philippe Caseiro
h2. Etape 1 : Cloner le dépôt
108 3 Philippe Caseiro
109 3 Philippe Caseiro
@git clone http://dev-eole.ac-dijon.fr/git/eole-skeletor@
110 3 Philippe Caseiro
<pre>
111 3 Philippe Caseiro
Cloning into 'eole-skeletor'...
112 3 Philippe Caseiro
remote: Counting objects: 83, done.
113 3 Philippe Caseiro
remote: Compressing objects: 100% (71/71), done.
114 3 Philippe Caseiro
remote: Total 83 (delta 26), reused 0 (delta 0)
115 3 Philippe Caseiro
Unpacking objects: 100% (83/83), done.
116 3 Philippe Caseiro
</pre>
117 3 Philippe Caseiro
118 3 Philippe Caseiro
Vous disposez désormais d'un répertoire _eole-skeletor_. 
119 7 Lionel Morin
Ce répertoire contient un exemple type de dépôt standard.
120 3 Philippe Caseiro
121 3 Philippe Caseiro
h2. Etape 2: Créer votre propre dépôt
122 3 Philippe Caseiro
123 3 Philippe Caseiro
Lancer les commandes suivantes : 
124 3 Philippe Caseiro
125 3 Philippe Caseiro
@mkdir eole-monappli@
126 3 Philippe Caseiro
@cd eole-monappli@
127 3 Philippe Caseiro
@git init .@
128 3 Philippe Caseiro
@cp ../eole-skeletor/*.mk ../eole-skeletor/Makefile .@
129 3 Philippe Caseiro
@git add .@
130 3 Philippe Caseiro
@git commit -am "Premier commit : Ajout des fichiers Makefile standard"@
131 3 Philippe Caseiro
132 4 Philippe Caseiro
<pre>
133 4 Philippe Caseiro
user@host:code $ mkdir eole-monappli
134 4 Philippe Caseiro
user@host:code $ cd eole-monappli
135 4 Philippe Caseiro
user@host:code/eole-monappli $ git init .
136 4 Philippe Caseiro
Initialized empty Git repository in /tmp/eole-monappli/.git/
137 4 Philippe Caseiro
user@host:code/eole-monappli $ cp ../eole-skeletor/*.mk ../eole-skeletor/Makefile .
138 4 Philippe Caseiro
user@host:code/eole-monappli $ git add .
139 4 Philippe Caseiro
user@host:code/eole-monappli $ git commit -am "Premier commit : Ajout des fichiers Makefile standard"
140 4 Philippe Caseiro
[master (root-commit) 1be6951] Premier commit : Ajout des fichiers Makefile standard
141 4 Philippe Caseiro
3 files changed, 195 insertions(+)
142 4 Philippe Caseiro
create mode 100644 Makefile
143 4 Philippe Caseiro
create mode 100644 apps.mk
144 4 Philippe Caseiro
create mode 100644 eole.mk
145 4 Philippe Caseiro
user@host:code/eole-monappli $
146 4 Philippe Caseiro
</pre>
147 1 Philippe Caseiro
148 10 Philippe Caseiro
h2. Etape 3: Mise en place des fichiers (Makefile, dico, templates, sources, configurations...)
149 1 Philippe Caseiro
150 10 Philippe Caseiro
La première chose a faire est de mettre à jour le fichier Makefile pour qu'il corresponde a votre application.
151 26 Daniel Dehennin
Il faut mettre à jour 4 variables, SOURCE, EOLE_VERSION, VERSION et PKGAPPS 
152 1 Philippe Caseiro
153 26 Daniel Dehennin
* *SOURCE* contiens le nom de votre application
154 26 Daniel Dehennin
* *EOLE_VERSION* version EOLE cible, *2.3* ou *2.4* à l’heure actuelle
155 10 Philippe Caseiro
* *VERSION* contiens la version de votre application
156 11 Philippe Caseiro
* *PKGAPPS* contiens oui ou non, pour répondre à la question "voulez vous générer un paquet _monapplli-apps[2]_"
157 10 Philippe Caseiro
158 10 Philippe Caseiro
159 7 Lionel Morin
Pour que le "Makefile" installe votre fichier au bon endroit, il suffit de créer le répertoire adéquat et
160 1 Philippe Caseiro
d'y mettre votre fichier.
161 7 Lionel Morin
162 10 Philippe Caseiro
163 7 Lionel Morin
h3. Exemple d'ajout d'un dictionnaire "Eole" :
164 4 Philippe Caseiro
165 4 Philippe Caseiro
Il suffit de lancer les commandes suivantes : 
166 4 Philippe Caseiro
167 4 Philippe Caseiro
@mkdir dicos@
168 4 Philippe Caseiro
@cp XX_nom_appli.xml dicos@
169 4 Philippe Caseiro
170 3 Philippe Caseiro
<pre>
171 4 Philippe Caseiro
user@host:code/eole-monappli $ mkdir dicos
172 4 Philippe Caseiro
user@host:code/eole-monappli $ ls
173 4 Philippe Caseiro
apps.mk  dicos/  eole.mk  Makefile
174 4 Philippe Caseiro
user@host:code/eole-monappli $ cp /emplacement/de/mon/dico/XX_nom_appli.xml dicos
175 4 Philippe Caseiro
user@host:code/eole-monappli $ ls dicos
176 4 Philippe Caseiro
XX_nom_appli.xml
177 1 Philippe Caseiro
</pre>
178 1 Philippe Caseiro
179 1 Philippe Caseiro
Pour l'ajout d'un template la procédure est la même avec le répertoire tmpl.
180 1 Philippe Caseiro
181 1 Philippe Caseiro
h3. Exemple d'ajout de la génération d'une base de données
182 1 Philippe Caseiro
183 1 Philippe Caseiro
h4. Création de l'arborescence:
184 1 Philippe Caseiro
185 4 Philippe Caseiro
<pre>
186 4 Philippe Caseiro
├── sql
187 10 Philippe Caseiro
│   ├── conf
188 10 Philippe Caseiro
│   │   ├── gen
189 10 Philippe Caseiro
│   │   │   └── mon_appi.py
190 10 Philippe Caseiro
│   │   └── passwords
191 10 Philippe Caseiro
│   │       └── monappli.ini
192 10 Philippe Caseiro
│   └── gen
193 10 Philippe Caseiro
│       ├── premier_script.sql
194 10 Philippe Caseiro
│       └── second_script.sql
195 4 Philippe Caseiro
</pre>
196 4 Philippe Caseiro
197 4 Philippe Caseiro
@mkdir -p sql/conf/gen sql/conf/passwords sql/gen@
198 4 Philippe Caseiro
199 4 Philippe Caseiro
<pre>
200 4 Philippe Caseiro
user@host:code/eole-monappli $ mkdir -p sql/conf/gen sql/conf/passwords sql/gen
201 4 Philippe Caseiro
user@host:code/eole-monappli $ ls -R sql 
202 4 Philippe Caseiro
sql:
203 4 Philippe Caseiro
conf/  gen/
204 1 Philippe Caseiro
205 1 Philippe Caseiro
sql/conf:
206 4 Philippe Caseiro
gen/  passwords/
207 4 Philippe Caseiro
208 4 Philippe Caseiro
sql/conf/gen:
209 4 Philippe Caseiro
210 4 Philippe Caseiro
sql/conf/passwords:
211 4 Philippe Caseiro
212 4 Philippe Caseiro
sql/gen:
213 4 Philippe Caseiro
user@host:code/eole-monappli $ tree 
214 4 Philippe Caseiro
sql
215 4 Philippe Caseiro
├── conf
216 10 Philippe Caseiro
│   ├── gen
217 10 Philippe Caseiro
│   └── passwords
218 4 Philippe Caseiro
└── gen
219 4 Philippe Caseiro
</pre>
220 4 Philippe Caseiro
221 7 Lionel Morin
h4. Création des fichiers de configuration
222 4 Philippe Caseiro
223 4 Philippe Caseiro
Pour créer une base de données il faut plusieurs fichiers. 
224 4 Philippe Caseiro
* Un fichier de configuration pour la génération
225 4 Philippe Caseiro
* Un fichier de configuration pour la gestion des mots de passe d'accès à la base
226 7 Lionel Morin
* Les scripts SQL pour la création et l'initialisation de la base de données
227 4 Philippe Caseiro
228 4 Philippe Caseiro
h5. Fichier de Configuration pour la génération : 
229 4 Philippe Caseiro
230 7 Lionel Morin
Ce fichier contient les instructions nécessaires à la génération de la bases :
231 4 Philippe Caseiro
232 4 Philippe Caseiro
<pre><code class="python">
233 4 Philippe Caseiro
#-*-coding:utf-8-*-
234 4 Philippe Caseiro
###########################################################################
235 4 Philippe Caseiro
# Eole NG - 2011
236 4 Philippe Caseiro
# Copyright Pole de Competence Eole  (Ministere Education - Academie Dijon)
237 4 Philippe Caseiro
# Licence CeCill  cf /root/LicenceEole.txt
238 4 Philippe Caseiro
# eole@ac-dijon.fr
239 4 Philippe Caseiro
#
240 4 Philippe Caseiro
# gepi.py
241 4 Philippe Caseiro
#
242 4 Philippe Caseiro
# Création de la base de données mysql de gepi
243 4 Philippe Caseiro
#
244 4 Philippe Caseiro
###########################################################################
245 4 Philippe Caseiro
"""
246 4 Philippe Caseiro
Config pour gepi
247 4 Philippe Caseiro
"""
248 4 Philippe Caseiro
from eolesql.db_test import db_exists, test_var
249 4 Philippe Caseiro
250 4 Philippe Caseiro
GEPI_TABLEFILENAMES = ['/usr/share/eole/mysql/gepi/gen/gepi-create-0-initeole.sql',
251 4 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-1-structure.sql',
252 4 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-2-data.sql',
253 4 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-3-ajouteole.sql']
254 4 Philippe Caseiro
def test():
255 4 Philippe Caseiro
    """
256 4 Philippe Caseiro
    test l'existence de la base gepi
257 4 Philippe Caseiro
    """
258 4 Philippe Caseiro
    return test_var('activer_gepi') and not db_exists('gepi')
259 4 Philippe Caseiro
260 4 Philippe Caseiro
conf_dict = dict(filenames=GEPI_TABLEFILENAMES,
261 4 Philippe Caseiro
                 test=test)
262 4 Philippe Caseiro
</code></pre>
263 5 Philippe Caseiro
Il faut placer ce fichier dans le répertoire _*sql/conf/gen*_.
264 5 Philippe Caseiro
265 5 Philippe Caseiro
h5. Fichier de configuration de gestion des mots de passe
266 5 Philippe Caseiro
267 7 Lionel Morin
Ce fichier contient les instructions nécessaires au renouvellement des mots de passe
268 7 Lionel Morin
des utilisateurs ayant accès à la base de données. Les applications disposent d'un utilisateur
269 5 Philippe Caseiro
qui a des droits d'écriture dans les tables de la base, cet utilisateur a un mot de passe
270 7 Lionel Morin
qui est renouvelé régulièrement par les mécanismes "Eole". Ce fichier sert à faire en sorte
271 5 Philippe Caseiro
que la configuration de l'application soit mise à jour lors du changement du mot de passe.
272 5 Philippe Caseiro
273 5 Philippe Caseiro
Voici un exemple de fichier : 
274 5 Philippe Caseiro
275 5 Philippe Caseiro
276 5 Philippe Caseiro
<pre><code class="bash">
277 5 Philippe Caseiro
[gepi]
278 5 Philippe Caseiro
username=gepi
279 5 Philippe Caseiro
container=web
280 5 Philippe Caseiro
template=$dbPass="
281 5 Philippe Caseiro
filename=/var/www/html/gepi/secure/connect.inc.php
282 5 Philippe Caseiro
owner=root:www-data
283 5 Philippe Caseiro
chmod=660
284 5 Philippe Caseiro
</code></pre>
285 5 Philippe Caseiro
286 5 Philippe Caseiro
Quelques petites précisions : 
287 7 Lionel Morin
* username= nom de l'utilisateur utilisé par l'application pour accéder à la base
288 7 Lionel Morin
* container= nom du conteneur lxc où l'application est hébergée
289 7 Lionel Morin
* template= chaîne qui préfixe le mot de passe dans le fichier de configuration
290 7 Lionel Morin
* filname= fichier de configuration à mettre à jour
291 7 Lionel Morin
* owner= utilisateur et groupe propriétaire du fichier de configuration au format user:group
292 7 Lionel Morin
* chmod= droits du fichier au format XXX
293 5 Philippe Caseiro
294 5 Philippe Caseiro
Il faut placer ce fichier dans le répertoire _*sql/conf/passwords*_.
295 5 Philippe Caseiro
296 5 Philippe Caseiro
h5. Scripts SQL de création et d'initialisation de la base
297 5 Philippe Caseiro
298 7 Lionel Morin
Un seul script est obligatoire, le script de création (toujours le premier de la liste) 
299 5 Philippe Caseiro
<pre><code class="python">
300 7 Lionel Morin
# Liste des fichiers sql à exécuter (dans l'ordre)
301 5 Philippe Caseiro
GEPI_TABLEFILENAMES = ['/usr/share/eole/mysql/gepi/gen/gepi-create-0-initeole.sql',
302 5 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-1-structure.sql',
303 5 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-2-data.sql',
304 5 Philippe Caseiro
                       '/usr/share/eole/mysql/gepi/gen/gepi-create-3-ajouteole.sql']
305 5 Philippe Caseiro
</code></pre>
306 5 Philippe Caseiro
307 5 Philippe Caseiro
Dans l'exemple c'est le script _*/usr/share/eole/mysql/gepi/gen/gepi-create-0-initeole.sql*_.
308 5 Philippe Caseiro
309 7 Lionel Morin
Ce script est très souvent un "template" eole car on a besoin d'informations contenues dans la configuration "Eole".
310 5 Philippe Caseiro
311 7 Lionel Morin
Exemple :
312 5 Philippe Caseiro
313 5 Philippe Caseiro
<pre><code class="sql">
314 7 Lionel Morin
-- création de la base de données
315 5 Philippe Caseiro
CREATE DATABASE gepi CHARACTER SET utf8 COLLATE utf8_general_ci;
316 5 Philippe Caseiro
317 5 Philippe Caseiro
-- création du user de la base
318 5 Philippe Caseiro
grant all privileges on gepi.* to gepi@%%adresse_ip_web identified by 'gepi';
319 5 Philippe Caseiro
flush privileges ;
320 5 Philippe Caseiro
321 1 Philippe Caseiro
-- connexion à la base
322 1 Philippe Caseiro
\r gepi
323 1 Philippe Caseiro
324 1 Philippe Caseiro
325 1 Philippe Caseiro
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
326 1 Philippe Caseiro
</code></pre>
327 1 Philippe Caseiro
328 1 Philippe Caseiro
Comme ce fichier est un template il doit être placé dans le répertoire _*tmpl*_ et configuré dans le dico (dicos/XX_nom_appli.xml).
329 1 Philippe Caseiro
330 1 Philippe Caseiro
Les autres fichiers de la liste sont des scripts sql très souvent fournis par l'application et sont à placer dans le répertoire _*sql/gen*_.
331 1 Philippe Caseiro
332 1 Philippe Caseiro
h2. Tester l'installation via le Makefile standard
333 10 Philippe Caseiro
334 10 Philippe Caseiro
Lancer la commandes suivante depuis votre dépôt: 
335 10 Philippe Caseiro
336 10 Philippe Caseiro
@DESTDIR=/tmp/monappli make install@
337 10 Philippe Caseiro
338 10 Philippe Caseiro
<pre>
339 10 Philippe Caseiro
user@host code/mon_appi $ DESTDIR=/tmp/monappli make install
340 10 Philippe Caseiro
test ! -d sql/update || install -m 755 -d /tmp/monappli/usr/share/eole/mysql/eole-zarafa/updates
341 10 Philippe Caseiro
test ! -d sql/conf/gen || install -m 755 -d /tmp/monappli/usr/share/eole/applications/gen
342 10 Philippe Caseiro
install -m 755 -d /tmp/monappli/usr/share/eole
343 10 Philippe Caseiro
test ! -d zephir/srv || install -m 755 -d /services
344 10 Philippe Caseiro
test ! -d sso/user-info || install -m 755 -d /tmp/monappli/usr/share/sso/user_infos
345 10 Philippe Caseiro
install -m 755 -d /tmp/monappli/usr/share/eole/creole
346 10 Philippe Caseiro
test ! -d zephir/configs || install -m 755 -d /tmp/monappli/usr/share/zephir/monitor/configs
347 10 Philippe Caseiro
test ! -d zephir || install -m 755 -d /tmp/monappli/usr/share/zephir
348 10 Philippe Caseiro
test ! -d sso || install -m 755 -d /tmp/monappli/usr/share/sso
349 10 Philippe Caseiro
test ! -d lxc || install -m 755 -d /tmp/monappli/usr/share/eole/lxc
350 10 Philippe Caseiro
test ! -d sharenvole || install -m 755 -d /tmp/monappli/usr/share/envole/eole-zarafa
351 10 Philippe Caseiro
test ! -d sso/filtres || install -m 755 -d /tmp/monappli/usr/share/sso/app_filters
352 10 Philippe Caseiro
test ! -d posttemplate || install -m 755 -d /tmp/monappli/usr/share/eole/posttemplate
353 10 Philippe Caseiro
test ! -d lxc/fstab || install -m 755 -d /tmp/monappli/usr/share/eole/lxc/fstab
354 10 Philippe Caseiro
test ! -d postservice || install -m 755 -d /tmp/monappli/usr/share/eole/postservice
355 10 Philippe Caseiro
test ! -d tmpl || install -m 755 -d /tmp/monappli/usr/share/eole/creole/distrib
356 10 Philippe Caseiro
test ! -d pretemplate || install -m 755 -d /tmp/monappli/usr/share/eole/pretemplate
357 10 Philippe Caseiro
test ! -d sql/conf/passwords || install -m 755 -d /tmp/monappli/usr/share/eole/applications/passwords
358 10 Philippe Caseiro
test ! -d sql || install -m 755 -d /tmp/monappli/usr/share/eole/mysql/eole-zarafa
359 10 Philippe Caseiro
test ! -d dicos || install -m 755 -d /tmp/monappli/usr/share/eole/creole/dicos
360 10 Philippe Caseiro
test ! -d diagnose || install -m 755 -d /tmp/monappli/usr/share/eole/diagnose/module
361 10 Philippe Caseiro
test ! -d ldap/passwords || install -m 755 -d /tmp/monappli/usr/share/eole/annuaire/password_files
362 10 Philippe Caseiro
test ! -d sql/gen || install -m 755 -d /tmp/monappli/usr/share/eole/mysql/eole-zarafa/gen
363 10 Philippe Caseiro
if [ -d  sql/update ]; then for file in `ls -1  sql/update/`; do  install -m 644  sql/update/$file  /tmp/monappli/usr/share/eole/mysql/eole-zarafa/updates || true; done; fi
364 10 Philippe Caseiro
if [ -d  sql/conf/gen ]; then for file in `ls -1  sql/conf/gen/`; do  install -m 644  sql/conf/gen/$file  /tmp/monappli/usr/share/eole/applications/gen || true; done; fi
365 10 Philippe Caseiro
if [ -d  zephir/srv ]; then for file in `ls -1  zephir/srv/`; do  install -m 644  zephir/srv/$file  /services || true; done; fi
366 10 Philippe Caseiro
if [ -d  sso/user-info ]; then for file in `ls -1  sso/user-info/`; do  install -m 644  sso/user-info/$file  /tmp/monappli/usr/share/sso/user_infos || true; done; fi
367 10 Philippe Caseiro
if [ -d  zephir/configs ]; then for file in `ls -1  zephir/configs/`; do  install -m 644  zephir/configs/$file  /tmp/monappli/usr/share/zephir/monitor/configs || true; done; fi
368 10 Philippe Caseiro
if [ -d  zephir ]; then for file in `ls -1  zephir/`; do  install -m 644  zephir/$file  /tmp/monappli/usr/share/zephir || true; done; fi
369 10 Philippe Caseiro
if [ -d  sso ]; then for file in `ls -1  sso/`; do  install -m 644  sso/$file  /tmp/monappli/usr/share/sso || true; done; fi
370 10 Philippe Caseiro
if [ -d  lxc ]; then for file in `ls -1  lxc/`; do  install -m 644  lxc/$file  /tmp/monappli/usr/share/eole/lxc || true; done; fi
371 10 Philippe Caseiro
if [ -d  sharenvole ]; then for file in `ls -1  sharenvole/`; do  install -m 644  sharenvole/$file  /tmp/monappli/usr/share/envole/eole-zarafa || true; done; fi
372 10 Philippe Caseiro
if [ -d  sso/filtres ]; then for file in `ls -1  sso/filtres/`; do  install -m 644  sso/filtres/$file  /tmp/monappli/usr/share/sso/app_filters || true; done; fi
373 10 Philippe Caseiro
if [ -d  lxc/fstab ]; then for file in `ls -1  lxc/fstab/`; do  install -m 644  lxc/fstab/$file  /tmp/monappli/usr/share/eole/lxc/fstab || true; done; fi
374 10 Philippe Caseiro
if [ -d  tmpl ]; then for file in `ls -1  tmpl/`; do  install -m 644  tmpl/$file  /tmp/monappli/usr/share/eole/creole/distrib || true; done; fi
375 10 Philippe Caseiro
if [ -d  sql/conf/passwords ]; then for file in `ls -1  sql/conf/passwords/`; do  install -m 644  sql/conf/passwords/$file  /tmp/monappli/usr/share/eole/applications/passwords || true; done; fi
376 10 Philippe Caseiro
if [ -d  sql ]; then for file in `ls -1  sql/`; do  install -m 644  sql/$file  /tmp/monappli/usr/share/eole/mysql/eole-zarafa || true; done; fi
377 10 Philippe Caseiro
install: omission du répertoire « sql/conf »
378 10 Philippe Caseiro
if [ -d  dicos ]; then for file in `ls -1  dicos/`; do  install -m 644  dicos/$file  /tmp/monappli/usr/share/eole/creole/dicos || true; done; fi
379 10 Philippe Caseiro
if [ -d  ldap/passwords ]; then for file in `ls -1  ldap/passwords/`; do  install -m 644  ldap/passwords/$file  /tmp/monappli/usr/share/eole/annuaire/password_files || true; done; fi
380 10 Philippe Caseiro
if [ -d  sql/gen ]; then for file in `ls -1  sql/gen/`; do  install -m 644  sql/gen/$file  /tmp/monappli/usr/share/eole/mysql/eole-zarafa/gen || true; done; fi
381 10 Philippe Caseiro
if [ -d  posttemplate ]; then for file in `ls -1  posttemplate/`; do  install -m 755  posttemplate/$file  /tmp/monappli/usr/share/eole/posttemplate || true; done; fi
382 10 Philippe Caseiro
if [ -d  postservice ]; then for file in `ls -1  postservice/`; do  install -m 755  postservice/$file  /tmp/monappli/usr/share/eole/postservice || true; done; fi
383 10 Philippe Caseiro
if [ -d  pretemplate ]; then for file in `ls -1  pretemplate/`; do  install -m 755  pretemplate/$file  /tmp/monappli/usr/share/eole/pretemplate || true; done; fi
384 10 Philippe Caseiro
if [ -d  diagnose ]; then for file in `ls -1  diagnose/`; do  install -m 755  diagnose/$file  /tmp/monappli/usr/share/eole/diagnose/module || true; done; fi
385 10 Philippe Caseiro
user@host code/mon_appi $ tree /tmp/monappli
386 10 Philippe Caseiro
/tmp/monappli
387 10 Philippe Caseiro
└── usr
388 10 Philippe Caseiro
    └── share
389 10 Philippe Caseiro
        └── eole
390 10 Philippe Caseiro
            ├── applications
391 10 Philippe Caseiro
            │   ├── gen
392 10 Philippe Caseiro
            │   └── passwords
393 10 Philippe Caseiro
            ├── creole
394 10 Philippe Caseiro
            │   └── dicos
395 10 Philippe Caseiro
            └── mysql
396 10 Philippe Caseiro
                └── eole-monappli
397 10 Philippe Caseiro
                    └── gen
398 10 Philippe Caseiro
</pre>
399 10 Philippe Caseiro
400 18 Lionel Morin
Votre application a été installée dans _/tmp/monappli_ vous devriez y retrouver une arborescence similaire à celle de l'exemple.
401 10 Philippe Caseiro
402 10 Philippe Caseiro
403 10 Philippe Caseiro
fn1. XX = Ordre de traitement du dictionnaire (de 00 à 99).
404 14 Philippe Caseiro
405 17 Philippe Caseiro
fn2. Plus d'informations : http://dev-eole.ac-dijon.fr/projects/envole/wiki/EnvoleMigration23#%C3%89tape-3-la-division-des-paquets