Subversion Repositories eFlore/Applications.del

Rev

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

Rev 2037 Rev 2038
Line 1... Line 1...
1
<?php
1
<?php
2
// declare(encoding='UTF-8');
2
// declare(encoding='UTF-8');
3
/**
3
/**
4
 * Le script récupère tous les commentaires et déterminations fait ce jour et envoie un mail
4
 * Le script récupère tous les commentaires et déterminations fait ce jour et envoie un mail
5
 * aux auteurs des observations récapitulant celle-ci
5
 * aux auteurs des observations récapitulant celle-ci
-
 
6
 * Si un commentaire porte sur un autre commentaire, un message est envoyé à l'auteur
-
 
7
 * de celui-ci pour l'avertir de celui-là
6
 *
8
 *
7
 * @category   DEL
9
 * @category   DEL
8
 * @package    Scripts
10
 * @package    Scripts
9
 * @subpackage Commentaires
11
 * @subpackage Commentaires
10
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
12
 * @author     Mathias CHOUET <mathias@tela-botanica.org>
11
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
13
 * @author     Jean-Pascal MILCENT <jpm@tela-botanica.org>
12
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
14
 * @author     Aurelien PERONNET <aurelien@tela-botanica.org>
-
 
15
 * @author	   Michel GALABRU <ajudant-gerber@tela-botanica.org>
13
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
16
 * @license    GPL v3 <http://www.gnu.org/licenses/gpl.txt>
14
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
17
 * @license    CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
15
 * @copyright  1999-2014 Tela Botanica <accueil@tela-botanica.org>
18
 * @copyright  1999-2015 Tela Botanica <accueil@tela-botanica.org>
16
 */
19
 */
