Subversion Repositories Applications.annuaire

Rev

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

Rev 437 Rev 450
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
	/*+----------------------------------------------------------------------------------------------------+*/
26
	/*+----------------------------------------------------------------------------------------------------+*/
27
	// GET : consultation
27
	// GET : consultation
28
 
28
 
29
	public function getElement($ressources){
29
	public function getElement($ressources){
30
		$this->ressources = $ressources;
30
		$this->ressources = $ressources;
31
		$this->idAnnuaire = Config::get('annuaire_defaut');
31
		$this->idAnnuaire = Config::get('annuaire_defaut');
32
		$infos = null;
32
		$infos = null;
33
 
33
 
34
		if (isset($this->ressources[0])) {
34
		if (isset($this->ressources[0])) {
35
			$methode_demande = array_shift($this->ressources);
35
			if (is_int($this->ressources[0])) {
-
 
36
				// ATTENTION : Ces web services ne doivent être accessible que depuis des applis installées sur nos serveurs
36
			$methode = $this->traiterNomMethodeGet($methode_demande);
37
				// pour les communications inter-serveurs.
37
			if (method_exists($this, $methode)) {
38
				$this->controlerIpAutorisees();
38
				$infos = $this->$methode();
39
				$infos = $this->getInfosParId($this->ressources[0]);
39
			} else {
40
			} else {
-
 
41
				$methode_demande = array_shift($this->ressources);
-
 
42
				$methode = $this->traiterNomMethodeGet($methode_demande);
-
 
43
				if (method_exists($this, $methode)) {
-
 
44
					$infos = $this->$methode();
-
 
45
				} else {
40
				$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete GET.";
46
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete GET.";
-
 
47
				}
41
			}
48
			}
42
		} else {
49
		} else {
43
			$this->messages[] = "Le premier paramêtre du chemin du service doit correspondre au type de ressource demandée.";
50
			$this->messages[] = "Le premier paramêtre du chemin du service doit correspondre au type de ressource demandée.";
44
		}
51
		}
45
 
52
 
46
		if (!is_null($infos)) {
53
		if (!is_null($infos)) {
47
			$this->envoyerJson($infos);
54
			$this->envoyerJson($infos);
48
		} else {
55
		} else {
49
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
56
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
50
			$this->envoyerTxt($info);
57
			$this->envoyerTxt($info);
51
		}
58
		}
52
	}
59
	}
-
 
60
 
-
 
61
 
-
 
62
	/**
-
 
63
	 * Permet d'obtenir des infos pour un id utilisateur indiqué dans la ressource.
-
 
64
	 * RESSOURCE : /utilisateur/#id
-
 
65
	 * PARAMÊTRES : aucun
-
 
66
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
-
 
67
	 *  - id : identifiant numérique de l'utilisateur
-
 
68
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
-
 
69
	 *  - pseudo : pseudo de l'utilisateur.
-
 
70
	 *  - intitule : l'intitulé à affiche (choix auto entre "pseudo" et "prénom nom")
-
 
71
	 *  - prenom : prénom
-
 
72
	 *  - nom : nom de famille.
-
 
73
	 *  - courriel : courriel
-
 
74
	 */
-
 
75
	public function getInfosParId($id_utilisateur) {
-
 
76
		$champs = array('champ_id', 'champ_mail', 'champ_prenom', 'champ_nom');
-
 
77
 
-
 
78
		$infos_utilisateurs = $this->getAnnuaire()->obtenirValeursUtilisateur($this->idAnnuaire, $id_utilisateur, $champs);
-
 
79
		$infos_utilisateurs['pseudoUtilise'] = $this->obtenirPseudoUtilise($id_utilisateur);
-
 
80
		$infos_utilisateurs['pseudo'] = $this->obtenirPseudo($id_utilisateur);
-
 
81
		$infos_utilisateurs['intitule'] = $this->formaterIntitule($infos_utilisateurs);
-
 
82
 
-
 
83
		return $infos_utilisateurs;
-
 
84
	}
