Projet

Général

Profil

Doc-geting-started » Historique » Version 31

Joël Cuissinat, 08/03/2013 15:50

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