Subversion Repositories Applications.annuaire

Rev

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

Rev 534 Rev 536
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Service retournant les prénoms et nom  d'un utilisateur en fonction de son courriel.
4
 * Service retournant les prénoms et nom  d'un utilisateur en fonction de son courriel.
5
 * UNe liste de courriel peut être passé dans la ressource.
5
 * UNe liste de courriel peut être passé dans la ressource.
6
 * Exemple :
6
 * Exemple :
7
 * /utilisateur/Prenom-nom-par-courriel/jpm@tela-botanica.org,aurelien@tela-botanica.org
7
 * /utilisateur/Prenom-nom-par-courriel/jpm@tela-botanica.org,aurelien@tela-botanica.org
8
 *
8
 *
9
 * @category	php 5.2
9
 * @category	php 5.2
10
 * @package		Annuaire::Services
10
 * @package		Annuaire::Services
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
11
 * @author		Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
12
 * @copyright	Copyright (c) 2010, Tela Botanica (accueil@tela-botanica.org)
13
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
13
 * @license		http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
14
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
14
 * @license		http://www.gnu.org/licenses/gpl.html Licence GNU-GPL
15
 * @version		$Id$
15
 * @version		$Id$
16
 */
16
 */
17
class Utilisateur extends JRestService {
17
class Utilisateur extends JRestService {
18
 
18
 
19
	private $donnees = null;
19
	private $donnees = null;
20
	private $idAnnuaire = null;
20
	private $idAnnuaire = null;
21
	private $utilisateurId = null;
21
	private $utilisateurId = null;
22
	private $metadonneeModele = null;
22
	private $metadonneeModele = null;
23
	private $annuaireModele = null;
23
	private $annuaireModele = null;
24
	private $messagerieModele = null;
24
	private $messagerieModele = null;
25
 
25
 
26
	const FORMAT_JSON = "json";
26
	const FORMAT_JSON = "json";
27
	const FORMAT_XML = "xml";
27
	const FORMAT_XML = "xml";
28
	const FORMAT_LDEHYDE = "méthanal"; // hihi hoho
28
	const FORMAT_LDEHYDE = "méthanal"; // hihi hoho
-
 
29
 
-
 
30
	public function __construct($config, $demarrer_session = true) {
-
 
31
		parent::__construct($config, $demarrer_session);
-
 
32
		$this->idAnnuaire = Config::get('annuaire_defaut');
-
 
33
	}
29
 
34
 
30
	/*+----------------------------------------------------------------------------------------------------+*/
35
	/*+----------------------------------------------------------------------------------------------------+*/
31
	// GET : consultation
36
	// GET : consultation
32
 
37
 
33
	public function getElement($ressources){
38
	public function getElement($ressources){
34
		$this->ressources = $ressources;
39
		$this->ressources = $ressources;
35
		$this->idAnnuaire = Config::get('annuaire_defaut');
-
 
36
		$infos = null;
40
		$infos = null;
37
 
41
 
38
		if (isset($this->ressources[0])) {
42
		if (isset($this->ressources[0])) {
39
			if (preg_match('/^[0-9]+$/', $this->ressources[0])) {
43
			if (preg_match('/^[0-9]+$/', $this->ressources[0])) {
40
				// ATTENTION : Ces web services ne doivent être accessible que depuis des applis installées sur nos serveurs
44
				// ATTENTION : Ces web services ne doivent être accessible que depuis des applis installées sur nos serveurs
41
				// pour les communications inter-serveurs.
45
				// pour les communications inter-serveurs.
42
				$this->controlerIpAutorisees();
46
				$this->controlerIpAutorisees();
43
				$infos = $this->getInfosParId($this->ressources[0]);
47
				$infos = $this->getInfosParId($this->ressources[0]);
44
			} else {
48
			} else {
45
				$methode_demande = array_shift($this->ressources);
49
				$methode_demande = array_shift($this->ressources);
46
				$methode = $this->traiterNomMethodeGet($methode_demande);
50
				$methode = $this->traiterNomMethodeGet($methode_demande);
47
				if (method_exists($this, $methode)) {
51
				if (method_exists($this, $methode)) {
48
					$infos = $this->$methode($this->ressources[0]);
52
					$infos = $this->$methode($this->ressources[0]);
49
				} else {
53
				} else {
50
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete GET.";
54
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete GET.";
51
				}
55
				}
52
			}
56
			}
53
		} else {
57
		} else {
54
			$this->messages[] = "Le premier paramètre du chemin du service doit correspondre au type de ressource demandée.";
58
			$this->messages[] = "Le premier paramètre du chemin du service doit correspondre au type de ressource demandée.";
55
		}
59
		}
56
 
60
 
57
		// possibilité d'envoyer en plusieurs formats @TODO faire ça plus proprement
61
		// possibilité d'envoyer en plusieurs formats @TODO faire ça plus proprement
58
		$format = self::FORMAT_JSON;
62
		$format = self::FORMAT_JSON;
59
		$dernierIndex = count($this->ressources) - 1;
63
		$dernierIndex = count($this->ressources) - 1;
60
		if ($dernierIndex >= 0) {
64
		if ($dernierIndex >= 0) {
61
			$dernierParametre = $this->ressources[$dernierIndex];
65
			$dernierParametre = $this->ressources[$dernierIndex];
62
			if (in_array($dernierParametre, array(self::FORMAT_JSON, self::FORMAT_XML))) {
66
			if (in_array($dernierParametre, array(self::FORMAT_JSON, self::FORMAT_XML))) {
63
				$format = $dernierParametre;
67
				$format = $dernierParametre;
64
			}
68
			}
65
		}
69
		}
66
 
70
 
67
		if (!is_null($infos)) {
71
		if (!is_null($infos)) {
68
			switch ($format) {
72
			switch ($format) {
69
				case self::FORMAT_XML :
73
				case self::FORMAT_XML :
70
					$this->envoyerXml($infos);
74
					$this->envoyerXml($infos);
71
				break;
75
				break;
72
				case self::FORMAT_JSON :
76
				case self::FORMAT_JSON :
73
				default :
77
				default :
74
					$this->envoyerJson($infos);
78
					$this->envoyerJson($infos);
75
			}
79
			}
76
		} else {
80
		} else {
77
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
81
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
78
			$this->envoyerTxt($info);
82
			$this->envoyerTxt($info);
79
		}
83
		}
80
	}
84
	}
81
	
85
	
82
	public function getIdentiteConnectee() {
86
	public function getIdentiteConnectee() {
83
		if (isset($_COOKIE[$this->config['database_ident']['nom_cookie_persistant']])) {
87
		if (isset($_COOKIE[$this->config['database_ident']['nom_cookie_persistant']])) {
84
		
88
		
85
			$cookie = $_COOKIE[$this->config['database_ident']['nom_cookie_persistant']];
89
			$cookie = $_COOKIE[$this->config['database_ident']['nom_cookie_persistant']];
86
			// le cookie de papyrus contient un md5 concaténé à l'email utilisateur
90
			// le cookie de papyrus contient un md5 concaténé à l'email utilisateur
87
			$courriel = substr($cookie , 32, strlen($cookie));
91
			$courriel = substr($cookie , 32, strlen($cookie));
88
 
92
 
89
			$id_utilisateur = $this->getAnnuaire()->obtenirIdParMail($this->idAnnuaire, $courriel);
93
			$id_utilisateur = $this->getAnnuaire()->obtenirIdParMail($this->idAnnuaire, $courriel);
90
			$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $id_utilisateur);
94
			$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $id_utilisateur);
91
			
95
			
92
			$infos = array_pop($infos);
96
			$infos = array_pop($infos);
93
			
97
			
94
			$infos['pseudoUtilise'] = $this->obtenirPseudoUtilise($id_utilisateur);
98
			$infos['pseudoUtilise'] = $this->obtenirPseudoUtilise($id_utilisateur);
95
			$infos['pseudo'] = $this->obtenirPseudo($id_utilisateur);
99
			$infos['pseudo'] = $this->obtenirPseudo($id_utilisateur);
96
			$infos['intitule'] = $this->formaterIntitule($infos);
100
			$infos['intitule'] = $this->formaterIntitule($infos);
97
			
101
			
98
			$infos['nomWiki'] = $this->formaterNomWiki($infos);
102
			$infos['nomWiki'] = $this->formaterNomWiki($infos);
99
			
103
			
100
			header("content-type: application/json");
104
			header("content-type: application/json");
101
			echo json_encode($infos);
105
			echo json_encode($infos);
102
		} else  {
106
		} else  {
103
			echo json_encode(array());
107
			echo json_encode(array());
104
		}
108
		}
105
		
109
		
106
		exit;
110
		exit;
107
	}
111
	}
