summaryrefslogtreecommitdiff
path: root/pages/api/evening.php
diff options
context:
space:
mode:
authorRaindropsSys <contact@minteck.org>2023-06-21 22:32:25 +0200
committerRaindropsSys <contact@minteck.org>2023-06-21 22:32:25 +0200
commit7a7a49332df7c852abbaa33c7e8e87f93d064d61 (patch)
tree43daff24ec8ca4667aae9f3847948f868ae20894 /pages/api/evening.php
parent898a3d5af7d8bc4578786f1099d6fe092573d112 (diff)
downloadpluralconnect-7a7a49332df7c852abbaa33c7e8e87f93d064d61.tar.gz
pluralconnect-7a7a49332df7c852abbaa33c7e8e87f93d064d61.tar.bz2
pluralconnect-7a7a49332df7c852abbaa33c7e8e87f93d064d61.zip
Updated includes/external/matrix/index.js, added pages/api/evening.php and deleted pages/api/schedule.php (automated)
Diffstat (limited to 'pages/api/evening.php')
-rw-r--r--pages/api/evening.php138
1 files changed, 138 insertions, 0 deletions
diff --git a/pages/api/evening.php b/pages/api/evening.php
new file mode 100644
index 0000000..9884e05
--- /dev/null
+++ b/pages/api/evening.php
@@ -0,0 +1,138 @@
+<?php
+
+require_once $_SERVER['DOCUMENT_ROOT'] . "/includes/util/functions.inc";
+require_once $_SERVER['DOCUMENT_ROOT'] . "/includes/util/session.inc"; global $isLoggedIn; global $isLowerLoggedIn;
+if (!$isLoggedIn || $isLowerLoggedIn) {
+ header("Location: /-/login");
+ die();
+}
+
+$pairs = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/evening/pairs.json"), true);
+$ignored = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/evening/ignored.json"), true);
+$data = [];
+
+$members = $members = [
+ ...array_map(function ($i) {
+ $system = "ynmuc";
+ $i["_lastFronted"] = -1;
+ $id = $i["id"];
+ $memberData = $i;
+
+ $fronters = array_map(function ($item) {
+ return $item["id"];
+ }, json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/$system/fronters.json"), true)["members"]);
+
+ if (in_array($id, $fronters)) {
+ $i["_lastFronted"] = time();
+ } else {
+ $switches = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/$system/switches.json"), true);
+
+ $thisMember = array_filter($switches, function ($item) use ($memberData) {
+ return in_array($memberData["id"], $item["members"]);
+ });
+
+ $thisMember = array_values($thisMember);
+ $frontingEnd = null;
+
+ if (count($thisMember) > 0) {
+ $thisIndex = array_search($thisMember[0], $switches);
+
+ $frontingStart = $thisMember[0];
+ $frontingEnd = $switches[$thisIndex - 1];
+ }
+
+ if ($frontingEnd !== null && isset($frontingStart)) {
+ $i["_lastFronted"] = strtotime($frontingEnd["timestamp"]);
+ }
+ }
+
+ return $i;
+ }, array_values(array_filter(scoreOrderGlobal(), function ($i) {
+ return $i["_system"] === "ynmuc";
+ }))),
+ ...array_map(function ($i) {
+ $system = "gdapd";
+ $i["_lastFronted"] = -1;
+ $id = $i["id"];
+ $memberData = $i;
+
+ $fronters = array_map(function ($item) {
+ return $item["id"];
+ }, json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/$system/fronters.json"), true)["members"]);
+
+ if (in_array($id, $fronters)) {
+ $i["_lastFronted"] = time();
+ } else {
+ $switches = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/includes/data/$system/switches.json"), true);
+
+ $thisMember = array_filter($switches, function ($item) use ($memberData) {
+ return in_array($memberData["id"], $item["members"]);
+ });
+
+ $thisMember = array_values($thisMember);
+ $frontingEnd = null;
+
+ if (count($thisMember) > 0) {
+ $thisIndex = array_search($thisMember[0], $switches);
+
+ $frontingStart = $thisMember[0];
+ $frontingEnd = $switches[$thisIndex - 1];
+ }
+
+ if ($frontingEnd !== null && isset($frontingStart)) {
+ $i["_lastFronted"] = strtotime($frontingEnd["timestamp"]);
+ }
+ }
+
+ return $i;
+ }, array_values(array_filter(scoreOrderGlobal(), function ($i) {
+ return $i["_system"] === "gdapd";
+ })))
+];
+
+usort($pairs, function ($a, $b) use ($members) {
+ $times = [];
+
+ foreach ($a[0] as $id) {
+ $times[] = getLastFronted($members, $id);
+ }
+ foreach ($a[1] as $id) {
+ $times[] = getLastFronted($members, $id);
+ }
+
+ $timeA = time() - min(...$times);
+ $times = [];
+
+ foreach ($b[0] as $id) {
+ $times[] = getLastFronted($members, $id);
+ }
+ foreach ($b[1] as $id) {
+ $times[] = getLastFronted($members, $id);
+ }
+
+ $timeB = time() - min(...$times);
+
+ return $timeB - $timeA;
+}); $pairs = array_values($pairs); foreach ($pairs as $pair): $times = [];
+ foreach ($pair[0] as $id): $times[] = getLastFronted($members, $id); endforeach;
+ foreach ($pair[1] as $id): $times[] = getLastFronted($members, $id); endforeach;
+endforeach;
+
+$listI = 0; for ($i = 0; $i < 2; $i++): $pair = $pairs[$listI];
+ $data[$i] = [];
+ if (!in_array(date('Y-m-d', time() + 86400 * $i), $ignored)) {
+ $data[$i][0] = [];
+ $data[$i][1] = [];
+ foreach ($pair[0] as $id):
+ $data[$i][0][] = getMemberWithoutSystem($id)["display_name"] ?? getMemberWithoutSystem($id)["name"];
+ endforeach;
+ foreach ($pair[1] as $id):
+ $data[$i][1][] = getMemberWithoutSystem($id)["display_name"] ?? getMemberWithoutSystem($id)["name"];
+ endforeach;
+ } else {
+ $data[$i] = null;
+ }
+if (!in_array(date('Y-m-d', time() + 86400 * $i), $ignored)) $listI++; if ($listI === count($pairs)) $listI = 0; endfor;
+
+header("Content-Type: application/json");
+die(json_encode($data, JSON_PRETTY_PRINT)); \ No newline at end of file