Subversion Repositories Applications.annuaire

Rev

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