Subversion Repositories Applications.annuaire

Rev

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

Rev Author Line No. Line
423 jpm 1
<?php
46 aurelien 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;
423 jpm 20
 
214 aurelien 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 = '';
423 jpm 41
 
405 aurelien 42
	/**
43
	 * Tableau recapitulatif de la derniere recherche effectuée pour envoyer un message
44
	 */
45
	private $criteres_recherche_effectuee = null;
46 aurelien 46
 
47
	 /**
48
	  *
49
	  * Constructeur sans paramètres
50
	 */
51
	public function MessageControleur() {
52
		$this->__construct();
53
 
54
		// doit on modérer ?
55
		if(Config::get('moderer_mail') != null) {
56
			$this->moderer_mail = Config::get('moderer_mail');
57
		}
423 jpm 58
 
214 aurelien 59
		// doit on envoyer des copies des messages ?
60
		if(Config::get('moderation_copie') != null) {
61
			$this->moderation_copie = Config::get('moderation_copie');
62
		}
46 aurelien 63
 
64
		// mail du modérateur pour l'envoi de messages au dessus d'un certain seuil
65
		if($this->moderer_mail && Config::get('mail_moderateur') != null) {
66
			$this->mail_moderateur = Config::get('mail_moderateur');
67
		}
68
 
69
		// seuil de modération
70
		if($this->moderer_mail && Config::get('seuil_moderation_messages') != null) {
71
			$this->seuil_moderation = Config::get('seuil_moderation_messages');
72
		}
73
 
74
		// adresse d'expéditeur
75
		if(Config::get('adresse_mail_annuaire') != null) {
76
			$this->adresse_mail_annuaire = Config::get('adresse_mail_annuaire');
77
		}
78
	}
79
 
423 jpm 80
	/** -------------------Fonctions pour l'inscription et l'oubli de mot de passe  -----------------------*/
81
 
120 aurelien 82
	/**
83
	 * En cas de tentative d'inscription, envoie un mail contenant un lien de confirmation à l'utilisateur
84
	 * @param string $adresse_mail adresse mail
85
	 * @param string $nom nom
86
	 * @param string $prenom prénom
87
	 * @param string $code_confirmation_inscription code de confirmation à inclure dans le mail
88
	 *
89
	 * @return boolean le succès ou l'échec de l'envoi du mail
90
	 */
91
	public function envoyerMailConfirmationInscription($adresse_mail, $nom, $prenom, $code_confirmation_inscription) {
423 jpm 92
		$lien_confirmation_inscription = AppControleur::getUrlConfirmationInscription($code_confirmation_inscription);
120 aurelien 93
 
349 aurelien 94
		$donnees = array('nom' => $nom, 'prenom' => $prenom, 'lien_confirmation_inscription' => $lien_confirmation_inscription);
120 aurelien 95
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_confirmation_inscription',$donnees);
423 jpm 96
 
170 aurelien 97
		// en attendant de gérer mieux l'envoi en mode texte
98
		// remplacement du &amp dans les urls
99
		$contenu_mail = str_replace('&amp;', '&', $contenu_mail);
423 jpm 100
 
101
		return $this->envoyerMail(Config::get('adresse_mail_annuaire'),$adresse_mail,'Inscription à l\'annuaire',$contenu_mail);
120 aurelien 102
	}
103
 
104
	 /** En cas d'oubli de mot de passe, régénère le mot de passe et envoie un mail à l'utilisateur
105
	 * @param int $id_annuaire l'identifiant d'annuaire
106
	 * @param string $adresse_mail adresse mail
107
	 * @return boolean le succès ou l'échec de l'envoi du mail
108
	 */
