Subversion Repositories Applications.annuaire

Rev

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

Rev 503 Rev 507
1
<?php
1
<?php
2
// Encodage : UTF-8
2
// Encodage : UTF-8
3
// +-------------------------------------------------------------------------------------------------------------------+
3
// +-------------------------------------------------------------------------------------------------------------------+
4
/**
4
/**
5
* Traitement des mails en attente de modération de l'annuaire
5
* Traitement des mails en attente de modération de l'annuaire
6
*
6
*
7
* Description : classe permettant de gérer l'envoi des mails en attente de modération dans l'annuaire
7
* Description : classe permettant de gérer l'envoi des mails en attente de modération dans l'annuaire
8
* Utilisation : php script.php mail
8
* Utilisation : php script.php mail
9
*
9
*
10
//Auteur original :
10
//Auteur original :
11
* @author       Aurélien PERONNET <jpm@tela-botanica.org>
11
* @author       Aurélien PERONNET <jpm@tela-botanica.org>
12
* @copyright	Tela-Botanica 1999-2014
12
* @copyright	Tela-Botanica 1999-2014
13
* @licence		GPL v3 & CeCILL v2
13
* @licence		GPL v3 & CeCILL v2
14
* @version		$Id$
14
* @version		$Id$
15
*/
15
*/
16
 
16
 
