This repository has been archived by the owner on Apr 19, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathcontroller.php
executable file
·78 lines (66 loc) · 1.76 KB
/
controller.php
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
<?php
/*
* Copyright (c) Codiad & Andr3as, distributed
* as-is and without warranty under the MIT License.
* See http://opensource.org/licenses/MIT for more information.
* This information must remain intact.
*/
//error_reporting(0);
require_once('../../common.php');
if ($_GET['action'] !== 'authenticate') {
checkSession();
}
require_once('class.tfa.php');
$Auth = new TFA();
switch($_GET['action']) {
case 'authenticate':
if(!isset($_POST['username']) || !isset($_POST['password'])){
die(json_encode(array('status' => "error", 'message' => 'Missing username or password')));
}
$Auth->username = $_POST['username'];
$Auth->password = $_POST['password'];
if (isset($_POST['token'])) {
$Auth->token = $_POST['token'];
}
$Auth->Authenticate();
break;
case 'switchState':
if(!isset($_POST['token']) || !isset($_POST['password'])){
die(json_encode(array('status' => "error", 'message' => 'Missing token or password')));
}
$Auth->username = $_SESSION['user'];
$Auth->password = $_POST['password'];
$Auth->token = $_POST['token'];
if ($Auth->IsTFAEnabled()) {
$Auth->DisableTFA();
} else {
$Auth->EnableTFA();
}
break;
default:
echo '{"status":"error","message":"No Type"}';
break;
}
if ($Auth->returnMessage !== '') {
echo $Auth->returnMessage;
}
function getWorkspacePath($path) {
//Security check
if (!Common::checkPath($path)) {
die('{"status":"error","message":"Invalid path"}');
}
if (strpos($path, "/") === 0) {
//Unix absolute path
return $path;
}
if (strpos($path, ":/") !== false) {
//Windows absolute path
return $path;
}
if (strpos($path, ":\\") !== false) {
//Windows absolute path
return $path;
}
return "../../workspace/".$path;
}
?>