item; foreach($config_xml as $item){ $this->modules["$item[id]"] = $item; } $this->getModules(); $this->buildConfigMenu(); }else{ echo 'Impossible de trouver le fichier de configuration.'; } } /** * * Initialise les modules activés uniquement */ function getModules(){ foreach($this->modules as $module=>$moduleConf){ if(file_exists('modules/'.$module.'/'.ucfirst($module).'.php') && $moduleConf->visibility == "true"){ $params = array(); foreach($moduleConf as $confParam){ $params[$confParam->getName()] = "$confParam"; } require 'modules/'.$module.'/'.ucfirst($module).'.php'; call_user_func(array($module, "start"), $params); } } } /** * * Construit et insère le menu de changement de config */ function buildConfigMenu(){ echo '

Modules configuration


'; foreach($this->modules as $module=>$moduleConf){ echo $module.' module : visibility == "true") echo " checked"; echo '/>true  visibility == "false") echo " checked"; echo '/>false

'; } echo 'Enregistrer
'; echo ''; } /** * * @property Chaque module possède la fonction updateModule en static qui permet de changer un ou plusieurs de ses attributs * @param $module String Nom du module à modifier * @param $things2change Array du ou des attributs à modifier avec sa ou ses nouvelles valeurs * @return "ok" String si c'est bon, ou le message d'erreur */ public static function updateModule($module, $things2change){ require '../modules/'.$module.'/'.ucfirst($module).'.php'; return call_user_func(array($module, "updateConfig"), $things2change); } }