53
 
85
 
54
	/**
86
	/**
55
	 * Permet d'obtenir les prénoms et noms des courriels des utilisateurs indiqués dans la ressource.
87
	 * Permet d'obtenir les prénoms et noms des courriels des utilisateurs indiqués dans la ressource.
56
	 * RESSOURCE : /utilisateur/prenom-nom-par-courriel/[courriel,courriel,...]
88
	 * RESSOURCE : /utilisateur/prenom-nom-par-courriel/[courriel,courriel,...]
57
	 * PARAMÊTRES : aucun
89
	 * PARAMÊTRES : aucun
58
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
90
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
59
	 *  - id : identifiant numérique de l'utilisateur
91
	 *  - id : identifiant numérique de l'utilisateur
60
	 *  - prenom : prénom
92
	 *  - prenom : prénom
61
	 *  - nom : nom de famille.
93
	 *  - nom : nom de famille.
62
	 */
94
	 */
63
	public function getPrenomNomParCourriel() {
95
	public function getPrenomNomParCourriel() {
64
		$courriels = explode(',', $this->ressources[0]);
96
		$courriels = explode(',', $this->ressources[0]);
65
		$infos = $this->getAnnuaire()->obtenirPrenomNomParCourriel($this->idAnnuaire, $courriels);
97
		$infos = $this->getAnnuaire()->obtenirPrenomNomParCourriel($this->idAnnuaire, $courriels);
66
		$infous_courriel_minuscule = array();
98
		$infous_courriel_minuscule = array();
67
		foreach ($infos as $courriel => $utilisateur) {
99
		foreach ($infos as $courriel => $utilisateur) {
68
			$courriel = strtolower($courriel);
100
			$courriel = strtolower($courriel);
69
			$infous_courriel_minuscule[$courriel] = $utilisateur;
101
			$infous_courriel_minuscule[$courriel] = $utilisateur;
70
		}
102
		}
71
		return $infos;
103
		return $infos;
72
	}
104
	}
73
 
105
 
74
	/**
106
	/**
75
	 * Permet d'obtenir les identités des utilisateurs indiqués dans la ressource.
107
	 * Permet d'obtenir les identités des utilisateurs indiqués dans la ressource.
76
	 * RESSOURCE : /utilisateur/identite-par-courriel/[courriel,courriel,...]
108
	 * RESSOURCE : /utilisateur/identite-par-courriel/[courriel,courriel,...]
77
	 * PARAMÊTRES : aucun
109
	 * PARAMÊTRES : aucun
78
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
110
	 * RÉPONSE : Tableau possédant un courriel de la ressource en clé et en valeur :
79
	 *  - id : identifiant numérique de l'utilisateur
111
	 *  - id : identifiant numérique de l'utilisateur
80
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
112
	 *  - pseudoUtilise : indique si on doit utiliser le pseudo à la place de Prénom NOM
81
	 *  - pseudo : pseudo de l'utilisateur.
113
	 *  - pseudo : pseudo de l'utilisateur.
82
	 *  - prenom : prénom
114
	 *  - prenom : prénom
83
	 *  - nom : nom de famille.
115
	 *  - nom : nom de famille.
84
	 */
116
	 */
85
	public function getIdentiteParCourriel() {
117
	public function getIdentiteParCourriel() {
86
		$infos_utilisateurs = array();
118
		$infos_utilisateurs = array();
87
		$utilisateurs = $this->getPrenomNomParCourriel();
119
		$utilisateurs = $this->getPrenomNomParCourriel();
88
		foreach ($utilisateurs as $courriel => $utilisateur) {
120
		foreach ($utilisateurs as $courriel => $utilisateur) {
89
			$id = $utilisateur['id'];
121
			$id = $utilisateur['id'];
90
			$utilisateur['pseudo'] = $this->obtenirPseudo($id);
122
			$utilisateur['pseudo'] = $this->obtenirPseudo($id);
91
			$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
123
			$utilisateur['pseudoUtilise'] = $this->obtenirPseudoUtilise($id);
92
			$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
124
			$utilisateur['intitule'] = $this->formaterIntitule($utilisateur);
93
			$infos_utilisateurs[$courriel] = $utilisateur;
125
			$infos_utilisateurs[$courriel] = $utilisateur;
94
		}
126
		}
95
		return $infos_utilisateurs;
127
		return $infos_utilisateurs;
96
	}
128
	}
