Subversion Repositories Applications.reseau

Rev

Rev 103 | Only display areas with differences | Ignore whitespace | Details | Blame | Last modification | View Log | RSS feed

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