Subversion Repositories Applications.annuaire

Rev

Rev 214 | Rev 272 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

Rev Author Line No. Line
46 aurelien 1
<?
2
/**
3
* PHP Version 5
4
*
5
* @category  PHP
6
* @package   annuaire
7
* @author    aurelien <aurelien@tela-botanica.org>
8
* @copyright 2010 Tela-Botanica
9
* @license   http://www.cecill.info/licences/Licence_CeCILL_V2-fr.txt Licence CECILL
10
* @version   SVN: <svn_id>
11
* @link      /doc/annuaire/
12
*/
13
 
120 aurelien 14
Class MessageControleur extends AppControleur {
46 aurelien 15
 
16
	/**
17
	 * Les mails doivent ils être modérés ?
18
	 */
19
	private $moderer_mail = false;
214 aurelien 20
 
21
	/**
22
	 * Doit on envoyer une copie des message au modérateur
23
	 */
24
	private $moderation_copie = false;
46 aurelien 25
 
26
	/**
27
	 * Le ou les mails des modérateurs, si ce sont plusieurs mails,
28
	 * ils doivent être séparés par des virgules
29
	 */
30
	private $mail_moderateur = '';
31
 
32
	/**
33
	 * Nombre de destinataires au dessus duquel on modère les mails
34
	 */
35
	private $seuil_moderation = 10;
36
 
37
	/**
38
	 * Adresse mail de l'expéditeur à partir laquelle sont envoyée les mails de modération
39
	 */
40
	private $adresse_mail_annuaire = '';
41
 
42
	 /**
43
	  *
44
	  * Constructeur sans paramètres
45
	 */
46
	public function MessageControleur() {
47
 
48
		$this->__construct();
49
 
50
		// doit on modérer ?
51
		if(Config::get('moderer_mail') != null) {
52
			$this->moderer_mail = Config::get('moderer_mail');
53
		}
214 aurelien 54
 
55
		// doit on envoyer des copies des messages ?
56
		if(Config::get('moderation_copie') != null) {
57
			$this->moderation_copie = Config::get('moderation_copie');
58
		}
46 aurelien 59
 
60
		// mail du modérateur pour l'envoi de messages au dessus d'un certain seuil
61
		if($this->moderer_mail && Config::get('mail_moderateur') != null) {
62
			$this->mail_moderateur = Config::get('mail_moderateur');
63
		}
64
 
65
		// seuil de modération
66
		if($this->moderer_mail && Config::get('seuil_moderation_messages') != null) {
67
			$this->seuil_moderation = Config::get('seuil_moderation_messages');
68
		}
69
 
70
		// adresse d'expéditeur
71
		if(Config::get('adresse_mail_annuaire') != null) {
72
			$this->adresse_mail_annuaire = Config::get('adresse_mail_annuaire');
73
		}
74
	}
120 aurelien 75
 
76
/** -------------------Fonctions pour l'inscription et l'oubli de mot de passe  -----------------------*/
46 aurelien 77
 
120 aurelien 78
	/**
79
	 * En cas de tentative d'inscription, envoie un mail contenant un lien de confirmation à l'utilisateur
80
	 * @param string $adresse_mail adresse mail
81
	 * @param string $nom nom
82
	 * @param string $prenom prénom
83
	 * @param string $code_confirmation_inscription code de confirmation à inclure dans le mail
84
	 *
85
	 * @return boolean le succès ou l'échec de l'envoi du mail
86
	 */
87
	public function envoyerMailConfirmationInscription($adresse_mail, $nom, $prenom, $code_confirmation_inscription) {
88
 
89
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
90
		$base_url = new URL($url_cette_page);
91
		$base_url->setVariablesRequete(array());
92
		$base_url->setVariableRequete('m','annuaire_inscription_confirmation');
93
		$base_url->setVariableRequete('id',$code_confirmation_inscription);
94
 
95
		$donnees = array('nom' => $nom, 'prenom' => $prenom, 'lien_confirmation_inscription' => $base_url->getURL());
96
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_confirmation_inscription',$donnees);
170 aurelien 97
 
98
		// en attendant de gérer mieux l'envoi en mode texte
99
		// remplacement du &amp dans les urls
100
		$contenu_mail = str_replace('&amp;', '&', $contenu_mail);
120 aurelien 101
 
102
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
103
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
104
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
105
	     // En-têtes additionnels
106
	     $entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
107
 
233 aurelien 108
		return mail($adresse_mail,mb_encode_mimeheader('Inscription à l\'annuaire'),$contenu_mail, $entetes);
120 aurelien 109
 
110
	}
111
 
112
	 /** En cas d'oubli de mot de passe, régénère le mot de passe et envoie un mail à l'utilisateur
113
	 * @param int $id_annuaire l'identifiant d'annuaire
114
	 * @param string $adresse_mail adresse mail
115
	 * @return boolean le succès ou l'échec de l'envoi du mail
116
	 */
117
	public function envoyerMailOubliMdp($id_annuaire,$mail, $nouveau_mdp) {
118
 
119
		$base_url = clone(Registre::getInstance()->get('base_url_application'));
120
 
121
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
122
		$url_base = $url_cette_page;
123
		$base_url = new URL($url_base);
124
		$base_url->setVariablesRequete(array());
125
		$base_url->setVariableRequete('m','annuaire_fiche_utilisateur_consultation');
126
		$base_url->setVariableRequete('id_annuaire',$id_annuaire);
127
 
128
		$donnees['nouveau_mdp'] = $nouveau_mdp;
129
		$donnees['lien_profil'] = $base_url;
130
 
131
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_oubli_mdp',$donnees);
132
 
133
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
134
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
135
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
136
	     // En-têtes additionnels
137
	     $entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
138
 
233 aurelien 139
		 return mail($mail,mb_encode_mimeheader('Demande de réinitialisation de mot de passe'),$contenu_mail, $entetes);
120 aurelien 140
 
141
	}
142
 
143
 
144
/** -------------------Fonctions pour la messagerie entre utilisateurs -----------------------*/
145
 
233 aurelien 146
	/** Effectue une recherche dans la base de données et envoie un mail à tous les inscrits correspondants,
147
	 * à l'adresse donnée en paramètre
148
	 * @param string $expediteur l'expediteur du message
149
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
150
	 * @param string $sujet sujet du mail
151
	 * @return boolean true ou false suivant le succès ou non de l'envoi
152
	 */
153
	public function envoyerMailParRequete($id_annuaire, $expediteur, $criteres, $sujet, $message) {
154
 
155
		if(isset($criteres['exclusive'])) {
156
			$exclusive = $criteres['exclusive'];
157
		} else {
158
			$exclusive = true;
159
		}
160
 
161
		unset($criteres['page']);
162
		unset($criteres['taille_page']);
163
 
164
		$collecteur = new VerificationControleur();
165
		$tableau_valeur_collectees = $collecteur->collecterValeursRechercheMoteur($criteres, $this->obtenirChampsMappageAnnuaire($id_annuaire));
166
 
167
		$valeurs_recherchees = $tableau_valeur_collectees['valeurs_recherchees'];
168
		$valeurs_mappees = $tableau_valeur_collectees['valeurs_mappees'];
169
		$valeurs_get = $tableau_valeur_collectees['valeurs_get'];
170
 
171
		// on recherche dans les métadonnées
172
		$this->chargerModele('MetadonneeModele');
173
		// le résultat est un ensemble d'identifiants
174
		$resultat_metadonnees = $this->MetadonneeModele->rechercherDansValeurMetadonnees($id_annuaire,$valeurs_recherchees, $exclusive);
175
 
176
		// on recherche les infos dans la table annuaire mappée
177
		// en incluant ou excluant les id déjà trouvées dans les metadonnées
178
		// suivant le critères d'exclusivité ou non
179
		$this->chargerModele('AnnuaireModele');
180
		$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $resultat_metadonnees, $exclusive, 0, 0);
181
 
182
		$resultat_recherche = $resultat_annuaire_mappe['resultat'];
183
		$nb_resultats = $resultat_annuaire_mappe['total'];
184
 
185
		$destinataires = $this->aplatirTableauSansPreserverCles($resultat_recherche);
186
 
187
		return $this->envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet, $message);