97
 
129
 
98
	private function getAnnuaire() {
130
	private function getAnnuaire() {
99
		if (!isset($this->annuaireModele)) {
131
		if (!isset($this->annuaireModele)) {
100
			$this->annuaireModele = new AnnuaireModele();
132
			$this->annuaireModele = new AnnuaireModele();
101
		}
133
		}
102
		return $this->annuaireModele;
134
		return $this->annuaireModele;
103
	}
135
	}
104
 
136
 
105
	private function getMeta() {
137
	private function getMeta() {
106
		if (!isset($this->metadonneeModele)) {
138
		if (!isset($this->metadonneeModele)) {
107
			$this->metadonneeModele = new MetadonneeModele();
139
			$this->metadonneeModele = new MetadonneeModele();
108
		}
140
		}
109
		return $this->metadonneeModele;
141
		return $this->metadonneeModele;
110
	}
142
	}
111
 
143
 
112
	private function obtenirPseudo($id_utilisateur) {
144
	private function obtenirPseudo($id_utilisateur) {
113
		$pseudo = '';
145
		$pseudo = '';
114
		$id_champ_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'pseudo');
146
		$id_champ_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'pseudo');
115
		if ($this->getMeta()->valeurExiste($id_champ_pseudo, $id_utilisateur)) {
147
		if ($this->getMeta()->valeurExiste($id_champ_pseudo, $id_utilisateur)) {
116
			$pseudo = $this->getMeta()->obtenirValeurMetadonnee($id_champ_pseudo, $id_utilisateur);
148
			$pseudo = $this->getMeta()->obtenirValeurMetadonnee($id_champ_pseudo, $id_utilisateur);
117
		}
149
		}
118
		return $pseudo;
150
		return $pseudo;
119
	}
151
	}
120
 
152
 
121
	private function obtenirPseudoUtilise($id_utilisateur) {
153
	private function obtenirPseudoUtilise($id_utilisateur) {
122
		$pseudo_utilise = false;
154
		$pseudo_utilise = false;
123
		$id_champ_utilise_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'utilise_pseudo');
155
		$id_champ_utilise_pseudo = $this->getMeta()->renvoyerIdChampMetadonneeParAbreviation($this->idAnnuaire, 'utilise_pseudo');
124
		if ($this->getMeta()->valeurExiste($id_champ_utilise_pseudo, $id_utilisateur)) {
156
		if ($this->getMeta()->valeurExiste($id_champ_utilise_pseudo, $id_utilisateur)) {
125
				$booleen = $this->getMeta()->obtenirValeurMetadonnee($id_champ_utilise_pseudo, $id_utilisateur);
157
				$booleen = $this->getMeta()->obtenirValeurMetadonnee($id_champ_utilise_pseudo, $id_utilisateur);
126
				$pseudo_utilise = ($booleen == 0) ? false : true;
158
				$pseudo_utilise = ($booleen == 0) ? false : true;
127
		}
159
		}
128
		return $pseudo_utilise;
160
		return $pseudo_utilise;
129
	}
161
	}
130
 
162
 
