diff options
Diffstat (limited to 'pages/api/save-private.php')
-rw-r--r-- | pages/api/save-private.php | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/pages/api/save-private.php b/pages/api/save-private.php new file mode 100644 index 0000000..de7d505 --- /dev/null +++ b/pages/api/save-private.php @@ -0,0 +1,35 @@ +<?php + +require_once $_SERVER['DOCUMENT_ROOT'] . "/includes/session.inc"; global $isLoggedIn; +if (!$isLoggedIn) header("Location: /-/login") and die(); + +$request_raw = file_get_contents('php://input'); +$json_object = json_decode($request_raw, true); + +$system = $_GET['system'] ?? null; +$member = $_GET['member'] ?? null; +$content = $json_object['content'] ?? null; + +if (!isset($system) || trim($system) === "" || strlen($system) !== 5 || !preg_match("/[a-z]/i", $system)) + peh_error("System not found", 404); + +if (!isset($member) || trim($member) === "" || strlen($member) !== 5 || !preg_match("/[a-z]/i", $member)) + if ($member !== null && $member !== "null") peh_error("System member not found", 404); + +if (!isset($content)) + peh_error("No content", 400); + +if ($member !== null && $member !== "null") { + $file = $_SERVER['DOCUMENT_ROOT'] . "/includes/data/content/" . $member . "-private.html"; +} else { + $file = $_SERVER['DOCUMENT_ROOT'] . "/includes/data/content/" . $system . ".html"; +} + +if (trim($content) === "") { + if (file_exists($file)) { + unlink($file); + } + die(); +} + +file_put_contents($file, $content);
\ No newline at end of file |