108
	
112
	
109
	private function formaterNomWiki($infos) {
113
	private function formaterNomWiki($infos) {
110
		
114
		
111
		$prenom = ucfirst(strtolower($this->supprimerAccents($infos['prenom'])));
115
		$prenom = ucfirst(strtolower($this->supprimerAccents($infos['prenom'])));
112
		$nom = ucfirst(strtolower($this->supprimerAccents($infos['nom'])));
116
		$nom = ucfirst(strtolower($this->supprimerAccents($infos['nom'])));
113
		return $prenom.$nom;
117
		return $prenom.$nom;
114
	}
118
	}
115
	
119
	
116
	function supprimerAccents($str, $charset='utf-8') {
120
	function supprimerAccents($str, $charset='utf-8') {
117
		$str = htmlentities($str, ENT_NOQUOTES, $charset);
121
		$str = htmlentities($str, ENT_NOQUOTES, $charset);
118
	
122
	
119
		$str = preg_replace('#&([A-za-z])(?:acute|cedil|caron|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
123
		$str = preg_replace('#&([A-za-z])(?:acute|cedil|caron|circ|grave|orn|ring|slash|th|tilde|uml);#', '\1', $str);
120
		$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
124
		$str = preg_replace('#&([A-za-z]{2})(?:lig);#', '\1', $str); // pour les ligatures e.g. '&oelig;'
121
		$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
125
		$str = preg_replace('#&[^;]+;#', '', $str); // supprime les autres caractères
122
	
126
	
123
		return $str;
127
		return $str;
124
	}
128
	}
125
 
129
 
126
	/**
130
	/**
127
	 * Permet d'obtenir des infos pour un ou plusieurs ids utilisateurs indiqué(s) dans la ressource.
131
	 * Permet d'obtenir des infos pour un ou plusieurs ids utilisateurs indiqué(s) dans la ressource.
128
	 * RESSOURCE : /infos-par-ids/#id[,#id]*
132
	 * RESSOURCE : /infos-par-ids/#id[,#id]*
129
	 * PARAMÈTRES : forceArrayOfArrays - si true, retourne un tableau associatif même s'il n'y a qu'un
133
	 * PARAMÈTRES : forceArrayOfArrays - si true, retourne un tableau associatif même s'il n'y a qu'un
130
	 * 		résultat (casse la rétrocompatibilté)
134
	 * 		résultat (casse la rétrocompatibilté)
131
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
135
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
132
	 *  - id : identifiant numérique de l'utilisateur
136
	 *  - id : identifiant numérique de l'utilisateur
133
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
137
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
134
	 *  - pseudo : pseudo de l'utilisateur.
138
	 *  - pseudo : pseudo de l'utilisateur.
135
	 *  - intitule : l'intitulé à affiche (choix auto entre "pseudo" et "prénom nom")
139
	 *  - intitule : l'intitulé à affiche (choix auto entre "pseudo" et "prénom nom")
136
	 *  - prenom : prénom
140
	 *  - prenom : prénom
137
	 *  - nom : nom de famille.
141
	 *  - nom : nom de famille.
138
	 *  - courriel : courriel
142
	 *  - courriel : courriel
139
	 */
143
	 */
140
	public function getInfosParIds($ids_utilisateurs, $forceArrayOfArrays = false) {
144
	public function getInfosParIds($ids_utilisateurs, $forceArrayOfArrays = false) {
141
		$ids_utilisateurs = explode(',', $ids_utilisateurs);
145
		$ids_utilisateurs = explode(',', $ids_utilisateurs);
142
		if (count($ids_utilisateurs) == 1) {
146
		if (count($ids_utilisateurs) == 1) {
143
			// s'il n'y en a qu'un on ne passe pas un array
147
			// s'il n'y en a qu'un on ne passe pas un array
144
			$ids_utilisateurs = array_shift($ids_utilisateurs);
148
			$ids_utilisateurs = array_shift($ids_utilisateurs);
145
		}
149
		}
146
		$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $ids_utilisateurs);
150
		$infos = $this->getAnnuaire()->obtenirInfosUtilisateurParId($this->idAnnuaire, $ids_utilisateurs);
147
 
151
 
148
		foreach ($infos as $i => $info) {
152
		foreach ($infos as $i => $info) {
149
			$infos[$i]['pseudoUtilise'] = $this->obtenirPseudoUtilise($info['id']);
153
			$infos[$i]['pseudoUtilise'] = $this->obtenirPseudoUtilise($info['id']);
150
			$infos[$i]['pseudo'] = $this->obtenirPseudo($info['id']);
154
			$infos[$i]['pseudo'] = $this->obtenirPseudo($info['id']);
151
			$infos[$i]['intitule'] = $this->formaterIntitule($infos[$i]);
155
			$infos[$i]['intitule'] = $this->formaterIntitule($infos[$i]);
152
		}
156
		}
153
 
157
 
154
		// retrocompatibilité
158
		// retrocompatibilité
155
		if (count($infos) == 1 && (! $forceArrayOfArrays)) {
159
		if (count($infos) == 1 && (! $forceArrayOfArrays)) {
156
			$infos = array_shift($infos);
160
			$infos = array_shift($infos);
157
		}
161
		}
158
 
162
 
159
		return $infos;
163
		return $infos;
160
	}
164
	}