131
	private function formaterIntitule($utilisateur) {
163
	private function formaterIntitule($utilisateur) {
132
		$intitule = '';
164
		$intitule = '';
133
		if ($utilisateur['pseudoUtilise'] && trim($utilisateur['pseudo']) != '') {
165
		if ($utilisateur['pseudoUtilise'] && trim($utilisateur['pseudo']) != '') {
134
			$intitule = $utilisateur['pseudo'];
166
			$intitule = $utilisateur['pseudo'];
135
		} else {
167
		} else {
136
			$intitule = $utilisateur['prenom'].' '.$utilisateur['nom'];
168
			$intitule = $utilisateur['prenom'].' '.$utilisateur['nom'];
137
		}
169
		}
138
		return $intitule;
170
		return $intitule;
139
	}
171
	}
140
 
172
 
141
	/*+----------------------------------------------------------------------------------------------------+*/
173
	/*+----------------------------------------------------------------------------------------------------+*/
142
	// POST : mise à jour
174
	// POST : mise à jour
143
 
175
 
144
	public function updateElement($ressources, $donnees) {
176
	public function updateElement($ressources, $donnees) {
145
		$this->ressources = $ressources;
177
		$this->ressources = $ressources;
146
		$this->donnees = $donnees;
178
		$this->donnees = $donnees;
147
		$this->idAnnuaire = Config::get('annuaire_defaut');
179
		$this->idAnnuaire = Config::get('annuaire_defaut');
148
 
180
 
149
		$infos = null;
181
		$infos = null;
150
		if (isset($this->ressources[0])) {
182
		if (isset($this->ressources[0])) {
151
			$this->utilisateurId = array_shift($this->ressources);
183
			$this->utilisateurId = array_shift($this->ressources);
152
			if (isset($this->ressources[0])) {
184
			if (isset($this->ressources[0])) {
153
				$methode_demande = array_shift($this->ressources);
185
				$methode_demande = array_shift($this->ressources);
154
				$methode = $this->traiterNomMethodePost($methode_demande);
186
				$methode = $this->traiterNomMethodePost($methode_demande);
155
				if (method_exists($this, $methode)) {
187
				if (method_exists($this, $methode)) {
156
					$infos = $this->$methode();
188
					$infos = $this->$methode();
157
				} else {
189
				} else {
158
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete POST.";
190
					$this->messages[] = "Ce type de ressource '$methode_demande' n'est pas disponible pour la requete POST.";
159
				}
191
				}
160
			} else {
192
			} else {
161
				$this->messages[] = "La seconde ressource du service pour les requêtes POST doit correspondre au type de ressource demandée.";
193
				$this->messages[] = "La seconde ressource du service pour les requêtes POST doit correspondre au type de ressource demandée.";
162
			}
194
			}
163
		} else {
195
		} else {
164
			$this->messages[] = "La première ressource du service pour les requêtes POST doit être l'identifiant de l'utilisateur.";
196
			$this->messages[] = "La première ressource du service pour les requêtes POST doit être l'identifiant de l'utilisateur.";
165
		}
197
		}
166
 
198
 
167
		if (!is_null($infos)) {
199
		if (!is_null($infos)) {
168
			$this->envoyerJson($infos);
200
			$this->envoyerJson($infos);
169
		} else {
201
		} else {
170
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
202
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
171
			$this->envoyerTxt($info);
203
			$this->envoyerTxt($info);
172
		}
204
		}
173
	}
205
	}
174
 
206
 
