Subversion Repositories Applications.annuaire

Rev

Rev 170 | Rev 214 | 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;
20
 
21
	/**
22
	 * Le ou les mails des modérateurs, si ce sont plusieurs mails,
23
	 * ils doivent être séparés par des virgules
24
	 */
25
	private $mail_moderateur = '';
26
 
27
	/**
28
	 * Nombre de destinataires au dessus duquel on modère les mails
29
	 */
30
	private $seuil_moderation = 10;
31
 
32
	/**
33
	 * Adresse mail de l'expéditeur à partir laquelle sont envoyée les mails de modération
34
	 */
35
	private $adresse_mail_annuaire = '';
36
 
37
	 /**
38
	  *
39
	  * Constructeur sans paramètres
40
	 */
41
	public function MessageControleur() {
42
 
43
		$this->__construct();
44
 
45
		// doit on modérer ?
46
		if(Config::get('moderer_mail') != null) {
47
			$this->moderer_mail = Config::get('moderer_mail');
48
		}
49
 
50
		// mail du modérateur pour l'envoi de messages au dessus d'un certain seuil
51
		if($this->moderer_mail && Config::get('mail_moderateur') != null) {
52
			$this->mail_moderateur = Config::get('mail_moderateur');
53
		}
54
 
55
		// seuil de modération
56
		if($this->moderer_mail && Config::get('seuil_moderation_messages') != null) {
57
			$this->seuil_moderation = Config::get('seuil_moderation_messages');
58
		}
59
 
60
		// adresse d'expéditeur
61
		if(Config::get('adresse_mail_annuaire') != null) {
62
			$this->adresse_mail_annuaire = Config::get('adresse_mail_annuaire');
63
		}
64
	}
120 aurelien 65
 
66
/** -------------------Fonctions pour l'inscription et l'oubli de mot de passe  -----------------------*/
46 aurelien 67
 
120 aurelien 68
	/**
69
	 * En cas de tentative d'inscription, envoie un mail contenant un lien de confirmation à l'utilisateur
70
	 * @param string $adresse_mail adresse mail
71
	 * @param string $nom nom
72
	 * @param string $prenom prénom
73
	 * @param string $code_confirmation_inscription code de confirmation à inclure dans le mail
74
	 *
75
	 * @return boolean le succès ou l'échec de l'envoi du mail
76
	 */
77
	public function envoyerMailConfirmationInscription($adresse_mail, $nom, $prenom, $code_confirmation_inscription) {
78
 
79
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
80
		$base_url = new URL($url_cette_page);
81
		$base_url->setVariablesRequete(array());
82
		$base_url->setVariableRequete('m','annuaire_inscription_confirmation');
83
		$base_url->setVariableRequete('id',$code_confirmation_inscription);
84
 
85
		$donnees = array('nom' => $nom, 'prenom' => $prenom, 'lien_confirmation_inscription' => $base_url->getURL());
86
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_confirmation_inscription',$donnees);
170 aurelien 87
 
88
		// en attendant de gérer mieux l'envoi en mode texte
89
		// remplacement du &amp dans les urls
90
		$contenu_mail = str_replace('&amp;', '&', $contenu_mail);
120 aurelien 91
 
92
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
93
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
94
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
95
	     // En-têtes additionnels
96
	     $entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
97
 
98
		return mail($adresse_mail,'Inscription à l\'annuaire',$contenu_mail, $entetes);
99
 
100
	}
101
 
102
	 /** En cas d'oubli de mot de passe, régénère le mot de passe et envoie un mail à l'utilisateur
103
	 * @param int $id_annuaire l'identifiant d'annuaire
104
	 * @param string $adresse_mail adresse mail
105
	 * @return boolean le succès ou l'échec de l'envoi du mail
106
	 */
