From 6b796258d413f00e498ce7f80f73a9f6c061f29c Mon Sep 17 00:00:00 2001 From: RaindropsSys Date: Sat, 30 Mar 2024 23:40:33 +0100 Subject: Updated 5 files, added 2 files, deleted 495 files and renamed 7 files (automated) --- jobs/FrontersNotification.php | 94 +++++++++++++++++++++++++++++++++++++++++++ jobs/PKFronters.php | 46 +++++++++++++++++++++ jobs/PKMembers.php | 47 ++++++++++++++++++++++ jobs/PKSwitches.php | 90 +++++++++++++++++++++++++++++++++++++++++ jobs/PKSystem.php | 40 ++++++++++++++++++ 5 files changed, 317 insertions(+) create mode 100644 jobs/FrontersNotification.php create mode 100644 jobs/PKFronters.php create mode 100644 jobs/PKMembers.php create mode 100644 jobs/PKSwitches.php create mode 100644 jobs/PKSystem.php (limited to 'jobs') 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 @@ + 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 @@ + [ + '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 @@ + [ + '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 @@ + [ + '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 @@ + [ + '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"); +} -- cgit