109
	public function envoyerMailOubliMdp($id_annuaire,$mail, $nouveau_mdp) {
423 jpm 110
		$base_url = clone(Registre::getInstance()->get('base_url_application'));
120 aurelien 111
 
112
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
113
		$url_base = $url_cette_page;
114
		$base_url = new URL($url_base);
115
		$base_url->setVariablesRequete(array());
116
		$base_url->setVariableRequete('m','annuaire_fiche_utilisateur_consultation');
117
		$base_url->setVariableRequete('id_annuaire',$id_annuaire);
118
 
119
		$donnees['nouveau_mdp'] = $nouveau_mdp;
120
		$donnees['lien_profil'] = $base_url;
121
 
122
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_oubli_mdp',$donnees);
123
 
350 aurelien 124
		return $this->envoyerMail(Config::get('adresse_mail_annuaire'),$mail,'Demande de réinitialisation de mot de passe',$contenu_mail);
120 aurelien 125
	}
126
 
423 jpm 127
 
128
	/** -------------------Fonctions pour la messagerie entre utilisateurs -----------------------*/
129
 
233 aurelien 130
	/** Effectue une recherche dans la base de données et envoie un mail à tous les inscrits correspondants,
131
	 * à l'adresse donnée en paramètre
132
	 * @param string $expediteur l'expediteur du message
133
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
134
	 * @param string $sujet sujet du mail
135
	 * @return boolean true ou false suivant le succès ou non de l'envoi
136
	 */
137
	public function envoyerMailParRequete($id_annuaire, $expediteur, $criteres, $sujet, $message) {
346 jpm 138
		if (isset($criteres['exclusive'])) {
233 aurelien 139
			$exclusive = $criteres['exclusive'];
140
		} else {
141
			$exclusive = true;
142
		}
423 jpm 143
 
233 aurelien 144
		unset($criteres['page']);
145
		unset($criteres['taille_page']);
423 jpm 146
 
233 aurelien 147
		$collecteur = new VerificationControleur();
148
		$tableau_valeur_collectees = $collecteur->collecterValeursRechercheMoteur($criteres, $this->obtenirChampsMappageAnnuaire($id_annuaire));
405 aurelien 149
		$this->criteres_recherche_effectuee = $collecteur->convertirTableauRechercheVersChaine($id_annuaire, $criteres);
423 jpm 150
 
151
		$valeurs_recherchees = $tableau_valeur_collectees['valeurs_recherchees'];
152
		$valeurs_mappees = $tableau_valeur_collectees['valeurs_mappees'];
153
		$valeurs_get = $tableau_valeur_collectees['valeurs_get'];
154
 
155
		if (isset($criteres['tous']) && $criteres['tous'] == 1) {
272 aurelien 156
			$this->chargerModele('AnnuaireModele');
157
			$resultat_annuaire_mappe = $this->AnnuaireModele->chargerAnnuaireListeInscrits($id_annuaire,0,0);
158
		} else {
423 jpm 159
 
272 aurelien 160
			// on recherche dans les métadonnées
161
			$this->chargerModele('MetadonneeModele');
162
			// le résultat est un ensemble d'identifiants
163
			$resultat_metadonnees = $this->MetadonneeModele->rechercherDansValeurMetadonnees($id_annuaire,$valeurs_recherchees, $exclusive);
423 jpm 164
 
272 aurelien 165
			// on recherche les infos dans la table annuaire mappée
166
			// en incluant ou excluant les id déjà trouvées dans les metadonnées
167
			// suivant le critères d'exclusivité ou non
168
			$this->chargerModele('AnnuaireModele');
169
			$resultat_annuaire_mappe = $this->AnnuaireModele->rechercherInscritDansAnnuaireMappe($id_annuaire,$valeurs_mappees, $resultat_metadonnees, $exclusive, 0, 0);
423 jpm 170
 
272 aurelien 171
		}
423 jpm 172
 
233 aurelien 173
		$resultat_recherche = $resultat_annuaire_mappe['resultat'];
174
		$nb_resultats = $resultat_annuaire_mappe['total'];
175
		$destinataires = $this->aplatirTableauSansPreserverCles($resultat_recherche);
423 jpm 176
 
233 aurelien 177
		return $this->envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet, $message);
178
	}
423 jpm 179
 