175
	/**
207
	/**
176
	 * Permet d'envoyer un message à un utilisateur.
208
	 * Permet d'envoyer un message à un utilisateur.
177
	 * RESSOURCE : /utilisateur/[id]/message
209
	 * RESSOURCE : /utilisateur/[id]/message
178
	 * POST :
210
	 * POST :
179
	 *  - sujet : contient le sujet du message à envoyer.
211
	 *  - sujet : contient le sujet du message à envoyer.
180
	 *  - message : contient le contenu du message à envoyer.
212
	 *  - message : contient le contenu du message à envoyer.
181
	 *  - utilisateur_courriel : contient le courriel de l'utilisateur qui envoie le message (Il doit être
213
	 *  - utilisateur_courriel : contient le courriel de l'utilisateur qui envoie le message (Il doit être
182
	 *		inscrit dans l'annuaire par défaut de Tela Botanica).
214
	 *		inscrit dans l'annuaire par défaut de Tela Botanica).
183
	 *  - copies : peut contenir une liste de courriels séparés par des virguels auxquels une copie du
215
	 *  - copies : peut contenir une liste de courriels séparés par des virguels auxquels une copie du
184
	 *		message sera envoyée.
216
	 *		message sera envoyée.
185
	 *  - format (optionnel) : text ou html
217
	 *  - format (optionnel) : text ou html
186
	 * RÉPONSE :
218
	 * RÉPONSE :
187
	 *  - message : contient le message d'information concernant l'envoie.
219
	 *  - message : contient le message d'information concernant l'envoie.
188
	 */
220
	 */
189
	private function updateMessage() {
221
	private function updateMessage() {
190
		$destinataireId = $this->utilisateurId;//$this->donnees['destinataire_id'];
222
		$destinataireId = $this->utilisateurId;//$this->donnees['destinataire_id'];
191
		$sujet = stripslashes($this->donnees['sujet']);
223
		$sujet = stripslashes($this->donnees['sujet']);
192
		$contenu = stripslashes($this->donnees['message']);
224
		$contenu = stripslashes($this->donnees['message']);
193
		$envoyeur = $this->donnees['utilisateur_courriel'];
225
		$envoyeur = $this->donnees['utilisateur_courriel'];
194
		$copies = array_key_exists('copies', $this->donnees) ? explode(',', $this->donnees['copies']) : null;
226
		$copies = array_key_exists('copies', $this->donnees) ? explode(',', $this->donnees['copies']) : null;
195
		$format = isset($this->donnees['format']) ? $this->donnees['format'] : 'text';
227
		$format = isset($this->donnees['format']) ? $this->donnees['format'] : 'text';
196
 
228
 
197
		$info = null;
229
		$info = null;
198
		if ($this->estAutoriseMessagerie($envoyeur) || $this->getAnnuaire()->utilisateurExisteParMail($this->idAnnuaire, $envoyeur)) {
230
		if ($this->estAutoriseMessagerie($envoyeur) || $this->getAnnuaire()->utilisateurExisteParMail($this->idAnnuaire, $envoyeur)) {
199
			// il est possible de passer directement un email ou bien un id utilisateur
231
			// il est possible de passer directement un email ou bien un id utilisateur
200
			if(filter_var($destinataireId, FILTER_VALIDATE_EMAIL)) {
232
			if(filter_var($destinataireId, FILTER_VALIDATE_EMAIL)) {
201
				$destinataire = $destinataireId;
233
				$destinataire = $destinataireId;
202
			} else {
234
			} else {
203
				$destinataire = $this->getAnnuaire()->obtenirMailParId($this->idAnnuaire, $destinataireId);
235
				$destinataire = $this->getAnnuaire()->obtenirMailParId($this->idAnnuaire, $destinataireId);
204
			}
236
			}
205
			if ($destinataire) {
237
			if ($destinataire) {
206
				if ($format == 'html') {
238
				if ($format == 'html') {
207
					$envoie = $this->getMessagerie()->envoyerMail($envoyeur, $destinataire, $sujet, $contenu);
239
					$envoie = $this->getMessagerie()->envoyerMail($envoyeur, $destinataire, $sujet, $contenu);
208
				} else {
240
				} else {
209
					$envoie = $this->getMessagerie()->envoyerMailText($envoyeur, $destinataire, $sujet, $contenu);
241
					$envoie = $this->getMessagerie()->envoyerMailText($envoyeur, $destinataire, $sujet, $contenu);
210
				}
242
				}
211
				if ($envoie) {
243
				if ($envoie) {
212
					$info['message'] = "Votre message a bien été envoyé.";
244
					$info['message'] = "Votre message a bien été envoyé.";
213
					foreach ($copies as $copie) {
245
					foreach ($copies as $copie) {
214
						$sujet = '[COPIE] '.$sujet;
246
						$sujet = '[COPIE] '.$sujet;
215
						$contenu = "Message original envoyé par $envoyeur pour $destinataire.\n--\n".$contenu;
247
						$contenu = "Message original envoyé par $envoyeur pour $destinataire.\n--\n".$contenu;
216
						$this->getMessagerie()->envoyerMailText($envoyeur, $copie, $sujet, $contenu);
248
						$this->getMessagerie()->envoyerMailText($envoyeur, $copie, $sujet, $contenu);
217
					}
249
					}
218
				} else {
250
				} else {
219
					$info['message'] = "Le message n'a pas pu être envoyé.";
251
					$info['message'] = "Le message n'a pas pu être envoyé.";
220
				}
252
				}
221
			} else {
253
			} else {
222
				$info['message'] = "Aucun courriel ne correspond à l'id du destinataire.";
254
				$info['message'] = "Aucun courriel ne correspond à l'id du destinataire.";
223
			}
255
			}
224
		} else {
256
		} else {
225
			$info['message'] = "Vous n'êtes pas inscrit à Tela Botanica avec le courriel : $envoyeur.\n".
257
			$info['message'] = "Vous n'êtes pas inscrit à Tela Botanica avec le courriel : $envoyeur.\n".
226
				"Veuillez saisir votre courriel d'inscription ou vous inscrire à Tela Botanica.";
258
				"Veuillez saisir votre courriel d'inscription ou vous inscrire à Tela Botanica.";
227
		}
259
		}
228
		return $info;
260
		return $info;
229
	}
261
	}
