Subversion Repositories Applications.framework

Rev

Rev 98 | Rev 118 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

<?php
// declare(encoding='UTF-8');
/**
* classe Controlleur, coeur d'une application, c'est normalement la seule classe d'une application
* qui devrait être appelée de l'extérieur.
* Elle est abstraite donc doit obligatoirement être étendue
* 
* PHP Version 5 
* 
* @category  Class
* @package   Framework
* @author    aurelien <aurelien@tela-botanica.org>
* @copyright 2009 Tela-Botanica
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL  
* @license   http://www.gnu.org/licenses/gpl.html Licence GNU-GPL  
* @version   SVN: $$Id$$ 
* @link      /doc/framework/ 
* 
*/
abstract class Controleur {
    /**
     * Registre global, normalement accessible partout
     */
    private $_registre;
    /**
     * Gestionnaire d'exceptions php
     */
    private $__gestionnaire_exception;
    /**
     * Gestionnaire d'erreurs php
     */
    private $_gestionnaire_erreur;
    
    /**
     * Constructeur par défaut
     */
    final public function __construct() {    
        if (Config::existe('fw_html_errors')) {
                ini_set('html_errors', Config::get('fw_html_errors'));
        }
        
        $this->registre = Registre::getInstance(); 
        $this->registre->set('base_chemin_modele', Config::get('chemin_modeles')); 
        $this->registre->set('base_chemin_squelette', Config::get('chemin_squelettes')); 
        $this->registre->set('base_chemin_controleur', Config::get('chemin_controleurs')); 
        $this->registre->set('base_url_application', new Url(Config::get('url_base'))); 
        $this->_gestionnaire_exception = GestionnaireException::getInstance(); 
        $this->_gestionnaire_erreur = GestionnaireErreur::getInstance(); 
    }
    
    /**
    * Charge un modele donné et le rend disponible sous la forme $this->nom_modele
    * 
    * @param string $nom_modele le nom du modèle à charger
    * 
    * @return boolean false si le chargement a échoué, rien sinon
    */
    final protected function chargerModele($nom_modele) {
        
        $chemin_modele = ($this->registre->get('base_chemin_modele')).$nom_modele.'.php'; 
        
        if (!file_exists($chemin_modele)) {
            return false; 
        }
        
        include_once $chemin_modele; 
        
        if (!class_exists($nom_modele)) {
            return false;
        }
        
        $this->$nom_modele = new $nom_modele; 
    }
    
    /**
     * Fonction prenant en paramètre le nom d'un squelette et un tableau associatif de données, 
     * en extrait les variables, charge le squelette
     * et cree une variable de classe contenant les deux combinés.
     * 
     * @param String $nom_squelette le nom du squelette
     * @param Array  $donnees       un tableau associatif contenant les variables a injecter dans la vue
     * 
     * @return boolean false si la vue n'existe pas, rien sinon
     */
    final protected function chargerVue($nom_squelette,$donnees) {
        $chemin_squelette = ($this->registre->get('base_chemin_squelette')).$nom_squelette.'.tpl.html';
        
        if (!file_exists($chemin_squelette)) {
            return false ;    
        }
        
        $donnees['base_url'] = $this->registre->get('base_url_application');
        
        // on extrait les variables du tableau de données       
        extract($donnees);
        
        // et on enclenche la bufferisation de sortie
        ob_start();
        
        // si les tags courts sont désactivés
        if ((bool) @ini_get('short_open_tag') === false) {
            // on remplace les tags par la syntaxe classique avec echo
            echo eval('?>'.preg_replace("/;*\s*\?>/", "; ?>", str_replace('<?=', '<?php echo ', file_get_contents($chemin_squelette))));
        } else {
            // sinon, on se contente d'inclure le squelette
            include $chemin_squelette; 
        }
        
        // on récupère le buffer et on le vide    
        $tampon = ob_get_contents(); 
        @ob_end_clean(); 
                
        // enfin on renvoie le contenu
        $this->$nom_squelette = $tampon;
    }
}
?>