346 jpm 180
	/** Envoie un mail au format texte avec l'adresse de l'utilisateur donné en paramètre,
181
	 * à l'adresse donnée en paramètre
182
	 * @param string $expediteur l'expediteur du message
183
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
184
	 * @param string $sujet sujet du mail
185
	 * @return boolean true ou false suivant le succès ou non de l'envoi
186
	 */
187
	public function envoyerMailText($expediteur, $destinataires, $sujet, $message) {
188
		if (!is_array($destinataires)) {
189
			$destinataires = array($destinataires);
190
		}
423 jpm 191
 
349 aurelien 192
		// Définition d'un mail en texte simple
423 jpm 193
		$entetes =
346 jpm 194
			"X-Sender: <http://www.tela-botanica.org>\n".
195
			"X-Mailer: PHP\n".
196
			"X-auth-smtp-user: annuaire@tela-botanica.org \n".
197
			"X-abuse-contact: annuaire@tela-botanica.org \n".
198
			"Date: ".date("D, j M Y G:i:s O")."\n".
199
			'From: '.$expediteur."\n".
200
			"Content-Type: text/plain; charset=\"".Config::get('appli_encodage')."\";\n".
201
			"Content-Transfer-Encoding: 7bit;\n\n";
423 jpm 202
 
346 jpm 203
		$sujet = mb_encode_mimeheader($this->encoderChainePourEnvoiMail($sujet));
204
 
205
		$message_antislashe = $this->encoderChainePourEnvoiMail($message);
206
		$contenu = $this->filtrerChaine($message_antislashe);
423 jpm 207
 
346 jpm 208
		foreach ($destinataires as $destinataire) {
405 aurelien 209
			if (!mail('aurelien@tela-botanica.org', $sujet, $contenu, $entetes)) {
346 jpm 210
				return false;
423 jpm 211
			}
346 jpm 212
		}
213
		return true;
214
	}
423 jpm 215
 
46 aurelien 216
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
217
	 * à l'adresse donnée en paramètre
218
	 * @param string $expediteur l'expediteur du message
219
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
220
	 * @param string $sujet sujet du mail
221
	 * @return boolean true ou false suivant le succès ou non de l'envoi
222
	 */
120 aurelien 223
	public function envoyerMail($expediteur, $destinataires, $sujet, $message) {
346 jpm 224
		if (!is_array($destinataires)) {
233 aurelien 225
			$destinataires = array($destinataires);
46 aurelien 226
		}
423 jpm 227
 
272 aurelien 228
		$message_antislashe = $this->encoderChainePourEnvoiMail($message);
229
		$message_texte = $this->filtrerChaine($message_antislashe);
230
		$message_html = $message_antislashe;
423 jpm 231
 
272 aurelien 232
		$limite = "_----------=_parties_".md5(uniqid (rand()));
423 jpm 233
 
346 jpm 234
		$entetes = '';
423 jpm 235
		// Définition d'un mail en texte simple et html
346 jpm 236
		$entetes .= "X-Sender: <http://www.tela-botanica.org>\n";
237
		$entetes .= "X-Mailer: PHP\n";
238
		$entetes .= "X-auth-smtp-user: annuaire@tela-botanica.org \n";
239
		$entetes .= "X-abuse-contact: annuaire@tela-botanica.org \n";
240
		$entetes .= "Date: ".date("D, j M Y G:i:s O")."\n";
241
		$entetes .= 'From: '.$expediteur."\n";
242
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
243
		$entetes .= "Content-Type: multipart/alternative; boundary=\"".$limite."\";\n\n";
423 jpm 244
 
346 jpm 245
		$contenu = "";
423 jpm 246
 
349 aurelien 247
		// message en texte simple
346 jpm 248
		$contenu .= "--".$limite."\n";
249
		$contenu .= "Content-Type: text/plain; charset=\"".Config::get('appli_encodage')."\";\n";
250
		$contenu .= "Content-Transfer-Encoding: 7bit;\n\n";
251
		$contenu .= $message_texte."\n";
423 jpm 252
 
346 jpm 253
		// le message en html est préféré s'il est lisible
254
		$contenu .= "--".$limite."\n";
255
		$contenu .= "Content-Type: text/html;";
256
		$contenu .= "charset=\"".Config::get('appli_encodage')."\";\n";
257
		$contenu .= "Content-Transfer-Encoding: 7bit;\n\n";
423 jpm 258
		$contenu .= $message_html."\n";
259
 
346 jpm 260
		$contenu .= "--".$limite."--\n";
423 jpm 261
 
349 aurelien 262
		$sujet = $this->encoderChainePourEnvoiMail($sujet);
423 jpm 263
		$ok = true;
264
		foreach ($destinataires as $destinataire) {
265
			$ok = mail($destinataire, mb_encode_mimeheader($sujet), $contenu, $entetes);
266
			if (!$ok) {
267
				break;
268
			}
233 aurelien 269
		}
423 jpm 270
		return $ok;
46 aurelien 271
	}
