Subversion Repositories Applications.annuaire

Rev

Rev 327 | Rev 349 | Go to most recent revision | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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