Projet

Général

Profil

Doc-geting-started » Historique » Version 34

Lionel Morin, 19/06/2013 10:58

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