Commit 720808599905eaae55bc7dafed0aa018650a8d98

Authored by Etienne Pallier
2 parents 1093ec3c 6b99803c
Exists in master and in 1 other branch dev

Merge dev branch into master branch (vv3.7.9.60)

CHANGES.txt 0 → 100644
... ... @@ -0,0 +1,787 @@
  1 +CHANGEMENTS
  2 +
  3 +(Liste complète des évolutions: https://gitlab.irap.omp.eu/epallier/labinvent/commits/master)
  4 +
  5 +La liste ci-dessous est aussi en ligne ici : https://tinyurl.com/labinvent#heading=h.2r55bflctpt5
  6 +
  7 +-----------------------------------------------------------------------------------------------------------
  8 +
  9 +10/07/2020 v3.7.9.58-59 (EP)
  10 + - Nouveau filtre "age" (FINALISÉ) sur page index des matériels : Affichage des matériels par tranche d'âge (0-5 ans, 5-10, ...)
  11 + - Amélioration des filtres par statut => gardent les paramètres (options) déjà sélectionnées (age, nb lines, tri...)
  12 + - Bugfix url rewriting dans la page materiels/index pour supprimer le paramètre "page" car ça n'est pas pertinent et ça provoque plantages
  13 + - Grosse refactorisation du javascript dans la page materiels/index pour utiliser le meme code pour les 2 filtres "age" et "nb lines"
  14 + - Bugfixes code et nombreux petits bugfixes sur les css
  15 +
  16 +07/07/2020 v3.7.9.56-57 (EP)
  17 + - Nouveau filtre "age" sur page index des matériels : Affichage des matériels par tranche d'âge (0-5 ans, 5-10, ...)
  18 + - Materiel : technique ou/et inventoriable => trop compliqué et inutile => en fait c’est un OUX (exclusif)
  19 + => simplifier en ne gardant qu'UNE SEULE case à cocher qui s'appelle "materiel technique".
  20 + => Si cette case n'est pas cochée, le prix doit alors être supérieur à 1000E
  21 + => par contre, on garde quand même le champ ds la BD au cas où.
  22 + - Colorisation selon statut du matériel :
  23 + CREATED => bleu
  24 + VALIDATED => vert
  25 + TBA => orange
  26 + ARCHIVED => rouge
  27 +
  28 +06/07/2020 v3.7.9.54-55 (EP)
  29 + - Bugfix test SurCategories : marche maintenant sur php5 et php7
  30 + - Fichier LICENSE (AGPL)
  31 + - Conditions d'utilisation à accepter lors de l'installation
  32 + - script ./INSTALLATION
  33 + - Mode "nolimit" dans la config ("Superadmin a tous les droits", depuis menu Tools)
  34 + - Ajout d'un "alias" pour décrire chaque action de chaque controleur
  35 +
  36 +03/07/2020 v3.7.9.53 (EP)
  37 + - Bugfix Emprunts calcul sur les dates pourri : on utilise maintenant FrozenDate et FrozenTime de cakephp au lieu de DateTime de php
  38 +
  39 +30/06/2020 v3.7.9.51-52 (EP)
  40 + - Bugfix et refactorisation des actions documents /admission, /sortie, /ficheMateriel
  41 + => désormais, on passe l'id du matos associé et non pas son numero d'inventaire !!! (mauvais raccourci)
  42 + => ca permet de tester les conditions d'accès de ces actions en fonction du matériel concerné !!
  43 + - Bugfix test de ces mêmes actions (mal testées avant)
  44 + - L'ajout (/add) d'un suivi, emprunt, ou doc doit toujours se faire avec l'id de l'entité parente associée (en général materiel id)
  45 + => (/add/id) sinon refus
  46 + - ...
  47 +
  48 +29/06/2020 v3.7.9.50 (EP)
  49 + - Nouveau (et dernier dernier) super test ajouté : test du cycle de vie complet d'un matériel (CREATED => ... => ARCHIVED)
  50 +
  51 +26/06/2020 v3.7.9.48-49 (EP)
  52 + - TEST3 : Ajout d'un 3ème (et DERNIER) gros test générique des vues index et view de Materiels (/materiels/index et /view) qui teste le CONTENU des vues pour TOUS les materiels de la BD de test (fixture), aussi bien dans la vue index globale que dans CHAQUE vue détaillée de chaque matériel (et surtout en vérifiant aussi la liste des entités associées (suivis,emprunts,documents).
  53 +
  54 +25/06/2020 v3.7.9.43-47 (EP)
  55 + - TEST2 : Ajout d'un 2ème très gros test générique des vues index et view de Materiels (/materiels/index et /view) qui teste le CONTENU des vues (les boutons d'action)
  56 + à partir d'UN UNIQUE matériel de test qui est modifié à souhait pour essayer de représenter tous les grands cas possibles
  57 +
  58 +23/06/2020 v3.7.9.40-42 (EP)
  59 + - Nouvelle page qui affiche les messages de log PAR niveau (level info, debug, notice, error...) : disponible depuis la page Outils (/pages/logs)
  60 + - Toules les actions importantes (add,edit,delete, changement statut...) sont désormais loggées et donc affichables via la page Outils ci-dessus
  61 + - Accélération de la recherche du numéro de version dans le fichier README, affichée à CHAQUE page web du site !!!
  62 +
  63 +19/06/2020 v3.7.9.39 (EP)
  64 + - TEST1 : Ajout d'un 1er très gros test générique automatique pour (presque) TOUTES les actions de (presque) TOUS les controleurs principaux (Materiels, Suivis, et Emprunts) mais aussi du controleur "quelconque" SurCategories (pour vérifier que ça marche aussi, et j'ai bien fait car il est spécial ne serait-ce que de par son nom !!!)
  65 + - Dans ces tests génériques, on teste non seulement qu'une action s'exécute seulement quand elle y est autorisée, mais aussi qu'elle s'exécute correctement (au moins pour les actions CRUD : add,edit,delete...)
  66 +
  67 +12/06/2020 v3.7.9.37 (EP)
  68 + - Amélioré l'action materiels/print_label_ruban (impression etiquette) : un peu plus conforme au standard, un peu moins bidouille qu'avant, et surtout plus besoin de la finir par un "sale" "exit" => donc on peut maintenant la tester, et c'est ce qui a été fait ! (elle est pas encore total nickel mais bon c'est mieux qu'avant)
  69 + - modifié Fixtures pour supprimer les 'id' explicites
  70 + - bugfix action materiels/statusToBeArchived (ou statusToBearchived) => remplacé partout par statusTobearchived
  71 +
  72 +10/06/2020 v3.7.9.35 (EP)
  73 + - Requete SQL pour répercuter tous les changements depuis avril !!!
  74 + - 1ère version officielle mise en PROD depuis un bail (presque 2 mois)
  75 +
  76 +05/06/2020 v3.7.9.33 (EP)
  77 + - bugfix : renommé groupe_thematique_id en groupes_thematique_id pour etre harmonisé partout et surtout avec "groupes_metier_id" !!!
  78 + - AUTORISATIONS DESORMAIS ADAPTABLES POUR CHAQUE LABO => pris en compte (testé) aussi dans les tests avec setAuthorizations_TEST()
  79 + => chaque labo peut désormais adapter les autorisations des utilisateurs à sa sauce !!!
  80 + => on part des règles générales par défaut, puis on adapte si besoin, cool non ?
  81 + - Vues view (déjà fait avant) et index : les boutons d'action (éditer, valider, supprimer...) s'affichent désormais en fonction des autorisations centralisées
  82 +
  83 +04/06/2020 v3.7.9.30-31 (EP)
  84 + - MISE À JOUR DE TOUS LES CONTROLEURS pour le nouveau système d'autorisation
  85 + - SIMPLIFICATION DES AUTORISATIONS POUR LA PLUPART DES CONTROLEURS SIMPLES
  86 + - AUTORISATIONS PAR DÉFAUT POUR TOUT NOUVEAU CONTROLEUR BASIQUE
  87 + - NOUVELLE PAGE AFFICHANT LES AUTORISATIONS DYNAMIQUEMENT (/pages/acls ou /pages/acls/#nom_du_controleur)
  88 + => On peut ainsi vérifier ce qui est appliqué à l'instant T (juste après la modif d'une règle par exemple)
  89 +
  90 +03/06/2020 v3.7.9.29 (EP)
  91 + - NOUVEAU SYSTEME D'AUTORISATION DES ACTIONS => CENTRALISÉ et testé OK
  92 + => TOUS les tests passent sauf certains qui ne passent plus car les nouvelles conditions sont plus strictes
  93 + (ils ont été temporairement désactivés en attendant réécriture plus générique qui viendra très vite)
  94 + => Autorisations définies dans chaque controleur par setAuthorizations() qui initialise un tableau UNIQUE de AppController ($this->is_authorized_action)
  95 + => La méthode isAuthorized() de chaque controleur appelle isAuthorizedAction() (de AppController) qui autorise ou pas l'action en fonction de ce tableau unique
  96 + => Quand on veut changer une autorisation, il suffit de le faire UNE SEULE FOIS dans la méthode setAuthorizations()
  97 + Cette autorisation sera alors prise en compte PARTOUT dans le code (code des actions, des vues, etc...)
  98 + => L'initialisation des autorisations est faite (par la méthode setAuthorizationForAction() de AppController) dans un format standard,
  99 + quelque soit l'autorisation, donc c'est très LISIBLE et facile à modifier
  100 +
  101 +15/05/2020 v3.7.9.28 (EP)
  102 + - Utilisation systématique de variables "$CAN_xxx" dans les VUES pour tester si un affichage est autorisé ou pas
  103 + => bcp plus centralisé qu'avant, et bcp plus clean et lisible
  104 + => désormais TOUS les droits sont définis dans la SEULE méthode isAuthorized() de CHAQUE controleur et NULLE PART AILLEURS
  105 + => si on veut changer un droit d'accès quelconque, on ne le change QUE là. Ouf, on respire, c'est bien plus cohérent et maintenable qu'avant
  106 + => FIN de la galère de la gestion des droits (acl) enfin, il aura fallu quelques années pour y parvenir !!!
  107 +
  108 +11/05/2020 v3.7.9.27 (EP)
  109 + - Ajout d'un LOG applicatif dans le fichier /logs/debug.log pour toutes les actions importantes (add, edit, delete, ...) qui permet de savoir kiafekoi
  110 +
  111 +07/05/2020 Version 3.7.9.26 (EP)
  112 + - shortcuts dans AppController (donc disponible pour TOUS les controleurs) :
  113 + - $this->u = user courant
  114 + - $this->e = entité courante
  115 + - $this->e_id = id de l'entité courante
  116 + - $this->a = action en cours
  117 + - $this->c = controleur en cours (?)
  118 + - $this->getEntity($id=null) // id=null si matos courant
  119 + - harmonisation des noms de méthodes pour MaterielsController :
  120 + - $this->isCreated($id=null) // id=null si matos courant
  121 + - $this->belongsToUser($username, $id=null) // id=null si matos courant
  122 + et $this->belongsToCurrentUser($id=null) // id=null si matos courant
  123 + - $this->isSameGroupAsUser($userlogin, $id=null) // id=null si matos courant
  124 + et $this->isSameGroupAsCurrentUser($id=null) // // id=null si matos courant
  125 + - harmonisation des méthodes dans entité Materiel (Entity) :
  126 + - is_created, is_validated, is_tobearchived, is_archived
  127 + - belongsToUser($username) // owned or declared by user
  128 + - isSameGroupAsUser($usergroup1, $usergroup2) // is same group as user groups
  129 + - ...
  130 +
  131 +30/04/2020 Version 3.7.9.23 (EP)
  132 + - ajout de l'option globale $this->SUPERADMIN_CAN_DO_EVERYTHING dans AppController (false par défaut) pour donner rapidement TOUS les droits à superadmin (juste passer à true)
  133 + - Nouvelles règles ACL (conditions d'accès) sous forme de tableau $acl => en cours...
  134 + => ce changement offre plusieurs avantages, et devrait notamment permettre de :
  135 + - clarifier les conditions d'accès,
  136 + - les rendre plus facilement modifiables
  137 + - les rendre copiables d'une action à l'autre (et donc facilement réutilisables sans avoir à réécrire de code)
  138 + - afficher une page web présentant automatiquement (dynamiquement) une synthèse claire de toutes les ACL, action par action, et profil par profil
  139 + (ce qui permettra de se rendre compte plus facilement de l'état actuel des conditions d'accès)
  140 +
  141 +28/04/2020 Version 3.7.9.21 (EP)
  142 + - mon 1er View Helper dans src/View/Helper (MyButtonHelper) pour créer plus facilement des boutons !! :
  143 + - migration des fonctions getActionButton() et displayElement() dans MyButtonHelper et remplacement progressif dans les vues
  144 +
  145 +20/04/2020 Version 3.7.9.19 (EP)
  146 + - TOUTES les nombreuses sections Toggle javascript refactorisées en 5 lignes (show/hide) !!
  147 +
  148 +16/04/2020 Version 3.7.9.18 (EP)
  149 + Amelioration gestion des Dates... :
  150 + - GROS bugfix check dates : uniformisation du format date partout (vues et DatePicker.js et code javascript) => dd/mm/aaaa (au lieu de dd-mm-aa)
  151 + - nombreuses refactorisations, généralisations et améliorations du code javascript (bcp de refactorisation dans script.js)
  152 +
  153 +09/04/2020 Version 3.7.9.16-17 (EP)
  154 + Amelioration Suivis :
  155 + - ajout champ is_metro dans table type_suivis pour les types liés au module métrologie
  156 + - ajout champ "is_regular" dans table type_suivis pour déclarer les types de suivis réguliers (fréquence) ou irréguliers (date)
  157 + - début d'utilisation des migrations de BD
  158 +
  159 +01-02/04/2020 Version 3.7.9.13-14 (EP)
  160 + MATERIELS : GROSSE amélioration pour le fournisseur avec autocomplétion et autocorrection !!
  161 + (le fournisseur est toujours en BD mais il est automatiquement ajouté si on en saisit un nouveau)
  162 + (ça corrige aussi automatiquement si espaces en trop, y-compris les anciens déjà saisis,
  163 + bref c'est miraculous !!!)
  164 + (2 jours de boulot quand même...)
  165 +
  166 +31/03/2020 Version 3.7.9.12 (EP)
  167 + MATERIELS : Amélioration et Bugfixes par refactorisation des vues add et edit en 1 seule add_edit
  168 + + Ajout de fournisseur possible
  169 +
  170 +26/03/2020 Version 3.7.9.10 (EP)
  171 + EMPRUNTS : Amélioration par refactorisation (1)
  172 + Comme pour les docs attachés et les suivis (même principe) :
  173 + - refactorisation des actions add() et edit() en une seule add_or_edit() (car très semblables)
  174 + - refactorisation des vues add et edit en une seule add_edit (car très semblables)
  175 +
  176 +25/03/2020 Version 3.7.9.9 (EP)
  177 + SUIVIS : Amélioration par refactorisation (2)
  178 + Comme pour les docs attachés (même principe) :
  179 + - refactorisation des actions add() et edit() en une seule add_or_edit() (car très semblables)
  180 + - refactorisation des vues add et edit en une seule add_edit (car très semblables)
  181 +
  182 +24/03/2020 Version 3.7.9.8 (EP)
  183 + SUIVIS : Amélioration et nombreux Bugfixes !!! (1)
  184 + - ajout intitulé comme titre
  185 +
  186 +23/03/2020 Version 3.7.9.6-7 (EP)
  187 + DOCS LIÉS : Amélioration de la gestion des docs attachés (3)
  188 + - Enorme simplification grâce à la refactorisation des vues add et edit en une seule add_edit car elles sont très semblables
  189 + - Amélioration et nombreux bugfixes de la gestion des docs attachés (2)
  190 +
  191 +16/03/2020 Version 3.7.9.1-5 (EP)
  192 + Premiers bugfixes du nouveau site responsive
  193 +
  194 +11/03/2020 Version 3.7.9.0 (EP)
  195 + NOUVELLE VERSION RESPONSIVE validée et installée officiellement à l'IRAP et au CRAL (mobile ready)
  196 + Nouveau format de version qui colle à la version utilisée du framework Cakephp (3.7.9)
  197 +
  198 +10/03/2020 Version 2.14.8 (EP)
  199 + Dernier bugfix pour valider nouvelle version 2.14 (responsive) : bugfix test etiquette collée
  200 +
  201 +10/03/2020 Version 2.14.7 (EP)
  202 + Nombreux petits bugfixes (dont 1 gros : bouton CANCEL) :
  203 +
  204 +06/03/2020 Version 2.14.6 (EP)
  205 + 6 gros bugfixes de la version 2.14 (responsive) sur 1 semaine de boulot !!
  206 +
  207 +28/02/2020 Version 2.14.0 (Jeanne Prugniel, stagiaire CRAL)
  208 + Application maintenant "responsive" avec l'utilisation de boostrap (ok sur pc, tablette, et mobile)
  209 +
  210 +29/01-17/02/2020 Version 2.13.13-14 (EP)
  211 + Ajout bootstrap-ui
  212 +
  213 +21/01/2019 Version 2.13.12 (EP)
  214 + Bugfix connexion superadmin en mode SANS LDAP (en cours...)
  215 + Bugfix et amélioration script installation (script création users BDD...)
  216 + Amélioration script update (ajout mise à jour auto des plugins php)
  217 +
  218 +...
  219 +
  220 +
  221 +
  222 +
  223 +
  224 +-----------------------------------------------------------------------------------------------------------
  225 +
  226 +CHANGEMENTS DANS LE DÉTAIL (pas forcément visibles, parfois très importants mais internes, pour les devs)
  227 +
  228 +(Liste complète des évolutions: https://gitlab.irap.omp.eu/epallier/labinvent/commits/master)
  229 +
  230 +-----------------------------------------------------------------------------------------------------------
  231 +
  232 +03/07/2020 v3.7.9.53-54 (EP)
  233 + - Bugfix test SurCategories : devrait maintenant marcher sur php5 et php7
  234 + - Bugfix Emprunts calcul sur les dates pourri : on utilise maintenant FrozenDate et FrozenTime de cakephp au lieu de DateTime de php
  235 + - Changement stratégie find matériels, liste des Propriétaire : ce n'est plus la liste des gens qui ont au moins 1 materiel, mais la liste de tous les utilisateurs (tout le ldap)
  236 + - Bugfix suivis : type suivi doit être obligatoire !!!
  237 +
  238 +30/06/2020 v3.7.9.51-52 (EP)
  239 + - Bugfix et refactorisation des actions documents /admission, /sortie, /ficheMateriel
  240 + => désormais, on passe l'id du matos associé et non pas son numero d'inventaire !!! (mauvais raccourci)
  241 + => ca permet de tester les conditions d'accès de ces actions en fonction du matériel concerné !!
  242 + - Bugfix test de ces mêmes actions (mal testées avant)
  243 + - L'ajout (/add) d'un suivi, emprunt, ou doc doit toujours se faire avec l'id de l'entité parente associée (en général materiel id)
  244 + => (/add/id) sinon refus
  245 + - ...
  246 +
  247 +29/06/2020 v3.7.9.50 (EP)
  248 + - Nouveau (et dernier dernier) super test ajouté : test du cycle de vie complet d'un matériel (CREATED => ... => ARCHIVED)
  249 + - bugfix (en cours) des actions documents/admission et documents/sortie qui ne marchent plus car on ne leur passe pas un id mais un nom de doc...
  250 + - Nombreuses refactorisations dans les tests
  251 +
  252 +26/06/2020 v3.7.9.48-49 (EP)
  253 + - TEST3 : Ajout d'un 3ème (et DERNIER) gros test générique des vues index et view de Materiels (/materiels/index et /view) qui teste le CONTENU des vues pour TOUS les materiels de la BD de test (fixture), aussi bien dans la vue index globale que dans CHAQUE vue détaillée de chaque matériel (et surtout en vérifiant aussi la liste des entités associées (suivis,emprunts,documents).
  254 + - bugfix autorisations d'affichage des boutons d'action sur documents dans materiels/view/
  255 + - Nombreuses refactorisations
  256 +
  257 +25/06/2020 v3.7.9.43-47 (EP)
  258 + - TEST2 : Ajout d'un 2ème très gros test générique des vues index et view de Materiels (/materiels/index et /view) qui teste le CONTENU des vues (les boutons d'action)
  259 + à partir d'UN UNIQUE matériel de test qui est modifié à souhait pour essayer de représenter tous les grands cas possibles
  260 + - bugfix printLabel() : impression etiquette ne marchait plus !!
  261 + - Amélioration page /pages/acls
  262 + - bugfixes : ce test, plus status-to-be-archived => status-tobearchived, plus SurcategoriesController => SurCategoriesController
  263 + - ...
  264 +
  265 +23/06/2020 v3.7.9.40-42 (EP)
  266 + - Nouvelle page qui affiche les messages de log PAR niveau (level info, debug, notice, error...) : disponible depuis la page Outils (/pages/logs)
  267 + - Toules les actions importantes (add,edit,delete, changement statut...) sont désormais loggées et donc affichables via la page Outils ci-dessus
  268 + - Accélération de la recherche du numéro de version dans le fichier README, affichée à CHAQUE page web du site !!!
  269 +
  270 +19/06/2020 v3.7.9.39 (EP)
  271 + - TEST1 : Ajout d'un 1er très gros test générique automatique pour (presque) TOUTES les actions de (presque) TOUS les controleurs principaux (Materiels, Suivis, et Emprunts) mais aussi du controleur "quelconque" SurCategories (pour vérifier que ça marche aussi, et j'ai bien fait car il est spécial ne serait-ce que de par son nom !!!)
  272 + - Dans ces tests génériques, on teste non seulement qu'une action s'exécute seulement quand elle y est autorisée, mais aussi qu'elle s'exécute correctement (au moins pour les actions CRUD : add,edit,delete...)
  273 + - Le nombre total de tests (en ajoutant ces tests automatiques) monte à 200 (pile poil) !!!
  274 + - ajout champ 'nom' à la table emprunts => ajout d'un fichier sql pour la mise à jour
  275 + - ...
  276 +
  277 +17/06/2020 v3.7.9.38 (EP)
  278 + - Tests génériques automatiques pour (presque) toutes les actions de tous les controleurs principaux (Materiels, Suivis, Emprunts)
  279 + - Dans ces tests génériques, on teste non seulement qu'une action s'exécute seulement quand elle y est autorisée, mais aussi qu'elle s'exécute correctement (au moins pour les actions CRUD : add,edit,delete...)
  280 + - L'ajout d'un suivi, emprunt, ou document n'est plus autorisé SANS préciser l'id du matériel concerné, ce qui est logique
  281 + - ...
  282 +
  283 +12/06/2020 v3.7.9.37 (EP)
  284 + - Tests génériques automatiques pour (presque) toutes les actions du controleur Materiels => OK
  285 + - Amélioré l'action materiels/print_label_ruban (impression etiquette) : un peu plus conforme au standard, un peu moins bidouille qu'avant, et surtout plus besoin de la finir par un "sale" "exit" => donc on peut maintenant la tester, et c'est ce qui a été fait ! (elle est pas encore total nickel mais bon c'est mieux qu'avant)
  286 + - modifié Fixtures pour supprimer les 'id' explicites
  287 + - bugfix action materiels/statusToBeArchived (ou statusToBearchived) => remplacé partout par statusTobearchived
  288 +
  289 +10/06/2020 v3.7.9.36 (EP)
  290 + - Bugfixes pages tools-sm (autres listes), etiqueteuses, acls, suivis (plus de groupes)
  291 +
  292 +10/06/2020 v3.7.9.35 (EP)
  293 + - Requete SQL pour répercuter tous les changements depuis avril !!!
  294 + - 1ère version officielle mise en PROD depuis un bail (presque 2 mois)
  295 +
  296 +05/06/2020 v3.7.9.33 (EP)
  297 + - bugfix : renommé groupe_thematique_id en groupes_thematique_id pour etre harmonisé partout et surtout avec "groupes_metier_id" !!!
  298 + - bugfix : isSameGroup
  299 + - tous les tests actuels ok
  300 + - AUTORISATIONS DESORMAIS ADAPTABLES POUR CHAQUE LABO => pris en compte (testé) aussi dans les tests avec setAuthorizations_TEST()
  301 + => chaque labo peut désormais adapter les autorisations des utilisateurs à sa sauce !!!
  302 + => on part des règles générales par défaut, puis on adapte si besoin, cool non ?
  303 + - Vues view (déjà fait avant) et index : les boutons d'action (éditer, valider, supprimer...) s'affichent désormais en fonction des autorisations centralisées
  304 +
  305 +05/06/2020 v3.7.9.32 (EP)
  306 + - AUTORISATIONS DESORMAIS ADAPTABLES POUR CHAQUE LABO
  307 + => chaque labo peut désormais adapter les autorisations des utilisateurs à sa sauce !!!
  308 + => on part des règles générales par défaut, puis on adapte si besoin, cool non ?
  309 +
  310 +04/06/2020 v3.7.9.31 (EP)
  311 + - MISE À JOUR DE TOUS LES CONTROLEURS pour le nouveau système d'autorisation
  312 + - SIMPLIFICATION DES AUTORISATIONS POUR LA PLUPART DES CONTROLEURS SIMPLES
  313 + - AUTORISATIONS PAR DÉFAUT POUR TOUT NOUVEAU CONTROLEUR BASIQUE
  314 + - AMELIORATIONS DE LA PAGE AFFICHANT LES AUTORISATIONS DYNAMIQUEMENT (/pages/acls ou /pages/acls/#nom_du_controleur)
  315 + => On peut ainsi vérifier ce qui est appliqué à l'instant T (juste après la modif d'une règle par exemple)
  316 +
  317 +03/06/2020 v3.7.9.30 (EP)
  318 + - NOUVELLE PAGE AFFICHANT LES AUTORISATIONS DYNAMIQUEMENT (/pages/acls ou /pages/acls/#nom_du_controleur)
  319 + => On peut ainsi vérifier ce qui est appliqué à l'instant T (juste après la modif d'une règle par exemple)
  320 +
  321 +03/06/2020 v3.7.9.29 (EP)
  322 + - NOUVEAU SYSTEME D'AUTORISATION DES ACTIONS => CENTRALISÉ et testé OK
  323 + => TOUS les tests passent sauf certains qui ne passent plus car les nouvelles conditions sont plus strictes
  324 + (ils ont été temporairement désactivés en attendant réécriture plus générique qui viendra très vite)
  325 + => Autorisations définies dans chaque controleur par setAuthorizations() qui initialise un tableau UNIQUE de AppController ($this->is_authorized_action)
  326 + => La méthode isAuthorized() de chaque controleur appelle isAuthorizedAction() (de AppController) qui autorise ou pas l'action en fonction de ce tableau unique
  327 + => Quand on veut changer une autorisation, il suffit de le faire UNE SEULE FOIS dans la méthode setAuthorizations()
  328 + Cette autorisation sera alors prise en compte PARTOUT dans le code (code des actions, des vues, etc...)
  329 + => L'initialisation des autorisations est faite (par la méthode setAuthorizationForAction() de AppController) dans un format standard,
  330 + quelque soit l'autorisation, donc c'est très LISIBLE et facile à modifier
  331 +
  332 +15/05/2020 v3.7.9.28 (EP)
  333 + - Renforcement tests suivis et emprunts (materiel validated only) et refactorisations
  334 + - ajout de 2 très gros tests qui tuent des vues matos/index et matos/view en cours... (ce qui m'évitera plein de tests à la main)
  335 + - Ajout de la méthode complexe isManageableByUser() dans MaterielsController.php et dans Materiel.php
  336 + - Ajout de la méthode getRelatedMateriel() dans AppController, très optimisée
  337 + - Vers une unicité toujours plus grande des tests d'autorisation d'action (uniquement dans isAuthorized())
  338 + - Utilisation systématique et UNIQUE de la méthode isAuthorized() de CHAQUE controleur pour savoir si une action est autorisée ou pas
  339 + - Utilisation systématique de variables "$CAN_xxx" dans les VUES pour tester si un affichage est autorisé ou pas
  340 + => bcp plus centralisé qu'avant, et bcp plus clean et lisible
  341 + => désormais TOUS les droits sont définis dans la SEULE méthode isAuthorized() de CHAQUE controleur et NULLE PART AILLEURS
  342 + => si on veut changer un droit d'accès quelconque, on ne le change QUE là. Ouf, on respire, c'est bien plus cohérent et maintenable qu'avant
  343 + => FIN de la galère de la gestion des droits (acl) enfin, il aura fallu quelques années pour y parvenir !!!
  344 +
  345 +11/05/2020 v3.7.9.27 (EP)
  346 + - Ajout d'un LOG applicatif dans le fichier /logs/debug.log pour toutes les actions importantes (add, edit, delete, ...) qui permet de savoir kiafekoi
  347 + - Suppression des méthodes isAuthorizedAction() et isAuthorizedActionFor() car plus simple de ne garder QUE isAuthorized() en la modifiant un peu... => du coup, c'est désormais cette SEULE méthode (dans CHAQUE controleur) qui décide de l'accès ou non à une action selon le profil utilisateur
  348 +
  349 +07/05/2020 Version 3.7.9.26 (EP)
  350 + Diverses améliorations, simplifications, refactorisations, optimisations :
  351 + Harmonisation :
  352 + - shortcuts dans AppController (donc disponible pour TOUS les controleurs) :
  353 + - $this->u = user courant
  354 + - $this->e = entité courante
  355 + - $this->e_id = id de l'entité courante
  356 + - $this->a = action en cours
  357 + - $this->c = controleur en cours (?)
  358 + - $this->getEntity($id=null) // id=null si matos courant
  359 + - harmonisation des noms de méthodes pour MaterielsController :
  360 + - $this->isCreated($id=null) // id=null si matos courant
  361 + - $this->belongsToUser($username, $id=null) // id=null si matos courant
  362 + et $this->belongsToCurrentUser($id=null) // id=null si matos courant
  363 + - $this->isSameGroupAsUser($userlogin, $id=null) // id=null si matos courant
  364 + et $this->isSameGroupAsCurrentUser($id=null) // // id=null si matos courant
  365 + - harmonisation des méthodes dans entité Materiel (Entity) :
  366 + - is_created, is_validated, is_tobearchived, is_archived
  367 + - belongsToUser($username) // owned or declared by user
  368 + - isSameGroupAsUser($usergroup1, $usergroup2) // is same group as user groups
  369 + - ...
  370 + - poursuite généralisation utilisation de la fonction isAuthorizedAction() partout où on a besoin de connaitre les droits d'un user (view, index, ...)
  371 +
  372 +04/05/2020 Version 3.7.9.24 (EP)
  373 + Diverses améliorations, simplifications, refactorisations, optimisations :
  374 + - Nouvelle variable $this->current_user_entity "globale" et héritée par tous les controleurs (car définie dans AppController.beforeFilter())
  375 + => cette variable est un objet Entity et donc avec des propriétés (virtuelles) pratiques permettant de faire par exemple :
  376 + - $user->is_admin
  377 + - $user->is_resp
  378 + - $user->is_super
  379 + mais aussi :
  380 + - $user->is_admin_or_more()
  381 + - $user->is_admin_or_less()
  382 + - bugfix 3 TESTS !!!
  383 +
  384 +30/04/2020 Version 3.7.9.23 (EP)
  385 + Diverses améliorations, simplifications, refactorisations, optimisations :
  386 + - ajout de l'option globale $this->SUPERADMIN_CAN_DO_EVERYTHING dans AppController (false par défaut) pour donner rapidement TOUS les droits à superadmin (juste passer à true)
  387 + - regroupement des conditions d'accès des 3 actions ADD, EDIT, et DELETE car très semblables => remplacé 60 lignes par 10 !!!
  388 + - Grosse simplification (et bugfixes !!) des conditions d'accès à la plupart des actions de MaterielsController => c'est bien plus clair à lire
  389 + - Nouvelles règles ACL (conditions d'accès) sous forme de tableau $acl => en cours...
  390 + => ce changement offre plusieurs avantages, et devrait notamment permettre de :
  391 + - clarifier les conditions d'accès,
  392 + - les rendre plus facilement modifiables
  393 + - les rendre copiables d'une action à l'autre (et donc facilement réutilisables sans avoir à réécrire de code)
  394 + - afficher une page web présentant automatiquement (dynamiquement) une synthèse claire de toutes les ACL, action par action, et profil par profil
  395 + (ce qui permettra de se rendre compte plus facilement de l'état actuel des conditions d'accès)
  396 +
  397 +29/04/2020 Version 3.7.9.22 (EP)
  398 + Diverses améliorations, simplifications, optimisations :
  399 + - factorisation d'une partie de add_or_edit() dans AppController (appelée par les add_or_edit() de chaque controleur spécifique)
  400 + - Utilisation de $this->action et $this->action_id (...) de AppController.beforeFilter() un peu partout
  401 + - Utilisation de $this->entity de AppController.beforeFilter() un peu partout pour simplifier et surtout éviter (bcp) les accès BD redondants
  402 + - Optimisations pour éviter trop de requetes en BD et simplification des tests acl
  403 +
  404 +28/04/2020 Version 3.7.9.21 (EP)
  405 + Diverses améliorations, simplifications, optimisations :
  406 + - Ajout de $this->entity, $this->action et $this->entity_id (...) dans beforeFilter() pour simplifier et optimiser la suite des traitements
  407 + - simplification du isAuthorizedAction() de Materiels
  408 + - Optimisations pour éviter trop de requetes en BD et simplification des tests acl
  409 + - Meilleure gestion des aspects authentification et authorization
  410 + - mon 1er View Helper dans src/View/Helper (MyButtonHelper) pour créer plus facilement des boutons !! :
  411 + - migration des fonctions getActionButton() et displayElement() dans MyButtonHelper et remplacement progressif dans les vues
  412 +
  413 +24/04/2020 Version 3.7.9.20 (EP)
  414 + Améliorations diverses :
  415 + - Meilleure gestion des aspects authentification et authorization (car je comprends mieux maintenant)
  416 + - PagesController maintenant bien plus clean
  417 + - mon 1er View Helper dans src/View/Helper (MyButtonHelper) pour créer plus facilement des boutons !! :
  418 + - migration des fonctions getActionButton() et displayElement() dans MyButtonHelper et remplacement progressif dans les vues
  419 +
  420 +20/04/2020 Version 3.7.9.19 (EP)
  421 + Améliorations EMPRUNT... :
  422 + - Améliorations EMPRUNT
  423 + - mon 1er View Helper dans src/View/Helper (MyButtonHelper) pour créer plus facilement des boutons !!
  424 + - TOUTES les nombreuses sections Toggle javascript refactorisées en 5 lignes (show/hide) !!
  425 + - Début d'utilisation du HELPER Html pour raccourcis d'écriture
  426 +
  427 +16/04/2020 Version 3.7.9.18 (EP)
  428 + Amelioration gestion des Dates... :
  429 + - GROS bugfix check dates : uniformisation du format date partout (vues et DatePicker.js et code javascript) => dd/mm/aaaa (au lieu de dd-mm-aa)
  430 + - nombreuses refactorisations, généralisations et améliorations du code javascript (bcp de refactorisation dans script.js)
  431 +
  432 +09/04/2020 Version 3.7.9.17 (EP)
  433 + Amelioration Suivis (3) :
  434 + - ajout champ is_metro dans table type_suivis pour les types liés au module métrologie
  435 + - Nombreuses simplifications (et bugfix) des VUES en enrichissant le controleur de Suivis (et de Materiels)
  436 + - (les vues doivent toujours être le plus BETE, SIMPLE possibles, la complexité ne doit être QUE dans le controleur)
  437 + - commentaires et repagination pour que le code soit LISIBLE !!!!
  438 + - début d'utilisation des migrations de BD
  439 + - ...
  440 +
  441 +07/04/2020 Version 3.7.9.16 (EP)
  442 + Amelioration Suivis (2) :
  443 + - amélioration du code javascript par refactorisation
  444 + - test de cohérence des dates suite à saisie (javascript)
  445 + - ajout champ "is_regular" dans table type_suivis pour déclarer les types de suivis réguliers (fréquence) ou irréguliers (date)
  446 + - mise à jour vues suivi et type_suivis pour le champ "is_regular"
  447 + - commentaires
  448 + - début d'utilisation des migrations de BD
  449 + - ...
  450 +
  451 +02/04/2020 Version 3.7.9.15 (EP)
  452 + Bugfix Materiels bouton Annuler
  453 + Amelioration Suivis (1)
  454 +
  455 +01-02/04/2020 Version 3.7.9.13-14 (EP)
  456 + MATERIELS : GROSSE amélioration pour le fournisseur avec autocomplétion et autocorrection !!
  457 + (le fournisseur est toujours en BD mais il est automatiquement ajouté si on en saisit un nouveau)
  458 + (ça corrige aussi automatiquement si espaces en trop, y-compris les anciens déjà saisis,
  459 + bref c'est miraculous !!!)
  460 + (2 jours de boulot quand même...)
  461 +
  462 +31/03/2020 Version 3.7.9.12 (EP)
  463 + MATERIELS : Amélioration et Bugfixes par refactorisation des vues add et edit en 1 seule add_edit
  464 + + Ajout de fournisseur possible
  465 +
  466 +27/03/2020 Version 3.7.9.11 (EP)
  467 + Amélioration et Bugfixes de Emprunts, Suivis, et Docs attachés
  468 +
  469 +26/03/2020 Version 3.7.9.10 (EP)
  470 + EMPRUNTS : Amélioration par refactorisation (1)
  471 + Comme pour les docs attachés et les suivis (même principe) :
  472 + - refactorisation des actions add() et edit() en une seule add_or_edit() (car très semblables)
  473 + - refactorisation des vues add et edit en une seule add_edit (car très semblables)
  474 +
  475 +25/03/2020 Version 3.7.9.9 (EP)
  476 + SUIVIS : Amélioration par refactorisation (2)
  477 + Comme pour les docs attachés (même principe) :
  478 + - refactorisation des actions add() et edit() en une seule add_or_edit() (car très semblables)
  479 + - refactorisation des vues add et edit en une seule add_edit (car très semblables)
  480 + - debugging javascript en cours (car ça marchait pas très bien tout ça...)
  481 +
  482 +24/03/2020 Version 3.7.9.8 (EP)
  483 + SUIVIS : Amélioration et nombreux Bugfixes !!! (1)
  484 + - pb javascript si métrologie
  485 + - ajout intitulé comme titre
  486 + - vue édition : champs trop larges, champs éditables, champs inutiles...
  487 + - ...
  488 +
  489 +23/03/2020 Version 3.7.9.7 (EP)
  490 + DOCS LIÉS : Amélioration de la gestion des docs attachés (3)
  491 + - Enorme simplification grâce à la refactorisation des vues add et edit en une seule add_edit car elles sont très semblables
  492 + - TODO : faire la meme chose pour toutes les vues add et edit des différents objets (materiel, suivi, emprunt...)
  493 +
  494 +20/03/2020 Version 3.7.9.6 (EP)
  495 + DOCS LIÉS : Amélioration et nombreux bugfixes de la gestion des docs attachés (2)
  496 +
  497 +16/03/2020 Version 3.7.9.5 (EP)
  498 + Premiers bugfixes du nouveau site responsive (5)
  499 + - Nombreux bugfixes de la gestion des documents attachés (presque fini)
  500 + - superadmin ressemble de plus en plus au profil "admin" (avec un peu plus de droits)
  501 + - Forcer DebugKit (en mode debug) dans config/bootstrap.php : Configure::write('DebugKit.forceEnable', true);
  502 +
  503 +13/03/2020 Version 3.7.9.4 (EP)
  504 + Premiers bugfixes du nouveau site responsive (4)
  505 + - Fournisseur peut etre créé, modif, suppr par simple Utilisateur (improved)
  506 +
  507 +13/03/2020 Version 3.7.9.3 (EP)
  508 + Premiers bugfixes du nouveau site responsive (3) (contexte: coronavirus passe stade 3)
  509 + - Invalider => renommé Dévalider
  510 + - bugfix autres listes pour profil Utilisateur
  511 + - Fournisseur peut etre créé, modif, suppr par simple Utilisateur
  512 + - Doc lié : simplifié
  513 +
  514 +12/03/2020 Version 3.7.9.2 (EP)
  515 + Premiers bugfixes du nouveau site responsive (2) :
  516 + - Bugfix bouton "Nouveau" pour chaque liste de contenu variable (accès donné à "Administration")
  517 + - Gros BUGFIX des documents attachés... (et c'est pas fini !!) :
  518 + - materiels/view/ :
  519 + voir TOUTES les photos
  520 + lier doc et photo : doublon
  521 + - documents/view/ :
  522 + afficher si photo (ou type photo)
  523 + télécharger photo => sert à rien (en fait, c’est voir)
  524 +
  525 +12/03/2020 Version 3.7.9.1 (EP)
  526 + Premiers bugfixes du nouveau site responsive (1) :
  527 + - Ajout bouton "Nouveau" pour chaque liste de contenu variable (sites, catégories, organismes, suivis, feurs, ...)
  528 + - Alignement des boutons "Enregistrer" et "Annuler" sur Chrome
  529 +
  530 +11/03/2020 Version 3.7.9.0 (EP)
  531 + NOUVELLE VERSION RESPONSIVE validée et installée officiellement à l'IRAP et au CRAL (mobile ready)
  532 + Nouveau format de version qui colle à la version utilisée du framework Cakephp (3.7.9)
  533 +
  534 +10/03/2020 Version 2.14.8 (EP)
  535 + Dernier bugfix pour valider nouvelle version 2.14 (responsive) : bugfix test etiquette collée
  536 +
  537 +10/03/2020 Version 2.14.7 (EP)
  538 + Nombreux petits bugfixes (dont 1 gros : bouton CANCEL) :
  539 + - bugfix materiels/add : bouton CANCEL faisait un SUBMIT (comme pour /edit) !!!
  540 + - bugfix materiels/view : bugfix css responsive.css pour apparence et position boutons
  541 + - bugfix doc attaché :
  542 + - commentaire si doc attaché avec mauvais nom
  543 + - emplacement photo matériel (à gauche ou au-dessus et non pas à droite du QrCode, moche)
  544 + - lien téléchargement documents attachés
  545 + - bugfix pb accent sur liste materiels associés à une catégorie
  546 + - etiquette posée => vert (rouge sinon)
  547 + - apropos updated
  548 + - lien vers page etiqueteuse updated
  549 + - ...
  550 +
  551 +06/03/2020 Version 2.14.6 (EP)
  552 + 6 gros bugfixes de la version 2.14 (responsive) sur 1 semaine de boulot !!
  553 +
  554 +28/02/2020 Version 2.14.0 (Jeanne Prugniel, stagiaire CRAL)
  555 + Application maintenant "responsive" avec l'utilisation de boostrap (ok sur pc, tablette, et mobile)
  556 +
  557 +18/02/2020 Version 2.13.15 (EP)
  558 + Cleanup et bugfix accent perdu sur menu gauche (mac only !!!)
  559 +
  560 +29/01-17/02/2020 Version 2.13.13-14 (EP)
  561 + Ajout bootstrap-ui
  562 +
  563 +21/01/2019 Version 2.13.12 (EP)
  564 + Bugfix connexion superadmin en mode SANS LDAP (en cours...)
  565 + Bugfix et amélioration script installation (script création users BDD...)
  566 + Amélioration script update (ajout mise à jour auto des plugins php)
  567 +
  568 +17/07/2019 Version 2.13.10 (EP)
  569 + Bugfix et grosse amelioration :
  570 + validation d'un materiel TECHNIQUE => desormais possible pour un Responsable de groupe (metier ou thematique)
  571 + Bugfix : depuis la vue d'un matériel, actions faites sur matériel (valider, invalider, tba, archiver) ramènent à cette fiche
  572 + Bugfix : emails envoyés aux responsables sur action sur un matos (valider, invalider, tba, archive) ne plantent plus !!!
  573 + Refactorisation des ACL => toujours plus simple
  574 +
  575 +13/06/2019 Version 2.13.9 (EP)
  576 + Refonte des fichiers d'installation (installation.sh et fichiers BD)
  577 +
  578 +13/06/2019 Version 2.13.7-8 (EP)
  579 + Bugfix envoi mail avec doc (photo) attachée
  580 + Ajout 2 logos pour le CRAL
  581 +
  582 +06/06/2019 Version 2.13.0-6 (EP)
  583 + LDAP CACHED cleanup
  584 + Bugfixed materiels/find/puis tri /puis export CSV (ne marchait pas)
  585 + Amélioration materiels/index Export CSV => trié par numéro labo (desc)
  586 + Bugfix materiels/add catégorie (et sous-categ) perdue après erreur saisie
  587 + Bugfix fichiers liés send by email (webroot)
  588 + Adapté code pour doc admission pour le CRAL
  589 +
  590 +06/06/2019 Version 2.12.28-35 (EP)
  591 + LDAP CACHED v8
  592 + Nouvelle fonction $mydebug($D, $arg) disponible dans toutes les vues
  593 + Pagination Utilisateurs avec "debut" et "fin"
  594 +
  595 +05/06/2019 Version 2.12.27 (EP)
  596 + Bugfix et Améliorations Export CSV
  597 +
  598 +04/06/2019 Version 2.12.26 (EP)
  599 + Bugfix et Améliorations Emprunt
  600 +
  601 +03/06/2019 Version 2.12.24-25 (EP)
  602 + LDAP CACHED v3
  603 +
  604 +24/05/2019 Version: 2.12.22-23 (EP)
  605 + Bugfix QrCode : http et https bien gérés
  606 + Update du script install/installation.sh pour etre plus logique
  607 +
  608 +23/05/2019 Version: 2.12.21 (EP)
  609 + Retour exception si table configurations vide
  610 +
  611 +21/05/2019 Version: 2.12.18-20 (EP)
  612 + Bugfix affichage boutons vue matériel (parfois 2e ligne chevauchait 1ère ligne)
  613 + (Enorme) Simplification des vues materiels/view et index (toujours en cours)
  614 + Bugfix actions sur pdf interdites
  615 +
  616 +17/05/2019 Version: 2.12.15-17 (EP)
  617 + Bugfix modif matos: on ne doit plus pouvoir modifier un materiel validé (ou plus) => il faut le dé-valider avant !
  618 + Bugfix et amelioration tests
  619 + Simplification des vues (en cours)
  620 +
  621 +16/05/2019 Version: 2.12.12-14 (EP)
  622 + Bugfix ajout materiel
  623 + Bugfix tests
  624 + Ajout tests pour fonctionnalité "Copier ce materiel"
  625 +
  626 +15/05/2019 Version: 2.12.11 (EP)
  627 + Bugfix, simplification, et amélioration de la fonctionnalité "Copier ce matériel"
  628 +
  629 +13/05/2019 Version: 2.12.8-10 (EP)
  630 + Ajout de l'option "Librairie pdf utilisée" pour choisir entre fpdf et dompdf
  631 + Génération des pdf avec 2 moteurs au choix (fpdf ou dompdf)
  632 + Production des 3 docs pdf avec dompdf: admission, sortie, et fiche_materiel
  633 +
  634 +06/05/2019 Version: 2.12.6-7 (EP)
  635 + Bugfix et Optimisation de l'ajout/édition d'un utilisateur privilégié ou d'un matériel (en mode LDAP) : un seul appel définitif du ldap
  636 +
  637 +23/01/2019 Version: 2.10.1 à 2.10.6 (EP)
  638 + Mise à jour framework cakephp et amélioration recherche matériel et bugfix ldap:
  639 + - Mise à jour du framework cakephp à la version courante : passage de v3.5 à v3.7
  640 + ($ php composer.phar require --update-with-dependencies "cakephp/cakephp:3.7.*")
  641 + - Adaptations pour cakephp 3.7
  642 + - Ajout du dossier vendor/ dans git (désormais versionné pour faciliter la mise à jour du framework cakephp)
  643 + - Recherche Matériels : Bugfixes et améliorations
  644 + - Bugfix Recherche générale sur plusieurs mots : fait un AND de ces mots et non pas un OR !!!
  645 + - Bugfix Recherche générale d'une date
  646 + - Ajout recherche générale d'un fournisseur et d'une catégorie
  647 + - Bugfix recherche sur un montant à virgule...
  648 + - Complète refactorisation de MaterielsController::find(), y avait besoin !
  649 + - Ajout de tests
  650 + - ...
  651 + - Nouveaux fichiers VERSION, UPDATE.sh, et mise à jour de TESTS.sh
  652 + - LDAP authentified bugfix
  653 +
  654 +15/01/2019 Version: 2.9.2 (EP)
  655 + Nouveau script "install/update.sh" pour mettre à jour automatiquement le logiciel (git pull) ET la BD (si besoin)
  656 +
  657 +10/01/2019 Version: 2.9.1.11 (EP)
  658 + Nouveau mode LDAP AUTHENTIFIÉ opérationnel (pour le CRAL) :
  659 + - **ATTENTION, MODIF DE LA BD, il faut exécuter le script de mise à jour suivant**:
  660 + - cd database/update/
  661 + - ./db-update-2019-01-09.sh ("-CRAL.sh" pour le CRAL) :
  662 + - renommé tous les champs et variables *_ldap en ldap_* pour meilleure lisibilité
  663 + - adapté la section LDAP de la config
  664 + - cleanup
  665 + - update fichier database/labinvent_last_version.sql contenant la BD COMPLETE
  666 +
  667 +21/12/2018 Version: 2.9.1.4 (EP)
  668 + Version et date affichés automatiquement et merge vues listes... :
  669 + - Version et date affichés automatiquement à partir du README.md
  670 + - Les vues "Voir les autres listes" et "Outils/Gérer le contenu variable..." sont désormais les mêmes
  671 +
  672 +14/12/2018 Version: 2.9.1.0 (EP)
  673 + - Ajout en cours du mode LDAP authentifié
  674 + - Nouvelle documentation (dossier doc/)
  675 +
  676 +ETE 2018 Version: 2.9.0 (Malik Imelhaine)
  677 + - Nombreux petits bugfixes et petites améliorations (a priori sans changement structure BD)
  678 +
  679 +-----------------------------------------------------------------------------------------------------------
  680 +02/02/2018 Version: 2.8.1 (EP)
  681 + - Nombreux bugfixes (saisie dates, etiquette, doc admission...)
  682 +
  683 +15/09/2017 Version: 2.8.0 (EP)
  684 + - Nouveau système ACL simplifié basé sur les tableaux $easyACL (en cours)
  685 + - Tests paramétrés
  686 + - Bugfix emails
  687 +
  688 +-----------------------------------------------------------------------------------------------------------
  689 +30/08/2017 Version: 2.7.9 (EP)
  690 + - fonction intelligente AppController::getUserRole() qui donne le role "Utilisateur" par défaut pour un utilisateur non privilégié
  691 + - Refactorisation des ACL (authorizations) dans isAuthorized() et beforeFilter()
  692 +
  693 +28/08/2017 Version: 2.7.6 (EP)
  694 + - renforcement important des TESTS : généralisation, refactorisation, simplification + numérotation systématique (cf doc ACL)
  695 + - nouvelle classe General dont héritent tous les tests
  696 + - nouvelle philo mise en place : 1 fichier tests par Controleur (c'était déjà le cas), puis pour un controleur donné, tri des tests par ACTION, puis pour chaque action, tests systématique de tous les ROLES (profils) avec les cas particuliers de chacun
  697 +
  698 +06/07/2017 Version: 2.7.3 (EP)
  699 + - suppression du contenu de vendor/ => désormais ignoré car autogénéré
  700 + - update des plugins phpqrcode et fpdf => désormais via composer.json
  701 + - amélioration script install => pour générer automatiquement le contenu de vendor/
  702 +
  703 +30/06/2017 Version: 2.7.0 (EP)
  704 + Passage de Cakephp3.2 à 3.4, Phpunit 5 à 6, et compatibilité avec Php5.6 et 7
  705 +
  706 +-----------------------------------------------------------------------------------------------------------
  707 +12/05/2017 Version: 2.6.2 (Thibaud Ajas?)
  708 + L'ajout d'un gestionnaire du matériel est désormais obligatoire à l'ajout d'un matériel
  709 +
  710 +09/05/2017 Version: 2.6.0 (Thibaud Ajas?)
  711 + Les noms des matériels sont en rouge dans la liste lorsque la date de garantie à été dépassée,
  712 + ainsi que la date elle-même dans leur fiche détaillée
  713 + Petits bugfixes divers
  714 +
  715 +-----------------------------------------------------------------------------------------------------------
  716 +25/04/2017 Version: 2.5.6 (Thibaud Ajas?)
  717 + On peut maintenant configurer et choisir sur la page le nombre de materiels affichés (20 par défaut)
  718 + Petits bugfixes divers
  719 + Amélioration du script et de la doc d'installation
  720 +
  721 +-----------------------------------------------------------------------------------------------------------
  722 +24/06/2016 Version: 2.4.7.2 (Version 2.4 finale)
  723 + Implémentation des ACL (droits) & Autres demandes
  724 + https://projects.irap.omp.eu/versions/107
  725 +
  726 +-----------------------------------------------------------------------------------------------------------
  727 +30/05/2016 Version: 2.3.2.1 (Version 2.3 finale)
  728 + Implémentation du LDAP (vrai et fake)
  729 + https://projects.irap.omp.eu/versions/108
  730 +
  731 +-----------------------------------------------------------------------------------------------------------
  732 +23/05/2016 Version: 2.2.5.4 (Version 2.2 finale)
  733 + Implémentation de toutes les autres actions
  734 + https://projects.irap.omp.eu/versions/106
  735 +
  736 +-----------------------------------------------------------------------------------------------------------
  737 +12/05/2016 Version: 2.1.10 (Version 2.1 finale)
  738 + Implémentation complète du CRUD
  739 + https://projects.irap.omp.eu/versions/101
  740 +
  741 +-----------------------------------------------------------------------------------------------------------
  742 +04/05/16 Version 2.0.8 (Version 2.0 finale)
  743 + Version de base (from bake) : php5 + cakephp3
  744 + https://projects.irap.omp.eu/versions/105
  745 +
  746 +-----------------------------------------------------------------------------------------------------------
  747 +21/01/16 Version 1.3.636 (Version 1.3 finale)
  748 + php5 + cakephp2.1
  749 + https://projects.irap.omp.eu/versions/17
  750 +
  751 +-----------------------------------------------------------------------------------------------------------
  752 +(SECTION OBSOLETE, HISTORIQUE)
  753 +
  754 +MODIFICATIONS STRUCTURELLES A FAIRE MANUELLEMENT APRES LA MISE A JOUR (git pull)
  755 +
  756 +30/06/16 (v2.5.4.0) Se placer dans database/update et exécuter le script ./db-update-2016-06-30.sh
  757 +
  758 +28/06/16 (v2.5.1.0) Se placer dans database/update et exécuter le script ./db-update-2016-06-28.sh
  759 +
  760 +27/06/16 (v2.5.0.0) Se placer dans database/update et exécuter le script ./db-update-2016-06-27.sh
  761 +
  762 +24/06/16 (v2.4.7.2) Se placer dans database/update et exécuter le script ./db-update-2016-06-24-2.sh
  763 +
  764 +24/06/16 (v2.4.7.0) Se placer dans database/update et exécuter le script ./db-update-2016-06-24.sh
  765 +
  766 +23/06/16 (v2.4.6.5) Se placer dans database/update et exécuter le script ./db-update-2016-06-23.sh
  767 +
  768 +23/06/16 (v2.4.6.4) Se placer dans database/update et exécuter le script ./db-update-2016-06-22.sh
  769 +
  770 +20/06/16 (v2.4.6.0) Se placer dans database/update et exécuter le script ./db-update-2016-06-20.sh
  771 +
  772 +17/06/16 (v2.4.4.4) (Exceptionnel) Exécuter les lignes suivantes (à la racine) :
  773 + cp -p config/app.php ../config/app.php.ORIG
  774 + cp config/app.default.php ../config/app.php
  775 + Puis completez app.php (datasources => default & test (username, password, database)) avec app.php.ORIG
  776 +
  777 +15/06/16 (v2.4.4.0) Adapter la BD en exécutant le script sql ./db-update-2016-06-15.sql
  778 +
  779 +13/06/16 (v2.4.3.10) Adapter la BD en exécutant le script sql ./db-update-2016-06-13.sql
  780 +
  781 +07/06/16 (v2.4.3.2) Adapter la BD en exécutant le script sql ./db-update-2016-06-07.sql
  782 +
  783 +06/06/16 (v2.4.3.0) Adapter la BD en exécutant le script sql ./db-update-2016-06-06.sql
  784 +
  785 +04/06/16 (v???) Se placer dans install/ et exécuter le script d'installation ./installation.sh (en mode UPDATE)
  786 +
  787 +
... ...
README.md
... ... @@ -45,13 +45,13 @@ Logiciel testé et validé sur les configurations suivantes :
45 45 VERSION ACTUELLE
46 46  
47 47 Date: 13/07/2020
48   -Version: 3.7.9.60
  48 +Version: 3.7.9.60 (encours)
49 49 Author: EP
50 50 Commentaire:
51   - - Bugfix requete sql db-update-2020-06-10.sh pour IAS
52   -
53 51 - Nouvelle page web "Nouveautés" (/pages/changes)
54 52 - Changements migrés dans fichier CHANGES.txt et affichés proprement dans une nouvelle page web changes.ctp
  53 + - Bugfix requete sql db-update-2020-06-10.sh pour IAS
  54 +
55 55 - Nouvelle page web "Statistiques mensuelles" (/pages/stats)
56 56  
57 57 IMPORTANT :
... ... @@ -88,7 +88,6 @@ CHANGEMENTS VISIBLES (MILESTONES)
88 88 La liste ci-dessous est aussi en ligne ici : https://tinyurl.com/labinvent#heading=h.2r55bflctpt5
89 89  
90 90 -----------------------------------------------------------------------------------------------------------
91   -VERSION ACTUELLE
92 91  
93 92 10/07/2020 v3.7.9.58-59 (EP)
94 93 - Nouveau filtre "age" (FINALISÉ) sur page index des matériels : Affichage des matériels par tranche d'âge (0-5 ans, 5-10, ...)
... ...
src/Controller/PagesController.php
... ... @@ -88,6 +88,8 @@ class PagesController extends AppController
88 88 $page = null;
89 89 if (! empty($path[0])) $page = $path[0];
90 90 */
  91 +
  92 + $pages_authorized_without_connexion = ['about', 'acls', 'changes'];
91 93 $this->action = $this->getActionPassed();
92 94 if ($this->action == "display") {
93 95 $this->page = $this->request->getParam('pass.0');
... ... @@ -96,7 +98,7 @@ class PagesController extends AppController
96 98 // mais seulement pour la page 'about'
97 99 //if (in_array($path[0], ['about', 'tools'])) echo "yes"; else echo "no";
98 100 //if ( $this->page == 'about' ) $this->LdapAuth->allow(['display']);
99   - if ( in_array($this->page, ['about', 'acls']) ) $this->LdapAuth->allow(['display']);
  101 + if ( in_array($this->page, $pages_authorized_without_connexion) ) $this->LdapAuth->allow(['display']);
100 102 }
101 103  
102 104 }
... ... @@ -118,8 +120,9 @@ class PagesController extends AppController
118 120  
119 121 // Action display 'acls' (affichage de la page 'Autorisations')
120 122 $this->setAuthorizationsForAction('display/acls', 0);
121   -
122   - // Action display 'home' (affichage de la page 'Acceuil')
  123 + $this->setAuthorizationsForAction('display/changes', 0);
  124 +
  125 + // Action display 'home' (affichage de la page 'Accueil')
123 126 $this->setAuthorizationsForAction('display/home', 0);
124 127  
125 128 // Action display 'tools' (affichage de la page 'menu Outils')
... ...
src/Template/Layout/default.ctp
... ... @@ -181,15 +181,19 @@ $this->append('script', $this->Html->script(['script', 'DatepickerConfig', 'onTa
181 181  
182 182 <a class="col-lg-2" href="http://cakephp.org">Baked with CAKEPHP</a>
183 183  
184   - <div class="col-lg-5" id="bugreport"><a href="https://tinyurl.com/labinvent#heading=h.2gyqfeghae4k"><h3>WHAT's NEW ?</h3></a>
185   - <i>
  184 + <div class="col-lg-5" id="bugreport">
  185 + <!--
  186 + <a href="https://tinyurl.com/labinvent#heading=h.2gyqfeghae4k"><h3>WHAT's NEW ?</h3></a>
  187 + -->
  188 + <a href="/pages/changes"><h3>WHAT's NEW ?</h3></a>
  189 + <i>
186 190 <!--
187 191 (<a href="https://projects.irap.omp.eu/projects/inventirap/roadmap?tracker_ids[]=1&tracker_ids[]=2&tracker_ids[]=4&tracker_ids[]=5&tracker_ids[]=6&tracker_ids[]=7&tracker_ids[]=8&tracker_ids[]=9#version_2.04_-_Impl%C3%A9mentation_des_ACL_%28droits%29">ROADMAP : Activité restant à réaliser</a>)
188 192 (<a href="https://projects.irap.omp.eu/projects/inventirap/issues?query_id=263">ROADMAP => Activité restant à réaliser - TODO LIST</a>)
189 193 -->
190 194 (<a href="https://docs.google.com/spreadsheets/d/1vRW67Mr_l5gg1Ae9w7wpMAFYBP74MqFD6J3q4iZ0Ax4/edit#gid=0">ROADMAP => Activité restant à réaliser - TODO LIST</a>)
191 195 <br/><h6>Merci de communiquer remarques et bugs à <a href="mailto:inventirap@irap.omp.eu">LABINVENT-MAILING-LIST</a></h6>
192   - </i>
  196 + </i>
193 197 </div>
194 198  
195 199 <div class="col-lg-3" id="version">
... ...
src/Template/Pages/about.ctp
... ... @@ -31,8 +31,13 @@ Licence GPL (http://www.gnu.org/copyleft/gpl.html)&lt;br&gt;&lt;br&gt;
31 31 See http://www.gnu.org/licenses
32 32 </section>
33 33 EOD;
  34 +
34 35 echo '<br/>';
35   -echo '<a href="' . 'https://tinyurl.com/labinvent">Documentation générale</a>';
  36 +echo '<a href="/pages/changes">Changements faits sur le logiciel (nouveautés et historique)</a>';
  37 +
  38 +echo '<br/><br/>';
  39 +echo '<a href="https://tinyurl.com/labinvent">Documentation générale</a>';
  40 +
36 41 echo '<br/><br/>';
37 42 echo '<a href="' . $this->request->webroot . 'webroot/doc/userguide/labinvent2_userguide.pdf">Guide utilisateur</a>';
38 43 ?>
... ...