Files
FreshRSS/lib/minz/Error.php
Alexandre Alapetite 878e96202e Grosse refactorisation pour permettre le chargement automatique des classes
C'est parti de changements pour
https://github.com/marienfressinaud/FreshRSS/issues/255 et finalement
j'ai continué la refactorisation...

Ajout de préfixes FreshRSS_ et Minz_ sur le modèle de SimplePie_.
Toutes les classes sont maintenant en chargement automatique (devrait
améliorer les performances en évitant de charger plein de classes
inutilisées, et faciliter la maintenance).
Suppression de set_include_path().
Si souhaité, certaines classes de Minz pourraient être déplacées dans un
sous-répertoire, par exemple les exceptions.

Tests et relecture nécessaires.
2013-12-15 03:30:24 +01:00

95 lines
2.2 KiB
PHP
Executable File

<?php
/**
* MINZ - Copyright 2011 Marien Fressinaud
* Sous licence AGPL3 <http://www.gnu.org/licenses/>
*/
/**
* La classe Error permet de lancer des erreurs HTTP
*/
class Minz_Error {
public function __construct () { }
/**
* Permet de lancer une erreur
* @param $code le type de l'erreur, par défaut 404 (page not found)
* @param $logs logs d'erreurs découpés de la forme
* > $logs['error']
* > $logs['warning']
* > $logs['notice']
* @param $redirect indique s'il faut forcer la redirection (les logs ne seront pas transmis)
*/
public static function error ($code = 404, $logs = array (), $redirect = false) {
$logs = self::processLogs ($logs);
$error_filename = APP_PATH . '/Controllers/ErrorController.php';
if (file_exists ($error_filename)) {
$params = array (
'code' => $code,
'logs' => $logs
);
Minz_Response::setHeader ($code);
if ($redirect) {
Minz_Request::forward (array (
'c' => 'error'
), true);
} else {
Minz_Request::forward (array (
'c' => 'error',
'params' => $params
), false);
}
} else {
$text = '<h1>An error occured</h1>'."\n";
if (!empty ($logs)) {
$text .= '<ul>'."\n";
foreach ($logs as $log) {
$text .= '<li>' . $log . '</li>'."\n";
}
$text .= '</ul>'."\n";
}
Minz_Response::setHeader ($code);
Minz_Response::setBody ($text);
Minz_Response::send ();
exit ();
}
}
/**
* Permet de retourner les logs de façon à n'avoir que
* ceux que l'on veut réellement
* @param $logs les logs rangés par catégories (error, warning, notice)
* @return la liste des logs, sans catégorie,
* > en fonction de l'environment
*/
private static function processLogs ($logs) {
$env = Minz_Configuration::environment ();
$logs_ok = array ();
$error = array ();
$warning = array ();
$notice = array ();
if (isset ($logs['error'])) {
$error = $logs['error'];
}
if (isset ($logs['warning'])) {
$warning = $logs['warning'];
}
if (isset ($logs['notice'])) {
$notice = $logs['notice'];
}
if ($env == Minz_Configuration::PRODUCTION) {
$logs_ok = $error;
}
if ($env == Minz_Configuration::DEVELOPMENT) {
$logs_ok = array_merge ($error, $warning, $notice);
}
return $logs_ok;
}
}