423 jpm 272
 
274 aurelien 273
	public function envoyerMailAvecPieceJointe($expediteur, $destinataires, $sujet, $message, $piece_jointe = null, $nom_fichier, $type_mime = 'text/plain') {
346 jpm 274
		if (!is_array($destinataires)) {
274 aurelien 275
			$destinataires = array($destinataires);
276
		}
423 jpm 277
 
274 aurelien 278
		$message_antislashe = $this->encoderChainePourEnvoiMail($message);
279
		$message_texte = $this->filtrerChaine($message);
423 jpm 280
		$message_html = nl2br($message_antislashe);
281
 
274 aurelien 282
		$limite = "_----------=_parties_".md5(uniqid (rand()));
283
		$limite_partie_message = "_----------=_parties_".md5(uniqid (rand() + 1));
284
 
346 jpm 285
		$entetes = '';
423 jpm 286
 
346 jpm 287
		// Définition d'un mail avec différents type de contenu
288
		$entetes .= "X-Sender: <http://www.tela-botanica.org>\n";
289
		$entetes .= "X-Mailer: PHP\n";
290
		$entetes .= "X-auth-smtp-user: annuaire@tela-botanica.org \n";
291
		$entetes .= "X-abuse-contact: annuaire@tela-botanica.org \n";
292
		$entetes .= "Date: ".date("D, j M Y G:i:s O")."\n";
293
		$entetes .= 'From: '.$expediteur."\n";
294
		$entetes .= 'MIME-Version: 1.0' . "\n";
423 jpm 295
 
346 jpm 296
		// Définition d'un type de contenu mixed (mail (texte + html) + piece jointe)
297
		$entetes .= "Content-Type: multipart/mixed; boundary=\"".$limite."\";\n\n";
423 jpm 298
 
346 jpm 299
		$contenu = "";
423 jpm 300
 
346 jpm 301
		// Première sous partie : contenu du mail
302
		$contenu .= "\n--".$limite."\n";
423 jpm 303
 
346 jpm 304
		// Définition d'un type de contenu alternatif pour l'envoi en html et texte
305
		$contenu .= "Content-Type: multipart/alternative; boundary=\"".$limite_partie_message."\";\n";
423 jpm 306
 
346 jpm 307
		// Version texte
308
		$contenu .= "\n--".$limite_partie_message."\n";
309
		$contenu .= "Content-Type: text/plain;";
310
		$contenu .= "charset=\"".Config::get('appli_encodage')."\";\n";
311
		$contenu .= "Content-Transfer-Encoding: 7bit;\n";
312
		$contenu .= "\n";
313
		$contenu .= $message_texte."\n";
423 jpm 314
 
346 jpm 315
		// Version html
316
		$contenu .= "--".$limite_partie_message."\n";
317
		$contenu .= "Content-Type: text/html;";
318
		$contenu .= "charset=\"".Config::get('appli_encodage')."\";\n";
319
		$contenu .= "Content-Transfer-Encoding: 7bit;\n";
320
		$contenu .= "\n";
423 jpm 321
		$contenu .= $message_html."\n";
322
 
346 jpm 323
		$contenu .= "\n--".$limite_partie_message."--\n";
423 jpm 324
 
346 jpm 325
		$contenu .= "--".$limite."\n";
423 jpm 326
 
346 jpm 327
		// Seconde sous partie : pièce jointe
328
		if ($piece_jointe != null) {
329
			$attachment = chunk_split(base64_encode($piece_jointe));
423 jpm 330
 
346 jpm 331
			$contenu .= "Content-Type: ".$type_mime."; name=\"".$nom_fichier."\"\n";
332
			$contenu .= "Content-Transfer-Encoding: base64\n";
333
			$contenu .= "Content-Disposition: attachment; filename=\"".$nom_fichier."\"\n";
334
			$contenu .= "X-Attachment-Id: ".md5($attachment)."\n\n";
423 jpm 335
 
346 jpm 336
			$contenu .= $attachment;
337
			$contenu .= "\n--".$limite."--\n";
338
		}
423 jpm 339
 
346 jpm 340
		foreach ($destinataires as $destinataire) {
405 aurelien 341
			if (!mail('aurelien@tela-botanica.org', mb_encode_mimeheader($sujet), $contenu, $entetes)) {
274 aurelien 342
				return false;
423 jpm 343
			}
274 aurelien 344
		}
345
		return true;
346
	}