17
class Mail extends Script {
17
class Mail extends Script {
18
	//TODO: cette classe est en doublon avec du code de l'annuaire
18
	//TODO: cette classe est en doublon avec du code de l'annuaire
19
	// une fois passé à la dernière version du framework, il faudrait factoriser ces fonctions 
19
	// une fois passé à la dernière version du framework, il faudrait factoriser ces fonctions 
20
	// dans une lib commune accessible aux scripts et au code standard
20
	// dans une lib commune accessible aux scripts et au code standard
21
	const STATUT_A_TRAITER = 'a_traiter';
21
	const STATUT_A_TRAITER = 'a_traiter';
22
	const STATUT_EN_TRAITEMENT = 'en_traitement';
22
	const STATUT_EN_TRAITEMENT = 'en_traitement';
23
	const STATUT_EN_ECHEC = 'en_echec';
23
	const STATUT_EN_ECHEC = 'en_echec';
24
	
24
	
25
	// Définit le délai au bout du quel on remet des mails en traitement à traiter
25
	// Définit le délai au bout du quel on remet des mails en traitement à traiter
26
	// au format (avec la syntaxe utilisée avec INTERVAL en SQL)
26
	// au format (avec la syntaxe utilisée avec INTERVAL en SQL)
27
	// http://dev.mysql.com/doc/refman/5.0/fr/date-and-time-functions.html
27
	// http://dev.mysql.com/doc/refman/5.0/fr/date-and-time-functions.html
28
	const DELAI_MAX_TRAITEMENT = '10 HOUR';
28
	const DELAI_MAX_TRAITEMENT = '10 HOUR';
29
	
29
	
30
	private $modele = null;
30
	private $modele = null;
31
	
31
	
32
	public function executer() {	
32
	public function executer() {	
33
		$this->bdd = new Bdd();
33
		$this->bdd = new Bdd();
34
		
34
		
35
		$cmd = $this->getParametre('a');
35
		$cmd = $this->getParametre('a');
36
		$this->mode_verbeux = $this->getParametre('v');
36
		$this->mode_verbeux = $this->getParametre('v');
37
		
37
		
38
		$retour = array();
38
		$retour = array();
39
		
39
		
40
		switch($cmd) {
40
		switch($cmd) {
41
			case "tous":
41
			case "tous":
42
				$retour = $this->traiterMailsEnAttente();
42
				$retour = $this->traiterMailsEnAttente();
43
			break;
43
			break;
44
			// TODO: case supplémentaire pour traiter un mail par son id ?
44
			// TODO: case supplémentaire pour traiter un mail par son id ?
45
			// TODO: option "force" pour traiter les mails quelques soient leur statut ?
45
			// TODO: option "force" pour traiter les mails quelques soient leur statut ?
46
			default:	
46
			default:	
47
		}
47
		}
48
		
48
		
49
		if($this->mode_verbeux) {
49
		if($this->mode_verbeux) {
50
			// echo pour que bash capte la sortie et stocke dans le log
50
			// echo pour que bash capte la sortie et stocke dans le log
51
			echo 'Identifiants des mails traites : '.implode(',', $retour)."--";
51
			echo 'Identifiants des mails traites : '.implode(',', $retour)."--";
52
		}
52
		}
53
	}
53
	}
54
	
54
	
55
	private function traiterMailsEnAttente() {
55
	private function traiterMailsEnAttente() {
56
		// Gaston Lagaffe
56
		// Gaston Lagaffe
57
		$mails_en_retard = $this->traiterMailsEnRetard();
57
		$mails_en_retard = $this->traiterMailsEnRetard();
58
		$mails_a_traiter = $this->obtenirMailsEnAttente();
58
		$mails_a_traiter = $this->obtenirMailsEnAttente();
59
		
59
		
60
		$retour = array();
60
		$retour = array();
61
		if(count($mails_a_traiter) > 0 && $this->mettreMailsEnCoursDeTraitement()) {
61
		if(count($mails_a_traiter) > 0 && $this->mettreMailsEnCoursDeTraitement()) {
62
			foreach($mails_a_traiter as $donnees_brutes_mail) {
62
			foreach($mails_a_traiter as $donnees_brutes_mail) {
63
				$mail_a_moderer = $this->decoderDonneeTemporaire($donnees_brutes_mail);
63
				$mail_a_moderer = $this->decoderDonneeTemporaire($donnees_brutes_mail);
64
				$id_mail = $donnees_brutes_mail['adt_id'];
64
				$id_mail = $donnees_brutes_mail['adt_id'];
65
				
65
				
66
				$resultat_envoi = true;
66
				$resultat_envoi = true;
67
				$envois_echoues = $this->envoyerMail($mail_a_moderer['expediteur'],
67
				$envois_echoues = $this->envoyerMail($mail_a_moderer['expediteur'],
68
						$mail_a_moderer['destinataires'],
68
						$mail_a_moderer['destinataires'],
69
						$mail_a_moderer['sujet'],
69
						$mail_a_moderer['sujet'],
70
						$mail_a_moderer['message']);
70
						$mail_a_moderer['message']);
71
				
71
				
72
				if(empty($envois_echoues)) {
72
				if(empty($envois_echoues)) {
73
					$this->supprimerMailTraite($id_mail);
73
					$this->supprimerMailTraite($id_mail);
74
				} else {
74
				} else {
75
					// TODO: supprimer les destinataires qui ont fonctionné, et mettre à jour 
75
					// TODO: supprimer les destinataires qui ont fonctionné, et mettre à jour 
76
					// le mail dans les données temporaire avec les destinataires qui restent 
76
					// le mail dans les données temporaire avec les destinataires qui restent 
77
					// pour pouvoir finir de l'envoyer
77
					// pour pouvoir finir de l'envoyer
78
					$this->avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer);
78
					$this->avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer);
79
					$resultat_envoi = false;
79
					$resultat_envoi = false;
80
				}
80
				}
81
				
81
				
82
				// TODO: logger également erreur d'envoi ?
82
				// TODO: logger également erreur d'envoi ?
83
				$retour[$id_mail] = $resultat_envoi;
83
				$retour[$id_mail] = $resultat_envoi;
84
			}
84
			}
85
		}
85
		}
86
		return $retour;
86
		return $retour;
87
	}
87
	}
88
	
88
	
