Subversion Repositories Applications.annuaire

Rev

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

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