web-base/index.php

95 lines
2.9 KiB
PHP
Raw Normal View History

2020-02-09 23:02:19 +01:00
<?php
2020-04-03 18:09:01 +02:00
use Api\Request;
2020-06-18 15:35:09 +02:00
use Configuration\Configuration;
2020-04-03 18:09:01 +02:00
use Documents\Document404;
use Elements\Document;
2020-04-03 15:56:04 +02:00
include_once 'core/core.php';
include_once 'core/datetime.php';
include_once 'core/constants.php';
2020-02-10 00:52:25 +01:00
2020-06-18 15:35:09 +02:00
if (!is_readable(getClassPath(Configuration::class))) {
2020-06-18 15:39:38 +02:00
header("Content-Type: application/json");
2020-06-18 15:39:10 +02:00
die(json_encode(array( "success" => false, "msg" => "Configuration directory is not readable, check permissions before proceeding." )));
2020-06-18 15:35:09 +02:00
}
2020-02-09 23:02:19 +01:00
spl_autoload_extensions(".php");
spl_autoload_register(function($class) {
2020-06-18 15:35:09 +02:00
$full_path = getClassPath($class, true);
if(file_exists($full_path)) {
2020-02-09 23:02:19 +01:00
include_once $full_path;
2020-06-18 15:35:09 +02:00
} else {
2020-02-09 23:02:19 +01:00
include_once getClassPath($class, false);
2020-06-18 15:35:09 +02:00
}
2020-02-09 23:02:19 +01:00
});
2020-06-18 15:35:09 +02:00
$config = new Configuration();
2020-02-09 23:02:19 +01:00
$installation = (!$config->load());
$user = new Objects\User($config);
2020-02-10 00:52:25 +01:00
if(isset($_GET["api"]) && is_string($_GET["api"])) {
header("Content-Type: application/json");
if($installation) {
$response = createError("Not installed");
} else {
$apiFunction = $_GET["api"];
if(empty($apiFunction)) {
header("403 Forbidden");
$response = "";
} else if(!preg_match("/[a-zA-Z]+(\/[a-zA-Z]+)*/", $apiFunction)) {
2020-02-10 12:16:34 +01:00
header("400 Bad Request");
2020-02-10 00:52:25 +01:00
$response = createError("Invalid Method");
} else {
2020-04-02 21:19:06 +02:00
$apiFunction = implode("\\", array_map('ucfirst', explode("/", $apiFunction)));
if($apiFunction[0] !== "\\") $apiFunction = "\\$apiFunction";
$class = "\\Api$apiFunction";
2020-02-10 00:52:25 +01:00
$file = getClassPath($class);
if(!file_exists($file)) {
header("404 Not Found");
$response = createError("Not found");
2020-04-03 18:09:01 +02:00
} else if(!is_subclass_of($class, Request::class)) {
2020-02-10 12:16:34 +01:00
header("400 Bad Request");
2020-04-03 18:09:01 +02:00
$response = createError("Invalid Method");
2020-02-10 00:52:25 +01:00
} else {
$request = new $class($user, true);
$success = $request->execute();
$msg = $request->getLastError();
$response = $request->getJsonResult();
}
}
}
2020-02-09 23:02:19 +01:00
} else {
2020-04-02 21:19:06 +02:00
$documentName = $_GET["site"];
2020-02-10 00:52:25 +01:00
if ($installation) {
2020-04-02 21:19:06 +02:00
if ($documentName !== "" && $documentName !== "index.php") {
$response = "Redirecting to <a href=\"/\">/</a>";
header("Location: /");
} else {
$document = new Documents\Install($user);
2020-04-02 22:25:13 +02:00
$response = $document->getCode();
2020-04-02 21:19:06 +02:00
}
2020-02-10 00:52:25 +01:00
} else {
2020-02-10 12:32:53 +01:00
if(empty($documentName) || strcasecmp($documentName, "install") === 0) {
$documentName = "home";
} else if(!preg_match("/[a-zA-Z]+(\/[a-zA-Z]+)*/", $documentName)) {
$documentName = "Document404";
}
$documentName = strtoupper($documentName[0]) . substr($documentName, 1);
$documentName = str_replace("/", "\\", $documentName);
$class = "\\Documents\\$documentName";
$file = getClassPath($class);
2020-04-03 18:09:01 +02:00
if(!file_exists($file) || !is_subclass_of($class, Document::class)) {
$document = new Document404($user);
2020-02-10 12:32:53 +01:00
} else {
$document = new $class($user);
}
2020-02-10 00:52:25 +01:00
2020-06-17 23:50:08 +02:00
$user->processVisit();
2020-04-02 22:25:13 +02:00
$response = $document->getCode();
}
2020-02-09 23:02:19 +01:00
}
2020-02-10 00:52:25 +01:00
$user->sendCookies();
2020-04-03 18:09:01 +02:00
die($response);