Subversion Repositories Applications.annuaire

Rev

Rev 56 | Go to most recent revision | Details | 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
 
14
Class MessageControleur extends Controleur {
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
	}
65
 
66
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre,
67
	 * à l'adresse donnée en paramètre
68
	 * @param string $expediteur l'expediteur du message
69
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
70
	 * @param string $sujet sujet du mail
71
	 * @return boolean true ou false suivant le succès ou non de l'envoi
72
	 */
73
	private function envoyerMail($expediteur, $destinataires, $sujet, $message) {
74
 
75
		if(is_array($destinataires)) {
76
			$destinataires = implode(',',$destinataires);
77
		}
78
 
79
		 // Pour envoyer un mail HTML, l'en-tête Content-type doit être défini
80
	     $entetes  = 'MIME-Version: 1.0' . "\r\n";
81
	     $entetes .= 'Content-type: text/html; charset='.Config::get('appli_encodage'). "\r\n";
82
	     // En-têtes additionnels
83
	     $entetes .= 'To: '.$destinataires."\r\n";
84
	     $entetes .= 'From: '.$expediteur."\r\n";
85
 
86
	     $contenu_mail = $message;
87
 
88
		return mail($destinataires, $sujet, $contenu_mail, $entetes);
89
	}
90
 
91
	/**
92
	 * Avec des l'informations d'expéditions données en paramètres, décide si un mail peut être envoyé directement
93
	 * ou bien s'il doit être stocké et soumis à modération
94
	 * @param int $id_annuaire l'identifiant de l'annuaire à utiliser
95
	 * @param string $expediteur l'expéditeur du mail
96
	 * @param array $destinataires les destinataires du mail
97
	 * @param string $sujet sujet du message
98
	 * @param string $message corps du message
99
	 */
100
	public function envoyerMailDirectOuModere($id_annuaire, $expediteur, $destinataires, $sujet = '', $message = '') {
101
 
102
		// on remplace les identifiants par leurs destinataires
103
		$this->chargerModele('AnnuaireModele');
104
		$destinataires = $this->AnnuaireModele->obtenirMailParTableauId($id_annuaire, $destinataires);
105
 
106
		// si on modere les mails et s'il y a trop de destinataires
107
		if($this->moderer_mail && count($destinataires) >= $this->seuil_moderation) {
108
			// on prévient le moderateur
109
			$this->stockerMailPourModeration($expediteur, $destinataires, $sujet, $message);
110
 
111
		} else {
112
			// sinon, envoi direct
113
			$this->envoyerMail($expediteur, $destinataires, $sujet, $message);
114
		}
115
 
116
	}
117
 
118
	/**
119
	 * Retrouve les informations d'un mail en attente de modération et envoie le mail
120
	 * @param string $code_confirmation le code associé au données en attente
121
	 */
122
	public function envoyerMailModere($code_confirmation) {
123
 
124
		// chargement des données temporaire
125
		$message_modele = $this->getModele('DonneeTemporaireModele');
126
		$mail_a_moderer = $message_modele->chargerDonneeTemporaire($code_confirmation);
127
 
128
		if($mail_a_moderer) {
129
			// envoi
130
			$this->envoyerMail($mail_a_moderer['expediteur'],
131
								$mail_a_moderer['destinataires'],
132
								$mail_a_moderer['sujet'],
133
								$mail_a_moderer['message']);
134
			// suppression des données temporaires
135
			// TODO: envoyer un message à l'utilisateur original ?
136
			$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
137
 
138
			return true;
139
		}
140
 
141
		return false;
142
	}
143
 
144
	/**
145
	 * Supprime un mail en attente de modération grâce au code donné en paramètre
146
	 * @param string $code_confirmation le code associé au données en attente
147
	 */
148
	public function supprimerMailModere($code_confirmation) {
149
 
150
		$message_modele = $this->getModele('DonneeTemporaireModele');
151
		$supression_donnees_temp = $message_modele->supprimerDonneeTemporaire($code_confirmation);
152
 
153
		return true;
154
	}
155
 
156
	/**
157
	 * Stocke un mail dans la base des données temporaires et envoie un mail au modérateur
158
	 * @param string $expediteur l'expéditeur du mail
159
	 * @param array $destinataires les destinataires du mail
160
	 * @param string $sujet sujet du message
161
	 * @param string $message corps du message
162
	 */
163
	private function stockerMailPourModeration($expediteur ,$destinataires, $sujet, $message) {
164
 
165
		$mail = array('expediteur' => $expediteur,
166
				 'destinataires' => $destinataires,
167
					'sujet' => $sujet,
168
					'message' => $message);
169
 
170
		$message_modele = $this->getModele('DonneeTemporaireModele');
171
		$id_stockage = $message_modele->stockerDonneeTemporaire($mail);
172
 
173
		if($id_stockage) {
174
			$this->envoyerMailModeration($id_stockage,$sujet , $message);
175
			return true;
176
		}
177
 
178
		return false;
179
 
180
	}
181
 
182
	/**
183
	 * Envoie un mail au modérateur contenant les lien pour, au choix, refuser ou bien accepter l'envoi du mail
184
	 * @param int $id_mail_a_moderer identifiant du mail à modérer (dans la table des données temporaires)
185
	 * @param string $sujet_message_a_moderer sujet du message
186
	 * @param string $message_a_moderer corps du message
187
	 */
188
	private function envoyerMailModeration($id_mail_a_moderer, $sujet_message_a_moderer, $message_a_moderer) {
189
 
190
		$base_url = clone(Registre::getInstance()->get('base_url_application'));
191
 
192
		$donnees = array();
193
 
194
		$base_url->setVariableRequete('id',$id_mail_a_moderer);
195
 
196
		$lien_accepter_mail = clone($base_url);
197
		$lien_refuser_mail = clone($base_url);
198
 
199
		$lien_accepter_mail->setVariableRequete('m','message_moderation_confirmation');
200
		$lien_refuser_mail->setVariableRequete('m','message_moderation_suppression');
201
 
202
		$donnees['lien_accepter_mail'] = $lien_accepter_mail;
203
		$donnees['lien_refuser_mail'] = $lien_refuser_mail;
204
		$donnees['sujet_message'] = $sujet_message_a_moderer;
205
		$donnees['contenu_message'] = $message_a_moderer;
206
 
207
		$contenu_mail = $this->getVue(Config::get('dossier_squelettes_mails').'mail_moderation_message',$donnees);
208
 
209
		return $this->envoyerMail($this->adresse_mail_annuaire, $this->mail_moderateur, 'Un message est en attente de modération', $contenu_mail);
210
 
211
	}
212
 
213
}