Subversion Repositories Applications.annuaire

Rev

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

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