347
 
46 aurelien 348
	/**
349
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
350
	 * ou bien s'il doit être stocké et soumis à modération
351
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
352
	 * @param string $expediteur l'expéditeur du mail
353
	 * @param array $destinataires les destinataires du mail
354
	 * @param string $sujet sujet du message
355
	 * @param string $message corps du message
405 aurelien 356
	 * @param string $donnees_sup tableau d'informations supplémentaires à joindre au message
46 aurelien 357
	 */
358
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
272 aurelien 359
		$donnees['erreurs'] = false;
423 jpm 360
 
361
		if (!Registre::getInstance()->get('est_admin')) {
376 aurelien 362
			$donnees['contenu_message'] = $this->filtrerChaine($message);
363
		} else {
364
			$donnees['contenu_message'] = nl2br($message);
365
		}
116 aurelien 366
		$sujet = $this->filtrerChaine($sujet);
423 jpm 367
 
355 aurelien 368
		if(count($destinataires) == 0) {
369
			$donnees['erreurs'] = true;
370
			$donnees['pas_de_destinataire'] = true;
371
		}
423 jpm 372
 
373
		if (trim($sujet) == '') {
355 aurelien 374
			$donnees['erreurs'] = true;
375
			$donnees['pas_de_sujet'] = true;
376 aurelien 376
		} else {
377
			$donnees['sujet_message'] = $sujet;
355 aurelien 378
		}
423 jpm 379
 
380
		if (trim($message) == '') {
355 aurelien 381
			$donnees['erreurs'] = true;
382
			$donnees['pas_de_message'] = true;
383
		}
423 jpm 384
 
385
		if (!$donnees['erreurs'])  {
376 aurelien 386
			$template_mail = 'mail_messagerie';
423 jpm 387
 
376 aurelien 388
			if(Registre::getInstance()->get('est_admin')) {
423 jpm 389
				$template_mail = 'mail_messagerie_admin';
376 aurelien 390
			}
423 jpm 391
 
355 aurelien 392
			$destinataires_mail = $this->obtenirMailParTableauId($id_annuaire, $destinataires);
376 aurelien 393
			$message = $this->getVue(Config::get('dossier_squelettes_mails').$template_mail,$donnees);
423 jpm 394
 
355 aurelien 395
			// si on modere les mails et s'il y a trop de destinataires
405 aurelien 396
			//if($this->moderer_mail && count($destinataires_mail) >= $this->seuil_moderation) {
423 jpm 397
 
355 aurelien 398
				$stockage_mail = $this->stockerMailPourModeration($expediteur, $destinataires_mail, $sujet, $message);
399
				$donnees['moderation'] = true;
423 jpm 400
 
401
				if (!$stockage_mail) {
355 aurelien 402
					$donnees['erreurs'] = true;
403
				}
423 jpm 404
 
405 aurelien 405
			/*} else {
423 jpm 406
 
355 aurelien 407
				// sinon, envoi direct
408
				$envoi_mail_direct = $this->envoyerMail($expediteur, $destinataires_mail, $sujet, $message);
423 jpm 409
 
355 aurelien 410
				if($this->moderation_copie) {
411
					$this->envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires_mail, $message);
412
				}
423 jpm 413
 
355 aurelien 414
				if(!$envoi_mail_direct) {
415
					$donnees['erreurs'] = true;
416
				}
423 jpm 417
 
355 aurelien 418
				$donnees['moderation'] = false;
405 aurelien 419
			}*/
46 aurelien 420
		}
