Subversion Repositories Applications.annuaire

Rev

Rev 562 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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