161
 
165
 
162
	/**
166
	/**
163
	 * Méthode rétrocompatible : appelle getInfosParIds et s'il n'y a qu'un résultat,
167
	 * Méthode rétrocompatible : appelle getInfosParIds et s'il n'y a qu'un résultat,
164
	 * ne retourne pas un tableau associatif mais un tableau simple
168
	 * ne retourne pas un tableau associatif mais un tableau simple
165
	 * @return array
169
	 * @return array
166
	 */
170
	 */
167
	public function getInfosParId($ids_utilisateurs) {
171
	public function getInfosParId($ids_utilisateurs) {
168
		return $this->getInfosParIds($ids_utilisateurs, true);
172
		return $this->getInfosParIds($ids_utilisateurs, true);
169
	}
173
	}
170
 
174
 
171
	/**
175
	/**
172
	 * Permet d'obtenir les prénoms et noms des courriels des utilisateurs indiqués dans la ressource.
176
	 * Permet d'obtenir les prénoms et noms des courriels des utilisateurs indiqués dans la ressource.
173
	 * RESSOURCE : /utilisateur/prenom-nom-par-courriel/[courriel,courriel,...]
177
	 * RESSOURCE : /utilisateur/prenom-nom-par-courriel/[courriel,courriel,...]
174
	 * PARAMÈTRES : aucun
178
	 * PARAMÈTRES : $courriels des adresses courriel séparées par des virgules; si != null, sera utilisé à la place de la ressource d'URL
175
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
179
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
176
	 *  - id : identifiant numérique de l'utilisateur
180
	 *  - id : identifiant numérique de l'utilisateur
177
	 *  - prenom : prénom
181
	 *  - prenom : prénom
178
	 *  - nom : nom de famille.
182
	 *  - nom : nom de famille.
179
	 */
183
	 */
