| Line 13... |
Line 13... |
| 13 |
* @licence GPL v3 & CeCILL v2
|
13 |
* @licence GPL v3 & CeCILL v2
|
| 14 |
* @version $Id$
|
14 |
* @version $Id$
|
| 15 |
*/
|
15 |
*/
|
| Line 16... |
Line 16... |
| 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
|
| - |
|
19 |
// une fois passé à la dernière version du framework, il faudrait factoriser ces fonctions
|
| 18 |
|
20 |
// dans une lib commune accessible aux scripts et au code standard
|
| 19 |
const STATUT_A_TRAITER = 'a_traiter';
|
21 |
const STATUT_A_TRAITER = 'a_traiter';
|
| Line -... |
Line 22... |
| - |
|
22 |
const STATUT_EN_TRAITEMENT = 'en_traitement';
|
| - |
|
23 |
|
| - |
|
24 |
// Définit le délai au bout du quel on remet des mails en traitement à traiter
|
| - |
|
25 |
// au format (avec la syntaxe utilisée avec INTERVAL en SQL)
|
| - |
|
26 |
// http://dev.mysql.com/doc/refman/5.0/fr/date-and-time-functions.html
|
| 20 |
const STATUT_EN_TRAITEMENT = 'en_traitement';
|
27 |
const DELAI_MAX_TRAITEMENT = '10 HOUR';
|
| Line 21... |
Line 28... |
| 21 |
|
28 |
|
| 22 |
private $modele = null;
|
29 |
private $modele = null;
|
| Line 23... |
Line 30... |
| 23 |
|
30 |
|
| 24 |
public function executer() {
|
31 |
public function executer() {
|
| Line 25... |
Line 32... |
| 25 |
$this->bdd = new Bdd();
|
32 |
$this->bdd = new Bdd();
|
| 26 |
|
33 |
|
| 27 |
$cmd = $this->getParametre('a');
|
34 |
$cmd = $this->getParametre('a');
|
| 28 |
$this->mode_verbeux = $this->getParametre('v');
|
35 |
$this->mode_verbeux = $this->getParametre('v');
|
| 29 |
|
36 |
|
| 30 |
switch($cmd) {
|
37 |
switch($cmd) {
|
| 31 |
case "Tous":
|
38 |
case "tous":
|
| - |
|
39 |
$retour = $this->traiterMailsEnAttente();
|
| - |
|
40 |
break;
|
| - |
|
41 |
// TODO: case supplémentaire pour traiter un mail par son id ?
|
| - |
|
42 |
// TODO: option "force" pour traiter les mails quelques soient leur statut ?
|
| 32 |
$this->traiterMailsEnAttente();
|
43 |
default:
|
| 33 |
break;
|
44 |
}
|
| Line 34... |
Line 45... |
| 34 |
// TODO: case supplémentaire pour traiter un mail par son id ?
|
45 |
|
| 35 |
// TODO: option "force" pour traiter les mails quelques soient leur statut ?
|
46 |
if($this->mode_verbeux) {
|
| Line 45... |
Line 56... |
| 45 |
$retour = array();
|
56 |
$retour = array();
|
| 46 |
if(count($mails_a_traiter) > 0 && $this->mettreMailsEnCoursDeTraitement()) {
|
57 |
if(count($mails_a_traiter) > 0 && $this->mettreMailsEnCoursDeTraitement()) {
|
| 47 |
foreach($mails_a_traiter as $donnees_brutes_mail) {
|
58 |
foreach($mails_a_traiter as $donnees_brutes_mail) {
|
| 48 |
$mail_a_moderer = $this->decoderDonneeTemporaire($donnees_brutes_mail);
|
59 |
$mail_a_moderer = $this->decoderDonneeTemporaire($donnees_brutes_mail);
|
| 49 |
$id_mail = $donnees_brutes_mail['adt_id'];
|
60 |
$id_mail = $donnees_brutes_mail['adt_id'];
|
| 50 |
|
61 |
|
| - |
|
62 |
$resultat_envoi = true;
|
| 51 |
$resultat_envoi = $this->envoyerMail($mail_a_moderer['expediteur'],
|
63 |
$envois_echoues = $this->envoyerMail($mail_a_moderer['expediteur'],
|
| 52 |
$mail_a_moderer['destinataires'],
|
64 |
$mail_a_moderer['destinataires'],
|
| 53 |
$mail_a_moderer['sujet'],
|
65 |
$mail_a_moderer['sujet'],
|
| 54 |
$mail_a_moderer['message']);
|
66 |
$mail_a_moderer['message']);
|
| Line 55... |
Line 67... |
| 55 |
|
67 |
|
| 56 |
if($resultat_envoi) {
|
68 |
if(empty($envois_echoues)) {
|
| - |
|
69 |
$this->supprimerMailTraite($id_mail);
|
| - |
|
70 |
} else {
|
| - |
|
71 |
// TODO: supprimer les destinataires qui ont fonctionné, et mettre à jour
|
| - |
|
72 |
// le mail dans les données temporaire avec les destinataires qui restent
|
| - |
|
73 |
// pour pouvoir finir de l'envoyer
|
| - |
|
74 |
$this->avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer);
|
| 57 |
$this->supprimerMailTraite($id_mail);
|
75 |
$resultat_envoi = false;
|
| - |
|
76 |
}
|
| 58 |
}
|
77 |
|
| 59 |
// TODO: logger erreur d'envoi ? envoyer mail récapitulatif
|
78 |
// TODO: logger également erreur d'envoi ?
|
| 60 |
$retour[$id_mail] = $resultat_envoi;
|
79 |
$retour[$id_mail] = $resultat_envoi;
|
| 61 |
}
|
80 |
}
|
| 62 |
}
|
81 |
}
|
| 63 |
return $retour;
|
82 |
return $retour;
|
| Line -... |
Line 83... |
| - |
|
83 |
}
|
| - |
|
84 |
|
| - |
|
85 |
private function avertirModerateurEchecEnvoi($envois_echoues, $mail_a_moderer) {
|
| - |
|
86 |
|
| - |
|
87 |
$corps_mail_echoue = "L'envoi d'un mail modéré à échoué pour les destinataires suivants (".count($envois_echoues)." au total) : <br />";
|
| - |
|
88 |
$corps_mail_echoue .= implode(", ", $envois_echoues);
|
| - |
|
89 |
$corps_mail_echoue .= "<br /><br /><br />";
|
| - |
|
90 |
$corps_mail_echoue .= "--- <i> Message original ---</i><br />";
|
| - |
|
91 |
$corps_mail_echoue .= "Expéditeur : ".$mail_a_moderer['expediteur']."<br />";
|
| - |
|
92 |
$corps_mail_echoue .= "Sujet : ".$mail_a_moderer['sujet']."<br />";
|
| - |
|
93 |
$corps_mail_echoue .= "Message original : ".$mail_a_moderer['message']."<br />";
|
| - |
|
94 |
|
| - |
|
95 |
$sujet = "L'envoi d'un mail modéré a échoué pour un ou plusieurs destinataires";
|
| - |
|
96 |
|
| - |
|
97 |
// TODO: Que faire si l'envoi de mail d'avertissement échoue également ?
|
| - |
|
98 |
$envoi_avertissement = $this->envoyerMail(Config::get('adresse_mail_annuaire'),
|
| - |
|
99 |
Config::get('mail_moderateur'),
|
| - |
|
100 |
$sujet,
|
| - |
|
101 |
$corps_mail_echoue);
|
| - |
|
102 |
|
| - |
|
103 |
return $envoi_avertissement;
|
| 64 |
}
|
104 |
}
|
| 65 |
|
105 |
|
| 66 |
private function obtenirMailsEnAttente() {
|
106 |
private function obtenirMailsEnAttente() {
|
| Line 67... |
Line 107... |
| 67 |
$requete = "SELECT * FROM annu_donnees_temp WHERE statut = '".self::STATUT_A_TRAITER."' ";
|
107 |
$requete = "SELECT * FROM annu_donnees_temp WHERE statut = '".self::STATUT_A_TRAITER."' ";
|
| Line 89... |
Line 129... |
| 89 |
$supp = $this->bdd->requeter($requete);
|
129 |
$supp = $this->bdd->requeter($requete);
|
| 90 |
return $supp;
|
130 |
return $supp;
|
| 91 |
}
|
131 |
}
|
| Line 92... |
Line 132... |
| 92 |
|
132 |
|
| - |
|
133 |
private function remettreATraiterMailsEnRetard() {
|
| - |
|
134 |
// Les mails a traiter depuis plus de 10 heures sont considérés comme échoués et donc remis à traiter
|
| 93 |
private function remettreATraiterMailsEnRetard() {
|
135 |
// (en cas de plantage du script ou du serveur de mail pendant leur traitement)
|
| 94 |
$requete = "UPDATE annu_donnees_temp SET statut = '".self::STATUT_A_TRAITER."', date_debut_traitement = NULL ".
|
136 |
$requete = "UPDATE annu_donnees_temp SET statut = '".self::STATUT_A_TRAITER."', date_debut_traitement = NULL ".
|
| 95 |
"WHERE statut = '".self::STATUT_EN_TRAITEMENT."' ".
|
137 |
"WHERE statut = '".self::STATUT_EN_TRAITEMENT."' ".
|
| Line 96... |
Line 138... |
| 96 |
"AND date_debut_traitement < (DATE_SUB(now(), INTERVAL 10 HOUR)) ";
|
138 |
"AND date_debut_traitement < (DATE_SUB(now(), INTERVAL ".self::DELAI_MAX_TRAITEMENT.")) ";
|
| 97 |
|
139 |
|
| 98 |
$maj = $this->bdd->requeter($requete);
|
140 |
$maj = $this->bdd->requeter($requete);
|
| Line 113... |
Line 155... |
| 113 |
*/
|
155 |
*/
|
| 114 |
public function envoyerMail($expediteur, $destinataires, $sujet, $message_html, $message_texte = '', $adresse_reponse = null) {
|
156 |
public function envoyerMail($expediteur, $destinataires, $sujet, $message_html, $message_texte = '', $adresse_reponse = null) {
|
| 115 |
if (!is_array($destinataires)) {
|
157 |
if (!is_array($destinataires)) {
|
| 116 |
$destinataires = array($destinataires);
|
158 |
$destinataires = array($destinataires);
|
| 117 |
}
|
159 |
}
|
| 118 |
$message_html = $this->encoderChainePourEnvoiMail($message_html);
|
- |
|
| 119 |
if ($message_texte == '') {
|
160 |
if ($message_texte == '') {
|
| 120 |
$message_texte = $this->filtrerChaine($message_html);
|
161 |
$message_texte = $this->filtrerChaine($message_html);
|
| 121 |
}
|
162 |
}
|
| Line 122... |
Line 163... |
| 122 |
|
163 |
|
| Line 149... |
Line 190... |
| 149 |
"Content-Type: text/html; charset=\"$encodage\";".$eol.
|
190 |
"Content-Type: text/html; charset=\"$encodage\";".$eol.
|
| 150 |
"Content-Transfer-Encoding: 8bit;".$eol.$eol.
|
191 |
"Content-Transfer-Encoding: 8bit;".$eol.$eol.
|
| 151 |
$message_html.$eol.$eol.
|
192 |
$message_html.$eol.$eol.
|
| 152 |
"--$limite--".$eol.$eol;
|
193 |
"--$limite--".$eol.$eol;
|
| Line 153... |
Line 194... |
| 153 |
|
194 |
|
| - |
|
195 |
$sujetEncode = mb_encode_mimeheader($sujet, mb_internal_encoding(), "B", "\n");
|
| 154 |
$sujetEncode = mb_encode_mimeheader($this->encoderChainePourEnvoiMail($sujet), $encodage, "B", "\n");
|
196 |
$resultats_envois_echoues = array();
|
| 155 |
$ok = true;
|
197 |
$ok = true;
|
| 156 |
foreach ($destinataires as $destinataire) {
|
198 |
foreach ($destinataires as $destinataire) {
|
| 157 |
$ok = mail($destinataire, $sujetEncode, $contenu, $entetes);
|
199 |
$ok = mail($destinataire, $sujetEncode, $contenu, $entetes);
|
| - |
|
200 |
if (!$ok) {
|
| 158 |
if (!$ok) {
|
201 |
$resultats_envois_echoues[] = $destinataire;
|
| - |
|
202 |
}
|
| - |
|
203 |
}
|
| - |
|
204 |
return $resultats_envois_echoues;
|
| - |
|
205 |
}
|
| - |
|
206 |
|
| - |
|
207 |
/** Transforme automatiquement le message html en message txt.
|
| - |
|
208 |
*
|
| - |
|
209 |
* Réalise un strip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
|
| - |
|
210 |
*/
|
| - |
|
211 |
private function filtrerChaine($messageHtml) {
|
| - |
|
212 |
$messageTxt = strip_tags($messageHtml);
|
| - |
|
213 |
if ($messageHtml != $messageTxt) {
|
| - |
|
214 |
$html = $this->ajouterHrefDansBalise($messageHtml);
|
| - |
|
215 |
$messageAvecEntites = strip_tags($html);
|
| - |
|
216 |
// TODO : en précisant l'encodage de l'appli dans html_entity_decode un double encodage UTF-8 se produit...
|
| - |
|
217 |
$messageTxt = html_entity_decode($messageAvecEntites, ENT_QUOTES);
|
| - |
|
218 |
}
|
| - |
|
219 |
return $messageTxt;
|
| - |
|
220 |
}
|
| - |
|
221 |
|
| - |
|
222 |
/**
|
| - |
|
223 |
* Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
|
| - |
|
224 |
* chevrons (<>) dans le contenu de la balise "a".
|
| - |
|
225 |
*/
|
| - |
|
226 |
private function ajouterHrefDansBalise($html) {
|
| - |
|
227 |
$dom = new DOMDocument;
|
| - |
|
228 |
$dom->loadHTML($html);
|
| - |
|
229 |
foreach ($dom->getElementsByTagName('a') as $node) {
|
| - |
|
230 |
if ($node->hasAttribute( 'href' )) {
|
| - |
|
231 |
$href = $node->getAttribute('href');
|
| 159 |
break;
|
232 |
$node->nodeValue = $node->nodeValue." < $href >";
|
| 160 |
}
|
233 |
}
|
| - |
|
234 |
}
|
| 161 |
}
|
235 |
$html = $dom->saveHtml();
|
| 162 |
return $ok;
|
236 |
return $html;
|
| 163 |
}
|
237 |
}
|
| 164 |
}
|
238 |
}
|
| 165 |
?>
|
239 |
?>
|