Subversion Repositories Applications.framework

Rev

Rev 244 | Rev 299 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 244 Rev 266
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$
17
 * @version	$Id$
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, $parametres) {
59
	private static function charger($script_nom, $parametres) {
60
		$Script = null;
60
		$Script = null;
61
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
61
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
62
		
62
		
63
		$classe_nom = self::obtenirNomClasse($script_nom);
63
		$classe_nom = self::obtenirNomClasse($script_nom);
-
 
64
		$dossier_nom = strtolower($script_nom);
64
		$fichier_script = Config::get('chemin_modules').$script_nom.DS.$classe_nom.'.php';
65
		$fichier_script = Config::get('chemin_modules').$dossier_nom.DS.$classe_nom.'.php';
65
		
66
		
66
		if (!file_exists($fichier_script)){
67
		if (!file_exists($fichier_script)){
67
			trigger_error("Erreur : script '$fichier_script' inconnu!\n", E_USER_ERROR);
68
			trigger_error("Erreur : script '$fichier_script' inconnu!\n", E_USER_ERROR);
68
		} else {
69
		} else {
69
			require_once $fichier_script;
70
			require_once $fichier_script;
70
			if (!class_exists( $classe_nom)) {
71
			if (!class_exists( $classe_nom)) {
71
				trigger_error("Erreur: impossible de trouver la classe de la commande : $classe_nom\n", E_USER_ERROR);
72
				trigger_error("Erreur: impossible de trouver la classe de la commande : $classe_nom\n", E_USER_ERROR);
72
			} else {
73
			} else {
73
				$Script = new $classe_nom($script_nom, $parametres);
74
				$Script = new $classe_nom($script_nom, $parametres);
74
			}
75
			}
75
		}
76
		}
76
		return $Script;
77
		return $Script;
77
	}
78
	}
78
	
79
	
79
	private static function obtenirNomClasse($script_nom) {
80
	private static function obtenirNomClasse($script_nom) {
80
		$nom_classe = implode('', array_map('ucfirst', explode('_', strtolower($script_nom))));
81
		$nom_classe = implode('', array_map('ucfirst', explode('_', strtolower($script_nom))));
81
		return $nom_classe;
82
		return $nom_classe;
82
	}
83
	}
83
	
84
	
84
	private static function getParametres($argv) {
85
	private static function getParametres($argv) {
85
		$parametres = array();
86
		$parametres = array();
86
		// Récupération des options
87
		// Récupération des options
87
		while (count($argv)) {
88
		while (count($argv)) {
88
			if (isset($argv[1]) && $argv[1]{0} != '-') {
89
			if (isset($argv[1]) && $argv[1]{0} != '-') {
89
				$param = array_shift($argv);
90
				$param = array_shift($argv);
90
				$parametres[$param] = array_shift($argv);
91
				$parametres[$param] = array_shift($argv);
91
			} elseif (!isset($argv[1]) || $argv[1]{0} == '-') {
92
			} elseif (!isset($argv[1]) || $argv[1]{0} == '-') {
92
				$parametres[array_shift($argv)] = null;
93
				$parametres[array_shift($argv)] = null;
93
			} else {
94
			} else {
94
				trigger_error("Erreur: valeur manquante pour le paramêtre '".$argv[0]."' \n", E_USER_ERROR);
95
				trigger_error("Erreur: valeur manquante pour le paramêtre '".$argv[0]."' \n", E_USER_ERROR);
95
			}
96
			}
96
		}
97
		}
97
		return $parametres;
98
		return $parametres;
98
	}
99
	}
99
}
100
}
100
?>
101
?>