180
	public function getPrenomNomParCourriel() {
184
	public function getPrenomNomParCourriel($courriels) {
181
		$courriels = explode(',', $this->ressources[0]);
185
		$courriels = explode(',', $courriels);
182
		$infos = $this->getAnnuaire()->obtenirPrenomNomParCourriel($this->idAnnuaire, $courriels);
186
		$infos = $this->getAnnuaire()->obtenirPrenomNomParCourriel($this->idAnnuaire, $courriels);
183
		return $infos;
187
		return $infos;
184
	}
188
	}
185
 
189
 
186
	/**
190
	/**
187
	 * Permet d'obtenir les identités des utilisateurs indiqués dans la ressource.
191
	 * Permet d'obtenir les identités des utilisateurs indiqués dans la ressource.
188
	 * RESSOURCE : /utilisateur/identite-par-courriel/[courriel,courriel,...]
192
	 * RESSOURCE : /utilisateur/identite-par-courriel/[courriel,courriel,...]
189
	 * PARAMÈTRES : aucun
193
	 * PARAMÈTRES : $courriels des adresses courriel séparées par des virgules; si != null, sera utilisé à la place de la ressource d'URL
190
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
194
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
191
	 *  - id : identifiant numérique de l'utilisateur
195
	 *  - id : identifiant numérique de l'utilisateur
192
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
196
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
193
	 *  - pseudo : pseudo de l'utilisateur.
197
	 *  - pseudo : pseudo de l'utilisateur.
194
	 *  - prenom : prénom
198
	 *  - prenom : prénom
195
	 *  - nom : nom de famille.
199
	 *  - nom : nom de famille.
196
	 */
200
	 */
197
	public function getIdentiteParCourriel() {
201
	public function getIdentiteParCourriel($courriels) {
198
		$infos_utilisateurs = array();
202
		$infos_utilisateurs = array();
199
		$utilisateurs = $this->getPrenomNomParCourriel();
203
		$utilisateurs = $this->getPrenomNomParCourriel($courriels);
200
		foreach ($utilisateurs as $courriel => $utilisateur) {
204
		foreach ($utilisateurs as $courriel => $utilisateur) {
201
			$id = $utilisateur['id'];
205
			$id = $utilisateur['id'];
202
			$utilisateur['pseudo'] = $this->obtenirPseudo($id);
206
			$utilisateur['pseudo'] = $this->obtenirPseudo($id);
203
			$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
207
			$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
204
			$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
208
			$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
205
			$courriel = strtolower($courriel);
209
			$courriel = strtolower($courriel);
206
			$infos_utilisateurs[$courriel] = $utilisateur;
210
			$infos_utilisateurs[$courriel] = $utilisateur;
207
		}
211
		}
208
		return $infos_utilisateurs;
212
		return $infos_utilisateurs;
209
	}
213
	}
210
 
214
 
211
	/**
215
	/**
212
	 * Même principe que getIdentiteParCourriel() mais pour un seul courriel, et renvoie plus d'infos :
216
	 * Même principe que getIdentiteParCourriel() mais pour un seul courriel, et renvoie plus d'infos :
213
	 * RESSOURCE : /utilisateur/identite-complete-par-courriel/courriel[/format]
217
	 * RESSOURCE : /utilisateur/identite-complete-par-courriel/courriel[/format]
214
	 * PARAMÈTRES : format : "json" (par défaut) ou "xml" (pour
218
	 * PARAMÈTRES : format : "json" (par défaut) ou "xml" (pour
215
	 *   rétrocompatibilité avec le service eFlore_chatin/annuaire_tela/xxx/courriel) 
219
	 *   rétrocompatibilité avec le service eFlore_chatin/annuaire_tela/xxx/courriel) 
216
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
220
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
217
	 * - id : identifiant numérique de l'utilisateur
221
	 * - id : identifiant numérique de l'utilisateur
218
	 * - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
222
	 * - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
219
	 * - pseudo : pseudo de l'utilisateur.
223
	 * - pseudo : pseudo de l'utilisateur.
220
	 * - prenom : prénom
224
	 * - prenom : prénom
221
	 * - nom : nom de famille.
225
	 * - nom : nom de famille.
222
	 * - mot_de_passe : le mot de passe haché (15% de matières grasses, peut contenir des traces de soja)
226
	 * - mot_de_passe : le mot de passe haché (15% de matières grasses, peut contenir des traces de soja)
223
	 * - fonction
227
	 * - fonction
224
	 * - titre
228
	 * - titre
225
	 * - site_web
229
	 * - site_web
226
	 * - adresse01
230
	 * - adresse01
227
	 * - adresse02
231
	 * - adresse02
228
	 * - code_postal
232
	 * - code_postal
229
	 * - ville
233
	 * - ville
230
	 * - departement
234
	 * - departement
231
	 * - region
235
	 * - region
232
	 * - pays
236
	 * - pays
233
	 * - date_inscription
237
	 * - date_inscription
234
	 */
238
	 */
