Subversion Repositories Applications.annuaire

Rev

Rev 486 | Rev 491 | Go to most recent revision | Show entire file | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

Rev 486 Rev 490
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
?>