Subversion Repositories Applications.framework

Rev

Rev 230 | Rev 244 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
214 jpm 1
<?php
2
// declare(encoding='UTF-8');
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
5
 * Script.
6
 * Elle va déclencher l'éxecution du script via l'appel de la méthode executer().
7
 * C'est une Singleton.
8
 *
9
 * @category	PHP 5.2
10
 * @package	Framework
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @author		Delphine CAUQUIL <delphine@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
241 jpm 15
 * @license	http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL-v2
16
 * @since 		0.3
17
 * @version	$Id$
214 jpm 18
 * @link		/doc/framework/
19
 */
20
 
21
class Cli {
22
 
241 jpm 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');
25
 
26
 
214 jpm 27
	/**
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().
30
	 * @return void
31
	 */
32
	public static function executer() {
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);
35
		}
36
 
37
		// Récupération de la ligne de commande
38
		$argv = $_SERVER['argv'];
39
		// Nous dépilons le nom du fichier qui initialise le framework et appele cette méthode.
40
		array_shift($argv);
41
		// Nous dépilons le nom du script à lancer
42
		$script = array_shift($argv);
43
		// Récupération des paramètres d'execution du script
44
		$parametres = self::getParametres($argv);
45
 
46
		// Chargement du script à lancer
47
		$Script = Cli::charger($script, $parametres);
48
		if (!is_null($Script)) {
49
			$Script->executer();
50
		}
51
 
52
		// 	Affichage des exceptions et erreurs générées par le script
53
		echo GestionnaireException::getExceptions();
54
 
55
		// Fin d'execution
56
		exit(0);
57
	}
58
 
59
	private static function charger($script_nom, $parametres) {
60
		$Script = null;
241 jpm 61
		Config::verifierPresenceParametres(self::$parametres_obligatoires);
214 jpm 62
 
63
		$classe_nom = implode('', array_map('ucfirst', explode('_', strtolower($script_nom))));
64
		$fichier_script = Config::get('chemin_modules').$script_nom.DS.$classe_nom.'.php';
65
 
66
		if (!file_exists($fichier_script)){
67
			trigger_error("Erreur : script '$fichier_script' inconnu!\n", E_USER_ERROR);
68
		} else {
69
			require_once $fichier_script;
70
			if (!class_exists( $classe_nom)) {
71
				trigger_error("Erreur: impossible de trouver la classe de la commande : $classe_nom\n", E_USER_ERROR);
72
			} else {
73
				$Script = new $classe_nom($script_nom, $parametres);
74
			}
75
		}
76
		return $Script;
77
	}
78
 
79
	private static function getParametres($argv) {
80
		$parametres = array();
81
		// Récupération des options
82
		while (count($argv)) {
83
			if (isset($argv[1]) && $argv[1]{0} != '-') {
84
				$param = array_shift($argv);
85
				$parametres[$param] = array_shift($argv);
86
			} elseif (!isset($argv[1]) || $argv[1]{0} == '-') {
87
				$parametres[array_shift($argv)] = null;
88
			} else {
89
				trigger_error("Erreur: valeur manquante pour le paramêtre '".$argv[0]."' \n", E_USER_ERROR);
90
			}
91
		}
92
		return $parametres;
93
	}
94
}
95
?>