235
	public function getIdentiteCompleteParCourriel() {
239
	public function getIdentiteCompleteParCourriel() {
236
 
240
 
237
		$this->authentificationHttpSimple();
241
		$this->authentificationHttpSimple();
238
 
242
 
239
		$infos_utilisateurs = array();
243
		$infos_utilisateurs = array();
240
		$courriel = $this->ressources[0];
244
		$courriel = $this->ressources[0];
241
		$utilisateur = $this->getAnnuaire()->obtenirMaximumInfosParCourriel($this->idAnnuaire, $courriel);
245
		$utilisateur = $this->getAnnuaire()->obtenirMaximumInfosParCourriel($this->idAnnuaire, $courriel);
242
 
246
 
243
		$id = $utilisateur['id'];
247
		$id = $utilisateur['id'];
244
		$utilisateur['pseudo'] = $this->obtenirPseudo($id);
248
		$utilisateur['pseudo'] = $this->obtenirPseudo($id);
245
		$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
249
		$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
246
		$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
250
		$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
247
 
251
 
248
		// ouksépabo
252
		// ouksépabo
249
		$this->baliseMaitresse = "personne";
253
		$this->baliseMaitresse = "personne";
250
 
254
 
251
		return $utilisateur;
255
		return $utilisateur;
252
	}
256
	}
253
 
257
 
254
	private function getAnnuaire() {
258
	private function getAnnuaire() {
255
		if (!isset($this->annuaireModele)) {
259
		if (!isset($this->annuaireModele)) {
256
			$this->annuaireModele = new AnnuaireModele();
260
			$this->annuaireModele = new AnnuaireModele();
257
		}
261
		}
258
		return $this->annuaireModele;
262
		return $this->annuaireModele;
259
	}
263
	}
260
 
264
 
261
	private function getMeta() {
265
	private function getMeta() {
262
		if (!isset($this->metadonneeModele)) {
266
		if (!isset($this->metadonneeModele)) {
263
			$this->metadonneeModele = new MetadonneeModele();
267
			$this->metadonneeModele = new MetadonneeModele();
264
		}
268
		}
265
		return $this->metadonneeModele;
269
		return $this->metadonneeModele;
266
	}
270
	}
267
 
271
 
268
	private function obtenirPseudo($id_utilisateur) {
272
	private function obtenirPseudo($id_utilisateur) {
269
		$pseudo = '';
273
		$pseudo = '';
270
		$id_champ_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'pseudo');
274
		$id_champ_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'pseudo');
271
		if ($this->getMeta()->valeurExiste($id_champ_pseudo, $id_utilisateur)) {
275
		if ($this->getMeta()->valeurExiste($id_champ_pseudo, $id_utilisateur)) {
272
			$pseudo = $this->getMeta()->obtenirValeurMetadonnee($id_champ_pseudo, $id_utilisateur);
276
			$pseudo = $this->getMeta()->obtenirValeurMetadonnee($id_champ_pseudo, $id_utilisateur);
273
		}
277
		}
274
		return $pseudo;
278
		return $pseudo;
275
	}
279
	}
276
 
280
 
277
	private function obtenirPseudoUtilise($id_utilisateur) {
281
	private function obtenirPseudoUtilise($id_utilisateur) {
278
		$pseudo_utilise = false;
282
		$pseudo_utilise = false;
279
		$id_champ_utilise_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'utilise_pseudo');
283
		$id_champ_utilise_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'utilise_pseudo');
280
		if ($this->getMeta()->valeurExiste($id_champ_utilise_pseudo, $id_utilisateur)) {
284
		if ($this->getMeta()->valeurExiste($id_champ_utilise_pseudo, $id_utilisateur)) {
281
				$booleen = $this->getMeta()->obtenirValeurMetadonnee($id_champ_utilise_pseudo, $id_utilisateur);
285
				$booleen = $this->getMeta()->obtenirValeurMetadonnee($id_champ_utilise_pseudo, $id_utilisateur);
282
				$pseudo_utilise = ($booleen == 0) ? false : true;
286
				$pseudo_utilise = ($booleen == 0) ? false : true;
283
		}
287
		}
284
		return $pseudo_utilise;
288
		return $pseudo_utilise;
285
	}
289
	}
286
 
290
 
287
	private function formaterIntitule($utilisateur) {
291
	private function formaterIntitule($utilisateur) {
288
		$intitule = '';
292
		$intitule = '';
289
		if ($utilisateur['pseudoUtilise'] && trim($utilisateur['pseudo']) != '') {
293
		if ($utilisateur['pseudoUtilise'] && trim($utilisateur['pseudo']) != '') {
290
			$intitule = $utilisateur['pseudo'];
294
			$intitule = $utilisateur['pseudo'];
291
		} else {
295
		} else {
292
			$intitule = $utilisateur['prenom'].' '.$utilisateur['nom'];
296
			$intitule = $utilisateur['prenom'].' '.$utilisateur['nom'];
293
		}
297
		}
294
		return $intitule;
298
		return $intitule;
295
	}
299
	}
296
 
300
 
297
	/*+----------------------------------------------------------------------------------------------------+*/
301
	/*+----------------------------------------------------------------------------------------------------+*/
298
	// POST : mise à jour
302
	// POST : mise à jour
299
 
303
 
