Subversion Repositories Applications.annuaire

Rev

Rev 233 | Rev 273 | 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
 
272 aurelien 171
		if(isset($criteres['tous']) && $criteres['tous'] == 1) {
172
			$this->chargerModele('AnnuaireModele');
173
			$resultat_annuaire_mappe = $this->AnnuaireModele->chargerAnnuaireListeInscrits($id_annuaire,0,0);
174
		} else {
233 aurelien 175
 
272 aurelien 176
			// on recherche dans les métadonnées
177
			$this->chargerModele('MetadonneeModele');
178
			// le résultat est un ensemble d'identifiants
179
			$resultat_metadonnees = $this->MetadonneeModele->rechercherDansValeurMetadonnees($id_annuaire,$valeurs_recherchees, $exclusive);
180
 
181
			// on recherche les infos dans la table annuaire mappée
182
			// en incluant ou excluant les id déjà trouvées dans les metadonnées
183
			// suivant le critères d'exclusivité ou non
184
			$this->chargerModele('AnnuaireModele');
185
			$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $resultat_metadonnees, $exclusive, 0, 0);
186
 
187
		}
188
 
233 aurelien 189
		$resultat_recherche = $resultat_annuaire_mappe['resultat'];
190
		$nb_resultats = $resultat_annuaire_mappe['total'];
191
 
192
		$destinataires = $this->aplatirTableauSansPreserverCles($resultat_recherche);
193
 
194
		return $this->envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet, $message);
195
 
196
	}
120 aurelien 197
 
46 aurelien 198
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
199
	 * à l'adresse donnée en paramètre
200
	 * @param string $expediteur l'expediteur du message
201
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
202
	 * @param string $sujet sujet du mail
203
	 * @return boolean true ou false suivant le succès ou non de l'envoi
204
	 */
120 aurelien 205
	public function envoyerMail($expediteur, $destinataires, $sujet, $message) {
46 aurelien 206
 
233 aurelien 207
		if(!is_array($destinataires)) {
208
			$destinataires = array($destinataires);
46 aurelien 209
		}
272 aurelien 210
 
211
		$message_antislashe = $this->encoderChainePourEnvoiMail($message);
212
 
213
		$message_texte = $this->filtrerChaine($message_antislashe);
214
 
215
		$message_html = $message_antislashe;
216
 
217
		$limite = "_----------=_parties_".md5(uniqid (rand()));
46 aurelien 218
 
233 aurelien 219
		foreach($destinataires as $destinataire) {
272 aurelien 220
 
221
			// Définition d'un mail en text simple et html
233 aurelien 222
			$entetes .= 'From: '.$expediteur."\r\n";
272 aurelien 223
			$entetes .= 'MIME-Version: 1.0' . "\r\n";
224
			$entetes .= "Content-Type: multipart/alternative; boundary=\"".$limite."\";\r\n";
225
 
226
			$contenu = "";
227
 
228
			$contenu .= "\r\n--".$limite."\r\n";
229
			$contenu .= "Content-Type: text/plain;";
230
			$contenu .= "charset=\"".Config::get('appli_encodage')."\";\r\n";
231
			$contenu .= "Content-Transfer-Encoding: quoted-printable;\r\n";
232
			$contenu .= "\r\n";
233
			$contenu .= $message_texte;
234
 
235
			$contenu .= "\r\n--".$limite."\r\n";
236
			$contenu .= "Content-Type: text/html;";
237
			$contenu .= "charset=\"".Config::get('appli_encodage')."\";\r\n";
238
			$contenu .= "Content-Transfer-Encoding: quoted-printable;\r\n";
239
			$contenu .= "\r\n";
240
			$contenu .= nl2br($message_antislashe);
241
 
233 aurelien 242
			$sujet = $this->encoderChainePourEnvoiMail($sujet);
272 aurelien 243
 
244
			if(!mail($destinataire, mb_encode_mimeheader($sujet), $contenu, $entetes)) {
233 aurelien 245
				return false;
246
			}
247
		}
248
 
249
		return true;
46 aurelien 250
	}
251
 
