Subversion Repositories Applications.referentiel

Compare Revisions

Ignore whitespace Rev 38 → Rev 39

/trunk/interfaces/controleurs/Test.php
15,6 → 15,8
*/
class Test extends AppliControleur {
const SCRIPT_A_LANCER = 'tests';
private $referentiel = null;
private $traitementDao = null;
53,20 → 55,15
// Traitement de l'info sur le code du référentiel
if (isset($this->referentiel)) {
$donnees['ref'] = $this->referentiel;
 
// Recherche des traitements en attente
$resultat = $this->traitementDao->getTraitementsEnAttente($this->referentiel);
if (is_array($resultat)) {
$donnees['traitements_en_attente'] = $resultat;
}
$donnees['traitements_en_attente'] = $this->traitementDao->getTraitementsEnAttente($this->referentiel, self::SCRIPT_A_LANCER);
// Recherche des traitements en cours d'éxecution
$resultat = $this->traitementDao->getTraitementsEnCours($this->referentiel);
if (is_array($resultat)) {
$donnees['traitements_en_cours'] = $resultat;
}
$donnees['traitements_en_cours'] = $this->traitementDao->getTraitementsEnCours($this->referentiel, self::SCRIPT_A_LANCER);
// Recherche des traitements déjà effectué
$resultat = $this->traitementDao->getTraitementsTermines($this->referentiel);
$resultat = $this->traitementDao->getTraitementsTermines($this->referentiel, self::SCRIPT_A_LANCER);
if (is_array($resultat)) {
// Ajout de l'url vers la fiche du traitement
foreach ($resultat as &$traitement) {
76,7 → 73,7
}
} else {
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
}
}
$donnees['messages'] = $this->getMessages();
$this->setSortie(self::RENDU_CORPS, $this->getVue('form_traitement', $donnees), false);
88,73 → 85,8
* Lance l'ajout d'un traitement
*/
public function demanderTraitement() {
$this->ajouterTraitement();
$this->ajouterTraitement($this->referentiel, self::SCRIPT_A_LANCER);
$this->afficherInterface();
}
/**
* Lance l'ajout d'un traitement
*/
private function ajouterTraitement() {
if (!isset($this->referentiel)) {
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
} else {
$resultat_traitement_en_attente = $this->traitementDao->getTraitementsEnAttente($this->referentiel);
if ($resultat_traitement_en_attente) {
$this->addMessage("Un traitement est déjà en attente...");
} else {
$resultat_traitement_en_cours = $this->traitementDao->getTraitementsEnCours($this->referentiel);
if ($resultat_traitement_en_cours) {
$this->addMessage("Un traitement est déjà en cours...");
} else {
$resultat = $this->traitementDao->ajouterTraitement($this->referentiel);
if ($resultat != false) {
$this->addMessage("Le traitement #'$resultat' a été ajouté.");
$this->lancerScript();
} else {
$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 -d memory_limit=1073741824 -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/Versionnage.php
14,8 → 14,11
*/
class Versionnage extends AppliControleur {
const SCRIPT_A_LANCER = 'versionnage';
private $manuel = null;
private $referentiel = null;
private $traitementDao = null;
public function __construct() {
parent::__construct();
24,8 → 27,11
if (isset($_GET['ref'])) { // code du projet courrant
$this->referentiel = strtolower($_GET['ref']);
}
// Chargement des infos du manuel technique des référentiels
$this->manuel = parse_ini_file(Config::get('chemin_appli').DS.'..'.DS.'configurations'.DS.'referentiel_v2.1.ini');
$this->manuel = parse_ini_file(Config::get('chemin_appli').DS.'..'.DS.'configurations'.DS.'referentiel_v2.1.ini');
// Chargement des DAO nécessaires
$this->traitementDao = new TraitementDao();
}
//+----------------------------------------------------------------------------------------------------------------+
42,6 → 48,7
*/
public function afficherInterface() {
$donnees = array();
// Paramêtres pour l'url du formulaire
$this->url->unsetVariablesRequete(array('module', 'action', 'ref'));
$donnees['url_form'] = $this->url->getUrl();
66,9 → 73,41
}
}
// Traitement de l'info sur le code du référentiel
if (isset($this->referentiel)) {
// Récupération du référentiel courrant
$donnees['ref'] = $this->referentiel;
// Recherche des traitements en attente
$donnees['traitements_en_attente'] = $this->traitementDao->getTraitementsEnAttente($this->referentiel, self::SCRIPT_A_LANCER);
// Recherche des traitements en cours d'éxecution
$donnees['traitements_en_cours'] = $this->traitementDao->getTraitementsEnCours($this->referentiel, self::SCRIPT_A_LANCER);
// Recherche des traitements déjà effectué
$resultat = $this->traitementDao->getTraitementsTermines($this->referentiel, self::SCRIPT_A_LANCER);
if (is_array($resultat)) {
// Ajout de l'url vers la fiche du traitement
foreach ($resultat as &$traitement) {
$traitement['url'] = $this->obtenirUrlFicheTraitement($this->referentiel, $traitement['id_traitement']);
}
$donnees['traitements_termines'] = $resultat;
}
} else {
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
}
$this->setSortie(self::RENDU_CORPS, $this->getVue('form_version', $donnees), false);
$this->construireMenu($this->referentiel);
$this->construireFilAriane($this->referentiel);
}
/**
* Lance l'ajout d'un traitement
*/
public function demanderTraitement() {
$this->ajouterTraitement($this->referentiel, self::SCRIPT_A_LANCER);
$this->afficherInterface();
}
}
?>
/trunk/interfaces/controleurs/AppliControleur.php
259,4 → 259,69
$this->url->unsetVariablesRequete(array('module', 'id-r', 'ref'));
return $url;
}
/**
* Lance l'ajout d'un traitement
*/
protected function ajouterTraitement($referentiel_code, $script_nom) {
if (is_null($referentiel_code)) {
$this->addMessage("Aucun code de projet de référentiel n'est indiqué (Ex. bdnff).");
} else {
$traitementDao = new TraitementDao();
$resultat_traitement_en_attente = $traitementDao->getTraitementsEnAttente($referentiel_code, $script_nom);
if ($resultat_traitement_en_attente) {
$this->addMessage("Un traitement est déjà en attente...");
} else {
$resultat_traitement_en_cours = $traitementDao->getTraitementsEnCours($referentiel_code, $script_nom);
if ($resultat_traitement_en_cours) {
$this->addMessage("Un traitement est déjà en cours...");
} else {
$resultat = $traitementDao->ajouterTraitement($referentiel_code, $script_nom);
if ($resultat != false) {
$this->addMessage("Le traitement #'$resultat' a été ajouté.");
$this->lancerScript($referentiel_code, $script_nom);
} else {
$this->addMessage("Un problème est survenu lors de la tentative d'ajout du traitement.");
}
}
}
}
}
/**
* Lance le script d'execution des traitements
*/
protected function lancerScript($referentiel_code, $script_nom) {
$php = Config::get('chemin_bin_php');
$exe = Config::get('chemin_script');
$action = 'tout';
$log = Config::get('chemin_script_log');
$commande = "$php -d memory_limit=1073741824 -f $exe $script_nom -p $referentiel_code -a $action > $log &";
if ($this->verifierSafeModeOff() === false) {
$e = "Le safe_mode est actif sur ce serveur.";
} else if ($this->verifierAccesFonctionExec() === false) {
$e = "La fonction 'exec()' fait partie des fonctions désactivées sur ce serveur (voir disable_functions).";
} else {
$this->addMessage("Lancement du script effectuant les traitements.");
exec($commande);
}
 
// Affichage des message de paramêtrage du serveur si nécessaire
if (Config::get('script_messages') == true) {
$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>";
$this->addMessage(sprintf($message_erreur_tpl, $e));
}
}
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);
}
}