getModules

This commit is contained in:
fredtempez 2021-02-14 11:53:11 +01:00
parent fed10aa71d
commit 696d38b1f4
4 changed files with 85 additions and 74 deletions

View File

@ -1,4 +1,5 @@
<?php <?php
class helper { class helper {
/** Statut de la réécriture d'URL (pour éviter de lire le contenu du fichier .htaccess à chaque self::baseUrl()) */ /** Statut de la réécriture d'URL (pour éviter de lire le contenu du fichier .htaccess à chaque self::baseUrl()) */
@ -135,13 +136,22 @@ class helper {
* du numéro de version * du numéro de version
*/ */
public static function getModules($folder = 'module') { public static function getModules($folder = 'module') {
$modules = array();
// Le dossier existe-t-il ?
if (is_dir($folder)) {
$dirs = array_diff(scandir($folder), array('..', '.')); $dirs = array_diff(scandir($folder), array('..', '.'));
foreach ($dirs as $key => $value) { foreach ($dirs as $key => $value) {
// Dossier non vide // Dossier non vide
if (file_exists($folder . '/' . $value . '/' . $value . '.php')) { if (file_exists($folder . '/' . $value . '/' . $value . '.php')) {
// Lire les constantes // Lire les constantes en gérant les erreurs de nom de classe
try { try {
// Chargement des classes externes
if ($folder !== 'module') {
include_once ($folder . '/' . $value . '/' . $value . '.php');
if ( class_exists($value) ) {
$e = new $value;
}
}
$class_reflex = new \ReflectionClass($value); $class_reflex = new \ReflectionClass($value);
$class_constants = $class_reflex->getConstants(); $class_constants = $class_reflex->getConstants();
// Constante REALNAME // Constante REALNAME
@ -161,11 +171,13 @@ class helper {
'realName' => $realName, 'realName' => $realName,
'version' => $version 'version' => $version
]; ];
} catch (Exception $e){ } catch (Exception $e){
// on ne fait rien // on ne fait rien
} }
} }
} }
}
return($modules); return($modules);
} }

View File

@ -44,7 +44,7 @@ class common {
const ACCESS_TIMER = 1800; const ACCESS_TIMER = 1800;
// Numéro de version // Numéro de version
const ZWII_VERSION = '10.4.02.modules'; const ZWII_VERSION = '10.5.00';
const ZWII_UPDATE_CHANNEL = "v10"; const ZWII_UPDATE_CHANNEL = "v10";
public static $actions = []; public static $actions = [];

View File

@ -603,7 +603,7 @@ class config extends common {
* Affichage des modules installés * Affichage des modules installés
*/ */
public function modules() { public function modules() {
var_dump(helper::getModules ());
// Préparation du tableau des modules installés // Préparation du tableau des modules installés
// Liste des modules installés (répertoire de module/) // Liste des modules installés (répertoire de module/)
if ($dh = opendir( 'module/' )) { if ($dh = opendir( 'module/' )) {

View File

@ -441,8 +441,7 @@ class page extends common {
]); ]);
} }
} }
self::$moduleIds = array_merge( ['' => 'Aucun'] , helper::arrayCollumn(helper::getModules(),'realName','SORT_ASC')); self::$moduleIds = array_merge( ['' => 'Aucun'] , helper::arrayCollumn(helper::getModules(),'realName','SORT_ASC')); // Pages sans parent
// Pages sans parent
foreach($this->getHierarchy() as $parentPageId => $childrenPageIds) { foreach($this->getHierarchy() as $parentPageId => $childrenPageIds) {
if($parentPageId !== $this->getUrl(2)) { if($parentPageId !== $this->getUrl(2)) {
self::$pagesNoParentId[$parentPageId] = $this->getData(['page', $parentPageId, 'title']); self::$pagesNoParentId[$parentPageId] = $this->getData(['page', $parentPageId, 'title']);