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 6
/
controller.php
executable file
·74 lines (68 loc) · 1.97 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
<?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');
checkSession();
switch($_GET['action']) {
case 'getExtensions':
$path = 'extensions';
if (isset($_GET['path'])) {
$path .= '/' . $_GET['path'];
//Catch upper path
$path = str_replace("../", "", $path);
if (!is_dir($path)) {
echo '{"status":"error","message":"Invalid path!"}';
break;
}
}
$extensions = scandir($path);
$buffer = array();
foreach($extensions as $file) {
if ($file != "." && $file != "..") {
if (!is_dir($path . "/" . $file)) {
array_push($buffer, $file);
}
}
}
echo '{"status":"success","extensions":' . json_encode($buffer) . '}';
break;
case 'getContent':
if (isset($_GET['path'])) {
$path = 'extensions/' . $_GET['path'];
//Catch upper path
$path = str_replace("..", "", $path);
if (is_dir($path)) {
echo '{"status":"error","message":"Invalid path!"}';
break;
}
$content = file_get_contents($path);
echo json_encode(array("status" => "success", "content" => $content));
} else {
echo '{"status":"error","message":"Missing path"}';
}
break;
default:
echo '{"status":"error","message":"No Type"}';
break;
}
function getWorkspacePath($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;
}
?>