mirror of
https://github.com/FreshRSS/FreshRSS.git
synced 2025-12-23 21:47:44 -05:00
* PHPStan 2.0 fix https://github.com/FreshRSS/FreshRSS/issues/6989 https://github.com/phpstan/phpstan/releases/tag/2.0.0 https://github.com/phpstan/phpstan/blob/2.0.x/UPGRADING.md * More * More * Done * fix i18n CLI * Restore a PHPStan Next test For work towards PHPStan Level 10 * 4 more on Level 10 * fix getTagsForEntry * API at Level 10 * More Level 10 * Finish Minz at Level 10 * Finish CLI at Level 10 * Finish Controllers at Level 10 * More Level 10 * More * Pass bleedingEdge * Clean PHPStan options and add TODOs * Level 10 for main config * More * Consitency array vs. list * Sanitize themes get_infos * Simplify TagDAO->getTagsForEntries() * Finish reportAnyTypeWideningInVarTag * Prepare checkBenevolentUnionTypes and checkImplicitMixed * Fixes * Refix * Another fix * Casing of __METHOD__ constant
83 lines
2.1 KiB
PHP
83 lines
2.1 KiB
PHP
<?php
|
|
declare(strict_types=1);
|
|
|
|
/**
|
|
* MINZ - Copyright 2011 Marien Fressinaud
|
|
* Sous licence AGPL3 <http://www.gnu.org/licenses/>
|
|
*/
|
|
|
|
/**
|
|
* The Minz_Error class logs and raises framework errors
|
|
*/
|
|
class Minz_Error {
|
|
public function __construct() {}
|
|
|
|
/**
|
|
* Permet de lancer une erreur
|
|
* @param int $code le type de l'erreur, par défaut 404 (page not found)
|
|
* @param string|array<'error'|'warning'|'notice',list<string>> $logs logs d'erreurs découpés de la forme
|
|
* > $logs['error']
|
|
* > $logs['warning']
|
|
* > $logs['notice']
|
|
* @param bool $redirect indique s'il faut forcer la redirection (les logs ne seront pas transmis)
|
|
*/
|
|
public static function error(int $code = 404, string|array $logs = [], bool $redirect = true): void {
|
|
$logs = self::processLogs($logs);
|
|
$error_filename = APP_PATH . '/Controllers/errorController.php';
|
|
|
|
if (file_exists($error_filename)) {
|
|
Minz_Session::_params([
|
|
'error_code' => $code,
|
|
'error_logs' => $logs,
|
|
]);
|
|
|
|
Minz_Request::forward(['c' => 'error'], $redirect);
|
|
} else {
|
|
echo '<h1>An error occurred</h1>' . "\n";
|
|
|
|
if (!empty($logs)) {
|
|
echo '<ul>' . "\n";
|
|
foreach ($logs as $log) {
|
|
echo '<li>' . $log . '</li>' . "\n";
|
|
}
|
|
echo '</ul>' . "\n";
|
|
}
|
|
|
|
exit();
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Returns filtered logs
|
|
* @param string|array<'error'|'warning'|'notice',list<string>> $logs logs sorted by category (error, warning, notice)
|
|
* @return list<string> list of matching logs, without the category, according to environment preferences (production / development)
|
|
*/
|
|
private static function processLogs($logs): array {
|
|
if (is_string($logs)) {
|
|
return [$logs];
|
|
}
|
|
|
|
$error = [];
|
|
$warning = [];
|
|
$notice = [];
|
|
|
|
if (is_array($logs['error'] ?? null)) {
|
|
$error = $logs['error'];
|
|
}
|
|
if (is_array($logs['warning'] ?? null)) {
|
|
$warning = $logs['warning'];
|
|
}
|
|
if (is_array($logs['notice'] ?? null)) {
|
|
$notice = $logs['notice'];
|
|
}
|
|
|
|
switch (Minz_Configuration::get('system')->environment) {
|
|
case 'development':
|
|
return array_merge($error, $warning, $notice);
|
|
case 'production':
|
|
default:
|
|
return $error;
|
|
}
|
|
}
|
|
}
|