mirror of
https://github.com/EGroupware/egroupware.git
synced 2024-11-07 08:34:29 +01:00
70 lines
2.1 KiB
PHP
70 lines
2.1 KiB
PHP
<?php
|
|
|
|
// EGroupware modification start
|
|
require_once __DIR__.'/_egw_include.php';
|
|
// initialize the autoloader
|
|
//require_once(dirname(dirname(__FILE__)) . '/lib/_autoload.php');
|
|
// EGroupware modification end
|
|
|
|
// enable assertion handler for all pages
|
|
\SimpleSAML\Error\Assertion::installHandler();
|
|
|
|
// show error page on unhandled exceptions
|
|
function SimpleSAML_exception_handler($exception)
|
|
{
|
|
\SimpleSAML\Module::callHooks('exception_handler', $exception);
|
|
|
|
if ($exception instanceof \SimpleSAML\Error\Error) {
|
|
$exception->show();
|
|
} elseif ($exception instanceof \Exception) {
|
|
$e = new \SimpleSAML\Error\Error('UNHANDLEDEXCEPTION', $exception);
|
|
$e->show();
|
|
} elseif (class_exists('Error') && $exception instanceof \Error) {
|
|
$code = $exception->getCode();
|
|
$errno = ($code > 0) ? $code : E_ERROR;
|
|
$errstr = $exception->getMessage();
|
|
$errfile = $exception->getFile();
|
|
$errline = $exception->getLine();
|
|
SimpleSAML_error_handler($errno, $errstr, $errfile, $errline);
|
|
}
|
|
}
|
|
|
|
set_exception_handler('SimpleSAML_exception_handler');
|
|
|
|
// log full backtrace on errors and warnings
|
|
function SimpleSAML_error_handler($errno, $errstr, $errfile = null, $errline = 0, $errcontext = null)
|
|
{
|
|
if (\SimpleSAML\Logger::isErrorMasked($errno)) {
|
|
// masked error
|
|
return false;
|
|
}
|
|
|
|
static $limit = 5;
|
|
$limit -= 1;
|
|
if ($limit < 0) {
|
|
// we have reached the limit in the number of backtraces we will log
|
|
return false;
|
|
}
|
|
|
|
// show an error with a full backtrace
|
|
$context = (is_null($errfile) ? '' : " at $errfile:$errline");
|
|
$e = new \SimpleSAML\Error\Exception('Error ' . $errno . ' - ' . $errstr . $context);
|
|
$e->logError();
|
|
|
|
// resume normal error processing
|
|
return false;
|
|
}
|
|
|
|
set_error_handler('SimpleSAML_error_handler');
|
|
|
|
try {
|
|
\SimpleSAML\Configuration::getInstance();
|
|
} catch (\Exception $e) {
|
|
throw new \SimpleSAML\Error\CriticalConfigurationError(
|
|
$e->getMessage()
|
|
);
|
|
}
|
|
|
|
// set the timezone
|
|
\SimpleSAML\Utils\Time::initTimezone();
|