Commit aeceeabdc7375e1fcb6bcf6f77b972e24a3159dc

Authored by Alexandre
1 parent 765345a6

Version: 2.5.4.1

Maj docs (install, schema bdd) + bugfixes
	   
Version majeure en cours (2.5): https://projects.irap.omp.eu/versions/99

ROADMAP: https://projects.irap.omp.eu/projects/labinvent/roadmap
README-LABINVENT.md
@@ -51,16 +51,9 @@ Logiciel testé et validé sur les configurations suivantes : @@ -51,16 +51,9 @@ Logiciel testé et validé sur les configurations suivantes :
51 VERSION ACTUELLE 51 VERSION ACTUELLE
52 52
53 Date: 30/06/2016 53 Date: 30/06/2016
54 -Version: 2.5.4.0 54 +Version: 2.5.4.1
55 55
56 -!!! Se placer dans database/update et exécuter le script ./db-update-2016-06-30.sh !!!  
57 -  
58 -statut suivi + modif icone + liste - cacher n/a + divers ajustements + envoi mails + bugfixes  
59 -  
60 -Demande terminé : https://projects.irap.omp.eu/issues/3759  
61 - https://projects.irap.omp.eu/issues/3923  
62 - https://projects.irap.omp.eu/issues/3922  
63 - https://projects.irap.omp.eu/issues/3917 56 +Maj docs (install, schema bdd) + bugfixes
64 57
65 Version majeure en cours (2.5): https://projects.irap.omp.eu/versions/99 58 Version majeure en cours (2.5): https://projects.irap.omp.eu/versions/99
66 59
database/BDD_IRAP.mwb
No preview for this file type
database/BDD_IRAP.pdf
No preview for this file type
database/BDD_IRAP.png

128 KB | W: | H:

171 KB | W: | H:

  • 2-up
  • Swipe
  • Onion skin
install/INSTALLATION.txt
@@ -194,6 +194,11 @@ sudo a2dismod mpm_event @@ -194,6 +194,11 @@ sudo a2dismod mpm_event
194 sudo a2enmod mpm_prefork 194 sudo a2enmod mpm_prefork
195 </pre> 195 </pre>
196 196
  197 + * Activer le mode rewrite de Apache:
  198 +<pre>
  199 +sudo a2enmod rewrite
  200 +</pre>
  201 +
197 202
198 * *Configuration de Php* 203 * *Configuration de Php*
199 204
@@ -251,13 +256,14 @@ cd install/ @@ -251,13 +256,14 @@ cd install/
251 (vous pourriez éventuellement le faire en tant qu'administrateur "root", mais ça n'est pas nécessaire, le script fera quelques petits "sudo" seulement au besoin). 256 (vous pourriez éventuellement le faire en tant qu'administrateur "root", mais ça n'est pas nécessaire, le script fera quelques petits "sudo" seulement au besoin).
252 (Conseil : à la plupart des questions, laissez les réponses par défaut) 257 (Conseil : à la plupart des questions, laissez les réponses par défaut)
253 258
254 -h3. C/ CONFIGURATION WEB 259 +---
  260 +
  261 +h3. C/ CONFIGURATION DU SITE WEB