252
	/**
253
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
254
	 * ou bien s'il doit être stocké et soumis à modération
255
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
256
	 * @param string $expediteur l'expéditeur du mail
257
	 * @param array $destinataires les destinataires du mail
258
	 * @param string $sujet sujet du message
259
	 * @param string $message corps du message
260
	 */
261
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
116 aurelien 262
 
170 aurelien 263
		$destinataires_mail = $this->obtenirMailParTableauId($id_annuaire, $destinataires);
116 aurelien 264
 
272 aurelien 265
		$donnees['erreurs'] = false;
266
 
116 aurelien 267
		$donnees['contenu_message'] = $this->filtrerChaine($message);
268
		$sujet = $this->filtrerChaine($sujet);
269
		$message = $this->getVue(Config::get('dossier_squelettes_mails').'mail_messagerie',$donnees);
46 aurelien 270
 
271
		// si on modere les mails et s'il y a trop de destinataires
170 aurelien 272
		if($this->moderer_mail && count($destinataires_mail) >= $this->seuil_moderation) {
214 aurelien 273
 
272 aurelien 274
			$stockage_mail = $this->stockerMailPourModeration($expediteur, $destinataires_mail, $sujet, $message);
56 aurelien 275
			$donnees['moderation'] = true;
214 aurelien 276
 
272 aurelien 277
			if(!$stockage_mail) {
278
				$donnees['erreurs'] = true;
279
			}
280
 
46 aurelien 281
		} else {
233 aurelien 282
 
46 aurelien 283
			// sinon, envoi direct
272 aurelien 284
			$envoi_mail_direct = $this->envoyerMail($expediteur, $destinataires_mail, $sujet, $message);
214 aurelien 285
 
286
			if($this->moderation_copie) {
287
				$this->envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires_mail, $message);
288
			}
289
 
272 aurelien 290
			if(!$envoi_mail_direct) {
291
				$donnees['erreurs'] = true;
292
			}
293
 
56 aurelien 294
			$donnees['moderation'] = false;
46 aurelien 295
		}
296
 
56 aurelien 297
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_envoi_confirmation',$donnees);
298
 
299
		return $resultat;
300
 
46 aurelien 301
	}
214 aurelien 302
 
303
	public function obtenirMailParTableauId($id_annuaire, $destinataires) {
304
		// on remplace les identifiants par leurs destinataires
305
		$this->chargerModele('AnnuaireModele');
306
		$destinataires_mails = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
307
 
308
		return $destinataires_mails;
309
	}
310
 
311
	private function envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires, $message) {
312
 
313
		$donnees['expediteur_message'] = $expediteur;
314
		$donnees['sujet_message'] = $sujet;
315
		$donnees['contenu_message'] = $message;
316
 
317
		if(is_array($destinataires)) {
318
			$destinataires = implode(', ', $destinataires);
319
		}
320
 
321
		$donnees['destinataires_message'] = $destinataires;
322
 
323
		$contenu_mail_copie = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_copie',$donnees);
324
 
325
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message a été envoyé à travers l\'annuaire', $contenu_mail_copie);
326
	}
46 aurelien 327
 
214 aurelien 328
 
46 aurelien 329
	/**
330
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
331
	 * @param string $code_confirmation le code associé au données en attente
332
	 */
333
	public function envoyerMailModere($code_confirmation) {
334
 
335
		// chargement des données temporaire
336
		$message_modele = $this->getModele('DonneeTemporaireModele');
337
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
338
 
339
		if($mail_a_moderer) {
117 aurelien 340
			// envoi
96 aurelien 341
			$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
46 aurelien 342
								$mail_a_moderer['destinataires'],
343
								$mail_a_moderer['sujet'],
344
								$mail_a_moderer['message']);
96 aurelien 345
 
346
			if($resultat_envoi) {
347
				$donnees = array('envoi_reussi' => true);
348
			} else {
349
				$donnees = array('envoi_echoue' => true);
350
			}
351
 
46 aurelien 352
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
214 aurelien 353
 
96 aurelien 354
		} else {
355
			$donnees = array('message_inexistant' => true);
46 aurelien 356
		}
357
 
96 aurelien 358
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
359
		return $resultat;
46 aurelien 360
	}
