summaryrefslogtreecommitdiff
path: root/pages/api/save-private.php
diff options
context:
space:
mode:
Diffstat (limited to 'pages/api/save-private.php')
-rw-r--r--pages/api/save-private.php35
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