Files
outil-82/core/lib/Thelia/Log/AbstractTlogDestination.php
2021-01-19 18:19:37 +01:00

100 lines
3.3 KiB
PHP

<?php
/*************************************************************************************/
/* This file is part of the Thelia package. */
/* */
/* Copyright (c) OpenStudio */
/* email : dev@thelia.net */
/* web : http://www.thelia.net */
/* */
/* For the full copyright and license information, please view the LICENSE.txt */
/* file that was distributed with this source code. */
/*************************************************************************************/
namespace Thelia\Log;
abstract class AbstractTlogDestination
{
//Tableau de TlogDestinationConfig paramétrant la destination
protected $configs = array();
//Tableau des lignes de logs stockés avant utilisation par ecrire()
protected $logs = array();
public function __construct()
{
// Initialiser les variables de configuration
$this->configs = $this->getConfigs();
// Appliquer la configuration
$this->configure();
}
//Affecte une valeur à une configuration de la destination
public function setConfig($name, $value, $apply_changes = true)
{
foreach ($this->configs as $config) {
if ($config->getName() == $name) {
$config->setValue($value);
// Appliquer les changements
if ($apply_changes) {
$this->configure();
}
return true;
}
}
return false;
}
//Récupère la valeur affectée à une configuration de la destination
public function getConfig($name, $default = false)
{
foreach ($this->configs as $config) {
if ($config->getName() == $name) {
return $config->getValue();
}
}
return $default;
}
public function getConfigs()
{
return $this->configs;
}
//Ajoute une ligne de logs à la destination
public function add($string)
{
$this->logs[] = $string;
}
protected function insertAfterBody(&$res, $logdata)
{
$match = array();
if (preg_match("/(<body[^>]*>)/i", $res, $match)) {
$res = str_replace($match[0], $match[0] . "\n" . $logdata, $res);
}
}
// Demande à la destination de se configurer pour être prête
// a fonctionner. Si $config est != false, celà indique
// que seul le paramètre de configuration indiqué a été modifié.
protected function configure()
{
// Cette methode doit etre surchargée si nécessaire.
}
//Lance l'écriture de tous les logs par la destination
//$res : contenu de la page html
abstract public function write(&$res);
// Retourne le titre de cette destination, tel qu'affiché dans le menu de selection
abstract public function getTitle();
// Retourne une brève description de la destination
abstract public function getDescription();
}