Subversion Repositories Applications.reseau

Rev

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

Rev 19 Rev 46
1
<?php
1
<?php
2
/**
2
/**
3
 * Formulaire de remarques assisté
3
 * Formulaire de remarques assisté
4
 * - envoie un email et écrit dans un fichier log
4
 * - envoie un email et écrit dans un fichier log
5
 *
5
 *
6
 * Utilisation: http://www.tela-botanica.org/widget:reseau:remarques
6
 * Utilisation: http://www.tela-botanica.org/widget:reseau:remarques
7
 * Paramètres GET (optionnels):
7
 * Paramètres GET (optionnels):
8
 *   pageSource : URL de la page depuis laquelle l'utilisateur a cliqué sur "nous contacter"
8
 *   pageSource : URL de la page depuis laquelle l'utilisateur a cliqué sur "nous contacter"
9
 *     (exemple: http://www.tela-botanica.org/appli:cel)
9
 *   	(exemple: http://www.tela-botanica.org/appli:cel)
-
 
10
 *   service : service à l'adresse duquel envoyer le rapport, par défaut webmestre,
-
 
11
 *   	limité aux clefs de la liste self::$servicesAutorises
-
 
12
 *   	(exemple: cel)
10
 *   email : adresse à laquelle envoyer le rapport, par défaut webmestre@tela-botanica.org, limité à la liste self::$emailsAutorises
13
 *   email (DÉPRÉCIÉ) : adresse à laquelle envoyer le rapport, par défaut webmestre@tela-botanica.org,
-
 
14
 *   	limité aux valeurs de la liste self::$servicesAutorises
11
 *     (exemple: cel_remarques@tela-botanica.org)
15
 *   	(exemple: cel_remarques@tela-botanica.org)
12
 * 
16
 * 
13
 * @author	Mathias Chouet <mathias@tela-botanica.org>
17
 * @author	Mathias Chouet <mathias@tela-botanica.org>
14
 * @license	GPL v3 <http://www.gnu.org/licenses/gpl.txt>
18
 * @license	GPL v3 <http://www.gnu.org/licenses/gpl.txt>
15
 * @license	CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
19
 * @license	CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
16
 * @version	0.1
20
 * @version	0.1
17
 * @copyright 2014, Tela Botanica (accueil@tela-botanica.org)
21
 * @copyright 2014, Tela Botanica (accueil@tela-botanica.org)
18
 */
22
 */
