diff options
author | RaindropsSys <raindrops@equestria.dev> | 2024-03-30 23:40:33 +0100 |
---|---|---|
committer | RaindropsSys <raindrops@equestria.dev> | 2024-03-30 23:40:33 +0100 |
commit | 6b796258d413f00e498ce7f80f73a9f6c061f29c (patch) | |
tree | 49e64a5dd4cde2acff7f0a93ed3f8e20e1cb2dc8 /jobs | |
parent | 5860551daa0f60103ad24e93da29f401a653f144 (diff) | |
download | pluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.tar.gz pluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.tar.bz2 pluralconnect-6b796258d413f00e498ce7f80f73a9f6c061f29c.zip |
Updated 5 files, added 2 files, deleted 495 files and renamed 7 files (automated)
Diffstat (limited to 'jobs')
-rw-r--r-- | jobs/FrontersNotification.php | 94 | ||||
-rw-r--r-- | jobs/PKFronters.php | 46 | ||||
-rw-r--r-- | jobs/PKMembers.php | 47 | ||||
-rw-r--r-- | jobs/PKSwitches.php | 90 | ||||
-rw-r--r-- | jobs/PKSystem.php | 40 |
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"); +} |