107
	public function envoyerMailOubliMdp($id_annuaire,$mail, $nouveau_mdp) {
108
 
109
		$base_url = clone(Registre::getInstance()->get('base_url_application'));
110
 
111
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
112
		$url_base = $url_cette_page;
113
		$base_url = new URL($url_base);
114
		$base_url->setVariablesRequete(array());
115
		$base_url->setVariableRequete('m','annuaire_fiche_utilisateur_consultation');
116
		$base_url->setVariableRequete('id_annuaire',$id_annuaire);
117
 
118
		$donnees['nouveau_mdp'] = $nouveau_mdp;
119
		$donnees['lien_profil'] = $base_url;
120
 
121
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_oubli_mdp',$donnees);
122
 
123
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
124
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
125
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
126
	     // En-têtes additionnels
127
	     $entetes .= 'From: '.Config::get('adresse_mail_annuaire')."\r\n";
128
 
129
		 return mail($mail,'Demande de réinitialisation de mot de passe',$contenu_mail, $entetes);
130
 
131
	}
132
 
133
 
134
/** -------------------Fonctions pour la messagerie entre utilisateurs -----------------------*/
135
 
136
 
46 aurelien 137
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
138
	 * à l'adresse donnée en paramètre
139
	 * @param string $expediteur l'expediteur du message
140
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
141
	 * @param string $sujet sujet du mail
142
	 * @return boolean true ou false suivant le succès ou non de l'envoi
143
	 */
120 aurelien 144
	public function envoyerMail($expediteur, $destinataires, $sujet, $message) {
46 aurelien 145
 
146
		if(is_array($destinataires)) {
147
			$destinataires = implode(',',$destinataires);
148
		}
149
 
150
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
151
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
152
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
170 aurelien 153
	     $entetes .= 'Bcc:'.$destinataires . "\r\n";
46 aurelien 154
	     // En-têtes additionnels
155
	     $entetes .= 'From: '.$expediteur."\r\n";
156
 
157
	     $contenu_mail = $message;
158
 
170 aurelien 159
		return mail('', $sujet, $contenu_mail, $entetes);
46 aurelien 160
	}
161
 
162
	/**
163
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
164
	 * ou bien s'il doit être stocké et soumis à modération
165
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
166
	 * @param string $expediteur l'expéditeur du mail
167
	 * @param array $destinataires les destinataires du mail
168
	 * @param string $sujet sujet du message
169
	 * @param string $message corps du message
170
	 */
171
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
116 aurelien 172
 
170 aurelien 173
		$destinataires_mail = $this->obtenirMailParTableauId($id_annuaire, $destinataires);
116 aurelien 174
 
175
		$donnees['contenu_message'] = $this->filtrerChaine($message);
176
		$sujet = $this->filtrerChaine($sujet);
177
		$message = $this->getVue(Config::get('dossier_squelettes_mails').'mail_messagerie',$donnees);
46 aurelien 178
 
179
		// si on modere les mails et s'il y a trop de destinataires
170 aurelien 180
		if($this->moderer_mail && count($destinataires_mail) >= $this->seuil_moderation) {
46 aurelien 181
			// on prévient le moderateur
170 aurelien 182
			$this->stockerMailPourModeration($expediteur, $destinataires_mail, $sujet, $message);
56 aurelien 183
			$donnees['moderation'] = true;
46 aurelien 184
		} else {
185
			// sinon, envoi direct
170 aurelien 186
			$this->envoyerMail($expediteur, $destinataires_mail, $sujet, $message);
56 aurelien 187
			$donnees['moderation'] = false;
46 aurelien 188
		}
189
 
56 aurelien 190
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_envoi_confirmation',$donnees);
191
 
192
		return $resultat;
193
 
46 aurelien 194
	}
195
 
196
	/**
197
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
198
	 * @param string $code_confirmation le code associé au données en attente
199
	 */
