Subversion Repositories eFlore/Applications.del

Rev

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

Rev 1787 Rev 1789
1
<?php
1
<?php
2
class Messagerie {
2
class Messagerie {
3
 
3
 
4
	private $conteneur = null;
4
	private $conteneur = null;
5
 
5
 
6
	public function __construct($conteneur) {
6
	public function __construct($conteneur) {
7
		$this->conteneur = $conteneur;
7
		$this->conteneur = $conteneur;
8
	}
8
	}
9
 
9
 
10
	public function envoyerHtml($destinataires, $sujet, $messageHtml, $messageTxt = '') {
10
	public function envoyerHtml($destinataires, $sujet, $messageHtml, $messageTxt = '') {
11
		if ($messageTxt == '') {
11
		if ($messageTxt == '') {
12
			$messageSansHtml = $this->supprimerHtml($messageHtml);
12
			$messageSansHtml = $this->supprimerHtml($messageHtml);
13
			$messageTxt = $this->nettoyerTxt($messageSansHtml);
13
			$messageTxt = $this->nettoyerTxt($messageSansHtml);
14
		}
14
		}
15
		$encodage = $this->conteneur->getParametre('encodage_appli');
15
		$encodage = $this->conteneur->getParametre('encodage_appli');
16
		mb_internal_encoding($encodage);
16
		mb_internal_encoding($encodage);
17
		// tentative d'acceptation des sujets longs (+ 76 caractères) par les clients mail tatillons
17
		// tentative d'acceptation des sujets longs (+ 76 caractères) par les clients mail tatillons
18
		$sujetEncode = mb_encode_mimeheader($sujet, mb_internal_encoding(), "B", "\n");
18
		$sujetEncode = mb_encode_mimeheader($sujet, mb_internal_encoding(), "B", "\n");
19
 
19
 
20
		$emailExpediteur = $this->conteneur->getParametre('adresse_expediteur_recapitulatif');
20
		$emailExpediteur = $this->conteneur->getParametre('adresse_expediteur_recapitulatif');
21
		$dateHeure = date('r');
21
		$dateHeure = date('r');
22
		$uid = md5(uniqid(rand()));
22
		$uid = md5(uniqid(rand()));
23
		$limite = "_----------=_parties_$uid";
23
		$limite = "_----------=_parties_$uid";
24
		$eol = "\n";// ATTENTION : avec Qmail laisser seulement \n car il remplace automatiquement par \r\n
24
		$eol = "\n";// ATTENTION : avec Qmail laisser seulement \n car il remplace automatiquement par \r\n
25
 
25
 
26
		// Définition d'un mail en texte simple et html
26
		// Définition d'un mail en texte simple et html
27
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
27
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
28
		$entetes = 'X-Sender: <http://www.tela-botanica.org>'.$eol.
28
		$entetes = 'X-Sender: <http://www.tela-botanica.org>'.$eol.
29
			'X-Mailer: PHP-DEL-SCRIPTS'.$eol.
29
			'X-Mailer: PHP-DEL-SCRIPTS'.$eol.
30
			'X-auth-smtp-user: '.$emailExpediteur.$eol.
30
			'X-auth-smtp-user: '.$emailExpediteur.$eol.
31
			'X-abuse-contact: '.$emailExpediteur.$eol.
31
			'X-abuse-contact: '.$emailExpediteur.$eol.
32
			'Date: '.$dateHeure.$eol.
32
			'Date: '.$dateHeure.$eol.
33
			'From: '.$emailExpediteur.$eol.
33
			'From: '.$emailExpediteur.$eol.
-
 
34
			'Reply-To: '.$this->conteneur->getParametre('adresse_reponse').$eol.
34
			'MIME-Version: 1.0'.$eol.
35
			'MIME-Version: 1.0'.$eol.
35
			"Content-Type: multipart/alternative; boundary=\"$limite\";".$eol.$eol;
36
			"Content-Type: multipart/alternative; boundary=\"$limite\";".$eol.$eol;
36
 
37
 
37
		// le message en html est préféré s'il est lisible
38
		// le message en html est préféré s'il est lisible
38
		$contenu =
39
		$contenu =
39
			"--$limite".$eol.
40
			"--$limite".$eol.
40
			"Content-Type: text/plain; charset=\"$encodage\";".$eol.
41
			"Content-Type: text/plain; charset=\"$encodage\";".$eol.
41
			"Content-Transfer-Encoding: 8bit;".$eol.$eol.
42
			"Content-Transfer-Encoding: 8bit;".$eol.$eol.
42
			"$messageTxt".$eol.$eol.
43
			"$messageTxt".$eol.$eol.
43
			"--$limite".$eol.
44
			"--$limite".$eol.
44
			"Content-Type: text/html; charset=\"$encodage\";".$eol.
45
			"Content-Type: text/html; charset=\"$encodage\";".$eol.
45
			"Content-Transfer-Encoding: 8bit;".$eol.$eol.
46
			"Content-Transfer-Encoding: 8bit;".$eol.$eol.
46
			"$messageHtml".$eol.
47
			"$messageHtml".$eol.
47
			"--".$limite."--".$eol.$eol;
48
			"--".$limite."--".$eol.$eol;
48
 
49
 
49
		$envoieStatut = $this->envoyer($destinataires, $entetes, $sujetEncode, $contenu);
50
		$envoieStatut = $this->envoyer($destinataires, $entetes, $sujetEncode, $contenu);
50
 
51
 
51
		return $envoieStatut;
52
		return $envoieStatut;
52
	}
53
	}
53
 
54
 
54
	public function envoyerTxt($destinataires, $sujet, $messageTxt) {
55
	public function envoyerTxt($destinataires, $sujet, $messageTxt) {
55
		$emailExpediteur = $this->conteneur->getParametre('adresse_expediteur_recapitulatif');
56
		$emailExpediteur = $this->conteneur->getParametre('adresse_expediteur_recapitulatif');
56
		$encodage = $this->conteneur->getParametre('encodage_appli');
57
		$encodage = $this->conteneur->getParametre('encodage_appli');
57
		mb_internal_encoding($encodage);
58
		mb_internal_encoding($encodage);
58
		$sujetEncode = mb_encode_mimeheader($sujet);
59
		$sujetEncode = mb_encode_mimeheader($sujet);
59
		$dateHeure = date('r');
60
		$dateHeure = date('r');
60
		$eol = "\n";// ATTENTION : avec Qmail laisser seulement \n car il remplace automatiquement par \r\n
61
		$eol = "\n";// ATTENTION : avec Qmail laisser seulement \n car il remplace automatiquement par \r\n
61
 
62
 
62
		// Définition d'un mail en texte simple et html
63
		// Définition d'un mail en texte simple et html
63
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
64
		// multipart/alternative signifie même contenu de la forme la plus simple à la plus complexe
64
		$entetes = 'X-Sender: <http://www.tela-botanica.org>'.$eol.
65
		$entetes = 'X-Sender: <http://www.tela-botanica.org>'.$eol.
65
			'X-Mailer: PHP-DEL-SCRIPTS'.$eol.
66
			'X-Mailer: PHP-DEL-SCRIPTS'.$eol.
66
			'X-auth-smtp-user: '.$emailExpediteur.$eol.
67
			'X-auth-smtp-user: '.$emailExpediteur.$eol.
67
			'X-abuse-contact: '.$emailExpediteur.$eol.
68
			'X-abuse-contact: '.$emailExpediteur.$eol.
68
			'Date: '.$dateHeure.$eol.
69
			'Date: '.$dateHeure.$eol.
69
			'From: '.$emailExpediteur.$eol.
70
			'From: '.$emailExpediteur.$eol.
-
 
71
			'Reply-To: '.$this->conteneur->getParametre('adresse_reponse').$eol.
70
			'MIME-Version: 1.0'.$eol.
72
			'MIME-Version: 1.0'.$eol.
71
			"Content-Type: text/plain; charset=\"$encodage\";".$eol.$eol;
73
			"Content-Type: text/plain; charset=\"$encodage\";".$eol.$eol;
72
 
74
 
73
		// le message en html est préféré s'il est lisible
75
		// le message en html est préféré s'il est lisible
74
		$contenu = $messageTxt.$eol.$eol;
76
		$contenu = $messageTxt.$eol.$eol;
75
 
77
 
76
		$envoieStatut = $this->envoyer($destinataires, $entetes, $sujetEncode, $contenu);
78
		$envoieStatut = $this->envoyer($destinataires, $entetes, $sujetEncode, $contenu);
77
 
79
 
78
		return $envoieStatut;
80
		return $envoieStatut;
79
	}
81
	}
80
 
82
 
81
	private function envoyer($destinataires, $entetes, $sujet, $contenu) {
83
	private function envoyer($destinataires, $entetes, $sujet, $contenu) {
82
		$envoieStatut = mail(
84
		$envoieStatut = mail(
83
			$destinataires,
85
			$destinataires,
84
			$sujet,
86
			$sujet,
85
			$contenu,
87
			$contenu,
86
			$entetes
88
			$entetes
87
		);
89
		);
88
		return $envoieStatut;
90
		return $envoieStatut;
89
	}
91
	}
90
 
92
 
91
	/** Transforme automatiquement le message html en message txt.
93
	/** Transforme automatiquement le message html en message txt.
92
	 *
94
	 *
93
	 * Réalise un stip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
95
	 * Réalise un stip_tags et avant ça un remplacement des liens sur mesure pour les mettre au format email txt.
94
	 */
96
	 */
95
	private function supprimerHtml($messageHtml) {
97
	private function supprimerHtml($messageHtml) {
96
		$html = $this->ajouterHrefDansBalise($messageHtml);
98
		$html = $this->ajouterHrefDansBalise($messageHtml);
97
		$messageSansHtml = strip_tags($html);
99
		$messageSansHtml = strip_tags($html);
98
		return $messageSansHtml;
100
		return $messageSansHtml;
99
	}
101
	}
100
 
102
 
101
	/**
103
	/**
102
	 * Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
104
	 * Extrait la valeur de l'attribut href des balises HTML de liens (a) et ajoute le lien entre
103
	 * chevrons (<>) dans le contenu de la balise "a".
105
	 * chevrons (<>) dans le contenu de la balise "a".
104
	 */
106
	 */
105
	private function ajouterHrefDansBalise($html) {
107
	private function ajouterHrefDansBalise($html) {
106
		libxml_use_internal_errors(true);
108
		libxml_use_internal_errors(true);
107
		$dom = new DOMDocument();
109
		$dom = new DOMDocument();
108
		$dom->loadHTML($html);
110
		$dom->loadHTML($html);
109
		foreach ($dom->getElementsByTagName('a') as $node) {
111
		foreach ($dom->getElementsByTagName('a') as $node) {
110
			if ($node->hasAttribute( 'href' )) {
112
			if ($node->hasAttribute( 'href' )) {
111
				$href = $node->getAttribute('href');
113
				$href = $node->getAttribute('href');
112
				$node->nodeValue = $node->nodeValue." ( $href )";
114
				$node->nodeValue = $node->nodeValue." ( $href )";
113
			}
115
			}
114
		}
116
		}
115
		$html = $dom->saveHtml();
117
		$html = $dom->saveHtml();
116
		return $html;
118
		return $html;
117
	}
119
	}
118
 
120
 
119
	private function nettoyerTxt($message) {
121
	private function nettoyerTxt($message) {
120
		$messageSansTab = preg_replace('/\t+/', '', $message);
122
		$messageSansTab = preg_replace('/\t+/', '', $message);
121
		$messageSansRetourMultiple = preg_replace('/\n+/', "\n", $messageSansTab);
123
		$messageSansRetourMultiple = preg_replace('/\n+/', "\n", $messageSansTab);
122
		$messageTxt = html_entity_decode($messageSansRetourMultiple, null, 'UTF-8');
124
		$messageTxt = html_entity_decode($messageSansRetourMultiple, null, 'UTF-8');
123
		return $messageTxt;
125
		return $messageTxt;
124
	}
126
	}
125
}
127
}