Subversion Repositories eFlore/Applications.cel

Rev

Rev 3857 | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
416 aurelien 1
<?php
2
// declare(encoding='UTF-8');
3
/**
2462 jpm 4
 * Client REST chargé depuis la classe CEL.
5
 *
6
 * @internal   Mininum PHP version : 5.2
7
 * @category   CEL
8
 * @package    Services
9
 * @subpackage Bibliothèques
10
 * @version    0.1
11
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
12
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
13
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
14
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
15
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
16
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
17
 */
946 jpm 18
// TODO : remplacer les trigger_error par des exceptions qui pourrait être attrapées...
908 jpm 19
class CelRestClient {
20
	const HTTP_URL_REQUETE_SEPARATEUR = '&';
21
	const HTTP_URL_REQUETE_CLE_VALEUR_SEPARATEUR = '=';
22
	private $http_methodes = array('GET', 'POST', 'PUT', 'DELETE', 'HEAD', 'OPTIONS', 'CONNECT', 'TRACE');
23
	protected $parametres = null;
24
	private $url = null;
25
	private $reponse_entetes = null;
2462 jpm 26
 
416 aurelien 27
	//+----------------------------------------------------------------------------------------------------------------+
28
	// ACCESSEURS
2462 jpm 29
 
908 jpm 30
	public function getReponseEntetes($cle) {
31
		return $this->reponse_entetes;
416 aurelien 32
	}
2462 jpm 33
 
908 jpm 34
	public function getParametre($cle) {
35
		$valeur = (isset($this->parametres[$cle])) ? $this->parametres[$cle] : null;
36
		return $valeur;
416 aurelien 37
	}
2462 jpm 38
 
908 jpm 39
	public function ajouterParametre($cle, $valeur) {
40
		$this->parametres[$cle] = $valeur;
416 aurelien 41
	}
2462 jpm 42
 
908 jpm 43
	public function supprimerParametre($cle) {
44
		unset($this->parametres[$cle]);
416 aurelien 45
	}
2462 jpm 46
 
908 jpm 47
	public function nettoyerParametres() {
48
		$this->parametres = null;
416 aurelien 49
	}
2462 jpm 50
 
416 aurelien 51
	//+----------------------------------------------------------------------------------------------------------------+
52
	// MÉTHODES
2462 jpm 53
 
908 jpm 54
	public function consulter($url) {
416 aurelien 55
		$retour = $this->envoyerRequete($url, 'GET');
56
		return $retour;
57
	}
2462 jpm 58
 
908 jpm 59
	public function ajouter($url, Array $donnees) {
416 aurelien 60
		$retour = $this->envoyerRequete($url, 'PUT', $donnees);
61
		return $retour;
62
	}
2462 jpm 63
 
908 jpm 64
	public function modifier($url, Array $donnees) {
416 aurelien 65
		$retour = $this->envoyerRequete($url, 'POST', $donnees);
66
		return $retour;
67
	}
2462 jpm 68
 
908 jpm 69
	public function supprimer($url) {
416 aurelien 70
		$retour = $this->envoyerRequete($url, 'DELETE');
71
		return $retour;
72
	}
2462 jpm 73
 
908 jpm 74
	public function envoyerRequete($url, $mode, Array $donnees = array()) {
75
		$this->url = $url;
416 aurelien 76
		$contenu = false;
908 jpm 77
		if (! in_array($mode, $this->http_methodes)) {
416 aurelien 78
			$e = "Le mode de requête '$mode' n'est pas accepté!";
79
			trigger_error($e, E_USER_WARNING);
80
		} else {
908 jpm 81
			if ($mode == 'GET') {
82
				$this->traiterUrlParametres();
83
			}
416 aurelien 84
			$contexte = stream_context_create(array(
85
				'http' => array(
86
      				'method' => $mode,
87
					'header' => "Content-type: application/x-www-form-urlencoded\r\n",
908 jpm 88
      				'content' => http_build_query($donnees, null, self::HTTP_URL_REQUETE_SEPARATEUR))));
89
			$flux = @fopen($this->url, 'r', false, $contexte);
416 aurelien 90
			if (!$flux) {
908 jpm 91
				$this->reponse_entetes = $http_response_header;
92
				$e = "L'ouverture de l'url '{$this->url}' par la méthode HTTP '$mode' a échoué!";
416 aurelien 93
				trigger_error($e, E_USER_WARNING);
94
			} else {
95
				// Informations sur les en-têtes et métadonnées du flux
908 jpm 96
				$this->reponse_entetes = stream_get_meta_data($flux);
2462 jpm 97
 
416 aurelien 98
				// Contenu actuel de $url
99
				$contenu = stream_get_contents($flux);
2462 jpm 100
 
416 aurelien 101
				fclose($flux);
102
			}
908 jpm 103
			$this->traiterEntete();
416 aurelien 104
		}
105
		$this->reinitialiser();
106
		return $contenu;
107
	}
2462 jpm 108
 
908 jpm 109
	private function traiterUrlParametres() {
416 aurelien 110
		$parametres = array();
908 jpm 111
		if (count($this->parametres) > 0) {
112
			foreach ($this->parametres as $cle => $valeur) {
113
				$cle = rawurlencode($cle);
114
				$valeur = rawurlencode($valeur);
115
				$parametres[] = $cle.self::HTTP_URL_REQUETE_CLE_VALEUR_SEPARATEUR.$valeur;
116
			}
117
			$url_parametres = implode(self::HTTP_URL_REQUETE_SEPARATEUR, $parametres);
118
			$this->url = $this->url.'?'.$url_parametres;
416 aurelien 119
		}
120
	}
2462 jpm 121
 
908 jpm 122
	private function traiterEntete() {
123
		$infos = $this->analyserEntete();
124
		$this->traiterEnteteDebogage($infos);
416 aurelien 125
	}
2462 jpm 126
 
908 jpm 127
	private function analyserEntete() {
2462 jpm 128
		$entetes = $this->reponse_entetes;
908 jpm 129
		$infos = array('date' => null, 'uri' => $this->url, 'debogages' => null);
946 jpm 130
		if (isset($entetes)) {
131
			if (isset($entetes['wrapper_data'])) {
132
				$entetes = $entetes['wrapper_data'];
416 aurelien 133
			}
946 jpm 134
			foreach ($entetes as $entete) {
135
				if (preg_match('/^X_REST_DEBOGAGE_MESSAGES: (.+)$/', $entete, $match)) {
136
					$infos['debogages'] = json_decode($match[1]);
137
				}
138
				if (preg_match('/^Date: .+ ([012][0-9]:[012345][0-9]:[012345][0-9]) .*$/', $entete, $match)) {
139
					$infos['date'] = $match[1];
140
				}
416 aurelien 141
			}
142
		}
143
		return $infos;
144
	}
2462 jpm 145
 
908 jpm 146
	private function traiterEnteteDebogage($entetes_analyses) {
147
		if (isset($entetes['debogages'])) {
416 aurelien 148
			$date = $entetes['date'];
149
			$uri = $entetes['uri'];
908 jpm 150
			$debogages = $entetes['debogages'];
151
			foreach ($debogages as $debogage) {
152
				$e = "DEBOGAGE : $date - $uri :\n$debogage";
416 aurelien 153
				trigger_error($e, E_USER_NOTICE);
154
			}
155
		}
156
	}
2462 jpm 157
 
416 aurelien 158
	private function reinitialiser() {
908 jpm 159
		$this->nettoyerParametres();
416 aurelien 160
	}
161
}