89
	private function avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer) {
89
	private function avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer) {
90
		
90
		
91
		$corps_mail_echoue = "L'envoi d'un mail modéré à échoué pour les destinataires suivants (".count($envois_echoues)." au total) : <br />";
91
		$corps_mail_echoue = "L'envoi d'un mail modéré à échoué pour les destinataires suivants (".count($envois_echoues)." au total) : <br />";
92
		$corps_mail_echoue .= implode(", ", $envois_echoues);
92
		$corps_mail_echoue .= implode(", ", $envois_echoues);
93
		$corps_mail_echoue .= "<br /><br /><br />";
93
		$corps_mail_echoue .= "<br /><br /><br />";
94
		$corps_mail_echoue .= "--- <i> Message original ---</i><br />";
94
		$corps_mail_echoue .= "--- <i> Message original ---</i><br />";
95
		$corps_mail_echoue .= "Expéditeur  : ".$mail_a_moderer['expediteur']."<br />";
95
		$corps_mail_echoue .= "Expéditeur  : ".$mail_a_moderer['expediteur']."<br />";
96
		$corps_mail_echoue .= "Sujet  : ".$mail_a_moderer['sujet']."<br />";
96
		$corps_mail_echoue .= "Sujet  : ".$mail_a_moderer['sujet']."<br />";
97
		$corps_mail_echoue .= "Message original : ".$mail_a_moderer['message']."<br />";
97
		$corps_mail_echoue .= "Message original : ".$mail_a_moderer['message']."<br />";
98
		
98
		
99
		$sujet = "L'envoi d'un mail modéré a échoué pour un ou plusieurs destinataires";
99
		$sujet = "L'envoi d'un mail modéré a échoué pour un ou plusieurs destinataires";
100
			
100
			
101
		// TODO: Que faire si l'envoi de mail d'avertissement échoue également ?
101
		// TODO: Que faire si l'envoi de mail d'avertissement échoue également ?
102
		$envoi_avertissement = $this->envoyerMail(Config::get('adresse_mail_annuaire'),
102
		$envoi_avertissement = $this->envoyerMail(Config::get('adresse_mail_annuaire'),
103
				Config::get('mail_moderateur'),
103
				Config::get('mail_moderateur'),
104
				$sujet,
104
				$sujet,
105
				$corps_mail_echoue);
105
				$corps_mail_echoue);
106
		// echo pour que bash capte la sortie et stocke dans le log
106
		// echo pour que bash capte la sortie et stocke dans le log
107
		echo 'Envoi du mail au moderateur pour signaler un echec '."--";
107
		echo 'Envoi du mail au moderateur pour signaler un echec '."--";
108
		return $envoi_avertissement;
108
		return $envoi_avertissement;
109
	}
109
	}
110
	
110
	
111
	private function avertirModerateurEchecTraitement($mails_en_echec) {
111
	private function avertirModerateurEchecTraitement($mails_en_echec) {
112
		
112
		
113
		$ids_mails_en_echec = array();
113
		$ids_mails_en_echec = array();
114
		foreach($mails_en_echec as $mail_echec) {
114
		foreach($mails_en_echec as $mail_echec) {
115
			$ids_mails_en_echec[] = $mail_echec['adt_id'];
115
			$ids_mails_en_echec[] = $mail_echec['adt_id'];
116
		}
116
		}
117
	
117
	
118
		$corps_mail_mal_traite = "Échec de traitement pour : ".implode(',', $ids_mails_en_echec)." depuis plus de ".self::DELAI_MAX_TRAITEMENT." <br />";
118
		$corps_mail_mal_traite = "Échec de traitement pour : ".implode(',', $ids_mails_en_echec)." depuis plus de ".self::DELAI_MAX_TRAITEMENT." <br />";
119
		$sujet = "Un ou plusieurs mails sont en échec de traitement";
119
		$sujet = "Un ou plusieurs mails sont en échec de traitement";
120
			
120
			
121
		$envoi_avertissement = $this->envoyerMail(Config::get('adresse_mail_annuaire'),
121
		$envoi_avertissement = $this->envoyerMail(Config::get('adresse_mail_annuaire'),
122
				Config::get('mail_moderateur'),
122
				Config::get('mail_moderateur'),
123
				$sujet,
123
				$sujet,
124
				$corps_mail_mal_traite);
124
				$corps_mail_mal_traite);
125
		
125
		
126
		// echo pour que bash capte la sortie et stocke dans le log
126
		// echo pour que bash capte la sortie et stocke dans le log
127
		echo 'Envoi du mail au moderateur pour signaler un traitement en echec depuis trop longtemps '."--";
127
		echo 'Envoi du mail au moderateur pour signaler un traitement en echec depuis trop longtemps '."--";
128
		return $envoi_avertissement;
128
		return $envoi_avertissement;
129
	}
129
	}
130
	
130
	