421
 
56 aurelien 422
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_envoi_confirmation',$donnees);
423
 
424
		return $resultat;
46 aurelien 425
	}
423 jpm 426
 
214 aurelien 427
	public function obtenirMailParTableauId($id_annuaire, $destinataires) {
428
		// on remplace les identifiants par leurs destinataires
429
		$this->chargerModele('AnnuaireModele');
430
		$destinataires_mails = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
423 jpm 431
 
214 aurelien 432
		return $destinataires_mails;
433
	}
423 jpm 434
 
214 aurelien 435
	private function envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires, $message) {
436
		$donnees['expediteur_message'] = $expediteur;
437
		$donnees['sujet_message'] = $sujet;
438
		$donnees['contenu_message'] = $message;
423 jpm 439
 
440
		if (is_array($destinataires)) {
441
			$destinataires = implode(', ', $destinataires);
214 aurelien 442
		}
423 jpm 443
 
214 aurelien 444
		$donnees['destinataires_message'] = $destinataires;
423 jpm 445
		if ($this->criteres_recherche_effectuee != null) {
405 aurelien 446
			$donnees['criteres'] = $this->criteres_recherche_effectuee;
447
		}
423 jpm 448
 
214 aurelien 449
		$contenu_mail_copie = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_copie',$donnees);
423 jpm 450
 
451
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message a été envoyé à travers l\'annuaire', $contenu_mail_copie);
214 aurelien 452
	}
423 jpm 453
 
46 aurelien 454
	/**
455
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
456
	 * @param string $code_confirmation le code associé au données en attente
457
	 */
458
	public function envoyerMailModere($code_confirmation) {
459
		// chargement des données temporaire
460
		$message_modele = $this->getModele('DonneeTemporaireModele');
461
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
462
 
423 jpm 463
		if ($mail_a_moderer) {
464
			// envoi
96 aurelien 465
			$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
423 jpm 466
				$mail_a_moderer['destinataires'],
467
				$mail_a_moderer['sujet'],
468
				$mail_a_moderer['message']);
469
 
470
			if ($resultat_envoi) {
96 aurelien 471
				$donnees = array('envoi_reussi' => true);
472
			} else {
473
				$donnees = array('envoi_echoue' => true);
474
			}
423 jpm 475
 
46 aurelien 476
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
96 aurelien 477
		} else {
478
			$donnees = array('message_inexistant' => true);
46 aurelien 479
		}
480
 
96 aurelien 481
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
482
		return $resultat;
46 aurelien 483
	}
484
 
485
	/**
486
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
487
	 * @param string $code_confirmation le code associé au données en attente
488
	 */
489
	public function supprimerMailModere($code_confirmation) {
490
		$message_modele = $this->getModele('DonneeTemporaireModele');
491
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
423 jpm 492
 
116 aurelien 493
		$donnees = array('message_supprime' => true);
46 aurelien 494
 
116 aurelien 495
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
496
 
497
		return $resultat;
46 aurelien 498
	}
423 jpm 499
 
46 aurelien 500
	/**
501
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
502
	 * @param string $expediteur l'expéditeur du mail
503
	 * @param array $destinataires les destinataires du mail
504
	 * @param string $sujet sujet du message
505
	 * @param string $message corps du message
506
	 */