19
class Remarques extends WidgetCommun {
23
class Remarques extends WidgetCommun {
20
 
24
 
21
	const DS = DIRECTORY_SEPARATOR;
25
	const DS = DIRECTORY_SEPARATOR;
22
 
26
 
23
	/**
27
	/**
24
	 * adresse de destination par défaut, si une adresse non autorisée est spécifiée,
28
	 * service de destination par défaut, si un service ou une adresse non autorisés sont spécifiés,
25
	 * ou si aucune adresse n'est spécifiée
29
	 * ou si aucun service ni adresse n'est spécifié
26
	 */
30
	 */
27
	const EMAIL_PAR_DEFAUT = 'webmestre@tela-botanica.org';
31
	const SERVICE_PAR_DEFAUT = 'webmestre';
28
 
32
 
29
	/**
33
	/**
30
	 * liste des adresses de destination autorisées
34
	 * liste des adresses de destination autorisées
31
	 */
35
	 */
32
	private static $emailsAutorises = array(
36
	private static $servicesAutorises = array(
33
		'eflore_remarques@tela-botanica.org',
37
		'eflore' => 'eflore_remarques@tela-botanica.org',
34
		'pictoflora_remarques@tela-botanica.org',
38
		'pictoflora' => 'pictoflora_remarques@tela-botanica.org',
35
		'identiplante_remarques@tela-botanica.org',
39
		'identiplante' => 'identiplante_remarques@tela-botanica.org',
36
		'cel_remarques@tela-botanica.org',
40
		'cel' => 'cel_remarques@tela-botanica.org',
37
		'coel_remarques@tela-botanica.org',
41
		'coel' => 'coel_remarques@tela-botanica.org',
38
		'webmestre@tela-botanica.org',
42
		'webmestre' => 'webmestre@tela-botanica.org',
39
		'accueil@tela-botanica.org',
43
		'accueil' => 'accueil@tela-botanica.org'
40
		'mathias@tela-botanica.org'
-
 
41
	);
44
	);
42
 
45
 
43
	protected $cheminLog;
46
	protected $cheminLog;
44
	protected $pageSource;
47
	protected $pageSource;
-
 
48
	protected $serviceDestination;
45
	protected $emailDestination;
49
	protected $emailDestination;
46
	protected $action;
50
	protected $action;
47
 
51
 
48
	protected $description;
52
	protected $description;
49
	protected $gravite;
53
	protected $gravite;
50
	protected $navigateur;
54
	protected $navigateur;
51
	protected $systeme;
55
	protected $systeme;
52
	protected $coordonnees;
56
	protected $coordonnees;
53
 
57
 
54
	public function __construct($config, $parametres) {
58
	public function __construct($config, $parametres) {
55
		parent::__construct($config, $parametres);
59
		parent::__construct($config, $parametres);
56
 
60
 
57
		$this->pageSource = 'inconnue';
61
		$this->pageSource = 'inconnue';
58
		$this->emailDestination = self::EMAIL_PAR_DEFAUT;
62
		$this->serviceDestination = self::SERVICE_PAR_DEFAUT;
-
 
63
		$this->emailDestination = self::$servicesAutorises[self::SERVICE_PAR_DEFAUT];
59
		$this->action = null;
64
		$this->action = null;
60
 
65
 
61
		$this->description = null;
66
		$this->description = null;
62
		$this->gravite = null;
67
		$this->gravite = null;
63
		$this->navigateur = null;
68
		$this->navigateur = null;
64
		$this->systeme = null;
69
		$this->systeme = null;
65
		$this->coordonnees = null;
70
		$this->coordonnees = null;
66
 
71
 
67
		$this->cheminLog = $this->config['remarques']['cheminFichierLog'];
72
		$this->cheminLog = $this->config['remarques']['cheminFichierLog'];
68
	}
73
	}
69
 
74
 
70
	/**
75
	/**
71
	 * Méthode appelée par défaut pour charger ce widget
76
	 * Méthode appelée par défaut pour charger ce widget
72
	 */
77
	 */
73
	public function executer() {
78
	public function executer() {
74
		$this->collecterParametres();
79
		$this->collecterParametres();
75
		$squelette = dirname(__FILE__) . self::DS . 'squelettes' . self::DS . 'remarques.tpl.php';
80
		$squelette = dirname(__FILE__) . self::DS . 'squelettes' . self::DS . 'remarques.tpl.php';
76
 
81
 
77
		$widget['donnees']['url_css'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/css/defaut.css');
82
		$widget['donnees']['url_css'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/css/defaut.css');
78
		$widget['donnees']['url_js'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/js/defaut.js');
83
		$widget['donnees']['url_js'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/js/defaut.js');
79
		$widget['donnees']['email'] = $this->emailDestination;
84
		$widget['donnees']['service'] = $this->serviceDestination;
80
		$widget['donnees']['page'] = $this->pageSource;
85
		$widget['donnees']['page'] = $this->pageSource;
81
		$widget['donnees']['envoye'] = false;
86
		$widget['donnees']['envoye'] = false;
82
 
87
 
83
		if ($this->action === 'envoyer') {
88
		if ($this->action === 'envoyer') {
84
			$widget['donnees']['envoye'] = true;
89
			$widget['donnees']['envoye'] = true;
85
			// 1) entrée dans le log
90
			// 1) entrée dans le log
86
			try {
91
			try {
87
				$this->log();
92
				$this->log();
88
			} catch (Exception $e) {
93
			} catch (Exception $e) {
89
				echo "Erreur lors de la création de l'entrée dans le fichier log<br/>";
94
				echo "Erreur lors de la création de l'entrée dans le fichier log<br/>";
90
			}
95
			}
91
			// 2) email
96
			// 2) email
92
			try {
97
			try {
93
				$this->email();
98
				$this->email();
94
			} catch (Exception $e) {
99
			} catch (Exception $e) {
95
				echo "Erreur lors de l'envoi de l'email<br/>";
100
				echo "Erreur lors de l'envoi de l'email<br/>";
96
			}
101
			}
97
		}
102
		}
98
 
103
 
99
		$contenu = $this->traiterSquelettePhp($squelette, $widget['donnees']);
104
		$contenu = $this->traiterSquelettePhp($squelette, $widget['donnees']);
100
		$this->envoyer($contenu);
105
		$this->envoyer($contenu);
101
	}
106
	}
102
 
107
 
103
	// paramètres du widget en GET et du formulaire en POST
108
	// paramètres du widget en GET et du formulaire en POST
104
	protected function collecterParametres() {
109
	protected function collecterParametres() {
105
		if (isset($_GET['pageSource']) && $_GET['pageSource'] != '') {
110
		if (isset($_GET['pageSource']) && $_GET['pageSource'] != '') {
106
			$this->pageSource = $_GET['pageSource'];
111
			$this->pageSource = $_GET['pageSource'];
107
		}
112
		}
-
 
113
		if (isset($_GET['service']) && in_array($_GET['service'], array_keys(self::$servicesAutorises))) {
-
 
114
			$this->serviceDestination = $_GET['service'];
-
 
115
			$this->emailDestination = self::$servicesAutorises[$_GET['service']];
-
 
116
		} else {
-
 
117
			// Rétrocompatibilité (déprécié)
108
		if (isset($_GET['email']) && in_array($_GET['email'], self::$emailsAutorises)) {
118
			if (isset($_GET['email']) && in_array($_GET['email'], self::$servicesAutorises)) {
109
			$this->emailDestination = $_GET['email'];
119
				$this->emailDestination = $_GET['email'];
-
 
120
				$this->serviceDestination = array_search($_GET['email'], self::$servicesAutorises);
-
 
121
			}
110
		}
122
		}
111
		if (isset($_POST['action']) && $_POST['action'] != '') {
123
		if (isset($_POST['action']) && $_POST['action'] != '') {
112
			$this->action = $_POST['action'];
124
			$this->action = $_POST['action'];
113
		}
125
		}
114
		// contenu du formulaire
126
		// contenu du formulaire
115
		if (isset($_POST['description']) && $_POST['description'] != '') {
127
		if (isset($_POST['description']) && $_POST['description'] != '') {
116
			$this->description = stripslashes($_POST['description']);
128
			$this->description = stripslashes($_POST['description']);
117
		}
129
		}
118
		if (isset($_POST['gravite']) && $_POST['gravite'] != '') {
130
		if (isset($_POST['gravite']) && $_POST['gravite'] != '') {
119
			$this->gravite = $_POST['gravite'];
131
			$this->gravite = $_POST['gravite'];
120
		}
132
		}
121
		if (isset($_POST['navigateur']) && $_POST['navigateur'] != '') {
133
		if (isset($_POST['navigateur']) && $_POST['navigateur'] != '') {
122
			$this->navigateur = stripslashes($_POST['navigateur']);
134
			$this->navigateur = stripslashes($_POST['navigateur']);
123
		}
135
		}
124
		if (isset($_POST['systeme']) && $_POST['systeme'] != '') {
136
		if (isset($_POST['systeme']) && $_POST['systeme'] != '') {
125
			$this->systeme = stripslashes($_POST['systeme']);
137
			$this->systeme = stripslashes($_POST['systeme']);
126
		}
138
		}
127
		if (isset($_POST['coordonnees']) && $_POST['coordonnees'] != '') {
139
		if (isset($_POST['coordonnees']) && $_POST['coordonnees'] != '') {
128
			$this->coordonnees = stripslashes($_POST['coordonnees']);
140
			$this->coordonnees = stripslashes($_POST['coordonnees']);
129
		}
141
		}
130
	}
142
	}
131
 
143
 
132
	// ajoute une entrée au log
144
	// ajoute une entrée au log
133
	protected function log() {
145
	protected function log() {
134
		$contenu = ''.
146
		$contenu = ''.
135
			date("Y-m-d h:i:s") . "\n".
147
			date("Y-m-d h:i:s") . "\n".
136
			"Pour: " . $this->emailDestination . "\n".
148
			"Pour: " . $this->serviceDestination . " <" . $this->emailDestination . ">\n".
137
			"Page: " . $this->pageSource . "\n".
149
			"Page: " . $this->pageSource . "\n".
138
			"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
150
			"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
139
			"Contributeur: " . $this->coordonnees . "\n".
151
			"Contributeur: " . $this->coordonnees . "\n".
140
			"Gravité: " . $this->gravite . "\n".
152
			"Gravité: " . $this->gravite . "\n".
141
			"Navigateur: " . $this->navigateur . "\n".
153
			"Navigateur: " . $this->navigateur . "\n".
142
			"Système: " . $this->systeme . "\n".
154
			"Système: " . $this->systeme . "\n".
143
			"Description:\n  " . str_replace("\n", "\n  ", $this->description).
155
			"Description:\n  " . str_replace("\n", "\n  ", $this->description).
144
			"\n\n-----------------------------------------------------------------------\n\n";
156
			"\n\n-----------------------------------------------------------------------\n\n";
145
 
157
 
146
		file_put_contents($this->cheminLog, $contenu, FILE_APPEND);
158
		file_put_contents($this->cheminLog, $contenu, FILE_APPEND);
147
	}
159
	}
148
 
160
 
149
	// envoie un email
161
	// envoie un email
150
	protected function email() {
162
	protected function email() {
151
		$contenu = ''.
163
		$contenu = ''.
152
			date("Y-m-d h:i:s") . "\n".
164
			date("Y-m-d h:i:s") . "\n".
153
			"Pour: " . $this->emailDestination . "\n".
165
			"Pour: " . $this->serviceDestination . " <" . $this->emailDestination . ">\n".
154
			"Page: " . $this->pageSource . "\n".
166
			"Page: " . $this->pageSource . "\n".
155
			"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
167
			"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
156
			"Contributeur: " . $this->coordonnees . "\n".
168
			"Contributeur: " . $this->coordonnees . "\n".
157
			"Gravité: " . $this->gravite . "\n".
169
			"Gravité: " . $this->gravite . "\n".
158
			"Navigateur: " . $this->navigateur . "\n".
170
			"Navigateur: " . $this->navigateur . "\n".
159
			"Système: " . $this->systeme . "\n".
171
			"Système: " . $this->systeme . "\n".
160
			"Description:\n  " . str_replace("\n", "\n  ", $this->description);
172
			"Description:\n  " . str_replace("\n", "\n  ", $this->description);
161
 
173
 
162
		$entetes = 'Content-Type: text/plain; charset="utf-8" '.
174
		$entetes = 'Content-Type: text/plain; charset="utf-8" '.
163
			'Content-Transfer-Encoding: 8bit';
175
			'Content-Transfer-Encoding: 8bit';
164
 
176
 
165
		$sujet = substr($this->description, 0, 25).'... '.
177
		$sujet = substr($this->description, 0, 25).'... '.
166
			'('.($this->coordonnees == '' ? 'inconnu' : $this->coordonnees).')';
178
			'('.($this->coordonnees == '' ? 'inconnu' : $this->coordonnees).')';
167
 
179
 
168
		// mode charlot - mais y a rien dans le framework pour faire mieux
180
		// mode charlot - mais y a rien dans le framework pour faire mieux
169
		mail($this->emailDestination, $sujet, $contenu, $entetes);
181
		mail($this->emailDestination, $sujet, $contenu, $entetes);
170
	}
182
	}
171
}
183
}
172
?>
184
?>