Framework openMairie EXTRA - Historique des versions ==================================================== TODO: -ajouter le correctif à la référence externe om-theme : le bloc des actions en mode tablette (inf 1000 px) empêchait d'accéder au bas du formulaire -ajouter le correctif sur om_table d'openPéril sur la pagination avec des "group by" -ajouter le correctif sur om_filestorage_filesystem : ligne 393 if is_array($file["metadata"]) sinon erreur PHP fatale -ajouter au générateur la gestion de champs om_modif_datetime et om_modif_login => proposition à débattre / suivi JSON -ajouter à dbForm les méthodes pour afficher un tableau de valeurs avec une action par ligne simple et flexible (idem OEM) -ajouter le widget snapshot d'openMarchéForain ---------------------- 4.10.0-x4 (29/06/2023) ---------------------- * Correction [ FileSystem ] une erreur fatale pouvait se produire lors de la récupération d'un fichier temporaire sans métadonnées * Adaptation [ Application ] ajout de fonction de traçage mémoire et temps d'exécution ainsi que d'un envoi précoce vers la sortie pour aider à l'exécution et l'opitmisation des traitements lourds, en temps d'exécution (timeout frontal HTTP) ou en mémoire (fuite sur l'exécution SQL) * Adaptation [ REST ] récupération de tous les headers de réponse et journalisation sur services.log * Adaptation [ REST ] positionnement de timeout, par défaut: 1s à la connexion, et 5s à la réponse, surchargeable lor de l'appel à la méthode execute() * Adaptation [ texte ] fonction str_to_upper_without_accent() 4.10.0-x3 (14/03/2023) ---------------------- * Correction [ Select ] en consultation, on n'affichait l'identifiant technique des références ou vide au lieu du libellé attendu 4.10.0-x2 (10/03/2023) ---------------------- * Correction [ Select ] on pouvait avoir une alerte PHP si la requête ne ramenait aucune valeur * Correction [ Menu ] le menu escamotable n'était plus sensible au click 4.10.0-x1 (09/03/2023) ---------------------- * Correction [ Edition ] sous PHP 8, les éditions avec sous-état échouaient si number_format était appelé sur une chaine non numérique * Correction [ Technique ] la fonction getSelectOldValue appelée parfois par om_dbform::init_select avait conservé un paramètre de type ressource DB qui provoquait des erreurs d'exécution SQL * Adaptation [ Technique ] évite une erreur PHP en cas de resoumission de formulaire sur une session expirée * Adaptation [ openMairie ] migration 4.9.10 à 4.10.0 * Évolution : Support de plusieurs systèmes de stockage pour une unique application. Ticket #9984. * Évolution : Mise à niveau de la librairie tcpdf sur la dernière version (6.3.5 > 6.5.0). Ticket #9982. * Évolution : Mise à niveau de la librairie fpdf sur la dernière version (1.82 > 1.85). Ticket #10013. * Correction : Compatibilité PHP8.0 "PHP Deprecated: Required parameter $a follows optional parameter $b...". Ticket #9983. * Correction : Vérification de l'existence d'un tableau avant son utilisation dans om_formulaire::selecthiddenstatic(). Ticket #9985. * Correction : Problème d'encodage dans la méthode d'envoi de mail application::sendMail(). Ticket #9280. 1.0.15 (01/12/2022) ------------------- * Correction [ Edition ] sous PHP 8, les éditions avec sous-état échouaient si number_format était appelé sur chaine vide * Correction [ Edition ] sous PHP 8, pour les éditions avec sous-état, un message PHP deprecated remontait dans les traces 1.0.14 (08/11/2022) ------------------- * Correction [ Technique ] avec la suppression des alertes PHP 8.0, les listes avec recherches avancées ne s'affichaient plus 1.0.13 (24/10/2022) ------------------- * Adaptation [ Technique ] le script install.sh prend ses paramètres depuis dyn/database.inc.php * Adaptation [ Technique ] suppression des alertes DEPRECATED avec PHP 8.0 par reprise des méthodes et appels om_dbform::init_select($form, $maj, $field, ...) : suppression et regénération nécessaire des fichiers gen/obj/*, reprise des surcharges init_select 1.0.12 (06/04/2021) ------------------- * Correction : inclusion de la déclaration de la classe treatment_exception à la classe dbform, utilisable pour des retours d'erreur web-service hors HTML * Correction : du numéro de version dans om_version.inc.php 1.0.11 (02/04/2021) ------------------- * Adaptation : Mise à jour OM 4.9.10 : rafraichissemnt sous-formulaire mixed-content, générateur ordre des contraintes not null et suppression bug PostGreSql 12+ 1.0.10 (18/01/2020) ------------------- * Adaptation : ne provoque plus d'erreur de base de donnée si la table om_sig_flux n'existe pas * Correction des calculs de pagination en cas de requête de base avec des GROUP BY 1.0.9 (20/11/2020) ------------------ * Adaptation : la sécurisation du cookie de session est paramétrable à part dans dyn/config.inc.php, pour le cas où la couche SSL est assurée par un frontal web * Correction : la redirection https ne pouvait pas être mofifiée par le fichier dyn/config.inc.php 1.0.8 (20/11/2020) ------------------ * Adaptation : les headers HTTP n'était pas configurables par instance, ils le sont désormais via le fichier dyn/config.inc.php * Adaptation : les bases des URL des flux SIG sont ajoutées aux headers HTTP CSP img-src et CSP connect-src * Correction : en cas de non configuration spécifique du fichier journal d'erreur, on utilise toujours les paramètres par défaut 1.0.7 (25/09/2020) ------------------ * Adaptation [ Utilisateur ] limiter l'attribution de profils à ceux de hiérarchie au plus égale à celle de son propre profil * Adaptation [ Technique - sécurité ] renforcement du mode https obligatoire : redirection HTTP 1.0.6 (14/09/2020) ------------------ * Correction : le chemin des logs par défaut du module REST ignorait le paramétrage général * Adaptation : la limite de temps des éditions PDF était en dur à 180s, elle est désormais spécifiable à l'appel du calcul d'un PDF * Adaptation : Mise à jour OM 4.9.8, lorsque le flag utilisé était login_and_nohtml et que le login et/ou mot de passe étaient incorrects, le flag ne se comportait pas comme nohtml (il affaichait la structure de la page html) 1.0.5 (06/06/2020) ------------------ * Correction technique : définition des paramètres TCPDF nécessaires aux sous-états 1.0.4 (08/05/2020) ------------------ * Correction technique : appel des CSS lib/om-theme depuis la classe layout 1.0.3 (08/05/2020) ------------------ * Correction : pour les écrans de largeur inférieure à 1000px, le passage des widgets sur une colonne ne fonctionnait pas 1.0.2 (08/05/2020) ------------------ * Adaptation : le positionnement d'un titre avec [xxx] positionne une alerte en rouge dans la zone des 'shortlinks' 1.0.1 (08/05/2020) ------------------ * Adaptation : adaptation des tests auto à la prop0075 * Correction : Mise à jour OM 4.9.7 : correction des librairies externes pour compatibilité PHP7.4 * Correction : on remplace ' onXXX=' par ' jsattr=' et plus 'jsattr=' 1.0.0 (10/04/2020) basée sur OM4.9.6 ------------------ * Evolution : ajout à om_formulaire de widget monétaire et bouton-radio * Evolution : ajout à dbForm de méthodes utiles pour gérer les cas hors formulaire généré: traitements transactionnels, affichage de message retour * Evolution : ajout de la classe treatment_exception utile pour les traitements programmés et exécutés par appel web-service interne * Evolution : ajout d'éléments basique améliorant l'adaptabilité aux petits écrans : menu esacamotable et stlye "media-queries" #om_prop0064 * Evolution : extension des capacités de SendMail pour les rapporcher de celles de la fonction PHP, sans modifier l'usage précédent #om_prop0047 * Evolution : Le chemin des fichiers journaux devient paramétrable via dyn/filestorage.inc.php , et peut-être modifié à l'instanciation d'un om_rest_client , qui journalise aussi les headers HTTP envoyés. en cas d'erreur d'écriture des logs, l'erreur est affichée si le mode DEBUG est actif. #om_prop0066 * Evolution : Rendre plus efficace la protection contre la saisie de codes javascript dans les formulaires, protéger mieux d'une exécution en cas d'injection JavaScript par un autre moyen (SQL, Web-Service, ...) et permettre de conserver les " dans les valeurs. #om_prop0075 * Evolution : Mettre en place par défaut une configuration applicative des header HTTP correspondant aux bonnes pratiques, non dé-verrouillable par paramétrage pour conserver un haut niveau de sécurité. Sur certaines applications, suivant les ressources externes utilisées (notamment les flux SIG ou web-service), il pourrait subsister des blocages Content-Security-Policy. En ce cas, le blocage est visible dans la console JavaScript du navigateur ou en utilisant la fonctionnalité « report-uri » du header CSP. #om_prop0074 * Evolution : Cinq modifications pour rendre la session plus robuste #om_prop0073 > modifier l’identifiant de session après une authentification réussie, et ne pas changer son nom si elle est déjà active (cas improbable depuis correctif ) > regénérer l’identifiant de session à chaque requête limiter la durée de vie de session à 15mn, configurable dans dyn/config.inc.php, avec alerte JavaScript quand le temps maximum est atteint > positionner les paramètres de sécurisation des cookies recommandés en HTTP et HTTPS > proposer l’option de n’autoriser que le HTTPS, configurable dans dyn/config.inc.php , et pris en compte dans la redirection applicative avec le paramètre came_from * Evolution : La technique de hashage des mots de passe des utilisateurs locaux est modifiée: attention, les anciens mots de passe des utilisateurs deviennent inopérants. Pour la migration, on peut définir les hashages de mots de passe "temporaires" à affecter en SQL et communiquer aux utilisateurs concernés #om_prop0072 * Evolution : L'action "Mot de passe" proposée dans les actions personnelles applicatives n'est plus proposée aux utilisateurs de type annuaire 0.0.0 (10/04/2020) ------------------ Fork OM 4.9.6