230
 
262
 
231
	private function getMessagerie() {
263
	private function getMessagerie() {
232
		if (!isset($this->messagerieModele)) {
264
		if (!isset($this->messagerieModele)) {
233
			$this->messagerieModele = new MessageControleur();
265
			$this->messagerieModele = new MessageControleur();
234
		}
266
		}
235
		return $this->messagerieModele;
267
		return $this->messagerieModele;
236
	}
268
	}
237
 
269
 
238
	/*+----------------------------------------------------------------------------------------------------+*/
270
	/*+----------------------------------------------------------------------------------------------------+*/
239
	// PUT : ajout
271
	// PUT : ajout
240
 
272
 
241
	public function createElement($donnees) {
273
	public function createElement($donnees) {
242
		$this->donnees = $donnees;
274
		$this->donnees = $donnees;
243
		$this->idAnnuaire = Config::get('annuaire_defaut');
275
		$this->idAnnuaire = Config::get('annuaire_defaut');
244
 
276
 
245
		$infos = null;
277
		$infos = null;
246
		if (isset($this->donnees['methode'])) {
278
		if (isset($this->donnees['methode'])) {
247
			$methode_demande = $this->donnees['methode'];
279
			$methode_demande = $this->donnees['methode'];
248
			$methode = $this->traiterNomMethodePut($methode_demande);
280
			$methode = $this->traiterNomMethodePut($methode_demande);
249
			if (method_exists($this, $methode)) {
281
			if (method_exists($this, $methode)) {
250
				$infos = $this->$methode();
282
				$infos = $this->$methode();
251
			} else {
283
			} else {
252
				$this->messages[] = "Ce type de méthode '$methode_demande' n'est pas disponible pour la requete PUT.";
284
				$this->messages[] = "Ce type de méthode '$methode_demande' n'est pas disponible pour la requete PUT.";
253
			}
285
			}
254
		} else {
286
		} else {
255
			$this->messages[] = "Ce service n'est pas implémanté.";
287
			$this->messages[] = "Ce service n'est pas implémanté.";
256
		}
288
		}
257
 
289
 
258
		if (!is_null($infos)) {
290
		if (!is_null($infos)) {
259
			$this->envoyerJson($infos);
291
			$this->envoyerJson($infos);
260
		} else {
292
		} else {
261
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
293
			$info = 'Un problème est survenu : '.print_r($this->messages, true);
262
			$this->envoyerTxt($info);
294
			$this->envoyerTxt($info);
263
		}
295
		}
264
	}
296
	}