17
class AlerteMailCommentaires {
20
class AlerteMailCommentaires {
Line 18... Line 21...
18
 
21
 
19
	private $conteneur;
22
	protected $conteneur;
20
	private $testeurCourriel = null;
23
	protected $testeurCourriel = null;
21
	private $recapitulatifAdmin = [];
24
	protected $recapitulatifAdmin = [];
22
	private $messageRecapitulatif = null;
-
 
23
 
25
	protected $messageRecapitulatif = null;
24
	private $dateRenvoi = null;
26
	protected $dateRenvoi = null;
25
 
27
 
-
 
28
	protected $observations_concernees = array();
26
	private $observations_concernees = array();
29
	protected $commentaires_concernes = array();
27
	private $correspondance_id_obs_auteurs = array();
30
	protected $correspondance_id_obs_auteurs = array();
Line 28... Line 31...
28
	private 	$utilisateursInfos = array();
31
	protected $utilisateursInfos = array();
29
 
32
 
30
	public function __construct($conteneur) {
33
	public function __construct($conteneur) {
Line 31... Line 34...
31
		$this->conteneur = $conteneur;
34
		$this->conteneur = $conteneur;
32
	}
35
	}
33
 
36
 
34
	public function executer() {
37
	public function executer() {
35
		try {
38
		try {
36
			$this->verifierModeUtilisation();
39
			$this->verifierModeUtilisation();
37
			$this->verifierDateRenvoi();
40
			$this->verifierDateRenvoi();
38
			$observations = $this->chargerObservationsCommentees();
-
 
39
			if (!empty($observations)) {
41
			$observationsCommentees = $this->chargerObservationsCommentees();
40
				$this->formaterObservations($observations);
42
			$commentairesCommentes = $this->chargerCommentairesCommentes();
41
				$commentaires = $this->chargerCommentairesDuJour();
-
 
42
				$this->formaterCommentaires($commentaires);
43
			$this->formaterObservationsCommentees($observationsCommentees);
43
				$this->envoyerMessageAuxDestinataires();
44
			$this->formaterCommentairesCommentes($commentairesCommentes);
44
			}
45
			$this->envoyerMessageAuxDestinataires();
45
		} catch (Exception $e) {
46
		} catch (Exception $e) {
Line -... Line 47...
-
 
47
			echo "ERREUR: " . $e->getMessage() . "\n";
-
 
48
		}
-
 
49
	}
46
			$this->traiterErreur($e->getMessage());
50
 
47
		}
51
	/**
48
	}
52
	 * Passe en mode "test" si l'adresse email d'un testeur est fournie avec "-t"
49
 
53
	 */
50
	private function verifierModeUtilisation() {
54
	protected function verifierModeUtilisation() {
51
		$testeurCourriel = $this->conteneur->getParametre('t');
55
		$testeurCourriel = $this->conteneur->getParametre('t');
52
		if ($testeurCourriel) {
56
		if ($testeurCourriel) {
53
			if (filter_var($testeurCourriel, FILTER_VALIDATE_EMAIL)) {
57
			if (filter_var($testeurCourriel, FILTER_VALIDATE_EMAIL)) {
54
				$this->testeurCourriel = $testeurCourriel;
58
				$this->testeurCourriel = $testeurCourriel;
55
			} else {
59
			} else {
56
				$msg = "Veuillez indiquer une adresse de courriel valide à la suite du paramètre «-t».";
60
				$msg = "Veuillez indiquer une adresse de courriel valide à la suite du paramètre «-t».";
Line -... Line 61...
-
 
61
				throw new Exception($msg);
-
 
62
			}
-
 
63
		}
57
				new Exception($msg);
64
	}
58
			}
65
 
59
		}
66
	/**
60
	}
67
	 * Simule l'envoi à une date arbitraire, si celle-ci est fournie avec "-d"
61
 
68
	 */
62
	private function verifierDateRenvoi() {
69
	protected function verifierDateRenvoi() {
63
		$dateRenvoi = $this->conteneur->getParametre('d');
70
		$dateRenvoi = $this->conteneur->getParametre('d');
64
		if ($dateRenvoi) {
71
		if ($dateRenvoi) {
65
			if (preg_match('/^[0-9]{4}-[0-1][0-9]-[0-3][0-9]$/', $dateRenvoi)) {
72
			if (preg_match('/^[0-9]{4}-[0-1][0-9]-[0-3][0-9]$/', $dateRenvoi)) {
66
				$this->dateRenvoi = $dateRenvoi;
73
				$this->dateRenvoi = $dateRenvoi;
67
			} else {
74
			} else {
Line -... Line 75...
-
 
75
				$msg = "Veuillez indiquer une date au format yyyy-mm-dd valide à la suite du paramètre «-d».";
-
 
76
				throw new Exception($msg);
-
 
77
			}
-
 
78
		}
68
				$msg = "Veuillez indiquer une date au format yyyy-mm-dd valide à la suite du paramètre «-d».";
79
	}
69
				new Exception($msg);
80
 
70
			}
81
	/**
71
		}
82
	 * Charge toutes les observations ayant été commentées dans les dernières 24h
Line 72... Line 83...
72
	}
83
	 * et dont l'auteur souhaite être averti des commentaires
73
 
84
	 */
74
	private function chargerObservationsCommentees() {
-
 
75
		// Seuls les utilisateurs ayant explicitement refusé le mail sont ignorés
-
 
76
		$preferences = $this->conteneur->getBdd()->proteger('%"mail_notification_mes_obs":"0"%');
85
	protected function chargerObservationsCommentees() {
77
		$date = ($this->dateRenvoi == null) ? 'NOW()' : "'$this->dateRenvoi'";
-
 
78
 
86
		// Seuls les utilisateurs ayant explicitement refusé le mail sont ignorés
79
		//TODO: optimiser la requête si beaucoup de mails sont envoyés
87
		$preferences = $this->conteneur->getBdd()->proteger('%"mail_notification_mes_obs":"0"%');
80
		$requete = "SELECT * FROM del_observation AS do ".
-
 
81
			"WHERE do.id_observation IN ".
-
 
82
				"( ".
-
 
83
					//TODO: essayer de factoriser cette sous requete entre ici et la fonction du dessus
88
		$date = ($this->dateRenvoi == null) ? 'NOW()' : "'$this->dateRenvoi'";
84
					"SELECT dc.ce_observation ".
-
 
85
					"FROM del_commentaire AS dc ".
89
 
86
					"WHERE dc.ce_observation != '0' ".
-
 
87
					"AND dc.id_commentaire NOT IN ".
-
 
88
					"( ".
90
		$requete = "SELECT do.id_observation, do.ce_utilisateur, do.courriel_utilisateur, do.date_observation"
89
					"	SELECT dc.id_commentaire ".
-
 
90
					"	FROM del_commentaire AS dc, del_observation AS dob".
91
		. ", do.nom_sel, do.nom_ret, do.zone_geo, do.ce_zone_geo, do.lieudit, do.station"
91
					"	WHERE dc.nom_sel = dob.nom_sel ".
-
 
92
					"		AND dc.ce_utilisateur = dob.ce_utilisateur ".
-
 
93
					"		AND dc.ce_observation = dob.id_observation ".
-
 
94
					") ".
92
		. ", dc.nom_sel as dc_nom_sel, dc.utilisateur_prenom as dc_utilisateur_prenom, dc.utilisateur_nom as dc_utilisateur_nom, dc.texte as dc_texte"
95
					"AND TO_DAYS($date) - TO_DAYS(dc.date) IN (0, 1) ".
93
		. " FROM del_commentaire dc" // tous les commentaires
96
				") ".
94
		. " LEFT JOIN del_observation do" // infos obs d'origine
-
 
95
		. " ON dc.ce_observation = do.id_observation"
97
				"AND do.ce_utilisateur NOT IN ".
96
		. " WHERE (dc.ce_utilisateur != do.ce_utilisateur AND dc.utilisateur_courriel != do.courriel_utilisateur)" // en excluant les gens qui se parlent à eux-mêmes
98
					"( ".
97
		. " AND TO_SECONDS($date) - TO_SECONDS(dc.date) < 86400 AND TO_SECONDS($date) - TO_SECONDS(dc.date) > 0" // depuis moins de 24h
99
					"	SELECT id_utilisateur ".
98
		. " AND do.ce_utilisateur NOT IN ("
Line -... Line 99...
-
 
99
		. " 	SELECT id_utilisateur FROM del_utilisateur_infos WHERE preferences LIKE $preferences" // si l'auteur d'origine souhaite être averti
-
 
100
		. ")"
-
 
101
		. " -- " .__FILE__.':'.__LINE__;
-
 
102
 
-
 
103
		$observations = $this->conteneur->getBdd()->recupererTous($requete);
-
 
104
		return $observations;
-
 
105
	}
-
 
106
 
-
 
107
	/**
-
 
108
	 * Charge tous les commentaires ayant reçu une réponse dans les dernières 24h
-
 
109
	 * et dont l'auteur souhaite être averti des réponses à ses commentaires,
-
 
110
	 * le tout accompagné des infos de l'observation d'origine
-
 
111
	 */
-
 
112
	protected function chargerCommentairesCommentes() {
-
 
113
		// Seuls les utilisateurs ayant explicitement refusé le mail sont ignorés
-
 
114
		$preferences = $this->conteneur->getBdd()->proteger('%"mail_notification_mes_commentaires":"0"%');
-
 
115
		$date = ($this->dateRenvoi == null) ? 'NOW()' : "'$this->dateRenvoi'";
-
 
116
 
-
 
117
		$requete = "SELECT do.id_observation, do.ce_utilisateur, do.courriel_utilisateur, do.prenom_utilisateur, do.nom_utilisateur"
-
 
118
		. ",  do.date_observation, do.nom_sel, do.nom_ret, do.zone_geo, do.ce_zone_geo, do.lieudit, do.station"
-
 
119
		. ", dc.nom_sel as dc_nom_sel, dc.utilisateur_prenom as dc_utilisateur_prenom, dc.utilisateur_nom as dc_utilisateur_nom, dc.texte as dc_texte"
-
 
120
		. ", dco.id_commentaire as dco_id_commentaire, dco.ce_utilisateur as dco_ce_utilisateur, dco.date as dco_date, dco.texte as dco_texte"
-
 
121
		. ", dco.nom_sel as dco_nom_sel, dco.nom_ret as dco_nom_ret, dco.utilisateur_courriel as dco_utilisateur_courriel"
-
 
122
		. " FROM del_commentaire dc" // tous les commentaires
-
 
123
		. " LEFT JOIN del_commentaire dco" // portant sur un autre commentaire
-
 
124
		. " ON dc.ce_commentaire_parent = dco.id_commentaire"
-
 
125
		. " LEFT JOIN del_observation do" // infos obs d'origine
-
 
126
		. " ON dco.ce_observation = do.id_observation"
-
 
127
		. " WHERE (dc.ce_utilisateur != dco.ce_utilisateur AND dc.utilisateur_courriel != dco.utilisateur_courriel)" // en excluant les gens qui se parlent à eux-mêmes
-
 
128
		. " AND TO_SECONDS($date) - TO_SECONDS(dc.date) < 86400 AND TO_SECONDS($date) - TO_SECONDS(dc.date) > 0" // depuis moins de 24h
-
 
129
		. " AND dco.ce_utilisateur NOT IN ("
-
 
130
		. "		SELECT id_utilisateur FROM del_utilisateur_infos WHERE preferences LIKE $preferences" // si l'auteur d'origine souhaite être averti
100
					"	FROM del_utilisateur_infos ".
131
		. " )"
101
					"	WHERE preferences LIKE $preferences ".
132
		. " -- " .__FILE__.':'.__LINE__;
-
 
133
 
-
 
134
		$commentaires = $this->conteneur->getBdd()->recupererTous($requete);
102
					") ".
135
		return $commentaires;
-
 
136
	}
103
			"ORDER BY do.ce_utilisateur, do.id_observation ";
137
 
104
		$observations = $this->conteneur->getBdd()->recupererTous($requete);
138
	/**
105
		return $observations;
139
	 * Classe les observations par id_utilisateur (ou courriel si non inscrit)
-
 
140
	 * de l'auteur puis par id_observation, et enfile les données des commentaires
106
	}
141
	 * relatifs à chaque obs
107
 
142
	 */
108
	// classe les observations concernées par id_utilisateur (ou courriel si non inscrit)
143
	protected function formaterObservationsCommentees($liste) {
Line -... Line 144...
-
 
144
		//print_r($liste);
109
	// de l'auteur puis par id_observation
145
		foreach ($liste as $o) {
110
	private function formaterObservations($liste_obs) {
146
			$id_obs = $o['id_observation'];
111
		foreach ($liste_obs as $obs) {
147
			$id_auteur_obs = $o['ce_utilisateur'];
112
			$id_obs = $obs['id_observation'];
148
			// si utilisateur non inscrit
113
			$id_auteur_obs = $obs['ce_utilisateur'];
149
			if (($id_auteur_obs == 0) && ($o['courriel_utilisateur'] != '')) {
114
			if (($id_auteur_obs == 0) && ($obs['courriel_utilisateur'] != '')) {
150
				$id_auteur_obs = $o['courriel_utilisateur'];
115
				$id_auteur_obs = $obs['courriel_utilisateur'];
151
			}
Line 116... Line -...
116
			}
-
 
117
 
-
 
118
			$infos = array();
-
 
119
			$infos['id'] = $id_obs;
-
 
120
			$infos['nom_sci'] = $this->formaterNomSci($obs);
-
 
121
			$infos['date'] = $this->formaterDate($obs['date_observation']);
-
 
122
			$infos['lieu'] = $this->formaterLieu($obs);
-
 
123
			$infos['lien'] = $this->obtenirLienFiche($id_obs);
-
 
124
			$infos['commentaires'] = array();
-
 
125
 
-
 
126
			$this->correspondance_id_obs_auteurs[$id_obs] = $id_auteur_obs;
-
 
127
			$this->observations_concernees[$id_auteur_obs][$id_obs] = $infos;
-
 
128
		}
-
 
129
	}
-
 
130
 
-
 
131
	private function formaterNomSci($obs) {
-
 
132
		$nom = 'Espèce indéterminée';
-
 
133
		if ($obs['nom_ret'] != '') {
-
 
134
			$nom = $obs['nom_ret'];
-
 
135
		} else if($obs['nom_sel'] != '') {
-
 
136
			$nom = $obs['nom_sel'];
-
 
137
		}
152
 
138
		return $nom;
-
 
139
	}
-
 
140
 
153
			// infos à mentionner dans l'email
141
	private function formaterDate($date) {
-
 
142
		$dateFmt = '(date inconnue)';
154
			$infos = array();
143
		if ($date != '0000-00-00 00:00:00') {
-
 
144
			$time = strtotime($date);
-
 
145
			$dateFmt = date('d/m/Y', $time);
-
 
146
		}
155
			$infos['id'] = $id_obs;
-
 
156
			$infos['nom_sci'] = $this->formaterNomSci($o);
-
 
157
			$infos['date'] = $this->formaterDate($o['date_observation']);
Line 147... Line 158...
147
		return $dateFmt;
158
			$infos['lieu'] = $this->formaterLieu($o);
148
	}
-
 
149
 
159
			$infos['lien'] = $this->obtenirLienFiche($id_obs);
150
	private function formaterLieu($obs) {
-
 
151
		$lieuInfos = [];
-
 
152
		$champsLieu = ['zone_geo', 'lieudit', 'station'];
160
			$infos['commentaires'] = array();
153
		foreach ($champsLieu as $champ) {
-
 
154
			if (trim($obs[$champ]) == '') {
-
 
155
				continue;
-
 
156
			}
-
 
157
 
-
 
158
			$lieuIntitule = $obs[$champ];
161
 
159
			if ($champ == 'zone_geo') {
-
 
160
				$codeDept = $this->convertirCodeZoneGeoVersDepartement($obs['ce_zone_geo']);
162
			// mode gentleman
161
				$lieuIntitule .= empty($codeDept) ? '' : " ($codeDept)";
-
 
162
			}
163
			if (! isset($this->observations_concernees[$id_auteur_obs])) {
163
			$lieuInfos[] = $lieuIntitule;
164
				$this->observations_concernees[$id_auteur_obs] = array();
164
		}
165
			}
165
		$lieu = (count($lieuInfos) > 0) ? implode(' > ', $lieuInfos) : '(lieu inconnu)';
166
			$this->observations_concernees[$id_auteur_obs][$id_obs] = $infos;
166
		return $lieu;
-
 
167
	}
-
 
168
 
167
			$this->observations_concernees[$id_auteur_obs][$id_obs]['commentaires'] = array();
169
	private function convertirCodeZoneGeoVersDepartement($code_zone_geo) {
-
 
170
		$code_departement = '';
-
 
171
		if (preg_match('/^INSEE-C:([0-9]{2})[0-9]{3}$/', $code_zone_geo, $match)) {
-
 
172
			$code_departement = $match[1];
-
 
173
		}
-
 
174
		return $code_departement;
168
 
175
	}
-
 
176
 
-
 
177
	private function obtenirLienFiche($id_obs) {
-
 
178
		return sprintf($this->conteneur->getParametre('url_fiche_observation'), $id_obs);
-
 
179
	}
-
 
180
 
-
 
181
	protected function chargerCommentairesDuJour() {
169
			// isolation des données du commentaire
182
		$preferences = $this->conteneur->getBdd()->proteger('%"mail_notification_mes_obs":"0"%');
-
 
183
		$date = ($this->dateRenvoi == null) ? 'NOW()' : "'$this->dateRenvoi'";
-
 
184
 
170
			$commentaire = $this->arrayTranchette($o, 'dc_', true);
185
		// TODO: optimiser la requête si beaucoup de mails sont envoyés
-
 
186
		$requete = "SELECT * ".
-
 
187
			"FROM del_commentaire AS dc ".
-
 
188
			"WHERE dc.ce_observation != '0' ".
-
 
189
			"AND dc.id_commentaire NOT IN ".
-
 
190
			"( ".
-
 
191
			"	SELECT dc.id_commentaire ".
171
			//print_r($commentaire);
192
			"	FROM del_commentaire AS dc, del_observation AS dob".
-
 
193
			"	WHERE dc.nom_sel = dob.nom_sel ".
-
 
194
			"		AND dc.ce_utilisateur = dob.ce_utilisateur ".
172
			$commentaire['auteur'] = $this->formaterAuteurCommentaire($o);
195
			"		AND dc.ce_observation = dob.id_observation ".
173
			$this->observations_concernees[$id_auteur_obs][$id_obs]['commentaires'][] = $commentaire;
196
			") ".
-
 
197
			"AND dc.ce_utilisateur NOT IN ".
-
 
198
			"( ".
-
 
199
			"	SELECT id_utilisateur ".
174
		}
200
			"	FROM del_utilisateur_infos ".
175
		//print_r($this->observations_concernees); exit;
201
			"	WHERE preferences LIKE $preferences ".
176
	}
202
			") ".
177
 
203
			"AND TO_DAYS($date) - TO_DAYS(dc.date) IN (0, 1) ".
-
 
204
			"ORDER BY dc.ce_observation";
178
	/**
205
		$commentaires = $this->conteneur->getBdd()->recupererTous($requete);
179
	 * Classe les commentaires par id_utilisateur (ou courriel si non inscrit)
206
		return $commentaires;
-
 
207
	}
180
	 * de l'auteur puis par id_commentaire, et enfile les données des réponses
208
 
-
 
209
	protected function formaterCommentaires($liste_commentaires) {
-
 
210
		foreach ($liste_commentaires as $commentaire) {
-
 
211
			$id_obs = $commentaire['ce_observation'];
-
 
212
			if (isset($this->correspondance_id_obs_auteurs[$id_obs])) {
-
 
213
				$id_auteur_obs = $this->correspondance_id_obs_auteurs[$id_obs];
181
	 * (commentaires) relatives à chaque commentaire
214
				// si l'auteur du commentaire est l'auteur de l'obs, on évite de lui
-
 
215
				// rappeler qu'il se parle à lui-même
-
 
Line -... Line 182...
-
 
182
	 */
-
 
183
	protected function formaterCommentairesCommentes($liste) {
-
 
184
		//print_r($liste); exit;
-
 
185
		foreach ($liste as $o) {
216
				$id_auteur_commentaire = $commentaire['ce_utilisateur'];
186
			// infos sur le commentaire d'origine
-
 
187
			$id_co = $o['dco_id_commentaire'];
217
				if ($id_auteur_commentaire == 0 || $id_auteur_commentaire == '') { // cas du commentateur non-inscrit
188
			$id_auteur_co = $o['dco_ce_utilisateur'];
218
					$id_auteur_commentaire = $commentaire['utilisateur_courriel'];
189
			// si utilisateur non inscrit
-
 
190
			if (($id_auteur_co == 0) && ($o['dco_utilisateur_courriel'] != '')) {
-
 
191
				$id_auteur_co = $o['dco_utilisateur_courriel'];
-
 
192
			}
-
 
193
 
-
 
194
			// infos à mentionner dans l'email
-
 
195
			$infos = array();
-
 
196
			$infos['id_obs'] = $o['id_observation'];
-
 
197
			$id_auteur_obs = $o['ce_utilisateur'];
-
 
198
			// si utilisateur non inscrit
-
 
199
			if (($id_auteur_obs == 0) && ($o['courriel_utilisateur'] != '')) {
Line -... Line 200...
-
 
200
				$id_auteur_obs = $o['courriel_utilisateur'];
-
 
201
			}
-
 
202
			$infos['id_auteur_obs'] = $id_auteur_obs;
-
 
203
			$infos['auteur_obs'] = $this->formaterAuteurObs($o);
-
 
204
			$infos['nom_sci'] = $this->formaterNomSci($o);
-
 
205
			$infos['nom_sci_co'] = $this->formaterNomSci($o, 'dco_');
-
 
206
			$infos['date'] = $this->formaterDate($o['date_observation']);
-
 
207
			$infos['date_co'] = $this->formaterDate($o['dco_date']);
-
 
208
			$infos['texte_co'] = $o['dco_texte'];
-
 
209
			$infos['lieu'] = $this->formaterLieu($o);
-
 
210
			$infos['lien'] = $this->obtenirLienFiche($o['id_observation']);
-
 
211
			$infos['commentaires'] = array();
-
 
212
 
-
 
213
			// mode gentleman
-
 
214
			if (! isset($this->commentaires_concernes[$id_auteur_co])) {
-
 
215
				$this->commentaires_concernes[$id_auteur_co] = array();
-
 
216
			}
-
 
217
			$this->commentaires_concernes[$id_auteur_co][$id_co] = $infos;
-
 
218
			$this->commentaires_concernes[$id_auteur_co][$id_co]['commentaires'] = array();
-
 
219
 
-
 
220
			// isolation des données du commentaire
219
				}
221
			$commentaire = $this->arrayTranchette($o, 'dc_', true);
-
 
222
			$commentaire['auteur'] = $this->formaterAuteurCommentaire($o);
-
 
223
			$this->commentaires_concernes[$id_auteur_co][$id_co]['commentaires'][] = $commentaire;
-
 
224
		}
220
				if ($id_auteur_obs != $id_auteur_commentaire) {
225
		//print_r($this->commentaires_concernes); exit;
221
					$commentaire['auteur'] = $this->formaterAuteur($commentaire);
226
	}
222
					$this->observations_concernees[$id_auteur_obs][$id_obs]['commentaires'][] = $commentaire;
227
 
-
 
228
	/**
-
 
229
	 * Envoie un message par destinataire (auteur d'une observation ayant reçu
-
 
230
	 * un commentaire ou d'un commentaire ayant reçu une réponse), en format
-
 
231
	 * texte brut + HTML, avec un squelette différent selon que le destinataire
-
 
232
	 * est inscrit ou non; en mode test, n'envoie les messages qu'au testeur
-
 
233
	 */
-
 
234
	protected function envoyerMessageAuxDestinataires() {
-
 
235
		// liste des auteurs à contacter
-
 
236
		$auteurs = array_unique(array_merge(array_keys($this->observations_concernees), array_keys($this->commentaires_concernes)));
-
 
237
 
223
				}
238
		foreach ($auteurs as $auteurId) {
Line 224... Line 239...
224
			}
239
			$messageTxt = '';
225
		}
240
			$messageHtml = '';
226
	}
241
 
227
 
242
			// données concernant cet auteur
Line 258... Line 273...
258
		}
273
		}
259
		$this->envoyerMessagesTesteur();
274
		$this->envoyerMessagesTesteur();
260
	}
275
	}
Line 261... Line 276...
261
 
276
 
262
	// Envoie un message sans passer par l'annuaire, pour les utilisateurs non inscrits
277
	// Envoie un message sans passer par l'annuaire, pour les utilisateurs non inscrits
263
	private function envoyerMessageAdresseArbitraire($messageHtml, $messageTxt, $adresseAuteur) {
278
	protected function envoyerMessageAdresseArbitraire($messageHtml, $messageTxt, $adresseAuteur) {
264
		$dateFmt = $this->formaterDateCourante();
279
		$dateFmt = $this->formaterDateCourante();
265
		$sujet = sprintf($this->conteneur->getParametre('titre_message_recapitulatif'), $dateFmt);
280
		$sujet = sprintf($this->conteneur->getParametre('titre_message_recapitulatif'), $dateFmt);
Line 266... Line 281...
266
		$messagerie = $this->conteneur->getMessagerie();
281
		$messagerie = $this->conteneur->getMessagerie();
267
 
282
 
268
		// envoi mixte HTML + texte
283
		// envoi mixte HTML + texte
269
		$envoieStatut = $messagerie->envoyerHtml($adresseAuteur, $sujet, $messageHtml, $messageTxt);
284
		$envoieStatut = $messagerie->envoyerHtml($adresseAuteur, $sujet, $messageHtml, $messageTxt);
Line -... Line 285...
-
 
285
		return $envoieStatut;
-
 
286
	}
-
 
287
 
-
 
288
	/**
-
 
289
	 * Organise un peu les données d'un auteur pour les traiter plus facilement
-
 
290
	 * dans les squelettes de messages
-
 
291
	 */
-
 
292
	protected function formaterDonneesPourMessage($auteurId, $liste_obs, $liste_com) {
-
 
293
		$donnees = array(
-
 
294
			'liste_observations' => array(),
-
 
295
			'liste_commentaires' => array()
-
 
296
		);
-
 
297
		if ($liste_obs != null) {
-
 
298
			$donnees['liste_observations'] = $liste_obs;
-
 
299
		}
-
 
300
		if ($liste_com != null) {
-
 
301
			$donnees['liste_commentaires'] = $liste_com;
-
 
302
		}
-
 
303
 
-
 
304
		if (is_numeric($auteurId)) { // inscrit
-
 
305
			$infosUtilisateur = $this->telechargerUtilisateurInfos($auteurId);
-
 
306
			$donnees['auteur_formate'] = $this->formaterIntituleUtilisateur($infosUtilisateur);
-
 
307
		} else { // non-inscrit
-
 
308
			$donnees['auteur_formate'] = $auteurId;
-
 
309
		}
-
 
310
 
-
 
311
		return $donnees;
-
 
312
	}
-
 
313
 
-
 
314
	/**
270
		return $envoieStatut;
315
	 * Rédige un message HTML en appliquant les données fournies au squelette
271
	}
316
	 * adéquat, selon que le destinataire est inscrit ou non
272
 
317
	 */
273
	private function formaterMessageHtml($donnees, $inscrit=true) {
318
	protected function formaterMessageHtml($donnees, $inscrit=true) {
274
		if ($inscrit) {
319
		if ($inscrit) {
275
			$squelette = dirname(__FILE__).DS.'squelettes'.DS.'commentaires.tpl.html';
320
			$squelette = dirname(__FILE__).DS.'squelettes'.DS.'commentaires.tpl.html';
276
		} else {
321
		} else {
277
			$squelette = dirname(__FILE__).DS.'squelettes'.DS.'commentaires_non_inscrits.tpl.html';
322
			$squelette = dirname(__FILE__).DS.'squelettes'.DS.'commentaires_non_inscrits.tpl.html';
278
		}
323
		}
279
		$squelettePhp = $this->conteneur->getSquelettePhp();
324
		$squelettePhp = $this->conteneur->getSquelettePhp();
Line -... Line 325...
-
 
325
		$msgHtml = $squelettePhp->analyser($squelette, $donnees);
-
 
326
		return $msgHtml;
-
 
327
	}
-
 
328
 
280
		$msgHtml = $squelettePhp->analyser($squelette, $donnees);
329
	/**
281
		return $msgHtml;
330
	 * Rédige un message en texte brut en appliquant les données fournies au squelette
282
	}
331
	 * adéquat, selon que le destinataire est inscrit ou non
283
 
332
	 */
284
	private function formaterMessageTxt($donnees, $inscrit=true) {
333
	protected function formaterMessageTxt($donnees, $inscrit=true) {
285
		if ($inscrit) {
334
		if ($inscrit) {
Line 292... Line 341...
292
		// Nettoyage des tabulations pour indentation du code PHP
341
		// Nettoyage des tabulations pour indentation du code PHP
293
		$msgTxt = str_replace("\t", '', $msgTxt);
342
		$msgTxt = str_replace("\t", '', $msgTxt);
294
		return $msgTxt;
343
		return $msgTxt;
295
	}
344
	}
Line 296... Line -...
296
 
-
 
297
	private function formaterDonneesPourMessage($auteurId, $liste_obs) {
-
 
298
		$donnees = array();
-
 
299
		$donnees['liste_observations'] = $liste_obs;
-
 
300
 
-
 
301
		if (is_numeric($auteurId)) { // inscrit
-
 
302
			$infosUtilisateur = $this->telechargerUtilisateurInfos($auteurId);
-
 
303
			$donnees['auteur_formate'] = $this->formaterIntituleUtilisateur($infosUtilisateur);
-
 
304
		} else { // non-inscrit
-
 
305
			$donnees['auteur_formate'] = $auteurId;
-
 
306
		}
-
 
307
 
-
 
308
		return $donnees;
-
 
309
	}
-
 
310
 
-
 
311
	private function formaterIntituleUtilisateur($infos) {
-
 
312
		$intituleUtilisateur = isset($infos->intitule) ? $infos->intitule : '';
-
 
313
		return $intituleUtilisateur;
-
 
314
	}
-
 
315
 
345
 
316
	// envoie un message à un utilisateur inscrit, à l'aide de l'annuaire
346
	// envoie un message à un utilisateur inscrit, à l'aide de l'annuaire
Line 317... Line 347...
317
	private function envoyerMessage($messageHtml, $messageTxt, $id_destinataire) {
347
	protected function envoyerMessage($messageHtml, $messageTxt, $id_destinataire) {
318
 
348
 
319
		$url = sprintf($this->conteneur->getParametre('url_service_messagerie'), $id_destinataire);
349
		$url = sprintf($this->conteneur->getParametre('url_service_messagerie'), $id_destinataire);
320
		$dateFmt = $this->formaterDateCourante();
350
		$dateFmt = $this->formaterDateCourante();
Line 330... Line 360...
330
 
360
 
331
		$clientRest = $this->conteneur->getRestClient();
361
		$clientRest = $this->conteneur->getRestClient();
332
		$clientRest->modifier($url, $donnees);
362
		$clientRest->modifier($url, $donnees);
Line 333... Line -...
333
	}
-
 
334
 
-
 
335
	private function formaterDateCourante() {
-
 
336
		$date = ($this->dateRenvoi == null) ? time() : strtotime($this->dateRenvoi);
-
 
337
		$dateFmt = date('d-m-Y', $date);
-
 
338
		return $dateFmt;
-
 
339
	}
363
	}
340
 
364
 
341
	private function envoyerMessageRecap() {
365
	protected function envoyerMessageRecap() {
342
		$msgRecap = $this->obtenirMessageRecap();
366
		$msgRecap = $this->obtenirMessageRecap();
343
		$dateFmt = $this->formaterDateCourante();
367
		$dateFmt = $this->formaterDateCourante();
344
		$sujet = "IdentiPlante : commentaires du $dateFmt";
368
		$sujet = "IdentiPlante : commentaires du $dateFmt";
345
		$messagerie = $this->conteneur->getMessagerie();
369
		$messagerie = $this->conteneur->getMessagerie();
346
		$destinataire = $this->conteneur->getParametre('email_recap');
370
		$destinataire = $this->conteneur->getParametre('email_recap');
Line 347... Line 371...
347
		$messagerie->envoyerTxt($destinataire, $sujet, $msgRecap);
371
		$messagerie->envoyerTxt($destinataire, $sujet, $msgRecap);
348
	}
372
	}
349
 
373
 
350
	private function obtenirMessageRecap() {
374
	protected function obtenirMessageRecap() {
351
		if ($this->messageRecapitulatif == null) {
375
		if ($this->messageRecapitulatif == null) {
352
			$msgRecap = '';
376
			$msgRecap = '';
Line 364... Line 388...
364
		}
388
		}
365
		return $this->messageRecapitulatif;
389
		return $this->messageRecapitulatif;
366
	}
390
	}
Line 367... Line 391...
367
 
391
 
368
	// envoie au testeur une copie de chaque type de message envoyé aux utilisateurs
392
	// envoie au testeur une copie de chaque type de message envoyé aux utilisateurs
369
	private function envoyerMessagesTesteur() {
393
	protected function envoyerMessagesTesteur() {
370
		if ($this->testeurCourriel != null) {
394
		if ($this->testeurCourriel != null) {
371
			$messagerie = $this->conteneur->getMessagerie();
395
			$messagerie = $this->conteneur->getMessagerie();
Line 372... Line 396...
372
			$dateFmt = $this->formaterDateCourante();
396
			$dateFmt = $this->formaterDateCourante();
Line 376... Line 400...
376
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $msgRecap);
400
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $msgRecap);
Line 377... Line 401...
377
 
401
 
378
			// deux types de messages (inscrits et non inscrits)
402
			// deux types de messages (inscrits et non inscrits)
379
			$messageInscrits = null;
403
			$messageInscrits = null;
-
 
404
			$messageNonInscrits = null;
380
			$messageNonInscrits = null;
405
 
381
			// méga sous optimal
406
			// méga sous optimal
382
			foreach($this->recapitulatifAdmin as $idUtil => $mess) {
407
			foreach($this->recapitulatifAdmin as $idUtil => $mess) {
383
				if ($messageInscrits != null && $messageNonInscrits != null) {
408
				if ($messageInscrits != null && $messageNonInscrits != null) {
384
					break; // arrière, Satan ! (mais c'est bien pratique)
409
					break; // arrière, Satan ! (mais c'est bien pratique)
Line 395... Line 420...
395
 
420
 
396
			$sujet = "TESTEUR : TXT (inscrits) - commentaire du $dateFmt";
421
			$sujet = "TESTEUR : TXT (inscrits) - commentaire du $dateFmt";
Line 397... Line 422...
397
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $messageInscrits['txt']);
422
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $messageInscrits['txt']);
-
 
423
 
398
 
424
			$sujet = "TESTEUR : HTML (non inscrits) - commentaire du $dateFmt";
Line 399... Line 425...
399
			$sujet = "TESTEUR : HTML (non inscrits) - commentaire du $dateFmt";
425
			//echo "MNE HTML:: " . $messageNonInscrits['html'] . "\n\n"; exit;
400
			$messagerie->envoyerHtml($this->testeurCourriel, $sujet, $messageNonInscrits['html'], $messageNonInscrits['txt']);
426
			$messagerie->envoyerHtml($this->testeurCourriel, $sujet, $messageNonInscrits['html'], $messageNonInscrits['txt']);
401
 
427
 
402
			$sujet = "TESTEUR : TXT (non inscrits) - commentaire du $dateFmt";
428
			$sujet = "TESTEUR : TXT (non inscrits) - commentaire du $dateFmt";
Line 403... Line 429...
403
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $messageNonInscrits['txt']);
429
			$messagerie->envoyerTxt($this->testeurCourriel, $sujet, $messageNonInscrits['txt']);
404
		}
430
		}
405
	}
431
	}
406
 
432
 
407
	private function obtenirInfosUtilisateurs() {
433
	protected function obtenirInfosUtilisateurs() {
408
		$idUtilisateurs = array_keys($this->recapitulatifAdmin);
434
		$idUtilisateurs = array_keys($this->recapitulatifAdmin);
Line 418... Line 444...
418
		}
444
		}
419
		asort($utilisateursIntitules);
445
		asort($utilisateursIntitules);
420
		return $utilisateursIntitules;
446
		return $utilisateursIntitules;
421
	}
447
	}
Line 422... Line 448...
422
 
448
 
423
	private function telechargerUtilisateurInfos($utilisateurId) {
449
	protected function telechargerUtilisateurInfos($utilisateurId) {
424
		if (! isset($this->utilisateursInfos[$utilisateurId])) {
450
		if (! isset($this->utilisateursInfos[$utilisateurId])) {
425
			$urlTpl = $this->conteneur->getParametre('url_service_utilisateur');
451
			$urlTpl = $this->conteneur->getParametre('url_service_utilisateur');
426
			$url = sprintf($urlTpl, $utilisateurId);
452
			$url = sprintf($urlTpl, $utilisateurId);
427
			$clientRest = $this->conteneur->getRestClient();
453
			$clientRest = $this->conteneur->getRestClient();
428
			$json = $clientRest->consulter($url);
454
			$json = $clientRest->consulter($url);
-
 
455
			$infos = json_decode($json, true);
-
 
456
			if (is_array($infos)) {
-
 
457
				$infos = array_shift($infos);
429
			$infos = json_decode($json);
458
			}
430
			$this->utilisateursInfos[$utilisateurId] = isset($infos->id) ? $infos : $utilisateurId;
459
			$this->utilisateursInfos[$utilisateurId] = isset($infos['id']) ? $infos : $utilisateurId;
431
		}
460
		}
432
		return $this->utilisateursInfos[$utilisateurId];
461
		return $this->utilisateursInfos[$utilisateurId];
Line 433... Line 462...
433
	}
462
	}
434
 
463
 
435
	private function formaterUtilisateurInfos($infos) {
464
	protected function formaterUtilisateurInfos($infos) {
436
		$utilisateurId = isset($infos->id) ? $infos->id : intval($infos);
465
		$utilisateurId = isset($infos['id']) ? $infos['id'] : intval($infos);
437
		if (isset($infos->courriel) && isset($infos->intitule)) {
466
		if (isset($infos['courriel']) && isset($infos['intitule'])) {
438
			$prenomNom = $infos->nom.' '.$infos->prenom;
467
			$prenomNom = $infos['nom'].' '.$infos['prenom'];
439
			$pseudo = empty($infos->pseudo) ? '' : '['.$infos->pseudo.'] ';
468
			$pseudo = empty($infos['pseudo']) ? '' : '['.$infos['pseudo'].'] ';
440
			$courriel = $infos->courriel;
469
			$courriel = $infos['courriel'];
441
			$intitule = "$prenomNom $pseudo($courriel) - id#$utilisateurId";
470
			$intitule = "$prenomNom $pseudo($courriel) - id#$utilisateurId";
442
		} else {
471
		} else {
443
			$intitule = "Utilisateur avec id $utilisateurId introuvable";
472
			$intitule = "Utilisateur avec id $utilisateurId introuvable";
444
		}
473
		}
-
 
474
		return $intitule;
-
 
475
	}
-
 
476
 
-
 
477
	protected function formaterNomSci($obs, $prefixe='') {
-
 
478
		$cnr = $prefixe . 'nom_ret';
-
 
479
		$cns = $prefixe . 'nom_sel';
-
 
480
		$nom = 'Espèce indéterminée';
-
 
481
		if ($obs[$cnr] != '') {
-
 
482
			$nom = $obs[$cnr];
-
 
483
		} else if($obs[$cns] != '') {
-
 
484
			$nom = $obs[$cns];
-
 
485
		}
-
 
486
		return $nom;
-
 
487
	}
-
 
488
 
-
 
489
	protected function formaterDate($date) {
-
 
490
		$dateFmt = '(date inconnue)';
-
 
491
		if ($date != '0000-00-00 00:00:00') {
-
 
492
			$time = strtotime($date);
-
 
493
			$dateFmt = date('d/m/Y', $time);
-
 
494
		}
-
 
495
		return $dateFmt;
-
 
496
	}
-
 
497
 
-
 
498
	protected function formaterLieu($obs) {
-
 
499
		$lieuInfos = [];
-
 
500
		$champsLieu = ['zone_geo', 'lieudit', 'station'];
-
 
501
		foreach ($champsLieu as $champ) {
-
 
502
			if (trim($obs[$champ]) == '') {
-
 
503
				continue;
-
 
504
			}
-
 
505
 
-
 
506
			$lieuIntitule = $obs[$champ];
-
 
507
			if ($champ == 'zone_geo') {
-
 
508
				$codeDept = $this->convertirCodeZoneGeoVersDepartement($obs['ce_zone_geo']);
-
 
509
				$lieuIntitule .= empty($codeDept) ? '' : " ($codeDept)";
-
 
510
			}
-
 
511
			$lieuInfos[] = $lieuIntitule;
-
 
512
		}
-
 
513
		$lieu = (count($lieuInfos) > 0) ? implode(' > ', $lieuInfos) : '(lieu inconnu)';
-
 
514
		return $lieu;
-
 
515
	}
-
 
516
 
-
 
517
	protected function formaterDateCourante() {
-
 
518
		$date = ($this->dateRenvoi == null) ? time() : strtotime($this->dateRenvoi);
-
 
519
		$dateFmt = date('d-m-Y', $date);
-
 
520
		return $dateFmt;
-
 
521
	}
-
 
522
 
-
 
523
	protected function formaterAuteurObs($obs) {
-
 
524
		return $obs['prenom_utilisateur'].' '.$obs['nom_utilisateur'];
-
 
525
	}
-
 
526
 
-
 
527
	protected function formaterAuteurCommentaire($commentaire) {
-
 
528
		return $commentaire['dc_utilisateur_prenom'].' '.$commentaire['dc_utilisateur_nom'];
-
 
529
	}
-
 
530
 
-
 
531
	protected function formaterIntituleUtilisateur($infos) {
-
 
532
		$intituleUtilisateur = isset($infos['intitule']) ? $infos['intitule'] : '';
-
 
533
		return $intituleUtilisateur;
-
 
534
	}
-
 
535
 
-
 
536
	protected function convertirCodeZoneGeoVersDepartement($code_zone_geo) {
-
 
537
		$code_departement = '';
-
 
538
		if (preg_match('/^INSEE-C:([0-9]{2})[0-9]{3}$/', $code_zone_geo, $match)) {
-
 
539
			$code_departement = $match[1];
-
 
540
		}
-
 
541
		return $code_departement;
-
 
542
	}
-
 
543
 
-
 
544
	protected function obtenirLienFiche($id_obs) {
-
 
545
		return sprintf($this->conteneur->getParametre('url_fiche_observation'), $id_obs);
-
 
546
	}
-
 
547
 
-
 
548
	/**
-
 
549
	 * Copie dans un nouveau tableau les valeurs de $tab dont les clefs
-
 
550
	 * commencent par $prefixe
-
 
551
	 */
-
 
552
	protected function arrayTranchette($tab, $prefixe, $enleverPrefixe=false) {
-
 
553
		$res = array();
-
 
554
		foreach ($tab as $k => $v) {
-
 
555
			if (strpos($k, $prefixe) === 0) {
-
 
556
				$clef = $k;
-
 
557
				if ($enleverPrefixe === true) {
-
 
558
					$clef = substr($k, strlen($prefixe));
-
 
559
				}
-
 
560
				$res[$clef] = $v;
-
 
561
			}
-
 
562
		}
445
		return $intitule;
563
		return $res;
446
	}
564
	}