summaryrefslogtreecommitdiff
path: root/jobs
diff options
context:
space:
mode:
Diffstat (limited to 'jobs')
-rw-r--r--jobs/FrontersNotification.php94
-rw-r--r--jobs/PKFronters.php46
-rw-r--r--jobs/PKMembers.php47
-rw-r--r--jobs/PKSwitches.php90
-rw-r--r--jobs/PKSystem.php40
5 files changed, 317 insertions, 0 deletions
diff --git a/jobs/FrontersNotification.php b/jobs/FrontersNotification.php
new file mode 100644
index 0000000..ebe9213
--- /dev/null
+++ b/jobs/FrontersNotification.php
@@ -0,0 +1,94 @@
+<?php
+
+$options = json_decode($argv[1], true);
+$_SERVER['DOCUMENT_ROOT'] = "..";
+
+echo("Loading...\n");
+
+if (!function_exists("formatPonypush")) {
+ function formatPonypush($message) {
+ return "Update to Ponypush 3.1.0 or later — (\$PA1$\$" . base64_encode($message) . "\$\$)";
+ }
+}
+
+$app = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true);
+$system = $options["system"];
+
+echo("Processing for system $system\n");
+
+if ($system === "gdapd") {
+ $name = "Raindrops";
+} elseif ($system === "hrbom") {
+ $name = "Moonglow";
+} elseif (isset($app["other"]) && $system === $app["other"]["id"]) {
+ $name = $app["other"]["name"];
+} else {
+ die();
+}
+
+$fronters = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/fronters.json"), true);
+$currentFronter = $fronters["members"][0]["id"];
+file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/last.json", json_encode($currentFronter));
+
+$ntfy = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true)["ntfy"];
+
+if (count($fronters["members"]) > 1) {
+ echo("Creating context for 2 members\n");
+ $context = stream_context_create([
+ 'http' => [
+ 'method' => 'POST',
+ 'header' =>
+ "Content-Type: text/plain\r\n" .
+ "Title: " . formatPonypush("🌪️ Switch occurred in $name") . "\r\n" .
+ "Priority: default\r\n" .
+ "Tags: switch\r\n" .
+ "Actions: view, View " . $fronters["members"][0]["display_name"] . " on PluralKit, https://dash.pluralkit.me/profile/m/" . $fronters["members"][0]["id"] . ", clear=true;view, View " . $fronters["members"][1]["display_name"] . " on PluralKit, https://dash.pluralkit.me/profile/m/" . $fronters["members"][1]["name"] . ", clear=true\r\n" .
+ "Authorization: Basic " . base64_encode($ntfy["user"] . ":" . $ntfy["password"]),
+ 'content' => formatPonypush(($fronters["members"][0]["display_name"] ?? $fronters["members"][0]["name"]) . " and " . ($fronters["members"][1]["display_name"] ?? $fronters["members"][1]["name"]) . " switched in just now")
+ ]
+ ]);
+} else if (count($fronters["members"]) > 0) {
+ echo("Creating context for 1 member\n");
+ $context = stream_context_create([
+ 'http' => [
+ 'method' => 'POST',
+ 'header' =>
+ "Content-Type: text/plain\r\n" .
+ "Title: " . formatPonypush("🌪️ Switch occurred in $name") . "\r\n" .
+ "Priority: default\r\n" .
+ "Tags: switch\r\n" .
+ "Actions: view, View on PluralKit, https://dash.pluralkit.me/profile/m/" . $fronters["members"][0]["id"] . ", clear=true\r\n" .
+ "Authorization: Basic " . base64_encode($ntfy["user"] . ":" . $ntfy["password"]),
+ 'content' => formatPonypush(($fronters["members"][0]["display_name"] ?? $fronters["members"][0]["name"]) . " switched in just now")
+ ]
+ ]);
+} else {
+ echo("Creating context for no member (fallback pony)\n");
+ $context = stream_context_create([
+ 'http' => [
+ 'method' => 'POST',
+ 'header' =>
+ "Content-Type: text/plain\r\n" .
+ "Title: " . formatPonypush("🌪️ Switch occurred in $name") . "\r\n" .
+ "Priority: default\r\n" .
+ "Tags: switch\r\n" .
+ "Actions: view, View on PluralKit, https://dash.pluralkit.me/profile/s/" . $system . ", clear=true\r\n" .
+ "Authorization: Basic " . base64_encode($ntfy["user"] . ":" . $ntfy["password"]),
+ 'content' => formatPonypush("The fallback pony switched in just now")
+ ]
+ ]);
+}
+
+if ($system !== $app["other"]["id"] || !isset($app["other"])) {
+ echo("Sending to general public channel\n");
+ file_get_contents('https://' . $ntfy["server"] . '/public-switches', false, $context);
+}
+
+if ($system === "gdapd") {
+ $topic = "public-switches-raindrops";
+} else {
+ $topic = "main";
+}
+
+echo("Sending to specific channel ($topic)\n");
+file_get_contents('https://' . $ntfy["server"] . '/' . $topic, false, $context);
diff --git a/jobs/PKFronters.php b/jobs/PKFronters.php
new file mode 100644
index 0000000..2ad83f3
--- /dev/null
+++ b/jobs/PKFronters.php
@@ -0,0 +1,46 @@
+<?php
+
+$options = json_decode($argv[1], true);
+$_SERVER['DOCUMENT_ROOT'] = "..";
+
+echo("Loading...\n");
+
+$app = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true);
+$system = $options["system"];
+
+if ($app["other"]["id"] === $system) {
+ echo("Using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'header' =>
+ "Authorization: " . $app["other"]["token"] . "\r\n"
+ ]
+ ]);
+} else {
+ echo("Not using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'headers' => "User-Agent: Mozilla/5.0 (+Cold-Haze/1.1)\r\n"
+ ]
+ ]);
+}
+
+echo("Fetching...\n");
+sleep(1);
+$data = file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/fronters", false, $ctx);
+json_decode($data);
+
+if (trim($data) !== "" && $data !== false && json_last_error() === JSON_ERROR_NONE) {
+ echo("Data is valid, saved it\n");
+ file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/fronters.json", $data);
+} else {
+ echo("Data is invalid: " . json_last_error_msg() . ": " . $data . "\n");
+}
+
+echo("Running Signal integration...\n");
+chdir("/opt/peh/daemons");
+if ($system === "gdapd") exec("nice -n 19 node signal.js raindrops");
+if ($system === "hrbom") exec("nice -n 19 node signal.js moonglow");
+if ($system !== "gdapd" && $system !== "hrbom") exec("nice -n 19 node signal.js other");
diff --git a/jobs/PKMembers.php b/jobs/PKMembers.php
new file mode 100644
index 0000000..c46a82b
--- /dev/null
+++ b/jobs/PKMembers.php
@@ -0,0 +1,47 @@
+<?php
+
+$options = json_decode($argv[1], true);
+$_SERVER['DOCUMENT_ROOT'] = "..";
+
+echo("Loading...\n");
+
+$app = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true);
+$system = $options["system"];
+
+if ($app["other"]["id"] === $system) {
+ echo("Using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'header' =>
+ "Authorization: " . $app["other"]["token"] . "\r\n"
+ ]
+ ]);
+} else {
+ echo("Not using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'headers' => "User-Agent: Mozilla/5.0 (+Cold-Haze/1.1)\r\n"
+ ]
+ ]);
+}
+
+echo("Fetching...\n");
+sleep(1);
+$data = file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/members", false, $ctx);
+json_decode($data);
+
+if (trim($data) !== "" && $data !== false && json_last_error() === JSON_ERROR_NONE) {
+ echo("Data is valid, saved it\n");
+ $parsed = json_decode($data, true);
+
+ foreach ($parsed as $index => $member) {
+ echo(($member["display_name"] ?? $member["name"]) . "\n");
+ }
+
+ $data = json_encode($parsed, JSON_PRETTY_PRINT);
+ file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/members.json", $data);
+} else {
+ echo("Data is invalid\n");
+}
diff --git a/jobs/PKSwitches.php b/jobs/PKSwitches.php
new file mode 100644
index 0000000..392c84e
--- /dev/null
+++ b/jobs/PKSwitches.php
@@ -0,0 +1,90 @@
+<?php
+
+$options = json_decode($argv[1], true);
+$_SERVER['DOCUMENT_ROOT'] = "..";
+
+echo("Loading...\n");
+
+$app = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true);
+$system = $options["system"];
+
+if ($app["other"]["id"] === $system) {
+ echo("Using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'header' =>
+ "Authorization: " . $app["other"]["token"] . "\r\n"
+ ]
+ ]);
+} else {
+ echo("Not using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'headers' => "User-Agent: Mozilla/5.0 (+Cold-Haze/1.1)\r\n"
+ ]
+ ]);
+}
+
+echo("Fetching...\n");
+echo(" Part 1/6\n");
+sleep(1);
+$switches1 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches", false, $ctx), true);
+
+if (count($switches1) > 0 && json_last_error() === JSON_ERROR_NONE) {
+ $oldest = $switches1[count($switches1) - 1]["timestamp"];
+
+ echo(" Part 2/6\n");
+ sleep(1);
+ $switches2 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches?before=$oldest", false, $ctx), true);
+
+ if (count($switches2) > 0 && json_last_error() === JSON_ERROR_NONE) {
+ $oldest = $switches2[count($switches2) - 1]["timestamp"];
+
+ echo(" Part 3/6\n");
+ sleep(1);
+ $switches3 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches?before=$oldest", false, $ctx), true);
+
+ if (count($switches3) > 0 && json_last_error() === JSON_ERROR_NONE) {
+ $oldest = $switches3[count($switches3) - 1]["timestamp"];
+
+ echo(" Part 4/6\n");
+ sleep(1);
+ $switches4 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches?before=$oldest", false, $ctx), true);
+
+ if (count($switches4) > 0 && json_last_error() === JSON_ERROR_NONE) {
+ $oldest = $switches4[count($switches4) - 1]["timestamp"];
+
+ echo(" Part 5/6\n");
+ sleep(1);
+ $switches5 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches?before=$oldest", false, $ctx), true);
+
+ if (count($switches5) > 0 && json_last_error() === JSON_ERROR_NONE) {
+ $oldest = $switches5[count($switches5) - 1]["timestamp"];
+
+ echo(" Part 6/6\n");
+ sleep(1);
+ $switches6 = json_decode(file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system/switches?before=$oldest", false, $ctx), true);
+ } else {
+ $switches6 = [];
+ }
+ } else {
+ $switches5 = $switches6 = [];
+ }
+ } else {
+ $switches4 = $switches5 = $switches6 = [];
+ }
+ } else {
+ $switches3 = $switches4 = $switches5 = $switches6 = [];
+ }
+} else {
+ $switches2 = $switches3 = $switches4 = $switches5 = $switches6 = [];
+}
+
+if (json_last_error() === JSON_ERROR_NONE && $switches1 !== null && $switches2 !== null && $switches3 !== null && $switches4 !== null && $switches5 !== null && $switches6 !== null) {
+ echo("Data is valid, saved it\n");
+ file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/switches.json", json_encode([...$switches1, ...$switches2, ...$switches3, ...$switches4, ...$switches5, ...$switches6], JSON_PRETTY_PRINT));
+} else {
+ echo("Data is invalid\n");
+}
diff --git a/jobs/PKSystem.php b/jobs/PKSystem.php
new file mode 100644
index 0000000..66cbd64
--- /dev/null
+++ b/jobs/PKSystem.php
@@ -0,0 +1,40 @@
+<?php
+
+$options = json_decode($argv[1], true);
+$_SERVER['DOCUMENT_ROOT'] = "..";
+
+echo("Loading...\n");
+
+$app = json_decode(file_get_contents($_SERVER['DOCUMENT_ROOT'] . "/app.json"), true);
+$system = $options["system"];
+
+if ($app["other"]["id"] === $system) {
+ echo("Using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'header' =>
+ "Authorization: " . $app["other"]["token"] . "\r\n"
+ ]
+ ]);
+} else {
+ echo("Not using authentication\n");
+ $ctx = stream_context_create([
+ 'http' => [
+ 'method' => 'GET',
+ 'headers' => "User-Agent: Mozilla/5.0 (+Cold-Haze/1.1)\r\n"
+ ]
+ ]);
+}
+
+echo("Fetching...\n");
+sleep(1);
+$data = file_get_contents("https://pluralkit.equestria.dev/v2/systems/$system", false, $ctx);
+json_decode($data);
+
+if (trim($data) !== "" && $data !== false && json_last_error() === JSON_ERROR_NONE) {
+ echo("Data is valid, saved it\n");
+ file_put_contents($_SERVER['DOCUMENT_ROOT'] . "/data/$system/general.json", $data);
+} else {
+ echo("Data is invalid\n");
+}