300
	public function updateElement($ressources, $donnees) {
304
	public function updateElement($ressources, $donnees) {
301
		$this->ressources = $ressources;
305
		$this->ressources = $ressources;
302
		$this->donnees = $donnees;
306
		$this->donnees = $donnees;
303
		$this->idAnnuaire = Config::get('annuaire_defaut');
307
		$this->idAnnuaire = Config::get('annuaire_defaut');
304
 
308
 
305
		$infos = null;
309
		$infos = null;
306
		if (isset($this->ressources[0])) {
310
		if (isset($this->ressources[0])) {
307
			$this->utilisateurId = array_shift($this->ressources);
311
			$this->utilisateurId = array_shift($this->ressources);
308
			if (isset($this->ressources[0])) {
312
			if (isset($this->ressources[0])) {
309
				$methode_demande = array_shift($this->ressources);
313
				$methode_demande = array_shift($this->ressources);
310
				$methode = $this->traiterNomMethodePost($methode_demande);
314
				$methode = $this->traiterNomMethodePost($methode_demande);
311
				if (method_exists($this, $methode)) {
315
				if (method_exists($this, $methode)) {
312
					$infos = $this->$methode();
316
					$infos = $this->$methode();
313
				} else {
317
				} else {
314
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete POST.";
318
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete POST.";
315
				}
319
				}
316
			} else {
320
			} else {
317
				$this->messages[] = "La seconde ressource du service pour les requêtes POST doit correspondre au type de ressource demandée.";
321
				$this->messages[] = "La seconde ressource du service pour les requêtes POST doit correspondre au type de ressource demandée.";
318
			}
322
			}
319
		} else {
323
		} else {
320
			$this->messages[] = "La première ressource du service pour les requêtes POST doit être l'identifiant de l'utilisateur.";
324
			$this->messages[] = "La première ressource du service pour les requêtes POST doit être l'identifiant de l'utilisateur.";
321
		}
325
		}
322
 
326
 
323
		if (!is_null($infos)) {
327
		if (!is_null($infos)) {
324
			$this->envoyerJson($infos);
328
			$this->envoyerJson($infos);
325
		} else {
329
		} else {
326
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
330
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
327
			$this->envoyerTxt($info);
331
			$this->envoyerTxt($info);
328
		}
332
		}
329
	}
333
	}
330
 
334
 
331
	/**
335
	/**
332
	 * Permet d'envoyer un message à un utilisateur.
336
	 * Permet d'envoyer un message à un utilisateur.
333
	 * RESSOURCE : /utilisateur/[id]/message
337
	 * RESSOURCE : /utilisateur/[id]/message
334
	 * POST :
338
	 * POST :
335
	 *  - sujet : contient le sujet du message à envoyer.
339
	 *  - sujet : contient le sujet du message à envoyer.
336
	 *  - message : contient le contenu du message à envoyer.
340
	 *  - message : contient le contenu du message à envoyer.
337
	 *  - message_txt : (optionnel) si format HTML, peut contenir le contenu du message au format texte comme alternative au HTML à envoyer.
341
	 *  - message_txt : (optionnel) si format HTML, peut contenir le contenu du message au format texte comme alternative au HTML à envoyer.
338
	 *		Sinon le texte est extrait du HTML (attention à la mise en page!).
342
	 *		Sinon le texte est extrait du HTML (attention à la mise en page!).
339
	 *  - utilisateur_courriel : contient le courriel de l'utilisateur qui envoie le message (Il doit être
343
	 *  - utilisateur_courriel : contient le courriel de l'utilisateur qui envoie le message (Il doit être
340
	 *		inscrit dans l'annuaire par défaut de Tela Botanica).
344
	 *		inscrit dans l'annuaire par défaut de Tela Botanica).
341
	 *  - copies : peut contenir une liste de courriels séparés par des virguels auxquels une copie du
345
	 *  - copies : peut contenir une liste de courriels séparés par des virguels auxquels une copie du
342
	 *		message sera envoyée.
346
	 *		message sera envoyée.
343
	 *  - format (optionnel) : text ou html
347
	 *  - format (optionnel) : text ou html
344
	 * RÉPONSE :
348
	 * RÉPONSE :
345
	 *  - message : contient le message d'information concernant l'envoie.
349
	 *  - message : contient le message d'information concernant l'envoie.
346
	 */
350
	 */
