blob: 16e143ef7fcfa801238b19a03c57b5d817c8a759 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
|
<?php
$VIEWS_DIR = __DIR__ . '/..';
$CONTROLLERS_DIR = __DIR__ . '/../../controllers';
$MODELS_DIR = __DIR__ . '/../../models';
$uri = parse_url($_SERVER['REQUEST_URI'], PHP_URL_PATH);
if ($uri === '/nowayforward_human/xampp/setup.php') {
http_response_code(301); // Permanent redirect
header('Location: /');
exit;
}
$exploded = @explode('/', $uri, 4);
$root = '/' . @$exploded[1];
$subroot = '/' . @$exploded[2];
function route_view() {
global $root;
global $subroot;
global $uri;
switch ($uri) {
case '': case '/': case '/home':
return '/home';
}
switch ($root . $subroot) {
case '/list/update': return '/list/update';
case '/list/new': return '/list/new';
case '/list/add': return '/list/add';
case '/list/delete': return '/list/delete';
case '/archive/create': return '/archive/create';
}
switch ($root) {
case '/archive': return '/archive';
case '/user': return '/user';
case '/register': return '/user/create';
case '/login': return '/session/create';
case '/logout': return '/session/delete';
case '/list': return '/list';
case '/authenticate':
return '/user/authenticate.php';
}
http_response_code(404);
return '/404';
}
$view = $VIEWS_DIR . route_view();
require_once '../../models/database.php';
foreach (glob($MODELS_DIR . '/*.php') as $filename) {
require_once $filename;
}
$TOKEN = (array_key_exists('token', $_COOKIE)) ? ($_COOKIE['token'] ?? "") : ("");
function redirect(string $href) {
echo '<script type="text/javascript">window.location.href = "' . $href . '";</script>';
exit;
}
function require_login(string $redirect = '/login') {
global $TOKEN;
if ($TOKEN === '') {
redirect($redirect);
}
}
if (str_ends_with($view, '.php')) {
require_once $view;
}
else {
@include_once "$view/meta.php";
if (isset($controller)) {
require_once "$CONTROLLERS_DIR/$controller.php";
require_once "$CONTROLLERS_DIR/meta.php";
}
require_once './header.php';
require_once "$view/index.php";
require_once './footer.php';
}
|