265
 
297
 
266
	/**
298
	/**
267
	 * Permet d'identifier un utilisateur.
299
	 * Permet d'identifier un utilisateur.
268
	 * RESSOURCE : /utilisateur
300
	 * RESSOURCE : /utilisateur
269
	 * POST :
301
	 * POST :
270
	 *  - methode = 'connexion' : methode doit valoir 'connexion' pour connecter l'utilisateur.
302
	 *  - methode = 'connexion' : methode doit valoir 'connexion' pour connecter l'utilisateur.
271
	 *  - courriel : contient le courriel de l'utilisateur .
303
	 *  - courriel : contient le courriel de l'utilisateur .
272
	 *  - mdp : le mot de passe de l'utilisateur.
304
	 *  - mdp : le mot de passe de l'utilisateur.
273
	 *  - persistance : true si on veut laisser l'utilisateur connecté au delà de la session sinon false
305
	 *  - persistance : true si on veut laisser l'utilisateur connecté au delà de la session sinon false
274
	 * RÉPONSE :
306
	 * RÉPONSE :
275
	 *  - identifie : indiquer si l'utilisateur a été identifié (true) ou pas (false)
307
	 *  - identifie : indiquer si l'utilisateur a été identifié (true) ou pas (false)
276
	 *  - message : contient un message d'information complémentaire de l'état.
308
	 *  - message : contient un message d'information complémentaire de l'état.
277
	 */
309
	 */
278
	private function createConnexion() {
310
	private function createConnexion() {
279
		$courriel = stripslashes($this->donnees['courriel']);
311
		$courriel = stripslashes($this->donnees['courriel']);
280
		$mdp = stripslashes($this->donnees['mdp']);
312
		$mdp = stripslashes($this->donnees['mdp']);
281
		$persistance = (stripslashes($this->donnees['persistance']) == 'true') ? true : false;
313
		$persistance = (stripslashes($this->donnees['persistance']) == 'true') ? true : false;
282
 
314
 
283
		$infos = null;
315
		$infos = null;
284
		$infos['persistance'] = $persistance;
316
		$infos['persistance'] = $persistance;
285
		if ($this->verifierAcces($courriel, $mdp)) {
317
		if ($this->verifierAcces($courriel, $mdp)) {
286
			$infos['identifie'] = true;
318
			$infos['identifie'] = true;
287
			$infos['message'] = "Bienvenu.";
319
			$infos['message'] = "Bienvenu.";
288
			$dureeCookie = 0;
320
			$dureeCookie = 0;
289
			if ($persistance === true) {
321
			if ($persistance === true) {
290
				$dureeCookie = time()+3600*24*30;
322
				$dureeCookie = time()+3600*24*30;
291
				$this->creerCookiePersistant($dureeCookie, $courriel, $mdp);
323
				$this->creerCookiePersistant($dureeCookie, $courriel, $mdp);
292
			}
324
			}
293
			$this->creerCookieUtilisateur($dureeCookie, $courriel);
325
			$this->creerCookieUtilisateur($dureeCookie, $courriel);
294
			$infos['message'] = $_COOKIE;
326
			$infos['message'] = $_COOKIE;
295
		} else {
327
		} else {
296
			$infos['identifie'] = false;
328
			$infos['identifie'] = false;
297
			$infos['message'] = "Le courriel ou le mot de passe saisi est incorrect.";
329
			$infos['message'] = "Le courriel ou le mot de passe saisi est incorrect.";
298
		}
330
		}
299
		return $infos;
331
		return $infos;
300
	}
332
	}
301
}
333
}
302
?>
334
?>