188
 
189
	}
120 aurelien 190
 
46 aurelien 191
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
192
	 * à l'adresse donnée en paramètre
193
	 * @param string $expediteur l'expediteur du message
194
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
195
	 * @param string $sujet sujet du mail
196
	 * @return boolean true ou false suivant le succès ou non de l'envoi
197
	 */
120 aurelien 198
	public function envoyerMail($expediteur, $destinataires, $sujet, $message) {
46 aurelien 199
 
233 aurelien 200
		if(!is_array($destinataires)) {
201
			$destinataires = array($destinataires);
46 aurelien 202
		}
203
 
233 aurelien 204
		foreach($destinataires as $destinataire) {
205
			// Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
206
			$entetes  = 'MIME-Version: 1.0' . "\r\n";
207
			$entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
208
			//$entetes .= 'To:'.$destinataire . "\r\n";
209
			// En-têtes additionnels
210
			$entetes .= 'From: '.$expediteur."\r\n";
46 aurelien 211
 
233 aurelien 212
			$contenu_mail = $this->encoderChainePourEnvoiMail($message);
213
			$sujet = $this->encoderChainePourEnvoiMail($sujet);
214
 
215
			if(!mail($destinataire, mb_encode_mimeheader($sujet), $contenu_mail, $entetes)) {
216
				return false;
217
			}
218
		}
219
 
220
		return true;
46 aurelien 221
	}
