2019-08-27 00:32:24 +02:00
|
|
|
<?PHP
|
|
|
|
/**
|
|
|
|
* Generic collection of functions used in CSVXML.
|
2019-11-11 12:08:18 +01:00
|
|
|
*
|
|
|
|
* @file
|
|
|
|
*
|
|
|
|
* @author
|
2019-08-27 00:32:24 +02:00
|
|
|
*/
|
|
|
|
declare(strict_types = 1);
|
|
|
|
|
2020-08-10 20:05:22 +02:00
|
|
|
// Set autoloader
|
2022-11-07 00:31:57 +01:00
|
|
|
\error_reporting(E_ALL);
|
|
|
|
\ini_set('display_errors', "1");
|
2020-10-29 20:45:59 +01:00
|
|
|
\spl_autoload_register("mdCsvxmlAutoloader");
|
2022-11-07 00:31:57 +01:00
|
|
|
# \set_exception_handler("mdExceptionHandler");
|
|
|
|
# \set_error_handler("mdErrorHandler", E_ALL);
|
2020-08-10 20:05:22 +02:00
|
|
|
|
2020-10-29 20:45:59 +01:00
|
|
|
require_once __DIR__ . '/../inc/constants.php';
|
2020-10-21 16:31:30 +02:00
|
|
|
require_once __DIR__ . '/../vendor/autoload.php';
|
|
|
|
|
2020-08-10 20:05:22 +02:00
|
|
|
/**
|
|
|
|
* Autoloader for museum-digital.org.
|
|
|
|
*
|
|
|
|
* @param string $className Name of the class to load.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function mdCsvxmlAutoloader(string $className):void {
|
|
|
|
|
2021-03-06 12:45:51 +01:00
|
|
|
// Try using class map as defined through /scripts/buildClassMap.php
|
2020-08-10 20:05:22 +02:00
|
|
|
|
2021-03-06 12:45:51 +01:00
|
|
|
if (isset(AUTOLOAD_CLASS_MAP[$className])) {
|
|
|
|
include AUTOLOAD_CLASS_MAP[$className];
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Fallback: Load classes by autoload directories
|
2020-08-10 20:05:22 +02:00
|
|
|
|
2021-03-06 12:45:51 +01:00
|
|
|
foreach (AUTOLOAD_DIRS as $classDir) {
|
2020-10-29 20:45:59 +01:00
|
|
|
if (\file_exists("$classDir/$className.php")) {
|
2020-08-10 20:05:22 +02:00
|
|
|
include "$classDir/$className.php";
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Own error handler: Set to enforce exit on any error.
|
|
|
|
*
|
|
|
|
* @param integer $errno Error number.
|
|
|
|
* @param string $string Error message.
|
|
|
|
* @param string $file File in which the error occured.
|
|
|
|
* @param integer $line Line number.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function mdErrorHandler(int $errno, string $string, string $file, int $line):void {
|
|
|
|
|
|
|
|
$getStr = [];
|
|
|
|
foreach ($_GET as $key => $value) {
|
|
|
|
if (is_array($value)) continue;
|
|
|
|
$getStr[] = $key . "=" . $value;
|
|
|
|
}
|
|
|
|
|
|
|
|
$userMsg = "";
|
|
|
|
if (isset($_SESSION['anmnam'])) $userMsg .= " User: " . $_SESSION["anmnam"];
|
|
|
|
if (isset($_SESSION['username'])) $userMsg .= " (" . $_SESSION["username"] . ")";
|
|
|
|
if ($userMsg) $userMsg = " |--" . $userMsg;
|
|
|
|
|
|
|
|
$errorMsg = "";
|
|
|
|
|
|
|
|
if (!empty($_SERVER) && !empty($_SERVER["HTTP_HOST"])) {
|
|
|
|
|
|
|
|
$errorPage = $_SERVER['PHP_SELF'] . "?" . implode("&", $getStr);
|
|
|
|
$errorPageFull = "https://" . $_SERVER["HTTP_HOST"] . $errorPage;
|
|
|
|
|
|
|
|
$errorMsg = "*$errno (<a href='https://www.google.de/search?q=php+" . str_replace(" ", "+", $string) . "'>$string</a>) at $file: line_ $line _";
|
|
|
|
$errorMsg .= $userMsg;
|
|
|
|
$errorMsg .= " |-- Error generating page: <a href='$errorPageFull'>$errorPage</a>";
|
2020-08-11 13:39:47 +02:00
|
|
|
$errorMsg .= " |-- Used RAM / Peak RAM / Allowed: " . MD_STD::human_filesize(memory_get_usage()) . " / " . MD_STD::human_filesize(memory_get_peak_usage()) . " / " . ini_get("memory_limit");
|
2020-08-10 20:05:22 +02:00
|
|
|
|
|
|
|
$errorMsg = str_replace(PHP_EOL, " ", $errorMsg);
|
|
|
|
|
|
|
|
error_log($errorMsg);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($errno == E_ERROR) exit;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Exception handler to also be able to handle custom exceptions.
|
|
|
|
*
|
|
|
|
* @param Throwable $exception Exception.
|
|
|
|
*
|
|
|
|
* @return void
|
|
|
|
*/
|
|
|
|
function mdExceptionHandler(Throwable $exception):void {
|
|
|
|
|
|
|
|
$formatErrorPage = function(string $errorMsg = "", string $versionName = "") :string {
|
|
|
|
|
|
|
|
if (PHP_SAPI === "cli") {
|
|
|
|
return $errorMsg . PHP_EOL;
|
|
|
|
}
|
|
|
|
|
|
|
|
$output = '<!DOCTYPE html>
|
|
|
|
<html id="errorPage">
|
|
|
|
<head>
|
|
|
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
|
|
|
<meta http-equiv="content-type" content="text/html; charset=UTF-8"/>
|
2020-11-18 15:23:52 +01:00
|
|
|
<meta name="description" content="Validate import CSV files for museum-digital" />
|
2020-08-10 20:05:22 +02:00
|
|
|
<link rel="manifest" href="./manifest.webmanifest" />
|
2020-11-08 13:57:28 +01:00
|
|
|
<link rel="stylesheet" type="text/css" href="assets/css/csvxml.min.css" />
|
2020-11-18 15:52:01 +01:00
|
|
|
<meta name="theme-color" content="#aa4400" />
|
|
|
|
<meta name="robots" content="noindex" />
|
2020-11-08 13:57:28 +01:00
|
|
|
<link rel="shortcut icon" sizes="128x128" href="assets/img/mdlogo-csvxml.svg" />';
|
2020-08-10 20:05:22 +02:00
|
|
|
$output .= '
|
|
|
|
<title>Error :: ';
|
|
|
|
$output .= $versionName;
|
|
|
|
$output .= '</title>
|
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
|
|
|
|
<main>
|
2020-11-18 15:19:45 +01:00
|
|
|
<img src="/assets/img/mdlogo-csvxml.svg" alt="" />
|
2020-08-10 20:05:22 +02:00
|
|
|
<p>' . $errorMsg . '</p>
|
|
|
|
|
|
|
|
<nav>
|
|
|
|
<a href="index.php?t=home">Home</a>
|
|
|
|
<a href="index.php?t=museum">Museum</a>
|
|
|
|
<a href="index.php?t=collection">Collection</a>
|
|
|
|
<a href="index.php?t=exhibitions_overview">Exhibition</a>
|
|
|
|
<a href="index.php?t=events">Event</a>
|
|
|
|
<a href="index.php?t=topics">Topics</a>
|
|
|
|
<a href="index.php?t=listen&sv=+&done=yes">Objects</a>
|
|
|
|
</nav>
|
|
|
|
<nav>
|
|
|
|
<a href="index.php?t=kontakt">Contact</a>
|
|
|
|
<a href="index.php?t=impressum">Impressum</a>
|
|
|
|
<a href="index.php?t=privacy">Privacy Policy</a>
|
|
|
|
</nav>
|
|
|
|
</main>
|
|
|
|
|
|
|
|
</body>
|
|
|
|
</html>';
|
|
|
|
|
|
|
|
return $output;
|
|
|
|
};
|
|
|
|
|
|
|
|
$errorReporter = new MDErrorReporter("md:csvxml", "bugs-csvxml@museum-digital.de");
|
|
|
|
$errorCategory = MDErrorReporter::categorizeError($exception);
|
|
|
|
|
|
|
|
http_response_code(404);
|
|
|
|
|
|
|
|
switch ($errorCategory) {
|
|
|
|
case MDErrorReporter::MD_ERROR_KNOWN:
|
|
|
|
|
|
|
|
if (isset($_GET["output"]) and $_GET['output'] === "json") {
|
|
|
|
header('Content-type: application/json');
|
|
|
|
$output = [
|
|
|
|
"status" => "Error",
|
|
|
|
"msg" => $exception->getMessage(),
|
|
|
|
];
|
|
|
|
echo MD_STD::json_encode($output);
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
echo $formatErrorPage($exception->getMessage(), "");
|
|
|
|
exit;
|
|
|
|
|
|
|
|
default:
|
|
|
|
$errorReporter->sendErrorReport($exception, "joshua@museum-digital.de");
|
|
|
|
echo $formatErrorPage("Uncaught exception ...<br />Our team has been notified and will get to fixing this error shortly.", "");
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|