131
	private function obtenirMailsEnAttente() {
131
	private function obtenirMailsEnAttente() {
132
		$requete = "SELECT * FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_A_TRAITER."' ";
132
		$requete = "SELECT * FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_A_TRAITER."' ";
133
		$retour = $this->bdd->recupererTous($requete);
133
		$retour = $this->bdd->recupererTous($requete);
134
		// echo pour que bash capte la sortie et stocke dans le log
134
		// echo pour que bash capte la sortie et stocke dans le log
135
		echo 'Il y a '.count($retour).' mails en attente '."--";
135
		echo 'Il y a '.count($retour).' mails en attente '."--";
136
		return $retour;
136
		return $retour;
137
	}
137
	}
138
	
138
	
139
	private function mettreMailsEnCoursDeTraitement() {
139
	private function mettreMailsEnCoursDeTraitement() {
140
		$requete = "UPDATE annu_donnees_temp SET adt_statut = '".self::STATUT_EN_TRAITEMENT."', adt_date_debut_traitement = NOW() ".
140
		$requete = "UPDATE annu_donnees_temp SET adt_statut = '".self::STATUT_EN_TRAITEMENT."', adt_date_debut_traitement = NOW() ".
141
					"WHERE adt_statut = '".self::STATUT_A_TRAITER."' ";
141
					"WHERE adt_statut = '".self::STATUT_A_TRAITER."' ";
142
		$maj = $this->bdd->executer($requete);
142
		$maj = $this->bdd->executer($requete);
143
		// echo pour que bash capte la sortie et stocke dans le log
143
		// echo pour que bash capte la sortie et stocke dans le log
144
		echo $maj.' mails ont été mis en traitement '."--";
144
		echo $maj.' mails ont été mis en traitement '."--";
145
		return ($maj !== false);
145
		return ($maj !== false);
146
	}
146
	}
147
	
147
	
148
	private function mettreAJourMailMalTraite($id_mail_mal_traite, $mail_mal_traite, $envois_echoues) {	
148
	private function mettreAJourMailMalTraite($id_mail_mal_traite, $mail_mal_traite, $envois_echoues) {	
149
		// TODO: utiliser cette fonction lors de l'echec de plusieurs destinataires et renvoyer le lien
149
		// TODO: utiliser cette fonction lors de l'echec de plusieurs destinataires et renvoyer le lien
150
		// de confirmation
150
		// de confirmation
151
		$mail_mal_traite['destinataires'] = $envois_echoues;
151
		$mail_mal_traite['destinataires'] = $envois_echoues;
152
		$mail_mal_traite = $this->encoderDonneeTemporaire($mail_mal_traite);
152
		$mail_mal_traite = $this->encoderDonneeTemporaire($mail_mal_traite);
153
		
153
		
154
		$requete = "UPDATE annu_donnees_temp ".
154
		$requete = "UPDATE annu_donnees_temp ".
155
					"SET adt_donnees = '".$mail_mal_traite."' ".
155
					"SET adt_donnees = '".$mail_mal_traite."' ".
156
					"WHERE adt_id = '".$mail_a_moderer['adt_id']."'";
156
					"WHERE adt_id = '".$mail_a_moderer['adt_id']."'";
157
		
157
		
158
		$maj = $this->bdd->executer($requete);
158
		$maj = $this->bdd->executer($requete);
159
		return $maj;
159
		return $maj;
160
	}
160
	}
161
	
161
	
162
	private function supprimerMailTraite($id) {
162
	private function supprimerMailTraite($id) {
163
		$requete = "DELETE FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ".
163
		$requete = "DELETE FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ".
164
					"AND adt_id = '".$id."'";
164
					"AND adt_id = '".$id."'";
165
		// echo pour que bash capte la sortie et stocke dans le log
165
		// echo pour que bash capte la sortie et stocke dans le log
166
		echo'Suppression du mail '.$id.' qui a ete traite '."--";
166
		echo'Suppression du mail '.$id.' qui a ete traite '."--";
167
		$supp = $this->bdd->executer($requete);
167
		$supp = $this->bdd->executer($requete);
168
		return $supp;
168
		return $supp;
169
	}
169
	}
170
	
170
	
171
	private function supprimerMailsEnCoursDeTraitement() {
171
	private function supprimerMailsEnCoursDeTraitement() {
172
		$requete = "DELETE FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ";
172
		$requete = "DELETE FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ";
173
		$supp = $this->bdd->executer($requete);
173
		$supp = $this->bdd->executer($requete);
174
		return $supp;
174
		return $supp;
175
	}
175
	}