361
 
362
	/**
363
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
364
	 * @param string $code_confirmation le code associé au données en attente
365
	 */
366
	public function supprimerMailModere($code_confirmation) {
367
 
368
		$message_modele = $this->getModele('DonneeTemporaireModele');
369
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
116 aurelien 370
 
371
		$donnees = array('message_supprime' => true);
46 aurelien 372
 
116 aurelien 373
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
374
 
375
		return $resultat;
46 aurelien 376
	}
170 aurelien 377
 
46 aurelien 378
	/**
379
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
380
	 * @param string $expediteur l'expéditeur du mail
381
	 * @param array $destinataires les destinataires du mail
382
	 * @param string $sujet sujet du message
383
	 * @param string $message corps du message
384
	 */
385
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
386
 
387
		$mail = array('expediteur' => $expediteur,
388
				 'destinataires' => $destinataires,
389
					'sujet' => $sujet,
390
					'message' => $message);
391
 
392
		$message_modele = $this->getModele('DonneeTemporaireModele');
86 aurelien 393
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail, true);
46 aurelien 394
 
395
		if($id_stockage) {
177 aurelien 396
			$this->envoyerMailModeration($id_stockage, $destinataires, $sujet , $message);
46 aurelien 397
			return true;
398
		}
399
 
400
		return false;
401
 
402
	}
403
 
404
	/**
405
	 * Envoie un mail au modérateur contenant les lien pour, au choix, refuser ou bien accepter l'envoi du mail
406
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
407
	 * @param string $sujet_message_a_moderer sujet du message
408
	 * @param string $message_a_moderer corps du message
409
	 */
177 aurelien 410
	private function envoyerMailModeration($id_mail_a_moderer, $destinataires, $sujet_message_a_moderer, $message_a_moderer) {
46 aurelien 411
 
214 aurelien 412
		$url_cette_page = $this->getUrlCettePage();
70 aurelien 413
		$url_base = $url_cette_page;
46 aurelien 414
 
70 aurelien 415
		$base_url = new URL($url_base);
416
 
417
		$base_url->setVariablesRequete(array());
418
 
46 aurelien 419
		$donnees = array();
420
 
421
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
422
 
423
		$lien_accepter_mail = clone($base_url);
424
		$lien_refuser_mail = clone($base_url);
425
 
426
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
427
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
428
 
429
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
430
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
431
		$donnees['sujet_message'] = $sujet_message_a_moderer;
432
		$donnees['contenu_message'] = $message_a_moderer;
233 aurelien 433
 
177 aurelien 434
		if(is_array($destinataires)) {
435
			$destinataires = implode(', ', $destinataires);;
436
		}
437
		$donnees['destinataires_message'] = $destinataires;
46 aurelien 438
 
439
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
440
 
441
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
442
 
443
	}
116 aurelien 444
 
272 aurelien 445
	private function envoyerMailAvecPieceJointe($chemin, $type_mime_fichier) {
446
 
447
		/* Pièce jointe, on va dire que notre fichier s'appelle bidule.doc et qu'il se situe dans le répertoire courant */
448
		$fichier=file_get_contents($chemin);
449
		/* On utilise aussi chunk_split() qui organisera comme il faut l'encodage fait en base 64 pour se conformer aux standards */
450
		$fichier=chunk_split( base64_encode($fichier) );
451
 
452
		//Écriture de la pièce jointe
453
		$body = $body . "--" .$boundary. "\n
454
		Content-Type: application/msword; name=\"nom_fichier\"\r\n
455
		Content-Transfer-Encoding: base64\r\n
456
		Content-Disposition: attachment; filename=\"nom_fichier\"\r\n\n
457
		$fichier";
458
 
459
		//Fermeture de la frontière
460
		$body = $body . "--" . $boundary ."--";
461
 
462
	}
463
 
116 aurelien 464
	private function filtrerChaine($message) {
117 aurelien 465
 
116 aurelien 466
		return strip_tags($message);
467
	}
233 aurelien 468
 
469
	private function encoderChainePourEnvoiMail($chaine) {
470
		return stripslashes($chaine);
471
	}
46 aurelien 472
}