222
 
223
	/**
224
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
225
	 * ou bien s'il doit être stocké et soumis à modération
226
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
227
	 * @param string $expediteur l'expéditeur du mail
228
	 * @param array $destinataires les destinataires du mail
229
	 * @param string $sujet sujet du message
230
	 * @param string $message corps du message
231
	 */
232
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
116 aurelien 233
 
170 aurelien 234
		$destinataires_mail = $this->obtenirMailParTableauId($id_annuaire, $destinataires);
116 aurelien 235
 
236
		$donnees['contenu_message'] = $this->filtrerChaine($message);
237
		$sujet = $this->filtrerChaine($sujet);
238
		$message = $this->getVue(Config::get('dossier_squelettes_mails').'mail_messagerie',$donnees);
46 aurelien 239
 
240
		// si on modere les mails et s'il y a trop de destinataires
170 aurelien 241
		if($this->moderer_mail && count($destinataires_mail) >= $this->seuil_moderation) {
214 aurelien 242
 
170 aurelien 243
			$this->stockerMailPourModeration($expediteur, $destinataires_mail, $sujet, $message);
56 aurelien 244
			$donnees['moderation'] = true;
214 aurelien 245
 
46 aurelien 246
		} else {
233 aurelien 247
 
46 aurelien 248
			// sinon, envoi direct
170 aurelien 249
			$this->envoyerMail($expediteur, $destinataires_mail, $sujet, $message);
214 aurelien 250
 
251
			if($this->moderation_copie) {
252
				$this->envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires_mail, $message);
253
			}
254
 
56 aurelien 255
			$donnees['moderation'] = false;
46 aurelien 256
		}
257
 
56 aurelien 258
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_envoi_confirmation',$donnees);
259
 
260
		return $resultat;
261
 
46 aurelien 262
	}
214 aurelien 263
 
264
	public function obtenirMailParTableauId($id_annuaire, $destinataires) {
265
		// on remplace les identifiants par leurs destinataires
266
		$this->chargerModele('AnnuaireModele');
267
		$destinataires_mails = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
268
 
269
		return $destinataires_mails;
270
	}
271
 
272
	private function envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires, $message) {
273
 
274
		$donnees['expediteur_message'] = $expediteur;
275
		$donnees['sujet_message'] = $sujet;
276
		$donnees['contenu_message'] = $message;
277
 
278
		if(is_array($destinataires)) {
279
			$destinataires = implode(', ', $destinataires);
280
		}
281
 
282
		$donnees['destinataires_message'] = $destinataires;
283
 
284
		$contenu_mail_copie = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_copie',$donnees);
285
 
286
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message a été envoyé à travers l\'annuaire', $contenu_mail_copie);
287
	}
46 aurelien 288
 
214 aurelien 289
 