200
	public function envoyerMailModere($code_confirmation) {
201
 
202
		// chargement des données temporaire
203
		$message_modele = $this->getModele('DonneeTemporaireModele');
204
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
205
 
206
		if($mail_a_moderer) {
117 aurelien 207
			// envoi
96 aurelien 208
			$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
46 aurelien 209
								$mail_a_moderer['destinataires'],
210
								$mail_a_moderer['sujet'],
211
								$mail_a_moderer['message']);
96 aurelien 212
 
213
			if($resultat_envoi) {
214
				$donnees = array('envoi_reussi' => true);
215
			} else {
216
				$donnees = array('envoi_echoue' => true);
217
			}
218
 
46 aurelien 219
			// suppression des données temporaires
220
			// TODO: envoyer un message à l'utilisateur original ?
221
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
96 aurelien 222
		} else {
223
			$donnees = array('message_inexistant' => true);
46 aurelien 224
		}
225
 
96 aurelien 226
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
227
		return $resultat;
46 aurelien 228
	}
229
 
230
	/**
231
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
232
	 * @param string $code_confirmation le code associé au données en attente
233
	 */
234
	public function supprimerMailModere($code_confirmation) {
235
 
236
		$message_modele = $this->getModele('DonneeTemporaireModele');
237
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
116 aurelien 238
 
239
		$donnees = array('message_supprime' => true);
46 aurelien 240
 
116 aurelien 241
		$resultat = $this->getVue(Config::get('dossier_squelettes_annuaires').'message_moderation_confirmation',$donnees);
242
 
243
		return $resultat;
46 aurelien 244
	}
170 aurelien 245
 
246
	public function obtenirMailParTableauId($id_annuaire, $destinataires) {
247
		// on remplace les identifiants par leurs destinataires
248
		$this->chargerModele('AnnuaireModele');
249
		$destinataires_mails = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
250
 
251
		return $destinataires_mails;
252
	}
46 aurelien 253
 
254
	/**
255
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
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
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
262
 
263
		$mail = array('expediteur' => $expediteur,
264
				 'destinataires' => $destinataires,
265
					'sujet' => $sujet,
266
					'message' => $message);
267
 
268
		$message_modele = $this->getModele('DonneeTemporaireModele');
86 aurelien 269
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail, true);
46 aurelien 270
 
271
		if($id_stockage) {
177 aurelien 272
			$this->envoyerMailModeration($id_stockage, $destinataires, $sujet , $message);
46 aurelien 273
			return true;
274
		}
275
 
276
		return false;
277
 
278
	}
279
 
280
	/**
281
	 * Envoie un mail au modérateur contenant les lien pour, au choix, refuser ou bien accepter l'envoi du mail
282
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
283
	 * @param string $sujet_message_a_moderer sujet du message
284
	 * @param string $message_a_moderer corps du message
285
	 */
177 aurelien 286
	private function envoyerMailModeration($id_mail_a_moderer, $destinataires, $sujet_message_a_moderer, $message_a_moderer) {
46 aurelien 287
 
70 aurelien 288
		$url_cette_page = 'http://'.$_SERVER['SERVER_NAME'].$_SERVER['REQUEST_URI'];
289
		$url_base = $url_cette_page;
46 aurelien 290
 
70 aurelien 291
		$base_url = new URL($url_base);
292
 
293
		$base_url->setVariablesRequete(array());
294
 
46 aurelien 295
		$donnees = array();
296
 
297
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
298
 
299
		$lien_accepter_mail = clone($base_url);
300
		$lien_refuser_mail = clone($base_url);
301
 
302
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
303
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
304
 
305
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
306
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
307
		$donnees['sujet_message'] = $sujet_message_a_moderer;
308
		$donnees['contenu_message'] = $message_a_moderer;
177 aurelien 309
		if(is_array($destinataires)) {
310
			$destinataires = implode(', ', $destinataires);;
311
		}
312
		$donnees['destinataires_message'] = $destinataires;
46 aurelien 313
 
314
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
177 aurelien 315
 
316
		echo $contenu_mail;
317
		exit;
46 aurelien 318
 
319
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
320
 
321
	}
116 aurelien 322
 
323
	private function filtrerChaine($message) {
117 aurelien 324
 
116 aurelien 325
		return strip_tags($message);
326
	}
46 aurelien 327
 
328
}