176
	
176
	
177
	private function traiterMailsEnRetard() {
177
	private function traiterMailsEnRetard() {
178
		// Les mails a traiter depuis plus de 10 heures sont considérés comme échoués et donc remis à traiter
178
		// Les mails a traiter depuis plus de 10 heures sont considérés comme échoués et donc remis à traiter
179
		// (en cas de plantage du script ou du serveur de mail pendant leur traitement)
179
		// (en cas de plantage du script ou du serveur de mail pendant leur traitement)
180
		$requete = "UPDATE annu_donnees_temp SET adt_statut = '".self::STATUT_EN_ECHEC."', adt_date_debut_traitement = NULL ".
180
		$requete = "UPDATE annu_donnees_temp SET adt_statut = '".self::STATUT_EN_ECHEC."' ".
181
				"WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ".
181
				"WHERE adt_statut = '".self::STATUT_EN_TRAITEMENT."' ".
182
				"AND adt_date_debut_traitement < (DATE_SUB(now(), INTERVAL ".self::DELAI_MAX_TRAITEMENT.")) ";
182
				"AND adt_date_debut_traitement < (DATE_SUB(now(), INTERVAL ".self::DELAI_MAX_TRAITEMENT.")) ";
183
		
183
		
184
		$maj = $this->bdd->executer($requete);
184
		$maj = $this->bdd->executer($requete);
185
		// echo pour que bash capte la sortie et stocke dans le log
185
		// echo pour que bash capte la sortie et stocke dans le log
186
		echo 'Gestion des mails en retard '."--";
186
		echo 'Gestion des mails en retard '."--";
187
		if($maj !== false) {
187
		if($maj !== false && $maj != 0) {
188
			$requete = "SELECT * FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_ECHEC."'";
188
			$requete = "SELECT * FROM annu_donnees_temp WHERE adt_statut = '".self::STATUT_EN_ECHEC."' AND adt_date_debut_traitement IS NOT NULL";
189
			$mails_en_echec = $this->bdd->recupererTous($requete);
189
			$mails_en_echec = $this->bdd->recupererTous($requete);
-
 
190
			
190
			// echo pour que bash capte la sortie et stocke dans le log
191
			// echo pour que bash capte la sortie et stocke dans le log
191
			echo 'Avertissement, des mails sont en retard : '.count($mails_en_echec)."--";
192
			echo 'Avertissement, des mails sont en retard : '.count($mails_en_echec)."--";
192
			$this->avertirModerateurEchecTraitement($mails_en_echec);
193
			$this->avertirModerateurEchecTraitement($mails_en_echec);
-
 
194
			
-
 
195
			// Réinitialisation de la date pour éviter que l'avertissement soit réenvoyé plusieurs fois
-
 
196
			$requete = "UPDATE annu_donnees_temp SET adt_date_debut_traitement = NULL ".
-
 
197
					"WHERE adt_statut = '".self::STATUT_EN_ECHEC."' ";
-
 
198
			$maj = $this->bdd->executer($requete);
193
		}
199
		}
194
		
200
		
195
		return $maj;
201
		return $maj;
196
	}
202
	}
197
	
203
	
198
	private function encoderDonneeTemporaire($donnee) {
204
	private function encoderDonneeTemporaire($donnee) {
199
		return base64_encode(serialize($donnee));
205
		return base64_encode(serialize($donnee));
200
	}
206
	}
201
	
207
	
202
	private function decoderDonneeTemporaire($donnee_encodee) {
208
	private function decoderDonneeTemporaire($donnee_encodee) {
203
		return unserialize(base64_decode($donnee_encodee['adt_donnees']));
209
		return unserialize(base64_decode($donnee_encodee['adt_donnees']));
204
	}
210
	}
205
	
211
	