46 aurelien 290
	/**
291
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
292
	 * @param string $code_confirmation le code associé au données en attente
293
	 */
294
	public function envoyerMailModere($code_confirmation) {
295
 
296
		// chargement des données temporaire
297
		$message_modele = $this->getModele('DonneeTemporaireModele');
298
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
299
 
300
		if($mail_a_moderer) {
117 aurelien 301
			// envoi
96 aurelien 302
			$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
46 aurelien 303
								$mail_a_moderer['destinataires'],
304
								$mail_a_moderer['sujet'],
305
								$mail_a_moderer['message']);
96 aurelien 306
 
307
			if($resultat_envoi) {
308
				$donnees = array('envoi_reussi' => true);
309
			} else {
310
				$donnees = array('envoi_echoue' => true);
311
			}
312
 
46 aurelien 313
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
214 aurelien 314
 
96 aurelien 315
		} else {
316
			$donnees = array('message_inexistant' => true);
46 aurelien 317
		}
318
 
96 aurelien 319
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
320
		return $resultat;
46 aurelien 321
	}
322
 
323
	/**
324
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
325
	 * @param string $code_confirmation le code associé au données en attente
326
	 */
327
	public function supprimerMailModere($code_confirmation) {
328
 
329
		$message_modele = $this->getModele('DonneeTemporaireModele');
330
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
116 aurelien 331
 
332
		$donnees = array('message_supprime' => true);
46 aurelien 333
 
116 aurelien 334
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
335
 
336
		return $resultat;
46 aurelien 337
	}
170 aurelien 338
 
46 aurelien 339
	/**
340
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
341
	 * @param string $expediteur l'expéditeur du mail
342
	 * @param array $destinataires les destinataires du mail
343
	 * @param string $sujet sujet du message
344
	 * @param string $message corps du message
345
	 */
346
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
347
 
348
		$mail = array('expediteur' => $expediteur,
349
				 'destinataires' => $destinataires,
350
					'sujet' => $sujet,
351
					'message' => $message);
352
 
353
		$message_modele = $this->getModele('DonneeTemporaireModele');
86 aurelien 354
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail, true);
46 aurelien 355
 
356
		if($id_stockage) {
177 aurelien 357
			$this->envoyerMailModeration($id_stockage, $destinataires, $sujet , $message);
46 aurelien 358
			return true;
359
		}
360
 
361
		return false;
362
 
363
	}
364
 
365
	/**
366
	 * Envoie un mail au modérateur contenant les lien pour, au choix, refuser ou bien accepter l'envoi du mail
367
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
368
	 * @param string $sujet_message_a_moderer sujet du message
369
	 * @param string $message_a_moderer corps du message
370
	 */
177 aurelien 371
	private function envoyerMailModeration($id_mail_a_moderer, $destinataires, $sujet_message_a_moderer, $message_a_moderer) {
46 aurelien 372
 
214 aurelien 373
		$url_cette_page = $this->getUrlCettePage();
70 aurelien 374
		$url_base = $url_cette_page;
46 aurelien 375
 
70 aurelien 376
		$base_url = new URL($url_base);
377
 
378
		$base_url->setVariablesRequete(array());
379
 
46 aurelien 380
		$donnees = array();
381
 
382
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
383
 
384
		$lien_accepter_mail = clone($base_url);
385
		$lien_refuser_mail = clone($base_url);
386
 
387
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
388
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
389
 
390
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
391
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
392
		$donnees['sujet_message'] = $sujet_message_a_moderer;
393
		$donnees['contenu_message'] = $message_a_moderer;
233 aurelien 394
 
177 aurelien 395
		if(is_array($destinataires)) {
396
			$destinataires = implode(', ', $destinataires);;
397
		}
398
		$donnees['destinataires_message'] = $destinataires;
46 aurelien 399
 
400
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
401
 
402
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
403
 
404
	}
116 aurelien 405
 
406
	private function filtrerChaine($message) {
117 aurelien 407
 
116 aurelien 408
		return strip_tags($message);
409
	}
233 aurelien 410
 
411
	private function encoderChainePourEnvoiMail($chaine) {
412
		return stripslashes($chaine);
413
	}
46 aurelien 414
}