Subversion Repositories Applications.framework

Rev

Rev 477 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 477 Rev 479
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * CLI permet de récupérer les paramètres passés en ligne de commande pour instancier une classe héritant de la classe abstraite
4
 * CLI permet de récupérer les paramètres passés en ligne de commande pour instancier une classe héritant de la classe abstraite
5
 * Script.
5
 * Script.
6
 * Elle va déclencher l'éxecution du script via l'appel de la méthode executer().
6
 * Elle va déclencher l'éxecution du script via l'appel de la méthode executer().
7
 * C'est une Singleton.
7
 * C'est une Singleton.
8
 *
8
 *
9
 * @category	PHP 5.2
9
 * @category	PHP 5.2
10
 * @package	Framework
10
 * @package	Framework
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @author		Delphine CAUQUIL <delphine@tela-botanica.org>
12
 * @author		Delphine CAUQUIL <delphine@tela-botanica.org>
13
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
13
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
14
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
14
 * @license	http://www.gnu.org/licenses/gpl.html Licence GNU-GPL-v3
15
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
15
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
16
 * @since 		0.3
16
 * @since 		0.3
17
 * @version	$Id: Cli.php 477 2014-03-25 10:39:28Z jpm $
17
 * @version	$Id: Cli.php 479 2014-03-26 13:23:31Z jpm $
18
 * @link		/doc/framework/
18
 * @link		/doc/framework/
19
 */
19
 */
20
 
20
 