206
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre, à l'adresse donnée en paramètre.
212
	/** Envoie un mail avec l'adresse de l'utilisateur donné en paramètre, à l'adresse donnée en paramètre.
207
	 * ATTENTION : le sujet et le contenu envoyer à cette méthode doivent avoir le même encodage que l'application.
213
	 * ATTENTION : le sujet et le contenu envoyer à cette méthode doivent avoir le même encodage que l'application.
208
	 *
214
	 *
209
	 * @param string $expediteur l'expediteur du message
215
	 * @param string $expediteur l'expediteur du message
210
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
216
	 * @param mixed $destinataires un string ou un tableau de mails qui contiennent les destinataire
211
	 * @param string $sujet sujet du mail
217
	 * @param string $sujet sujet du mail
212
	 * @return boolean true ou false suivant le succès ou non de l'envoi
218
	 * @return boolean true ou false suivant le succès ou non de l'envoi
213
	 */
219
	 */
214
	public function envoyerMail($expediteur, $destinataires, $sujet, $message_html, $message_texte = '', $adresse_reponse = null) {
220
	public function envoyerMail($expediteur, $destinataires, $sujet, $message_html, $message_texte = '', $adresse_reponse = null) {
215
		if (!is_array($destinataires)) {
221
		if (!is_array($destinataires)) {
216
			$destinataires = array($destinataires);
222
			$destinataires = array($destinataires);
217
		}
223
		}
218
		if ($message_texte == '') {
224
		if ($message_texte == '') {
219
			$message_texte = $this->filtrerChaine($message_html);
225
			$message_texte = $this->filtrerChaine($message_html);
220
		}
226
		}
221
	
227
	
222
		$encodage = Config::get('appli_encodage');
228
		$encodage = Config::get('appli_encodage');
223
		$limite = "_----------=_parties_".md5(uniqid(rand()));
229
		$limite = "_----------=_parties_".md5(uniqid(rand()));
224
		$eol = "\n";
230
		$eol = "\n";
225
	
231
	
226
		$entetes = '';
232
		$entetes = '';
227
		// Définition d'un mail en texte simple et html
233
		// Définition d'un mail en texte simple et html
228
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
234
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
229
		$entetes .= "X-Sender: <http://www.tela-botanica.org>".$eol.
235
		$entetes .= "X-Sender: <http://www.tela-botanica.org>".$eol.
230
		"X-Mailer: PHP-ANNUAIRE-HTML".$eol.
236
		"X-Mailer: PHP-ANNUAIRE-HTML".$eol.
231
		"X-auth-smtp-user: annuaire@tela-botanica.org ".$eol.
237
		"X-auth-smtp-user: annuaire@tela-botanica.org ".$eol.
232
		"X-abuse-contact: annuaire@tela-botanica.org ".$eol.
238
		"X-abuse-contact: annuaire@tela-botanica.org ".$eol.
233
		'Date: '.date('r').$eol.
239
		'Date: '.date('r').$eol.
234
		'From: '.$expediteur.$eol.
240
		'From: '.$expediteur.$eol.
235
		'MIME-Version: 1.0'.$eol;
241
		'MIME-Version: 1.0'.$eol;
236
		if ($adresse_reponse !== null) {
242
		if ($adresse_reponse !== null) {
237
			$entetes .= 'Reply-To: '.$adresse_reponse.$eol;
243
			$entetes .= 'Reply-To: '.$adresse_reponse.$eol;
238
		}
244
		}
239
		$entetes .= "Content-Type: multipart/alternative; boundary=\"$limite\";".$eol.$eol;
245
		$entetes .= "Content-Type: multipart/alternative; boundary=\"$limite\";".$eol.$eol;
240
	
246
	
241
		// message en texte simple
247
		// message en texte simple
242
		$contenu = "--$limite".$eol.
248
		$contenu = "--$limite".$eol.
243
		"Content-Type: text/plain; charset=\"$encodage\";".$eol.
249
		"Content-Type: text/plain; charset=\"$encodage\";".$eol.
244
		"Content-Transfer-Encoding: 8bit;".$eol.$eol.
250
		"Content-Transfer-Encoding: 8bit;".$eol.$eol.
245
		$message_texte.$eol.$eol.
251
		$message_texte.$eol.$eol.
246
		// le message en html est préféré s'il est lisible
252
		// le message en html est préféré s'il est lisible
247
		"--$limite".$eol.
253
		"--$limite".$eol.
248
		"Content-Type: text/html; charset=\"$encodage\";".$eol.
254
		"Content-Type: text/html; charset=\"$encodage\";".$eol.
249
		"Content-Transfer-Encoding: 8bit;".$eol.$eol.
255
		"Content-Transfer-Encoding: 8bit;".$eol.$eol.
250
		$message_html.$eol.$eol.
256
		$message_html.$eol.$eol.
251
		"--$limite--".$eol.$eol;
257
		"--$limite--".$eol.$eol;
252
	
258
	
253
		$sujetEncode = mb_encode_mimeheader($sujet, mb_internal_encoding(), "B", "\n");
259
		$sujetEncode = mb_encode_mimeheader($sujet, mb_internal_encoding(), "B", "\n");
254
		$resultats_envois_echoues = array();
260
		$resultats_envois_echoues = array();
255
		$ok = true;
261
		$ok = true;
256
		foreach ($destinataires as $destinataire) {
262
		foreach ($destinataires as $destinataire) {
257
			$ok = mail($destinataire, $sujetEncode, $contenu, $entetes);
263
			$ok = mail($destinataire, $sujetEncode, $contenu, $entetes);
258
			if (!$ok) {
264
			if (!$ok) {
259
				// echo pour que bash capte la sortie et stocke dans le log
265
				// echo pour que bash capte la sortie et stocke dans le log
260
				echo'Echec envoi a '.$destinataire."\n";
266
				echo'Echec envoi a '.$destinataire."\n";
261
				$resultats_envois_echoues[] = $destinataire;
267
				$resultats_envois_echoues[] = $destinataire;
262
			}
268
			}
263
		}
269
		}
264
		return $resultats_envois_echoues;
270
		return $resultats_envois_echoues;
265
	}
271
	}
