2023-10-31 18:43:21 +00:00
|
|
|
<?php
|
2023-11-19 12:24:38 +00:00
|
|
|
require_once __DIR__ . '/vendor/autoload.php';
|
2023-10-31 18:43:21 +00:00
|
|
|
|
|
|
|
session_start();
|
|
|
|
|
2024-03-17 15:48:32 +00:00
|
|
|
error_reporting(E_ERROR | E_WARNING | E_PARSE);
|
|
|
|
|
2023-11-19 12:24:38 +00:00
|
|
|
if (empty($_SESSION)) {
|
|
|
|
$_SESSION['auth'] = false;
|
|
|
|
}
|
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
include "config.php";
|
2023-11-10 21:19:08 +00:00
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
// MySQL
|
2023-11-10 21:19:08 +00:00
|
|
|
$pdo = new PDO(DB_DSN, DB_USERNAME, DB_PASSWORD, PDO_OPTIONS);
|
2024-02-17 12:04:47 +00:00
|
|
|
// Email
|
|
|
|
if (defined("RESEND_API_KEY")) {
|
|
|
|
$resend = Resend::client(RESEND_API_KEY);
|
|
|
|
}
|
2023-11-10 21:19:08 +00:00
|
|
|
|
|
|
|
require "misc_functions.php";
|
2023-11-19 12:24:38 +00:00
|
|
|
require "database.php";
|
2024-02-17 12:04:47 +00:00
|
|
|
include("time_handler.php");
|
2023-11-19 12:24:38 +00:00
|
|
|
include("id_handler.php");
|
2023-11-10 21:19:08 +00:00
|
|
|
include("accounts_handler.php");
|
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
// Attempt to log the user in using their cookie if auth isn't set.
|
|
|
|
if (!$_SESSION['auth']) {
|
|
|
|
if (key_exists('keep_me_logged_in', $_COOKIE)) {
|
|
|
|
if (validate_access_token($_COOKIE['keep_me_logged_in'])) {
|
|
|
|
// Work out who the key belongs to
|
|
|
|
$cookie_owner = db_execute("SELECT * FROM tokens WHERE access_token = ?", [$_COOKIE['keep_me_logged_in']]);
|
|
|
|
if ($cookie_owner['type'] != "cookie") {
|
|
|
|
setcookie('keep_me_logged_in', '', time()-3600);
|
|
|
|
goto skip_cookie;
|
|
|
|
}
|
|
|
|
$_SESSION['auth'] = true;
|
|
|
|
$_SESSION['id'] = $cookie_owner['owner_id'];
|
2023-11-06 16:38:18 +00:00
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
} else {
|
|
|
|
setcookie('keep_me_logged_in', '', time()-3600);
|
|
|
|
}
|
|
|
|
}
|
2023-11-06 16:38:18 +00:00
|
|
|
}
|
2023-10-31 20:21:33 +00:00
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
skip_cookie:
|
|
|
|
|
2023-10-31 18:43:21 +00:00
|
|
|
$host_string = $_SERVER['HTTP_HOST'];
|
|
|
|
$host = explode('.', $host_string);
|
|
|
|
$uri_string = $_SERVER['REQUEST_URI'];
|
|
|
|
$query_string = explode('?', $uri_string);
|
2023-10-31 20:21:33 +00:00
|
|
|
$path = $query_string[0];
|
2023-11-06 16:38:18 +00:00
|
|
|
if (str_ends_with($path,'/') && $path != "/") {
|
|
|
|
header('Location: '.substr($path,0, -1));
|
|
|
|
exit;
|
|
|
|
}
|
2023-10-31 18:43:21 +00:00
|
|
|
$uri = array_values(array_filter(explode('/', $uri_string)));
|
2024-02-17 12:04:47 +00:00
|
|
|
try {
|
|
|
|
if ($_SESSION['auth']) {
|
|
|
|
$user = db_execute("SELECT * FROM `accounts` WHERE id = ? LIMIT 1", [$_SESSION['id']]);
|
|
|
|
if (!$user) {
|
|
|
|
// Account doesn't exist. Log the user out.
|
|
|
|
|
|
|
|
// We won't redirect to the logout endpoint because if this is going off there's something
|
|
|
|
// broken anyway.
|
|
|
|
session_destroy();
|
|
|
|
die("Your session was invalid so we've logged you out.");
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (Exception) {
|
|
|
|
echo('<header>Database is broken. Please tell an admin.</header>');
|
|
|
|
if ($uri_string == "/admin/init/database") { // Allows access to this page even if user doesn't have admin rights
|
|
|
|
// because you can't check the rights.
|
|
|
|
echo "<main>";
|
|
|
|
include "admin_initdatabase.php";
|
|
|
|
die ("</main>");
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
if (defined("SENTRY_DSN")) {
|
|
|
|
\Sentry\init([
|
|
|
|
'dsn' => SENTRY_DSN,
|
|
|
|
// Specify a fixed sample rate
|
|
|
|
'traces_sample_rate' => 1.0,
|
|
|
|
// Set a sampling rate for profiling - this is relative to traces_sample_rate
|
|
|
|
'profiles_sample_rate' => 1.0,
|
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function does_variable_exists( $variable ) {
|
|
|
|
return (isset($$variable)) ? "true" : "false";
|
|
|
|
}
|
2023-10-31 18:43:21 +00:00
|
|
|
|
|
|
|
if(isset($query_string[1])) {
|
2023-10-31 20:21:33 +00:00
|
|
|
$uri_string = $query_string[0];
|
|
|
|
$query_string = explode('&', $query_string[1]);
|
|
|
|
$query = array();
|
|
|
|
foreach($query_string as $string) {
|
2023-10-31 18:43:21 +00:00
|
|
|
$bits = explode('=', $string);
|
|
|
|
$query[$bits[0]] = $bits[1];
|
2023-10-31 20:21:33 +00:00
|
|
|
}
|
2023-10-31 18:43:21 +00:00
|
|
|
}
|
|
|
|
else {
|
2023-11-06 16:38:18 +00:00
|
|
|
$query = array();
|
2023-10-31 18:43:21 +00:00
|
|
|
}
|
|
|
|
|
2023-10-31 20:21:33 +00:00
|
|
|
|
2023-11-06 16:38:18 +00:00
|
|
|
$include = "404.html";
|
2023-10-31 20:21:33 +00:00
|
|
|
// routing
|
2023-11-06 16:38:18 +00:00
|
|
|
|
|
|
|
$paths = array(
|
|
|
|
"/" => ["landing.php"],
|
2024-02-17 12:04:47 +00:00
|
|
|
|
2023-11-11 16:16:04 +00:00
|
|
|
"/admin" => ['admin.php'],
|
2023-11-06 16:38:18 +00:00
|
|
|
"/admin/init/database" => ["admin_initdatabase.php"],
|
2023-11-19 12:24:38 +00:00
|
|
|
"/admin/list/accounts" => ["admin_accounts.php"],
|
|
|
|
"/admin/list/apps" => ["admin_apps.php"],
|
|
|
|
"/admin/create/app" => ["admin_apps_create.php"],
|
2024-05-29 17:33:57 +00:00
|
|
|
"/admin/create/token" => ["admin_create_token.php"],
|
2024-03-02 12:41:57 +00:00
|
|
|
"/admin/signinas" => ["signinas.php"],
|
2024-02-17 12:04:47 +00:00
|
|
|
"/admin/purge" => ["admin_purge.php"],
|
2023-11-19 12:24:38 +00:00
|
|
|
|
2024-03-02 12:41:57 +00:00
|
|
|
// Settings
|
2024-03-29 22:04:20 +00:00
|
|
|
"/dashboard" => ["dashboard.php", "Dashboard"],
|
2024-03-18 20:11:01 +00:00
|
|
|
"/settings" => ["settings.php", "Settings"],
|
2024-05-29 17:33:57 +00:00
|
|
|
"/settings/account" => ["settings_account.php", "Settings -> Account"],
|
2024-03-02 12:41:57 +00:00
|
|
|
|
2024-03-17 15:48:32 +00:00
|
|
|
"/account" => ["account.php", "Your account"],
|
2023-11-06 16:38:18 +00:00
|
|
|
"/signin" => ["signin.php", "Sign in"],
|
|
|
|
"/signup" => ["signup.php", "Sign up"],
|
2024-03-17 15:48:32 +00:00
|
|
|
"/signout" => ["signout.php", "Signed out"],
|
2023-11-10 21:19:08 +00:00
|
|
|
"/forgot/password" => ["forgot_password.php", "Forgot password"],
|
|
|
|
"/reset/password" => ["reset_password.php", "Reset password"],
|
2023-11-19 12:24:38 +00:00
|
|
|
"/docs" => ["docs.php", "Docs"],
|
2024-02-17 12:04:47 +00:00
|
|
|
"/credits" => ["credits.php", "Credits"],
|
2023-11-19 12:24:38 +00:00
|
|
|
"/profile" => ["profile.php", "Profile"],
|
2024-02-17 12:04:47 +00:00
|
|
|
|
|
|
|
"/signin/external/basic" => ["login_external_basic.php"]
|
2023-11-06 16:38:18 +00:00
|
|
|
);
|
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
if (!empty($uri) ) { // Go to jail. Go directly to jail. Do not pass Go.
|
|
|
|
if ($uri[0] == "api") {
|
|
|
|
include("api_handler.php");
|
|
|
|
exit(); // fuck this shit i'm out
|
|
|
|
}
|
2024-03-02 12:41:57 +00:00
|
|
|
if ($uri[0] == "public" && $uri[1] == "avatars") {
|
|
|
|
include("image_grabber.php");
|
|
|
|
exit();
|
|
|
|
}
|
2024-02-17 12:04:47 +00:00
|
|
|
}
|
|
|
|
|
2024-03-17 15:48:32 +00:00
|
|
|
$migrated = false;
|
2023-11-06 16:38:18 +00:00
|
|
|
if (isset($paths[$path])) {
|
|
|
|
$include = $paths[$path][0];
|
|
|
|
if (isset($paths[$path][1])) {
|
|
|
|
$doc_title = $paths[$path][1];
|
|
|
|
}
|
2024-03-17 15:48:32 +00:00
|
|
|
if (isset($paths[$path][2])) {
|
|
|
|
$migrated = $paths[$path][2];
|
2024-03-02 12:41:57 +00:00
|
|
|
}
|
2023-10-31 20:21:33 +00:00
|
|
|
}
|
2023-11-06 16:38:18 +00:00
|
|
|
|
2023-10-31 20:21:33 +00:00
|
|
|
else {
|
|
|
|
$doc_title = "404";
|
|
|
|
http_response_code(404);
|
|
|
|
}
|
2023-10-31 18:43:21 +00:00
|
|
|
|
2024-02-17 12:04:47 +00:00
|
|
|
|
2024-03-17 15:48:32 +00:00
|
|
|
if ($migrated) {
|
|
|
|
$output = "";
|
|
|
|
|
|
|
|
include($include);
|
|
|
|
}
|
2023-10-31 18:43:21 +00:00
|
|
|
?>
|
|
|
|
|
|
|
|
<!DOCTYPE html>
|
|
|
|
<html lang="en">
|
|
|
|
<head>
|
2023-10-31 20:21:33 +00:00
|
|
|
<?php include("head.php"); ?>
|
2023-10-31 18:43:21 +00:00
|
|
|
</head>
|
|
|
|
<body>
|
|
|
|
<?php include("header.php"); ?>
|
|
|
|
<main>
|
2024-03-02 12:41:57 +00:00
|
|
|
<?php
|
2023-11-11 16:16:04 +00:00
|
|
|
if (!empty($uri)) {
|
2023-11-19 12:24:38 +00:00
|
|
|
// print_r ($uri);
|
2023-11-11 16:16:04 +00:00
|
|
|
|
2023-11-19 12:24:38 +00:00
|
|
|
if ($uri[0] == "admin") {
|
|
|
|
echo "<h2 class=\"subheading\">Admin</h2>";
|
|
|
|
}
|
|
|
|
|
2024-03-29 22:02:39 +00:00
|
|
|
if ($uri[0] == "admin" && !$user['is_admin']) {
|
|
|
|
http_response_code(401);
|
|
|
|
die("<img src='https://http.cat/401.jpg' alt='A cat standing in front of a door with a No Cats Allowed sign on it.' />");
|
|
|
|
}
|
2024-02-17 12:04:47 +00:00
|
|
|
|
2023-11-19 12:24:38 +00:00
|
|
|
if ($uri[0] == "docs") {
|
|
|
|
$include = "docs.php";
|
|
|
|
}
|
2023-11-06 16:38:18 +00:00
|
|
|
}
|
|
|
|
|
2024-03-17 15:48:32 +00:00
|
|
|
if ($migrated) {
|
|
|
|
echo $output;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
include ($include);
|
|
|
|
}
|
2024-03-02 12:41:57 +00:00
|
|
|
?>
|
2023-10-31 18:43:21 +00:00
|
|
|
</main>
|
|
|
|
<?php include("footer.php"); ?>
|
|
|
|
</body>
|
2024-03-02 12:41:57 +00:00
|
|
|
</html>
|