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()) */
@ -19,7 +20,7 @@ class helper {
/** /**
* Récupérer l'adresse IP sans tenit compte du proxy * Récupérer l'adresse IP sans tenit compte du proxy
* @return string IP adress * @return string IP adress
* Cette focntion est utilisé par user * Cette focntion est utilisé par user
@ -129,41 +130,52 @@ class helper {
/** /**
* Retourne la liste des modules installés dans un tableau composé * Retourne la liste des modules installés dans un tableau composé
* du nom réel * du nom réel
* 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('..', '.'));
foreach ($dirs as $key => $value) {
// Dossier non vide
if (file_exists($folder . '/' . $value . '/' . $value . '.php')) {
// Lire les constantes en gérant les erreurs de nom de classe
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_constants = $class_reflex->getConstants();
// Constante REALNAME
if (array_key_exists('REALNAME', $class_constants)) {
$realName = $value::REALNAME;
} else {
$realName = ucfirst($value);
}
// Constante VERSION
if (array_key_exists('VERSION', $class_constants)) {
$version = $value::VERSION;
} else {
$version = '0.0';
}
// Affection
$modules [$value] = [
'realName' => $realName,
'version' => $version
];
$dirs = array_diff(scandir($folder), array('..', '.')); } catch (Exception $e){
foreach ($dirs as $key => $value) { // on ne fait rien
// Dossier non vide
if (file_exists($folder . '/' . $value . '/' . $value . '.php')) {
// Lire les constantes
try {
$class_reflex = new \ReflectionClass($value);
$class_constants = $class_reflex->getConstants();
// Constante REALNAME
if (array_key_exists('REALNAME', $class_constants)) {
$realName = $value::REALNAME;
} else {
$realName = ucfirst($value);
} }
// Constante VERSION }
if (array_key_exists('VERSION', $class_constants)) {
$version = $value::VERSION;
} else {
$version = '0.0';
}
// Affection
$modules [$value] = [
'realName' => $realName,
'version' => $version
];
} catch (Exception $e){
// 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

@ -34,7 +34,7 @@ class config extends common {
'moduleDelete' => self::GROUP_ADMIN 'moduleDelete' => self::GROUP_ADMIN
]; ];
public static $modInstal = []; public static $modInstal = [];
public static $str; public static $str;
@ -597,13 +597,13 @@ class config extends common {
'view' => 'advanced' 'view' => 'advanced'
]); ]);
} }
/* /*
* Installation de modules à partir d'un zip normalisé * Installation de modules à partir d'un zip normalisé
* 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/' )) {
@ -611,11 +611,11 @@ class config extends common {
while (($dirmodule = readdir($dh)) !== false) { while (($dirmodule = readdir($dh)) !== false) {
if( $dirmodule !== '.' && $dirmodule !== '..'){ if( $dirmodule !== '.' && $dirmodule !== '..'){
self::$modInstal[$i][0] = $dirmodule; self::$modInstal[$i][0] = $dirmodule;
self::$modInstal[$i][1] = page::$moduleNames[$dirmodule]; self::$modInstal[$i][1] = page::$moduleNames[$dirmodule];
// Lecture de la version pour les modules officiels et distribués // Lecture de la version pour les modules officiels et distribués
$blogversion = blog::VERSION; $blogversion = blog::VERSION;
$formversion = form::VERSION; $formversion = form::VERSION;
$galleryversion = gallery::VERSION; $galleryversion = gallery::VERSION;
$newsversion = news::VERSION; $newsversion = news::VERSION;
$redirectionversion = redirection::VERSION; $redirectionversion = redirection::VERSION;
$searchversion = search::VERSION; $searchversion = search::VERSION;
@ -627,7 +627,7 @@ class config extends common {
// Lecture de la version pour les modules non distribués // Lecture de la version pour les modules non distribués
elseif($this->getData(['module', '_gestion_modules_' , $dirmodule, 'version' ]) !== null){ elseif($this->getData(['module', '_gestion_modules_' , $dirmodule, 'version' ]) !== null){
self::$modInstal[$i][2] = $this->getData(['module', '_gestion_modules_' , $dirmodule, 'version' ]); self::$modInstal[$i][2] = $this->getData(['module', '_gestion_modules_' , $dirmodule, 'version' ]);
} }
self::$modInstal[$i][3] = 'non'; self::$modInstal[$i][3] = 'non';
self::$modInstal[$i][4] = ''; self::$modInstal[$i][4] = '';
self::$modInstal[$i][5] = ''; self::$modInstal[$i][5] = '';
@ -652,16 +652,16 @@ class config extends common {
} }
$modulesDistrib = array('blog', 'form', 'gallery', 'news', 'redirection', 'search'); $modulesDistrib = array('blog', 'form', 'gallery', 'news', 'redirection', 'search');
if( self::$modInstal[$i][4] =='' && array_search( self::$modInstal[$i][0], $modulesDistrib ) === false if( self::$modInstal[$i][4] =='' && array_search( self::$modInstal[$i][0], $modulesDistrib ) === false
&& $this->getData(['module', '_gestion_modules_', self::$modInstal[$i][0], 'delete' ]) === true){ && $this->getData(['module', '_gestion_modules_', self::$modInstal[$i][0], 'delete' ]) === true){
self::$modInstal[$i][5] = template::button('moduleDelete' . self::$modInstal[$i][0], [ self::$modInstal[$i][5] = template::button('moduleDelete' . self::$modInstal[$i][0], [
'class' => 'moduleDelete buttonRed', 'class' => 'moduleDelete buttonRed',
'href' => helper::baseUrl() . $this->getUrl(0) . '/moduleDelete/' . self::$modInstal[$i][0] . '/' . $_SESSION['csrf'], 'href' => helper::baseUrl() . $this->getUrl(0) . '/moduleDelete/' . self::$modInstal[$i][0] . '/' . $_SESSION['csrf'],
'value' => template::ico('cancel') 'value' => template::ico('cancel')
]); ]);
} }
} }
// Retour du formulaire ? // Retour du formulaire ?
if($this->isPost()) { if($this->isPost()) {
// Installation d'un module // Installation d'un module
@ -681,7 +681,7 @@ class config extends common {
$moduleDir = self::TEMP_DIR . $tempFolder . '/module'; $moduleDir = self::TEMP_DIR . $tempFolder . '/module';
$moduleName = ''; $moduleName = '';
if ( is_dir( $moduleDir )) { if ( is_dir( $moduleDir )) {
// Lire le nom du module // Lire le nom du module
if ($dh = opendir( $moduleDir )) { if ($dh = opendir( $moduleDir )) {
while (($file = readdir($dh)) !== false) { while (($file = readdir($dh)) !== false) {
$moduleName = $file; $moduleName = $file;
@ -690,7 +690,7 @@ class config extends common {
} }
// Module normalisé ? // Module normalisé ?
if( is_file( $moduleDir.'/'.$moduleName.'/'.$moduleName.'.php' ) AND is_file( $moduleDir.'/'.$moduleName.'/view/index/index.php' ) ){ if( is_file( $moduleDir.'/'.$moduleName.'/'.$moduleName.'.php' ) AND is_file( $moduleDir.'/'.$moduleName.'/view/index/index.php' ) ){
// Lecture de info.json et mémorisation des 3 paramètres version, update et delete // Lecture de info.json et mémorisation des 3 paramètres version, update et delete
$version = '?'; $version = '?';
$update = '?'; $update = '?';
@ -707,7 +707,7 @@ class config extends common {
$this->setData(['module','_gestion_modules_',$moduleName, 'version', $version]); $this->setData(['module','_gestion_modules_',$moduleName, 'version', $version]);
$this->setData(['module','_gestion_modules_',$moduleName, 'update', $update]); $this->setData(['module','_gestion_modules_',$moduleName, 'update', $update]);
$this->setData(['module','_gestion_modules_',$moduleName, 'delete', $delete]); $this->setData(['module','_gestion_modules_',$moduleName, 'delete', $delete]);
// Module déjà installé ? // Module déjà installé ?
$moduleInstal = false; $moduleInstal = false;
foreach( self::$modInstal as $key=>$value){ foreach( self::$modInstal as $key=>$value){
@ -725,7 +725,7 @@ class config extends common {
if(is_bool($update)){ if(is_bool($update)){
$validMaj = $checkValidMaj && $update; $validMaj = $checkValidMaj && $update;
} }
// Nouvelle installation ou mise à jour du module avec validation du concepteur et validation de l'utilisateur // Nouvelle installation ou mise à jour du module avec validation du concepteur et validation de l'utilisateur
if( ! $moduleInstal || ( $moduleInstal && $validMaj )){ if( ! $moduleInstal || ( $moduleInstal && $validMaj )){
// Copie récursive des dossiers // Copie récursive des dossiers
@ -756,7 +756,7 @@ class config extends common {
$notification = 'Impossible d\'ouvrir l\'archive'; $notification = 'Impossible d\'ouvrir l\'archive';
} }
} }
$this->addOutput([ $this->addOutput([
'redirect' => helper::baseUrl() . $this->getUrl(), 'redirect' => helper::baseUrl() . $this->getUrl(),
'notification' => $notification, 'notification' => $notification,
@ -769,13 +769,13 @@ class config extends common {
'view' => 'modules' 'view' => 'modules'
]); ]);
} }
/* /*
* *
* Effacement d'un module installé et non utilisé * Effacement d'un module installé et non utilisé
*/ */
public function moduleDelete() { public function moduleDelete() {
// Jeton incorrect // Jeton incorrect
if ($this->getUrl(3) !== $_SESSION['csrf']) { if ($this->getUrl(3) !== $_SESSION['csrf']) {
// Valeurs en sortie // Valeurs en sortie
@ -805,8 +805,8 @@ class config extends common {
]); ]);
} }
} }
public function script() { public function script() {
// Soumission du formulaire // Soumission du formulaire
if($this->isPost()) { if($this->isPost()) {
@ -1027,31 +1027,31 @@ class config extends common {
} }
return $newArray; return $newArray;
} }
/* /*
* Copie récursive de dossiers * Copie récursive de dossiers
* *
*/ */
private function custom_copy($src, $dst) { private function custom_copy($src, $dst) {
// open the source directory // open the source directory
$dir = opendir($src); $dir = opendir($src);
// Make the destination directory if not exist // Make the destination directory if not exist
@mkdir($dst); @mkdir($dst);
// Loop through the files in source directory // Loop through the files in source directory
while( $file = readdir($dir) ) { while( $file = readdir($dir) ) {
if (( $file != '.' ) && ( $file != '..' )) { if (( $file != '.' ) && ( $file != '..' )) {
if ( is_dir($src . '/' . $file) ){ if ( is_dir($src . '/' . $file) ){
// Recursively calling custom copy function // Recursively calling custom copy function
// for sub directory // for sub directory
$this -> custom_copy($src . '/' . $file, $dst . '/' . $file); $this -> custom_copy($src . '/' . $file, $dst . '/' . $file);
} }
else { else {
copy($src . '/' . $file, $dst . '/' . $file); copy($src . '/' . $file, $dst . '/' . $file);
} }
} }
} }
closedir($dir); closedir($dir);
} }
/* /*
@ -1086,6 +1086,6 @@ class config extends common {
} }
return true; return true;
} }
} }
} }

View File

@ -440,9 +440,8 @@ class page extends common {
'state' => true 'state' => true
]); ]);
} }
} }
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']);