-
Notifications
You must be signed in to change notification settings - Fork 2
Expand file tree
/
Copy pathindex.php
More file actions
87 lines (80 loc) · 2.42 KB
/
index.php
File metadata and controls
87 lines (80 loc) · 2.42 KB
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
<?php
define('NAME', 'DreamVids API');
define('ROOT', str_replace('index.php', '', $_SERVER['SCRIPT_FILENAME']), true);
define('WEBROOT', str_replace('index.php', '', $_SERVER['SCRIPT_NAME']), true);
define('BEANS', ROOT.'beans/');
define('SYSTEM', ROOT.'system/');
define('CONFIG', ROOT.'config/');
define('APP', ROOT.'app/');
define('MODELS', APP.'models/');
define('VIEWS', APP.'views/');
define('CONTROLLERS', APP.'controllers/');
// System requires
require_once SYSTEM.'ModelInterface.php';
require_once SYSTEM.'ResourceInterface.php';
require_once SYSTEM.'ControllerInterface.php';
require_once SYSTEM.'Utils.php';
require_once SYSTEM.'Database.php';
require_once SYSTEM.'Persist.php';
require_once SYSTEM.'Request.php';
require_once SYSTEM.'Config.php';
require_once SYSTEM.'PasswordManager.php';
require_once SYSTEM.'Response.php';
require_once SYSTEM.'Validator.php';
require_once SYSTEM.'JsonException.php';
require_once SYSTEM.'Router.php';
require_once SYSTEM.'PermChecker.php';
// Beans
require_once BEANS.'APIClient.php';
require_once BEANS.'APIPermission.php';
require_once BEANS.'APIAuthToken.php';
require_once BEANS.'User.php';
require_once BEANS.'Rank.php';
require_once BEANS.'Session.php';
require_once BEANS.'Channel.php';
// Models
require_once MODELS.'APIClient.php';
require_once MODELS.'Session.php';
// Controller
require_once Router::get()->getPathToRequire();
$classname = ucfirst(Request::get()->getArg(0)).'Ctrl';
if (Request::get()->getArg(1) != '') {
$_METHODS = [
'GET' => 'read',
'PATCH' => 'update',
'DELETE' => 'delete'
];
if (method_exists($classname, Request::get()->getArg(1))) {
$_METHODS['GET'] = Request::get()->getArg(1);
}
}
else {
$_METHODS = [
'GET' => 'fetch',
'POST' => 'create'
];
}
if (isset($_METHODS[Request::get()->getMethod()])) {
$methodname = $_METHODS[Request::get()->getMethod()];
if (Request::get()->getMethod() != 'GET') {
try{
Request::get()->decodeBody();
}catch (JsonException $e){
$response = new Response(Response::HTTP_400_BAD_REQUEST);
$response->addError("json", $e->getMessage());
$response->render();
}
}
}
else {
(new Response(Response::HTTP_405_METHOD_NOT_ALLOWED))->render();
}
$client = \Model\APIClient::getClient();
$session = \Model\Session::getSession();
if ($client != null) {
if (\Model\APIClient::hasPermission($client, $_METHODS)) {
$rep = $classname::$methodname();
$rep->render();
}
}
(new Response(Response::HTTP_401_UNAUTHORIZED))->render();