507
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
508
		$mail = array('expediteur' => $expediteur,
423 jpm 509
			'destinataires' => $destinataires,
510
			'sujet' => $sujet,
511
			'message' => $message);
46 aurelien 512
 
513
		$message_modele = $this->getModele('DonneeTemporaireModele');
86 aurelien 514
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail, true);
46 aurelien 515
 
423 jpm 516
		if ($id_stockage) {
324 aurelien 517
			$this->envoyerMailModeration($id_stockage, $expediteur ,$destinataires, $sujet , $message);
46 aurelien 518
			return true;
519
		}
520
		return false;
521
	}
522
 
523
	/**
405 aurelien 524
	 * Envoie un mail au modérateur contenant les liens pour, au choix, refuser ou bien accepter l'envoi du mail
46 aurelien 525
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
526
	 * @param string $sujet_message_a_moderer sujet du message
527
	 * @param string $message_a_moderer corps du message
528
	 */
324 aurelien 529
	private function envoyerMailModeration($id_mail_a_moderer, $expediteur, $destinataires, $sujet_message_a_moderer, $message_a_moderer) {
214 aurelien 530
		$url_cette_page = $this->getUrlCettePage();
70 aurelien 531
		$url_base = $url_cette_page;
46 aurelien 532
 
70 aurelien 533
		$base_url = new URL($url_base);
534
 
535
		$base_url->setVariablesRequete(array());
536
 
46 aurelien 537
		$donnees = array();
538
 
539
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
540
 
541
		$lien_accepter_mail = clone($base_url);
542
		$lien_refuser_mail = clone($base_url);
543
 
544
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
545
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
546
 
547
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
548
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
324 aurelien 549
		$donnees['expediteur_message'] = $expediteur;
46 aurelien 550
		$donnees['sujet_message'] = $sujet_message_a_moderer;
551
		$donnees['contenu_message'] = $message_a_moderer;
423 jpm 552
 
553
		if (is_array($destinataires)) {
554
			$destinataires = implode(', ', $destinataires);
177 aurelien 555
		}
556
		$donnees['destinataires_message'] = $destinataires;
423 jpm 557
		if ($this->criteres_recherche_effectuee != null) {
405 aurelien 558
			$donnees['criteres'] = $this->criteres_recherche_effectuee;
559
		}
46 aurelien 560
 
561
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
562
 
563
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
564
	}
294 aurelien 565
 
423 jpm 566
 
294 aurelien 567
	public function afficherMailsEnAttenteModeration() {
423 jpm 568
 
294 aurelien 569
	}
423 jpm 570
 
571
	/** Transforme automatiquement le message html en message txt.
572
	 *
573
	 * Réalise un strip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
574
	 */
575
	private function filtrerChaine($messageHtml) {
576
		$html = $this->ajouterHrefDansBalise($messageHtml);
577
		$messageTxt = strip_tags($html);
578
		return $messageTxt;
116 aurelien 579
	}
423 jpm 580
 
581
	/**
582
	 * Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
583
	 * chevrons (<>) dans le contenu de la balise "a".
584
	 */
585
	private function ajouterHrefDansBalise($html) {
586
		$dom = new DOMDocument;
587
		$dom->loadHTML($html);
588
		foreach ($dom->getElementsByTagName('a') as $node) {
589
			if ($node->hasAttribute( 'href' )) {
590
				$href = $node->getAttribute('href');
591
				$node->nodeValue = $node->nodeValue." < $href >";
592
			}
593
		}
594
		$html = $dom->saveHtml();
595
		return $html;
596
	}
597
 
233 aurelien 598
	private function encoderChainePourEnvoiMail($chaine) {
376 aurelien 599
		// TODO: fonction vide, à scinder en deux fonctions une pour les admins et l'autres
600
		// pour les utilisateurs normaux (genre filtrer html ou non)
274 aurelien 601
		return $chaine;
233 aurelien 602
	}
46 aurelien 603
}
274 aurelien 604
?>