21
class Cli {
21
class Cli {
22
 
22
 
23
	/** Tableau des noms des paramètres à définir dans le fichier de config car obligatoirement nécessaire à cette classe.*/
23
	/** Tableau des noms des paramètres à définir dans le fichier de config car obligatoirement nécessaire à cette classe.*/
24
	private static $parametres_obligatoires = array('chemin_modules');
24
	private static $parametres_obligatoires = array('chemin_modules');
25
 
25
 
26
 
26
 
27
	/**
27
	/**
28
	 * Execute la ligne de commande en récupérant le nom du script à lancer et ses paramètres.
28
	 * Execute la ligne de commande en récupérant le nom du script à lancer et ses paramètres.
29
	 * Instancie la classe du script à lancer et appelle la méthode executer().
29
	 * Instancie la classe du script à lancer et appelle la méthode executer().
30
	 * @return void
30
	 * @return void
31
	 */
31
	 */
32
	public static function executer() {
32
	public static function executer() {
33
		if ($_SERVER['argc'] < 2){
33
		if ($_SERVER['argc'] < 2){
34
		   trigger_error("Erreur: vous n'avez pas indiqué le nom du script. Voir '".$_SERVER['argv'][0]." help'.\n", E_USER_ERROR);
34
		   trigger_error("Erreur: vous n'avez pas indiqué le nom du script. Voir '".$_SERVER['argv'][0]." help'.\n", E_USER_ERROR);
35
		}
35
		}
36
 
36
 
37
		// Récupération de la ligne de commande
37
		// Récupération de la ligne de commande
38
		$argv = $_SERVER['argv'];
38
		$argv = $_SERVER['argv'];
39
		// Nous dépilons le nom du fichier qui initialise le framework et appele cette méthode.
39
		// Nous dépilons le nom du fichier qui initialise le framework et appele cette méthode.
40
		array_shift($argv);
40
		array_shift($argv);
41
		// Nous dépilons le nom du script à lancer
41
		// Nous dépilons le nom du script à lancer
42
		$script = array_shift($argv);
42
		$script = array_shift($argv);
43
		// Récupération des paramètres d'execution du script
43
		// Récupération des paramètres d'execution du script
44
		$parametres = self::getParametres($argv);
44
		$parametres = self::getParametres($argv);
45
 
45
 
46
		// Chargement du script à lancer
46
		// Chargement du script à lancer
47
		$Script = Cli::charger($script, $parametres);
47
		$Script = Cli::charger($script, $parametres);
48
		if (!is_null($Script)) {
48
		if (!is_null($Script)) {
49
			$Script->executer();
49
			$Script->executer();
50
		}
50
		}
51
 
51
 
52
		// 	Affichage des exceptions et erreurs générées par le script
52
		// 	Affichage des exceptions et erreurs générées par le script
53
		echo GestionnaireException::getExceptions();
53
		echo GestionnaireException::getExceptions();
54
 
54
 
55
		// Fin d'execution
55
		// Fin d'execution
56
		exit(0);
56
		exit(0);
57
	}
57
	}
58
 
58
 
59
	private static function charger($script_nom_original, $parametres) {
59
	private static function charger($script_nom_original, $parametres) {
60
		$Script = null;
60
		$Script = null;
61
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
61
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
62
 
-
 
63
 
62
 
64
		if (strpos($script_nom_original, DS)) {
63
		if (strpos($script_nom_original, DS)) {
65
			$decompoScriptNom = explode(DS, $script_nom_original);
64
			$decompoScriptNom = explode(DS, $script_nom_original);
66
			$script_nom = array_pop($decompoScriptNom);
65
			$script_nom = array_pop($decompoScriptNom);
67
			$dossier_nom = implode(DS, $decompoScriptNom);
66
			$dossier_nom = implode(DS, $decompoScriptNom);
68
		} else {
67
		} else {
69
			$dossier_nom = strtolower($script_nom_original);
68
			$dossier_nom = strtolower($script_nom_original);
-
 
69
			$script_nom = $script_nom_original;
70
		}
70
		}
71
 
71
 
72
		$classe_nom = self::obtenirNomClasse($script_nom);
72
		$classe_nom = self::obtenirNomClasse($script_nom);
73
		$fichier_script = Config::get('chemin_modules').$dossier_nom.DS.$classe_nom.'.php';
73
		$fichier_script = Config::get('chemin_modules').$dossier_nom.DS.$classe_nom.'.php';
74
 
74
 
75
		if (!file_exists($fichier_script)){
75
		if (!file_exists($fichier_script)){
76
			trigger_error("Erreur : script '$fichier_script' inconnu!\n", E_USER_ERROR);
76
			trigger_error("Erreur : script '$fichier_script' inconnu!\n", E_USER_ERROR);
77
		} else {
77
		} else {
78
			require_once $fichier_script;
78
			require_once $fichier_script;
79
			if (!class_exists( $classe_nom)) {
79
			if (!class_exists( $classe_nom)) {
80
				trigger_error("Erreur: impossible de trouver la classe de la commande : $classe_nom\n", E_USER_ERROR);
80
				trigger_error("Erreur: impossible de trouver la classe de la commande : $classe_nom\n", E_USER_ERROR);
81
			} else {
81
			} else {
82
				$Script = new $classe_nom($script_nom_original, $parametres);
82
				$Script = new $classe_nom($script_nom_original, $parametres);
83
			}
83
			}
84
		}
84
		}
85
		return $Script;
85
		return $Script;
86
	}
86
	}
87
 
87
 
88
	private static function obtenirNomClasse($script_nom) {
88
	private static function obtenirNomClasse($script_nom) {
89
		$nom_classe = implode('', array_map('ucfirst', explode('_', strtolower($script_nom))));
89
		$nom_classe = implode('', array_map('ucfirst', explode('_', strtolower($script_nom))));
90
		return $nom_classe;
90
		return $nom_classe;
91
	}
91
	}
92
 
92
 
93
	private static function getParametres($argv) {
93
	private static function getParametres($argv) {
94
		$parametres = array();
94
		$parametres = array();
95
		// Récupération des options
95
		// Récupération des options
96
		while (count($argv)) {
96
		while (count($argv)) {
97
			if (isset($argv[1]) && $argv[1]{0} != '-') {
97
			if (isset($argv[1]) && $argv[1]{0} != '-') {
98
				$param = array_shift($argv);
98
				$param = array_shift($argv);
99
				$parametres[$param] = array_shift($argv);
99
				$parametres[$param] = array_shift($argv);
100
			} elseif (!isset($argv[1]) || $argv[1]{0} == '-') {
100
			} elseif (!isset($argv[1]) || $argv[1]{0} == '-') {
101
				$parametres[array_shift($argv)] = null;
101
				$parametres[array_shift($argv)] = null;
102
			} else {
102
			} else {
103
				trigger_error("Erreur: valeur manquante pour le paramêtre '".$argv[0]."' \n", E_USER_ERROR);
103
				trigger_error("Erreur: valeur manquante pour le paramêtre '".$argv[0]."' \n", E_USER_ERROR);
104
			}
104
			}
105
		}
105
		}
106
		return $parametres;
106
		return $parametres;
107
	}
107
	}
108
}
108
}
109
?>
109
?>