347
	private function updateMessage() {
351
	private function updateMessage() {
348
		$destinataireId = $this->utilisateurId;//$this->donnees['destinataire_id'];
352
		$destinataireId = $this->utilisateurId;//$this->donnees['destinataire_id'];
349
		$sujet = stripslashes($this->donnees['sujet']);
353
		$sujet = stripslashes($this->donnees['sujet']);
350
		$contenu = stripslashes($this->donnees['message']);
354
		$contenu = stripslashes($this->donnees['message']);
351
		$contenuTxt = (isset($this->donnees['message_txt'])) ? $this->donnees['message_txt'] : null;
355
		$contenuTxt = (isset($this->donnees['message_txt'])) ? $this->donnees['message_txt'] : null;
352
		$envoyeur = $this->donnees['utilisateur_courriel'];
356
		$envoyeur = $this->donnees['utilisateur_courriel'];
353
		$adresse_reponse = (isset($this->donnees['reponse_courriel']) ? $this->donnees['reponse_courriel'] : $this->donnees['utilisateur_courriel']);
357
		$adresse_reponse = (isset($this->donnees['reponse_courriel']) ? $this->donnees['reponse_courriel'] : $this->donnees['utilisateur_courriel']);
354
		$copies = array_key_exists('copies', $this->donnees) ? explode(',', $this->donnees['copies']) : null;
358
		$copies = array_key_exists('copies', $this->donnees) ? explode(',', $this->donnees['copies']) : null;
355
		$format = isset($this->donnees['format']) ? $this->donnees['format'] : 'text';
359
		$format = isset($this->donnees['format']) ? $this->donnees['format'] : 'text';
356
 
360
 
357
		$info = null;
361
		$info = null;
358
		if ($this->estAutoriseMessagerie($envoyeur) || $this->getAnnuaire()->utilisateurExisteParMail($this->idAnnuaire, $envoyeur)) {
362
		if ($this->estAutoriseMessagerie($envoyeur) || $this->getAnnuaire()->utilisateurExisteParMail($this->idAnnuaire, $envoyeur)) {
359
			// il est possible de passer directement un email ou bien un id utilisateur
363
			// il est possible de passer directement un email ou bien un id utilisateur
360
			if(filter_var($destinataireId, FILTER_VALIDATE_EMAIL)) {
364
			if(filter_var($destinataireId, FILTER_VALIDATE_EMAIL)) {
361
				$destinataire = $destinataireId;
365
				$destinataire = $destinataireId;
362
			} else {
366
			} else {
363
				$destinataire = $this->getAnnuaire()->obtenirMailParId($this->idAnnuaire, $destinataireId);
367
				$destinataire = $this->getAnnuaire()->obtenirMailParId($this->idAnnuaire, $destinataireId);
364
			}
368
			}
365
			if ($destinataire) {
369
			if ($destinataire) {
366
				if ($format == 'html') {
370
				if ($format == 'html') {
367
					if (isset($contenuTxt)) {
371
					if (isset($contenuTxt)) {
368
						$envoie = $this->getMessagerie()
372
						$envoie = $this->getMessagerie()
369
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, $contenuTxt, $adresse_reponse);
373
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, $contenuTxt, $adresse_reponse);
370
					} else {
374
					} else {
371
						$envoie = $this->getMessagerie()
375
						$envoie = $this->getMessagerie()
372
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
376
							->envoyerMail($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
373
					}
377
					}
374
				} else {
378
				} else {
375
					$envoie = $this->getMessagerie()->envoyerMailText($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
379
					$envoie = $this->getMessagerie()->envoyerMailText($envoyeur, $destinataire, $sujet, $contenu, '', $adresse_reponse);
376
				}
380
				}
377
				if ($envoie) {
381
				if ($envoie) {
378
					$info['message'] = "Votre message a bien été envoyé.";
382
					$info['message'] = "Votre message a bien été envoyé.";
379
					foreach ($copies as $copie) {
383
					foreach ($copies as $copie) {
380
						$sujet = '[COPIE] '.$sujet;
384
						$sujet = '[COPIE] '.$sujet;
381
						$contenu = "Message original envoyé par $envoyeur pour $destinataire.\n--\n".$contenu;
385
						$contenu = "Message original envoyé par $envoyeur pour $destinataire.\n--\n".$contenu;
382
						$this->getMessagerie()->envoyerMailText($envoyeur, $copie, $sujet, $contenu, '', $adresse_reponse);
386
						$this->getMessagerie()->envoyerMailText($envoyeur, $copie, $sujet, $contenu, '', $adresse_reponse);
383
					}
387
					}
384
				} else {
388
				} else {
385
					$info['message'] = "Le message n'a pas pu être envoyé.";
389
					$info['message'] = "Le message n'a pas pu être envoyé.";
386
				}
390
				}
387
			} else {
391
			} else {
388
				$info['message'] = "Aucun courriel ne correspond à l'id du destinataire.";
392
				$info['message'] = "Aucun courriel ne correspond à l'id du destinataire.";
389
			}
393
			}
390
		} else {
394
		} else {
391
			$info['message'] = "Vous n'êtes pas inscrit à Tela Botanica avec le courriel : $envoyeur.\n".
395
			$info['message'] = "Vous n'êtes pas inscrit à Tela Botanica avec le courriel : $envoyeur.\n".
392
				"Veuillez saisir votre courriel d'inscription ou vous inscrire à Tela Botanica.";
396
				"Veuillez saisir votre courriel d'inscription ou vous inscrire à Tela Botanica.";
393
		}
397
		}
394
		return $info;
398
		return $info;
395
	}
399
	}
396
 
400
 
397
	private function getMessagerie() {
401
	private function getMessagerie() {
398
		if (!isset($this->messagerieModele)) {
402
		if (!isset($this->messagerieModele)) {
399
			$this->messagerieModele = new MessageControleur();
403
			$this->messagerieModele = new MessageControleur();
400
		}
404
		}
401
		return $this->messagerieModele;
405
		return $this->messagerieModele;
402
	}
406
	}
403
 
407
 
404
	/*+----------------------------------------------------------------------------------------------------+*/
408
	/*+----------------------------------------------------------------------------------------------------+*/
405
	// PUT : ajout
409
	// PUT : ajout
406
 
410
 
