Subversion Repositories Applications.annuaire

Rev

Rev 177 | Rev 233 | 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
 
108
		return mail($adresse_mail,'Inscription à l\'annuaire',$contenu_mail, $entetes);
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
 
139
		 return mail($mail,'Demande de réinitialisation de mot de passe',$contenu_mail, $entetes);
140
 
141
	}
142
 
143
 
144
/** -------------------Fonctions pour la messagerie entre utilisateurs -----------------------*/
145
 
146
 
46 aurelien 147
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
148
	 * à l'adresse donnée en paramètre
149
	 * @param string $expediteur l'expediteur du message
150
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
151
	 * @param string $sujet sujet du mail
152
	 * @return boolean true ou false suivant le succès ou non de l'envoi
153
	 */
120 aurelien 154
	public function envoyerMail($expediteur, $destinataires, $sujet, $message) {
46 aurelien 155
 
156
		if(is_array($destinataires)) {
157
			$destinataires = implode(',',$destinataires);
158
		}
159
 
160
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
161
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
162
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
170 aurelien 163
	     $entetes .= 'Bcc:'.$destinataires . "\r\n";
46 aurelien 164
	     // En-têtes additionnels
165
	     $entetes .= 'From: '.$expediteur."\r\n";
166
 
167
	     $contenu_mail = $message;
168
 
170 aurelien 169
		return mail('', $sujet, $contenu_mail, $entetes);
46 aurelien 170
	}
171
 
172
	/**
173
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
174
	 * ou bien s'il doit être stocké et soumis à modération
175
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
176
	 * @param string $expediteur l'expéditeur du mail
177
	 * @param array $destinataires les destinataires du mail
178
	 * @param string $sujet sujet du message
179
	 * @param string $message corps du message
180
	 */
181
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
116 aurelien 182
 
170 aurelien 183
		$destinataires_mail = $this->obtenirMailParTableauId($id_annuaire, $destinataires);
116 aurelien 184
 
185
		$donnees['contenu_message'] = $this->filtrerChaine($message);
186
		$sujet = $this->filtrerChaine($sujet);
187
		$message = $this->getVue(Config::get('dossier_squelettes_mails').'mail_messagerie',$donnees);
46 aurelien 188
 
189
		// si on modere les mails et s'il y a trop de destinataires
170 aurelien 190
		if($this->moderer_mail && count($destinataires_mail) >= $this->seuil_moderation) {
214 aurelien 191
 
170 aurelien 192
			$this->stockerMailPourModeration($expediteur, $destinataires_mail, $sujet, $message);
56 aurelien 193
			$donnees['moderation'] = true;
214 aurelien 194
 
46 aurelien 195
		} else {
214 aurelien 196
 
46 aurelien 197
			// sinon, envoi direct
170 aurelien 198
			$this->envoyerMail($expediteur, $destinataires_mail, $sujet, $message);
214 aurelien 199
 
200
			if($this->moderation_copie) {
201
				$this->envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires_mail, $message);
202
			}
203
 
56 aurelien 204
			$donnees['moderation'] = false;
46 aurelien 205
		}
206
 
56 aurelien 207
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_envoi_confirmation',$donnees);
208
 
209
		return $resultat;
210
 
46 aurelien 211
	}
214 aurelien 212
 
213
	public function obtenirMailParTableauId($id_annuaire, $destinataires) {
214
		// on remplace les identifiants par leurs destinataires
215
		$this->chargerModele('AnnuaireModele');
216
		$destinataires_mails = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
217
 
218
		return $destinataires_mails;
219
	}
220
 
221
	private function envoyerCopieMessageAuModerateur($id_annuaire, $expediteur, $sujet, $destinataires, $message) {
222
 
223
		$donnees['expediteur_message'] = $expediteur;
224
		$donnees['sujet_message'] = $sujet;
225
		$donnees['contenu_message'] = $message;
226
 
227
		if(is_array($destinataires)) {
228
			$destinataires = implode(', ', $destinataires);
229
		}
230
 
231
		$donnees['destinataires_message'] = $destinataires;
232
 
233
		$contenu_mail_copie = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_copie',$donnees);
234
 
235
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message a été envoyé à travers l\'annuaire', $contenu_mail_copie);
236
	}
