summaryrefslogtreecommitdiff
path: root/pages/api/money/create.php
diff options
context:
space:
mode:
Diffstat (limited to 'pages/api/money/create.php')
-rw-r--r--pages/api/money/create.php99
1 files changed, 99 insertions, 0 deletions
diff --git a/pages/api/money/create.php b/pages/api/money/create.php
new file mode 100644
index 0000000..ff06a37
--- /dev/null
+++ b/pages/api/money/create.php
@@ -0,0 +1,99 @@
+<?php
+
+require_once $_SERVER['DOCUMENT_ROOT'] . "/includes/util/session.inc"; global $isLoggedIn; global $_PROFILE;
+require_once $_SERVER['DOCUMENT_ROOT'] . "/includes/util/functions.inc";
+$app = $GLOBALS["ColdHazeApp"] = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/app.json"), true);
+if (!$isLoggedIn) header("Location: /-/login") and die();
+header("Content-Type: application/json");
+
+$request_raw = file_get_contents('php://input');
+$json_object = $data = json_decode($request_raw, true);
+
+$systemID = $_PROFILE["login"] === "cloudburst" ? "ynmuc" : "gdapd";
+$fronters = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/" . ($_PROFILE["login"] === "cloudburst" ? "ynmuc" : "gdapd") . "/fronters.json"), true)["members"];
+
+if (count($fronters) > 0) {
+ $myId = $fronters[0]["id"];
+} else {
+ $myId = "zdtsg";
+}
+
+$accounts = array_map(function ($i) {
+ $name = substr($i, 0, -5);
+ $data = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/money/" . $i), true);
+ $data["_name"] = $name;
+ return $data;
+}, array_values(array_filter(scandir($_SERVER['DOCUMENT_ROOT'] . "/includes/data/money"), function ($i) { return !str_starts_with($i, "."); })));
+$rate = (float)trim(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/exchange.txt"));
+
+$obj = [
+ "success" => false,
+ "error" => null
+];
+
+if ($_SERVER["REQUEST_METHOD"] !== "POST") {
+ $obj["success"] = false;
+ $obj["error"] = "INVALID_METHOD";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+
+if (!isset($data["amount"]) || !isset($data["id"]) || !isset($data["description"])) {
+ $obj["success"] = false;
+ $obj["error"] = "MISSING_OPERAND";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+
+$account = array_values(array_filter($accounts, function ($i) use ($data) { return $i["_name"] === $data["id"]; }))[0] ?? null;
+
+if (!isset($account)) {
+ $obj["success"] = false;
+ $obj["error"] = "ACCOUNT_NOT_FOUND";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+
+if (!(isset($data["amount"]) && is_numeric($data["amount"]) && (float)$data["amount"] < 9999 && (float)$data["amount"] > -9999)) {
+ $obj["success"] = false;
+ $obj["error"] = "INVALID_AMOUNT";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+if (!isset($data["description"])) $data["description"] = "";
+
+if (strlen($data["description"]) > 150) {
+ $obj["success"] = false;
+ $obj["error"] = "DESCRIPTION_TOO_LONG";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+
+if ($data["amount"] === 0) {
+ $obj["success"] = false;
+ $obj["error"] = "AMOUNT_IS_ZERO";
+ die(json_encode($obj, JSON_PRETTY_PRINT));
+}
+
+$ntfy = $GLOBALS["ColdHazeApp"]["ntfy"];
+file_get_contents('https://' . $ntfy["server"] . '/' . $ntfy["topic"], false, stream_context_create([
+ 'http' => [
+ 'method' => 'POST',
+ 'header' =>
+ "Content-Type: text/plain\r\n" .
+ "Title: " . formatPonypush((getMember($myId)["display_name"] ?? getMember($myId)["name"]) . " created a transaction to " . $account["name"] . " (" . ucfirst($account["owner"]) . ")") . "\r\n" .
+ "Tags: bits\r\n" .
+ "Authorization: Basic " . base64_encode($ntfy["user"] . ":" . $ntfy["password"]),
+ 'content' => formatPonypush(($account["currency"] === "gbp" ? "£" : "€") . abs((float)$_GET["amount"]) . " were " . ((float)$_GET["amount"] >= 0 ? "added" : "removed") . " just now" . (trim($_GET["description"]) !== "" ? ": " . $_GET["description"] : ""))
+ ]
+]));
+
+array_unshift($account["transactions"], [
+ "author" => $myId,
+ "description" => $_GET["description"],
+ "amount" => (float)$_GET["amount"],
+ "date" => date('c')
+]);
+
+$name = $account["_name"];
+unset($account["_name"]);
+
+file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/money/" . $name . ".json", json_encode($account, JSON_PRETTY_PRINT));
+
+$obj["success"] = true;
+die(json_encode($obj, JSON_PRETTY_PRINT)); \ No newline at end of file