Projet

Général

Profil

Doc-geting-started » Historique » Version 32

Philippe Caseiro, 08/04/2013 10:27

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