266
	
272
	
267
	/** Transforme automatiquement le message html en message txt.
273
	/** Transforme automatiquement le message html en message txt.
268
	 *
274
	 *
269
	 * Réalise un strip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
275
	 * Réalise un strip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
270
	 */
276
	 */
271
	private function filtrerChaine($messageHtml) {
277
	private function filtrerChaine($messageHtml) {
272
		$messageTxt = strip_tags($messageHtml);
278
		$messageTxt = strip_tags($messageHtml);
273
		if ($messageHtml != $messageTxt) {
279
		if ($messageHtml != $messageTxt) {
274
			$html = $this->ajouterHrefDansBalise($messageHtml);
280
			$html = $this->ajouterHrefDansBalise($messageHtml);
275
			$messageAvecEntites = strip_tags($html);
281
			$messageAvecEntites = strip_tags($html);
276
			// TODO : en précisant l'encodage de l'appli dans html_entity_decode un double encodage UTF-8 se produit...
282
			// TODO : en précisant l'encodage de l'appli dans html_entity_decode un double encodage UTF-8 se produit...
277
			$messageTxt = html_entity_decode($messageAvecEntites, ENT_QUOTES);
283
			$messageTxt = html_entity_decode($messageAvecEntites, ENT_QUOTES);
278
		}
284
		}
279
		return $messageTxt;
285
		return $messageTxt;
280
	}
286
	}
281
	
287
	
282
	/**
288
	/**
283
	 * Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
289
	 * Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
284
	 * chevrons (<>) dans le contenu de la balise "a".
290
	 * chevrons (<>) dans le contenu de la balise "a".
285
	 */
291
	 */
286
	private function ajouterHrefDansBalise($html) {
292
	private function ajouterHrefDansBalise($html) {
287
		$dom = new DOMDocument;
293
		$dom = new DOMDocument;
288
		$dom->loadHTML($html);
294
		$dom->loadHTML($html);
289
		foreach ($dom->getElementsByTagName('a') as $node) {
295
		foreach ($dom->getElementsByTagName('a') as $node) {
290
			if ($node->hasAttribute( 'href' )) {
296
			if ($node->hasAttribute( 'href' )) {
291
				$href = $node->getAttribute('href');
297
				$href = $node->getAttribute('href');
292
				$node->nodeValue = $node->nodeValue." < $href >";
298
				$node->nodeValue = $node->nodeValue." < $href >";
293
			}
299
			}
294
		}
300
		}
295
		$html = $dom->saveHtml();
301
		$html = $dom->saveHtml();
296
		return $html;
302
		return $html;
297
	}
303
	}
298
}
304
}
299
?>
305
?>