Subversion Repositories Applications.annuaire

Rev

Rev 486 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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