Subversion Repositories Applications.reseau

Rev

Rev 54 | Go to most recent revision | Details | Compare with Previous | Last modification | View Log | RSS feed

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