255 262
256 * Autoriser les fichiers .htaccess sur le site : 263 * Autoriser les fichiers .htaccess sur le site :
257 (cf http://book.cakephp.org/3.0/fr/installation.html#url-rewriting) 264 (cf http://book.cakephp.org/3.0/fr/installation.html#url-rewriting)
258 -  
259 <pre> 265 <pre>
260 -Allez dans le fichier /etc/apache2/apache2.conf, vérifier que la propriété 'AllowOverride' soit à la valeur 'All' pour le chemin correspondant à votre application (dossier '/' si '/var/www' non présent) : 266 +Allez dans le fichier /etc/apache2/apache2.conf (ou httpd.conf sur CentOS), vérifier que la propriété 'AllowOverride' soit à la valeur 'All' pour le chemin correspondant à votre application (dossier '/' si '/var/www' non présent) :
261 267
262 <Directory /> 268 <Directory />
263 Options FollowSymLinks 269 Options FollowSymLinks
@@ -276,65 +282,64 @@ Sinon, vous pouvez ajouter ceci, uniquement pour Labinvent, les attributs seront @@ -276,65 +282,64 @@ Sinon, vous pouvez ajouter ceci, uniquement pour Labinvent, les attributs seront
276 NB : si labinvent n'est pas dans le repertoire des sites webs, il faut mettre son chemin absolu a la place de /labinvent : 282 NB : si labinvent n'est pas dans le repertoire des sites webs, il faut mettre son chemin absolu a la place de /labinvent :
277 <Directory /chemin/abosolu/vers/labinvent> 283 <Directory /chemin/abosolu/vers/labinvent>
278 284
  285 +NB: Il faudra sans doute aussi faire un lien dans le dossier web racine de Apache (/var/www/html/) vers le repertoire d'installation
  286 +
  287 +NB: Une autre solution consisterait à créer un virtual host dédié
279 </pre> 288 </pre>
280 289
281 290
282 -* Activer le mode rewrite de Apache :  
283 -> sudo a2enmod rewrite  
284 291
285 * Redémarrer Apache 292 * Redémarrer Apache
286 293
287 -* Tester l'accès web à l'application : http://localhost/labinvent.git/  
288 -  
289 -* Vous devriez arriver par défaut sur une page correspondant au mode install, elle vous indique la bonne configuration de l'application et de ses dépendances  
290 -  
291 -* Vérifier simplement (point vert) si votre base sql est bien relié à votre application, si les droits données au dossiers temporaires sont suffisant, et si toutes les extensions sont bien intallées.  
292 -(La page affichera un message si l'URL-Rewriting ne fonctionne pas correctement)  
293 -  
294 -* Dans le cas contraire, reporter vous à l'extension correspondant ci-dessous, pour l'installer ou la configurer, puis aller à la section Configuration : 294 +* Tester l'accès web à l'application : http://localhost/labinvent/
  295 +Vous devriez arriver par défaut sur une page correspondant au mode install, elle vous indique la bonne configuration de l'application et de ses dépendances.
  296 +Vérifier simplement (point vert) si votre base de données est bien reliée à votre application, si les droits donnés aux dossiers temporaires sont suffisants, et si toutes les extensions sont bien intallées...
  297 +(La page affichera un message si l'URL-Rewriting ne fonctionne pas correctement).
  298 +Si tout est au vert, passez à l'étape suivante (D/ Configuration de l'application).
  299 +S'il y a des points rouges, reportez-vous ci-dessous à l'extension qui pose problème, pour l'installer ou la configurer:
295 300
296 * Extension PHP "mbstring" et librairie "zlib" 301 * Extension PHP "mbstring" et librairie "zlib"
297 -La collection de librairies est normalement déja installée avec PHP en tant que dépendances, sinon faire :  
298 -> sudo apt-get install libapache2-mod-php5  
299 -=> Redémarrer votre serveur et vérifier que la ligne correspondant à l'extension soit passé au vert.  
300 - 302 +La collection de librairies est normalement déja installée avec PHP en tant que dépendance, sinon faire :
  303 +<pre>
  304 +sudo apt-get install libapache2-mod-php5
  305 +</pre>
  306 +=> Redémarrer votre serveur et vérifier que la ligne correspondant à l'extension soit passée au vert.
301 307
302 * Librairie PHP "php-gd" 308 * Librairie PHP "php-gd"
303 -> sudo apt-get install php5-gd  
304 -=> Redémarrer votre serveur et vérifier que la ligne correspondant à l'extension soit passé au vert. 309 +<pre>
  310 +sudo apt-get install php5-gd
  311 +</pre>
  312 +=> Redémarrer votre serveur et vérifier que la ligne correspondant à l'extension soit passée au vert.
305 Si ce n'est toujours pas le cas, aller dans le fichier /etc/php5/apache2/php.ini : 313 Si ce n'est toujours pas le cas, aller dans le fichier /etc/php5/apache2/php.ini :
306 Vérifier que la ligne suivante est présente et décommentée (absence de ";" devant la ligne) sinon il faut la rajouter : 314 Vérifier que la ligne suivante est présente et décommentée (absence de ";" devant la ligne) sinon il faut la rajouter :
307 <pre> 315 <pre>
308 extension=gd.so 316 extension=gd.so
309 </pre> 317 </pre>
310 -=> Redémarrer votre serveur et vérifier que la ligne correspondant à l'extension soit passé au vert.  
311 318
  319 +* (Optionnel) Il est aussi conseillé d'avoir un "phpmyadmin" installé pour pouvoir gérer manuellement la base de données.
  320 +<pre>
  321 +sudo apt-get php5-mcrypt
  322 +sudo apt-get install phpmyadmin
  323 +Pensez à activer l'extension mcrypt : sudo php5enmod mcrypt
  324 +</pre>
312 325
313 -* Il est aussi conseillé d'avoir un "phpmyadmin" installé pour pouvoir gérer manuellement la base de données.  
314 -> sudo apt-get php5-mcrypt  
315 -> sudo apt-get install phpmyadmin  
316 -> Pensez à activer l'extension mcrypt : sudo php5enmod mcrypt  
317 -> Vous devez maintenant redémarrer Apache :  
318 -> > sudo service apache2 restart 326 +* Redémarrer votre serveur Web et vérifier que la ligne correspondant à l'extension soit passée au vert.
  327 +<pre>
  328 +sudo service apache2 restart
319 (ou simplement le recharger: utiliser "reload" au lieu de "restart") 329 (ou simplement le recharger: utiliser "reload" au lieu de "restart")
320 - 330 +</pre>
321 331
322 * URL-Rewriting 332 * URL-Rewriting
323 Il est possible que le mode rewrite ne fonctionne pas correctement si les fichiers .htaccess dans la racine et dans webroot disparaissent. Sur certains systèmes les fichiers commençant par un point peuvent disparaitre lors d'une copie. Si c'est le cas pour vous, voici le contenu de ces deux fichiers et leurs emplacements : 333 Il est possible que le mode rewrite ne fonctionne pas correctement si les fichiers .htaccess dans la racine et dans webroot disparaissent. Sur certains systèmes les fichiers commençant par un point peuvent disparaitre lors d'une copie. Si c'est le cas pour vous, voici le contenu de ces deux fichiers et leurs emplacements :
324 -  
325 <pre> 334 <pre>
326 Fichier ./.htaccess : 335 Fichier ./.htaccess :
327 -  
328 <IfModule mod_rewrite.c> 336 <IfModule mod_rewrite.c>
329 RewriteEngine on 337 RewriteEngine on
330 RewriteRule ^$ webroot/ [L] 338 RewriteRule ^$ webroot/ [L]
331 RewriteRule (.*) webroot/$1 [L] 339 RewriteRule (.*) webroot/$1 [L]
332 </IfModule> 340 </IfModule>
333 -</pre>  
334 341
335 -<pre>  
336 Fichier ./webroot/.htaccess : 342 Fichier ./webroot/.htaccess :
337 -  
338 <IfModule mod_rewrite.c> 343 <IfModule mod_rewrite.c>
339 RewriteEngine On 344 RewriteEngine On
340 RewriteCond %{REQUEST_FILENAME} !-f 345 RewriteCond %{REQUEST_FILENAME} !-f
@@ -342,29 +347,16 @@ Fichier ./webroot/.htaccess : @@ -342,29 +347,16 @@ Fichier ./webroot/.htaccess :
342 </IfModule> 347 </IfModule>
343 </pre> 348 </pre>
344 349
345 -h3. D/ TESTS  
346 -  
347 -* Nous vous conseillons de vérifier que les tests passent pour être sur que l'application est correctement installée.  
348 -  
349 -* Placez-vous à la racine du projet et exécutez la commande suivante :  
350 -<pre>  
351 -vendor/bin/phpunit  
352 -</pre>  
353 -  
354 -* Si ça ne marche pas, esssayer cette commande à la place:  
355 -<pre>  
356 -vendor/phpunit/phpunit/phpunit  
357 -</pre>  
358 350
359 -h3. E/ CONFIGURATION de l'application 351 +---
360 352
361 -* Une fois les tests validés, allez sur l'application. 353 +h3. D/ CONFIGURATION DU LOGICIEL D'INVENTAIRE
362 354
363 -* Vous arrivez sur une page d'informations, vous pouvez également configurer les paramètres généraux de l'application. 355 +* Depuis la page web de configuration "Configurer votre Labinvent", cliquez sur le lien "Editer la configuration générale" (en bas à gauche) pour configurer le logiciel, puis cliquez sur "Valider".
364 356
365 -* Une fois configurer vous pouvez stopper le mode install . 357 +* Maintenant, sortez du "mode installation" en cliquant sur le bouton "Stopper le mode installation"
366 358
367 -* Allez dans le dossier config à la racine du projet, et ouvrez le fichier ./config/app.php 359 +* Allez dans le dossier config à la racine du projet, et ouvrez le fichier config/app.php
368 <pre> 360 <pre>
369 Allez à la ligne 12 : 361 Allez à la ligne 12 :
370 'debug' => filter_var(env('DEBUG', true), FILTER_VALIDATE_BOOLEAN), 362 'debug' => filter_var(env('DEBUG', true), FILTER_VALIDATE_BOOLEAN),
@@ -373,27 +365,40 @@ Et remplacer le true par false : @@ -373,27 +365,40 @@ Et remplacer le true par false :
373 'debug' => filter_var(env('DEBUG', false), FILTER_VALIDATE_BOOLEAN), 365 'debug' => filter_var(env('DEBUG', false), FILTER_VALIDATE_BOOLEAN),
374 </pre> 366 </pre>
375 367
376 -* Connectez vous à l'aide de l'utilisateur créer lors de la création de la base et sans mot de passe. 368 +* Connectez-vous à l'aide du login utilisateur créé lors de la création de la base, SANS mot de passe
377 369
378 -* Si vous n'avez pas configurer l'application avec le mode install 370 +* Si vous n'avez pas configuré l'application avec le mode install
379 Dans le menu latéral, cliquez sur le lien "Outils", puis sur "Configuration générale de l'application". 371 Dans le menu latéral, cliquez sur le lien "Outils", puis sur "Configuration générale de l'application".
  372 +Sur cette page vous pouvez voir la configuration de votre application (nom, mode, ...) et l'éditer.
380 373
381 -* Sur cette page vous pouvez voir la configuration de votre application (nom, mode, ...) et l'éditer. 374 +* Ensuite retournez dans la liste des outils et cliquez sur "Gérer le contenu variable de l'application".
382 375
383 -* Ensuite retourner dans la liste des outils et cliquez sur "Gérer le contenu variable de l'application". 376 +* Sur cette page vous aurez accès à toutes les données statiques communes aux matériels (catégories, groupes métier et techniques, types de suivi, ...). Vous pouvez en ajouter, en supprimer ou les éditer..
384 377
385 -* Sur cette page vous aurez accès à toutes les données statiques commune au matériels (catégories, groupe métier et technique, type de suivi, ...).  
386 -Vous pouvez en ajouter, en supprimer ou les éditer..  
387 378
388 -h3. F/ Gestion de l'authentification des utilisateurs (LDAP) 379 +---
389 380
390 -* Labinvent peut être utilisé avec un LDAP, si vous utilisez ce mode, ceci vous concerne : 381 +h3. E/ TESTS
391 382
392 -* Une fois la connection au LDAP configuré (configuration générale de l'application), vous pouvez connecter un utilisateur de ce LDAP directement. 383 +* Nous vous conseillons de vérifier que les tests passent pour être sur que l'application est correctement installée.
393 384
394 -* Par défaut, un utilisateur provenant du LDAP a un statut de simple utilisateur, pour lui attribuer un rôle supérieur, il faut aller dans "gérer les utilisateurs privilégiés" du menu "outils". 385 +* Placez-vous à la racine du projet et exécutez la commande suivante :
  386 +<pre>
  387 +vendor/bin/phpunit
  388 +</pre>
395 389
396 -* Puis il faut ajouter l'utilisateur correspondant (liste déroulante des utilisateurs du LDAP), en lui attribuant un rôle. 390 +* Si ça ne marche pas, esssayer cette commande à la place:
  391 +<pre>
  392 +vendor/phpunit/phpunit/phpunit
  393 +</pre>
  394 +
  395 +h3. F/ Gestion de l'authentification des utilisateurs via un annuaire LDAP
  396 +
  397 +Labinvent peut être utilisé avec un LDAP. Si vous utilisez ce mode, ceci vous concerne :
  398 +
  399 +* Une fois la connexion au LDAP configurée (configuration générale de l'application), toute personne enregistrée dans l'annuaire LDAP peut désormais se connecter au logiciel.
  400 +
  401 +* Par défaut, un utilisateur provenant du LDAP a un statut de simple "utilisateur". Pour lui attribuer un rôle supérieur (privilégié), il faut aller dans "Gérer les utilisateurs privilégiés" du menu "Outils" pour l'y ajouter (liste déroulante des utilisateurs du LDAP), en lui attribuant un rôle.
397 402
398 --- 403 ---
399 404
@@ -426,22 +431,9 @@ Placez vous dans ./database/update et éxécutez les commandes correspondantes : @@ -426,22 +431,9 @@ Placez vous dans ./database/update et éxécutez les commandes correspondantes :
426 </pre> 431 </pre>
427 432
428 433
429 -3) [Seulement si nécessaire] Ré-exécuter le script d'installation  
430 -  
431 -4) [Seulement si étape 3 non effectué et si nécessaire] Exécuter le script de mise à jour du fichier de configuration (app.php)  
432 -<pre>  
433 -Placez vous dans ./install et entrez la ligne suivante :  
434 -  
435 -./update-app-php.sh  
436 -</pre>  
437 -  
438 -  
439 -cd install/  
440 -./install.sh  
441 434
442 Remarques : 435 Remarques :
443 -* Le fichier README-LABINVENT.md contient la liste des mise à jour de la base.  
444 -* Le fichier contient également une liste des versions ou il faut exécuter le script d'installation et dans quel mode (n'éxécutez qu'une fois le script, si votre version était antérieur). 436 +* Le fichier README-LABINVENT.md contient la liste des mises à jour.
445 437
446 --- 438 ---
447 439
@@ -449,14 +441,18 @@ h2. MODE PANIQUE @@ -449,14 +441,18 @@ h2. MODE PANIQUE
449 441
450 Vous avez changé la configuration du LDAP et elle ne fonctionne plus ! 442 Vous avez changé la configuration du LDAP et elle ne fonctionne plus !
451 Du coup, vous ne pouvez plus vous connecter au site ! 443 Du coup, vous ne pouvez plus vous connecter au site !
452 -Il faut donc repasser le logiciel en mode INSTALL pour pouvoir y accéder sans connexion.  
453 -Pour cela, exécuter la requête sql database/set_mode_install.sql sur la base de données: 444 +Pas de panique, le mode panique est là !
  445 +Il suffit de repasser le logiciel en mode INSTALL pour pouvoir y accéder sans connexion.
  446 +Pour cela, exécuter le script mode_panique.sh qui se trouve dans le dossier database/ :
454 447
455 <pre> 448 <pre>
456 -mysql -u login -p labinvent2 < set_mode_install.sql 449 +./mode_panique.sh
457 </pre> 450 </pre>
458 451
  452 +(
  453 +_Si vous préférez, vous pouvez aussi exécuter manuellement la requête sql set_mode_install.sql qui se trouve dans le même dossier:_
  454 +mysql -u login -p labinvent2 < set_mode_install.sql
459 _Remplacer 'login' par le 'username' défini dans votre fichier config/app.php dans la section Datasources (default)_ 455 _Remplacer 'login' par le 'username' défini dans votre fichier config/app.php dans la section Datasources (default)_
460 _Remplacer 'labinvent2' par le 'database' défini au même endroit_ 456 _Remplacer 'labinvent2' par le 'database' défini au même endroit_
461 -  
462 -(ou bien exécuter cette requête depuis phpmyadmin)  
463 \ No newline at end of file 457 \ No newline at end of file
  458 +_Ou bien exécuter cette requête depuis phpmyadmin_
  459 +)
464 \ No newline at end of file 460 \ No newline at end of file
src/Controller/MaterielsController.php
@@ -259,7 +259,7 @@ class MaterielsController extends AppController @@ -259,7 +259,7 @@ class MaterielsController extends AppController
259 $this->sendEmailToCreate($materiel->id); 259 $this->sendEmailToCreate($materiel->id);
260 } 260 }
261 261
262 - $message = $materiel->get('nom_createur').' a ajouté le matériel '.$materiel->get('designation').' ('.$materiel->numero_laboratoire.')'; 262 + $message = $materiel->get('nom_createur').' a ajouté le matériel "'.$materiel->get('designation').'" ('.$materiel->numero_laboratoire.')';
263 263
264 $mailsResp = TableRegistry::get('Users')->find()->select('email')->where(['role =' => 'Responsable', 'groupes_metier_id =' => $materiel->get('groupes_metier_id')])->orWhere(['role =' => 'Responsable', 'groupe_thematique_id =' => $materiel->get('groupes_thematique_id')])->toArray(); 264 $mailsResp = TableRegistry::get('Users')->find()->select('email')->where(['role =' => 'Responsable', 'groupes_metier_id =' => $materiel->get('groupes_metier_id')])->orWhere(['role =' => 'Responsable', 'groupe_thematique_id =' => $materiel->get('groupes_thematique_id')])->toArray();
265 $mails = []; 265 $mails = [];
@@ -328,7 +328,7 @@ class MaterielsController extends AppController @@ -328,7 +328,7 @@ class MaterielsController extends AppController
328 $this->Flash->success(__('Le matériel a bien été édité.')); 328 $this->Flash->success(__('Le matériel a bien été édité.'));
329 $this->sendEmailToManagement($id); 329 $this->sendEmailToManagement($id);
330 if($materiel->nom_modificateur != $materiel->nom_responsable) { 330 if($materiel->nom_modificateur != $materiel->nom_responsable) {
331 - $message = $materiel->get('nom_modificateur').' a édité le matériel '.$materiel->get('designation').' ('.$materiel->numero_laboratoire.')'; 331 + $message = $materiel->get('nom_modificateur').' a édité le matériel "'.$materiel->get('designation').'" ('.$materiel->numero_laboratoire.')';
332 $this->sendEmailTo('Modification d\'un matériel', $message, [$materiel->get('email_responsable')]); 332 $this->sendEmailTo('Modification d\'un matériel', $message, [$materiel->get('email_responsable')]);
333 } 333 }
334 return $this->redirect(['action' => 'view', $id]); 334 return $this->redirect(['action' => 'view', $id]);
@@ -475,7 +475,7 @@ class MaterielsController extends AppController @@ -475,7 +475,7 @@ class MaterielsController extends AppController
475 $this->Flash->error('Pour valider un matériel, les champs suivants ne doivent pas être vide : Nom propriétaire, Fournisseur, Numéro de commande, Organisme, prix et date de reception'); 475 $this->Flash->error('Pour valider un matériel, les champs suivants ne doivent pas être vide : Nom propriétaire, Fournisseur, Numéro de commande, Organisme, prix et date de reception');
476 return $this->redirect(['action' => 'edit', $id]); 476 return $this->redirect(['action' => 'edit', $id]);
477 } 477 }
478 - $message = 'Le matériel '.$materiel->get('designation').' ('.$materiel->numero_laboratoire.') a été validé.'; 478 + $message = 'Le matériel "'.$materiel->get('designation').'" ('.$materiel->numero_laboratoire.') a été validé.';
479 $this->sendEmailTo('Validation d\'un matériel', $message, [$materiel->get('email_responsable')]); 479 $this->sendEmailTo('Validation d\'un matériel', $message, [$materiel->get('email_responsable')]);
480 } 480 }
481 481
src/Template/Layout/default.ctp
@@ -94,7 +94,7 @@ $cakeDescription = &#39;Labinvent 2&#39;; @@ -94,7 +94,7 @@ $cakeDescription = &#39;Labinvent 2&#39;;
94 </i></td> 94 </i></td>
95 <td id="version"> 95 <td id="version">
96 <!-- VERSION M.m.f.b (version (M)ajeure, version (m)ineure, numero de nouvelle (f)onctionnalite, numero de (b)ugfix) --> 96 <!-- VERSION M.m.f.b (version (M)ajeure, version (m)ineure, numero de nouvelle (f)onctionnalite, numero de (b)ugfix) -->
97 - <font color="black">VERSION 2.5.4.0 (30/06/2016)</font> 97 + <font color="black">VERSION 2.5.4.1 (30/06/2016)</font>
98 </td> 98 </td>
99 </tr> 99 </tr>
100 </table> 100 </table>