Rev 103 | Blame | Compare with Previous | Last modification | View Log | RSS feed
<?php
/**
* Formulaire de remarques assisté
* - envoie un email et écrit dans un fichier log
*
* Utilisation: http://www.tela-botanica.org/widget:reseau:remarques
* Paramètres GET (optionnels):
* pageSource : URL de la page depuis laquelle l'utilisateur a cliqué sur "nous contacter"
* (exemple: http://www.tela-botanica.org/appli:cel)
* service : service à l'adresse duquel envoyer le rapport, par défaut webmestre,
* limité aux clefs de la liste $this->servicesAutorises
* (exemple: cel)
* email (DÉPRÉCIÉ) : adresse à laquelle envoyer le rapport, par défaut webmestre@tela-botanica.org,
* limité aux valeurs de la liste $this->servicesAutorises
* (exemple: cel_remarques@tela-botanica.org)
* lang : langage (un squelette correspondant doit exister)
* (exemple: en)
*
* @author Mathias Chouet <mathias@tela-botanica.org>
* @license GPL v3 <http://www.gnu.org/licenses/gpl.txt>
* @license CECILL v2 <http://www.cecill.info/licences/Licence_CeCILL_V2-en.txt>
* @version 0.1
* @copyright 2014, Tela Botanica (accueil@tela-botanica.org)
*/
class Remarques extends WidgetCommun {
const DS = DIRECTORY_SEPARATOR;
/**
* service de destination par défaut, si un service ou une adresse non autorisés sont spécifiés,
* ou si aucun service ni adresse n'est spécifié
*/
const SERVICE_PAR_DEFAUT = 'webmestre';
/** liste des adresses de destination autorisées (à régler dans la config) */
protected $servicesAutorises;
protected $cheminLog;
protected $pageSource;
protected $serviceDestination;
protected $emailDestination;
protected $action;
protected $langue;
protected $langueDefaut;
protected $description;
protected $gravite;
protected $navigateur;
protected $systeme;
protected $coordonnees;
protected $token;
public function __construct($config, $parametres) {
parent::__construct($config, $parametres);
$this->servicesAutorises = $this->config['remarques-services'];
$this->pageSource = 'inconnue';
$this->serviceDestination = self::SERVICE_PAR_DEFAUT;
$this->emailDestination = $this->servicesAutorises[self::SERVICE_PAR_DEFAUT];
$this->action = null;
$this->description = null;
$this->gravite = null;
$this->navigateur = null;
$this->systeme = null;
$this->coordonnees = null;
$this->jeton = null;
$this->cheminLog = $this->config['remarques']['cheminFichierLog'];
$this->langueDefaut = $this->config['remarques']['langueDefaut'];
session_start();
if (!isset($_SESSION['jeton'])) {
$_SESSION['jeton'] = bin2hex(openssl_random_pseudo_bytes(6));
}
}
/**
* Méthode appelée par défaut pour charger ce widget
*/
public function executer() {
$this->collecterParametres();
$squelette = dirname(__FILE__) . self::DS . 'squelettes' . self::DS . 'remarques_' . $this->langue . '.tpl.php';
if (! file_exists($squelette)) {
$squelette = dirname(__FILE__) . self::DS . 'squelettes' . self::DS . 'remarques_' . $this->langueDefaut . '.tpl.php';
}
$widget['donnees']['url_css'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/css/defaut.css');
$widget['donnees']['url_js'] = sprintf($this->config['chemins']['baseURLAbsoluDyn'], 'modules/remarques/squelettes/js/defaut.js');
$widget['donnees']['service'] = $this->serviceDestination;
$widget['donnees']['page'] = $this->pageSource;
$widget['donnees']['envoye'] = false;
$widget['donnees']['jeton'] = $_SESSION['jeton'];
if ($this->action === 'envoyer' && $this->jeton === $_SESSION['jeton']) {
$widget['donnees']['envoye'] = true;
// 1) entrée dans le log
try {
$this->log();
} catch (Exception $e) {
echo "Erreur lors de la création de l'entrée dans le fichier log<br/>";
}
// 2) email
try {
$this->email();
} catch (Exception $e) {
echo "Erreur lors de l'envoi de l'email<br/>";
}
}
$contenu = $this->traiterSquelettePhp($squelette, $widget['donnees']);
$this->envoyer($contenu);
}
// paramètres du widget en GET et du formulaire en POST
protected function collecterParametres() {
if (isset($_GET['pageSource']) && $_GET['pageSource'] != '') {
$this->pageSource = $_GET['pageSource'];
}
if (isset($_GET['lang']) && $_GET['lang'] != '') {
$this->langue = $_GET['lang'];
} else {
$this->langue = $this->langueDefaut;
}
if (isset($_GET['service']) && in_array($_GET['service'], array_keys($this->servicesAutorises))) {
$this->serviceDestination = $_GET['service'];
$this->emailDestination = $this->servicesAutorises[$_GET['service']];
} else {
// Rétrocompatibilité (déprécié)
if (isset($_GET['email']) && in_array($_GET['email'], $this->servicesAutorises)) {
$this->emailDestination = $_GET['email'];
$this->serviceDestination = array_search($_GET['email'], $this->servicesAutorises);
}
}
if (isset($_POST['action']) && $_POST['action'] != '') {
$this->action = $_POST['action'];
}
// contenu du formulaire
if (isset($_POST['description']) && $_POST['description'] != '') {
$this->description = stripslashes($_POST['description']);
}
if (isset($_POST['gravite']) && $_POST['gravite'] != '') {
$this->gravite = $_POST['gravite'];
}
if (isset($_POST['navigateur']) && $_POST['navigateur'] != '') {
$this->navigateur = stripslashes($_POST['navigateur']);
}
if (isset($_POST['systeme']) && $_POST['systeme'] != '') {
$this->systeme = stripslashes($_POST['systeme']);
}
if (isset($_POST['coordonnees']) && $_POST['coordonnees'] != '') {
$this->coordonnees = stripslashes($_POST['coordonnees']);
}
$this->jeton = stripslashes($_POST['jeton'] ?? 'pasdejeton');
}
// ajoute une entrée au log
protected function log() {
$contenu = ''.
date("Y-m-d H:i:s") . "\n".
"Pour: " . $this->serviceDestination . " <" . $this->emailDestination . ">\n".
"Page: " . $this->pageSource . "\n".
"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
"Contributeur: " . $this->coordonnees . "\n".
"Gravité: " . $this->gravite . "\n".
"Navigateur: " . $this->navigateur . "\n".
"Système: " . $this->systeme . "\n".
"Description:\n " . str_replace("\n", "\n ", $this->description).
"\n\n-----------------------------------------------------------------------\n\n";
file_put_contents($this->cheminLog, $contenu, FILE_APPEND);
}
// envoie un email
protected function email() {
$contenu = ''.
date("Y-m-d H:i:s") . "\n".
"Pour: " . $this->serviceDestination . " <" . $this->emailDestination . ">\n".
"Page: " . $this->pageSource . "\n".
"User agent: " . $_SERVER['HTTP_USER_AGENT'] . "\n".
"Contributeur: " . $this->coordonnees . "\n".
"Gravité: " . $this->gravite . "\n".
"Navigateur: " . $this->navigateur . "\n".
"Système: " . $this->systeme . "\n".
"Description:\n " . str_replace("\n", "\n ", $this->description);
$entetes = 'Content-Type: text/plain; charset="utf-8" '.
'Content-Transfer-Encoding: 8bit';
$sujet = substr($this->description, 0, 25).'... '.
'('.($this->coordonnees == '' ? 'inconnu' : $this->coordonnees).')';
// mode charlot - mais y a rien dans le framework pour faire mieux
mail($this->emailDestination, $sujet, $contenu, $entetes);
}
}
?>