Subversion Repositories Applications.framework

Rev

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