Subversion Repositories Applications.referentiel

Compare Revisions

Ignore whitespace Rev 24 → Rev 26

/trunk/interfaces/framework.defaut.php
1,6 → 1,6
<?php
// Inclusion du Framework
// Renomer ce fichier en "framework.php"
// Indiquyer ci-dessous le chemin vers le fichier autoload.inc.php de la bonne version du Framework
require_once '/framework/0.2/autoload.inc.php';
// Indiquyer ci-dessous le chemin absolu vers le fichier autoload.inc.php de la bonne version du Framework
require_once '/home/referentiel/www/commun/tbframework/0.2/autoload.inc.php';
?>
/trunk/interfaces/index.php
33,12 → 33,12
 
<link rel="stylesheet" type="text/css" media="print" href="http://www.tela-botanica.org/sites/commun/fr/styles/impression.css" />
 
<link rel="stylesheet" type="text/css" media="screen" href="squelettes/css/referentiel/referentiel.css" />
<link rel="stylesheet" type="text/css" media="screen" href="squelettes/css/humanity/jquery-ui-1.8.custom.css" />
<link rel="stylesheet" type="text/css" media="screen" href="squelettes/css/referentiel/debogage.css" />
<link rel="stylesheet" type="text/css" media="screen" href="interfaces/squelettes/css/referentiel/referentiel.css" />
<link rel="stylesheet" type="text/css" media="screen" href="interfaces/squelettes/css/humanity/jquery-ui-1.8.custom.css" />
<link rel="stylesheet" type="text/css" media="screen" href="interfaces/squelettes/css/referentiel/debogage.css" />
<script type="text/javascript" src="squelettes/js/jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="squelettes/js/jquery-ui-1.8.custom.min.js"></script>
<script type="text/javascript" src="interfaces/squelettes/js/jquery-1.4.2.min.js"></script>
<script type="text/javascript" src="interfaces/squelettes/js/jquery-ui-1.8.custom.min.js"></script>
</head>
<body xml:lang="fr" lang="fr">
<div id="reducteur">
/trunk/interfaces/controleurs/Test.php
17,7 → 17,6
private $referentiel = null;
private $traitementDao = null;
private $messages = null;
public function __construct() {
parent::__construct();
53,17 → 52,17
// Traitement de l'info sur le code du référentiel
if (isset($this->referentiel)) {
$donnees['ref'] = $this->referentiel;
$resultat = $this->traitementDao->getTraitementEnCours($this->referentiel);
$resultat = $this->traitementDao->getTraitementsEnCours($this->referentiel);
if ($resultat != false) {
$donnees['traitements'] = $resultat;
} else {
$this->messages[] = "Un problème est survenu lors de la tentative de récupération des traitements en cours.";
$this->addMessage("Un problème est survenu lors de la tentative de récupération des traitements en cours.");
}
} else {
$this->messages[] = "Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).";
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
}
$donnees['messages'] = $this->messages;
$donnees['messages'] = $this->getMessages();
$this->setSortie(self::RENDU_CORPS, $this->getVue('form_traitement', $donnees), false);
}
72,7 → 71,7
*/
public function demanderTraitement() {
$this->ajouterTraitement();
//$this->afficherInterface();
$this->afficherInterface();
}
/**
80,17 → 79,55
*/
private function ajouterTraitement() {
if (!isset($this->referentiel)) {
$this->messages[] = "Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).";
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
} else {
// TODO : vérifier qu'il n'y a pas déjà un traitement en cours pour ce projet.
$resultat = $this->traitementDao->ajouterTraitement($this->referentiel);
Debug::printr($resultat);
if ($resultat != false) {
$this->messages[] = "Le traitement #'' a été ajouté.";
$this->addMessage("Le traitement #'$resultat' a été ajouté.");
$this->lancerScript();
} else {
$this->messages[] = "Un problème est survenu lors de la tentative d'ajout du traitement.";
$this->addMessage("Un problème est survenu lors de la tentative d'ajout du traitement.");
}
}
}
/**
* Lance le script d'execution des traitements
*/
private function lancerScript() {
$php = Config::get('chemin_bin_php');
$exe = Config::get('chemin_script');
$script = 'tests';
$projet = $this->referentiel;
$action = 'tout';
$log = Config::get('chemin_script_log');
$commande = "$php -f $exe $script -p $projet -a $action > $log &";
 
$message_erreur_tpl = "%s\n.".
"Il est nécessaire de configurer le lancement du script via une tache dans le cron.\n".
"La commande à lancer est : <code>$commande</code>";
if ($this->verifierSafeModeOff() === false) {
$e = "Le safe_mode est actif sur ce serveur.";
$this->addMessage(sprintf($message_erreur_tpl, $e));
} else if ($this->verifierAccesFonctionExec() === false) {
$e = "La fonction 'exec()' fait partie des fonctions désactivées sur ce serveur (voir disable_functions).";
$this->addMessage(sprintf($message_erreur_tpl, $e));
} else {
Debug::printr($commande);
$this->addMessage("Lancement du script effectuant les traitements.");
exec($commande);
}
}
private function verifierSafeModeOff() {
return ('1' == ini_get('safe_mode')) ? false : true;
}
private function verifierAccesFonctionExec() {
$disabled = explode(', ', ini_get('disable_functions'));
return !in_array('exec', $disabled);
}
}
?>
/trunk/interfaces/controleurs/AppliControleur.php
17,11 → 17,15
const RENDU_CORPS = 'corps';
const RENDU_PIED = 'pied';
private $sortie = array();
private $parametres = array();
// FIXME : voir s'il est plus intéressant d'utiliser une méthode dans les classes filles
protected $url = null;
private $parametres = array();
private $sortie = array();
private $messages = null;
//+----------------------------------------------------------------------------------------------------------------+
// Constructeur
public function __construct() {
$registre = Registre::getInstance();
$this->parametres = $registre->get('parametres');
29,7 → 33,17
parent::__construct();
}
//+----------------------------------------------------------------------------------------------------------------+
// Accesseurs
 
/**
* Retourne le tableau de sortie à utiliser dans le controleur principal de l'application.
*/
public function getSortie() {
return $this->sortie;
}
 
/**
* Attribue à la bonne position de sortie un contenu.
*/
protected function setSortie($position, $contenu, $fusionner = false) {
43,6 → 57,25
}
/**
* Retourne le tableau des messages
*/
protected function getMessages() {
return $this->messages;
}
/**
* Ajoute un message
*/
protected function addMessage($message) {
if ('' != $message) {
$this->messages[] = $message;
}
}
//+----------------------------------------------------------------------------------------------------------------+
// Méthodes
/**
* Vérifie l'existence de la position indiquée pour son utilisation dans le tableau de sortie.
* @param string la position à tester.
* @return bool true si la position est valide, sinon false.
59,13 → 92,6
}
/**
* Retourne le tableau de sortie à utiliser dans le controleur principal de l'application.
*/
public function getSortie() {
return $this->sortie;
}
 
/**
* Execute l'action d'un module donnée et fusionne le résultat avec le tableau de sortie.
*/
protected function executerAction($ClasseModule, $action) {
/trunk/interfaces/framework.php
1,6 → 1,6
<?php
// Inclusion du Framework
// Renomer ce fichier en "framework.php"
// Indiquyer ci-dessous le chemin vers le fichier autoload.inc.php de la bonne version du Framework
require_once '../../framework/framework/autoload.inc.php';
// Indiquyer ci-dessous le chemin absolu vers le fichier autoload.inc.php de la bonne version du Framework
require_once '/home/jpm/web/framework/framework/autoload.inc.php';
?>