407
	public function createElement($donnees) {
411
	public function createElement($donnees) {
408
		
412
		
409
		$this->donnees = $donnees;
413
		$this->donnees = $donnees;
410
		$this->idAnnuaire = Config::get('annuaire_defaut');
414
		$this->idAnnuaire = Config::get('annuaire_defaut');
411
 
415
 
412
		$infos = null;
416
		$infos = null;
413
		if (isset($this->donnees['methode'])) {
417
		if (isset($this->donnees['methode'])) {
414
			$methode_demande = $this->donnees['methode'];
418
			$methode_demande = $this->donnees['methode'];
415
			$methode = $this->traiterNomMethodePut($methode_demande);
419
			$methode = $this->traiterNomMethodePut($methode_demande);
416
			if (method_exists($this, $methode)) {
420
			if (method_exists($this, $methode)) {
417
				$infos = $this->$methode();
421
				$infos = $this->$methode();
418
			} else {
422
			} else {
419
				$this->messages[] = "Ce type de méthode '$methode_demande' n'est pas disponible pour la requete PUT.";
423
				$this->messages[] = "Ce type de méthode '$methode_demande' n'est pas disponible pour la requete PUT.";
420
			}
424
			}
421
		} else {
425
		} else {
422
			$this->messages[] = "Ce service n'est pas implémanté.";
426
			$this->messages[] = "Ce service n'est pas implémanté.";
423
		}
427
		}
424
 
428
 
425
		if (!is_null($infos)) {
429
		if (!is_null($infos)) {
426
			$this->envoyerJson($infos);
430
			$this->envoyerJson($infos);
427
		} else {
431
		} else {
428
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
432
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
429
			$this->envoyerTxt($info);
433
			$this->envoyerTxt($info);
430
		}
434
		}
431
	}
435
	}
432
 
436
 
433
	/**
437
	/**
434
	 * Permet d'identifier un utilisateur.
438
	 * Permet d'identifier un utilisateur.
435
	 * RESSOURCE : /utilisateur
439
	 * RESSOURCE : /utilisateur
436
	 * POST :
440
	 * POST :
437
	 *  - methode = 'connexion' : methode doit valoir 'connexion' pour connecter l'utilisateur.
441
	 *  - methode = 'connexion' : methode doit valoir 'connexion' pour connecter l'utilisateur.
438
	 *  - courriel : contient le courriel de l'utilisateur .
442
	 *  - courriel : contient le courriel de l'utilisateur .
439
	 *  - mdp : le mot de passe de l'utilisateur.
443
	 *  - mdp : le mot de passe de l'utilisateur.
440
	 *  - persistance : true si on veut laisser l'utilisateur connecté au delà de la session sinon false
444
	 *  - persistance : true si on veut laisser l'utilisateur connecté au delà de la session sinon false
441
	 * RÉPONSE :
445
	 * RÉPONSE :
442
	 *  - identifie : indiquer si l'utilisateur a été identifié (true) ou pas (false)
446
	 *  - identifie : indiquer si l'utilisateur a été identifié (true) ou pas (false)
443
	 *  - message : contient un message d'information complémentaire de l'état.
447
	 *  - message : contient un message d'information complémentaire de l'état.
444
	 */
448
	 */
445
	private function createConnexion() {
449
	private function createConnexion() {
446
		$courriel = stripslashes($this->donnees['courriel']);
450
		$courriel = stripslashes($this->donnees['courriel']);
447
		$mdp = stripslashes($this->donnees['mdp']);
451
		$mdp = stripslashes($this->donnees['mdp']);
448
		$persistance = (stripslashes($this->donnees['persistance']) == 'true') ? true : false;
452
		$persistance = (stripslashes($this->donnees['persistance']) == 'true') ? true : false;
449
 
453
 
450
		$infos = null;
454
		$infos = null;
451
		$infos['persistance'] = $persistance;
455
		$infos['persistance'] = $persistance;
452
		if ($this->verifierAcces($courriel, $mdp)) {
456
		if ($this->verifierAcces($courriel, $mdp)) {
453
			$infos['identifie'] = true;
457
			$infos['identifie'] = true;
454
			$infos['message'] = "Bienvenu.";
458
			$infos['message'] = "Bienvenu.";
455
			$dureeCookie = 0;
459
			$dureeCookie = 0;
456
			if ($persistance === true) {
460
			if ($persistance === true) {
457
				$dureeCookie = time()+3600*24*30;
461
				$dureeCookie = time()+3600*24*30;
458
				$this->creerCookiePersistant($dureeCookie, $courriel, $mdp);
462
				$this->creerCookiePersistant($dureeCookie, $courriel, $mdp);
459
			}
463
			}
460
			$this->creerCookieUtilisateur($dureeCookie, $courriel);
464
			$this->creerCookieUtilisateur($dureeCookie, $courriel);
461
			$infos['message'] = $_COOKIE;
465
			$infos['message'] = $_COOKIE;
462
		} else {
466
		} else {
463
			$infos['identifie'] = false;
467
			$infos['identifie'] = false;
464
			$infos['message'] = "Le courriel ou le mot de passe saisi est incorrect.";
468
			$infos['message'] = "Le courriel ou le mot de passe saisi est incorrect.";
465
		}
469
		}
466
		return $infos;
470
		return $infos;
467
	}
471
	}
468
	
472
	
469
	/*+----------------------------------------------------------------------------------------------------+*/
473
	/*+----------------------------------------------------------------------------------------------------+*/
470
	// DELETE : suppression
474
	// DELETE : suppression
471
	
475
	
472
	/**
476
	/**
473
	 * Permet de déconnecter un utilisateur
477
	 * Permet de déconnecter un utilisateur
474
	 * RESSOURCE : /utilisateur
478
	 * RESSOURCE : /utilisateur
475
	 * DELETE 
479
	 * DELETE 
476
	 */
480
	 */
477
	public function deleteElement($uid) {
481
	public function deleteElement($uid) {
478
		if($uid[0] == 'deconnexion') {
482
		if($uid[0] == 'deconnexion') {
479
			$this->supprimerCookieUtilisateur();
483
			$this->supprimerCookieUtilisateur();
480
		}
484
		}
481
	}	
485
	}	
482
}
486
}
483
?>
487
?>