Subversion Repositories Applications.annuaire

Rev

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

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