46 aurelien 237
 
214 aurelien 238
 
46 aurelien 239
	/**
240
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
241
	 * @param string $code_confirmation le code associé au données en attente
242
	 */
243
	public function envoyerMailModere($code_confirmation) {
244
 
245
		// chargement des données temporaire
246
		$message_modele = $this->getModele('DonneeTemporaireModele');
247
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
248
 
249
		if($mail_a_moderer) {
117 aurelien 250
			// envoi
96 aurelien 251
			$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
46 aurelien 252
								$mail_a_moderer['destinataires'],
253
								$mail_a_moderer['sujet'],
254
								$mail_a_moderer['message']);
96 aurelien 255
 
256
			if($resultat_envoi) {
257
				$donnees = array('envoi_reussi' => true);
258
			} else {
259
				$donnees = array('envoi_echoue' => true);
260
			}
261
 
46 aurelien 262
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
214 aurelien 263
 
96 aurelien 264
		} else {
265
			$donnees = array('message_inexistant' => true);
46 aurelien 266
		}
267
 
96 aurelien 268
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
269
		return $resultat;
46 aurelien 270
	}
271
 
272
	/**
273
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
274
	 * @param string $code_confirmation le code associé au données en attente
275
	 */
276
	public function supprimerMailModere($code_confirmation) {
277
 
278
		$message_modele = $this->getModele('DonneeTemporaireModele');
279
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
116 aurelien 280
 
281
		$donnees = array('message_supprime' => true);
46 aurelien 282
 
116 aurelien 283
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
284
 
285
		return $resultat;
46 aurelien 286
	}
170 aurelien 287
 
46 aurelien 288
	/**
289
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
290
	 * @param string $expediteur l'expéditeur du mail
291
	 * @param array $destinataires les destinataires du mail
292
	 * @param string $sujet sujet du message
293
	 * @param string $message corps du message
294
	 */
295
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
296
 
297
		$mail = array('expediteur' => $expediteur,
298
				 'destinataires' => $destinataires,
299
					'sujet' => $sujet,
300
					'message' => $message);
301
 
302
		$message_modele = $this->getModele('DonneeTemporaireModele');
86 aurelien 303
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail, true);
46 aurelien 304
 
305
		if($id_stockage) {
177 aurelien 306
			$this->envoyerMailModeration($id_stockage, $destinataires, $sujet , $message);
46 aurelien 307
			return true;
308
		}
309
 
310
		return false;
311
 
312
	}
313
 
314
	/**
315
	 * Envoie un mail au modérateur contenant les lien pour, au choix, refuser ou bien accepter l'envoi du mail
316
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
317
	 * @param string $sujet_message_a_moderer sujet du message
318
	 * @param string $message_a_moderer corps du message
319
	 */
177 aurelien 320
	private function envoyerMailModeration($id_mail_a_moderer, $destinataires, $sujet_message_a_moderer, $message_a_moderer) {
46 aurelien 321
 
214 aurelien 322
		$url_cette_page = $this->getUrlCettePage();
70 aurelien 323
		$url_base = $url_cette_page;
46 aurelien 324
 
70 aurelien 325
		$base_url = new URL($url_base);
326
 
327
		$base_url->setVariablesRequete(array());
328
 
46 aurelien 329
		$donnees = array();
330
 
331
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
332
 
333
		$lien_accepter_mail = clone($base_url);
334
		$lien_refuser_mail = clone($base_url);
335
 
336
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
337
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
338
 
339
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
340
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
341
		$donnees['sujet_message'] = $sujet_message_a_moderer;
342
		$donnees['contenu_message'] = $message_a_moderer;
177 aurelien 343
		if(is_array($destinataires)) {
344
			$destinataires = implode(', ', $destinataires);;
345
		}
346
		$donnees['destinataires_message'] = $destinataires;
46 aurelien 347
 
348
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
349
 
350
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
351
 
352
	}
116 aurelien 353
 
354
	private function filtrerChaine($message) {
117 aurelien 355
 
116 aurelien 356
		return strip_tags($message);
357
	}
46 aurelien 358
 
359
}