summaryrefslogtreecommitdiff
path: root/daemons/signal.js
diff options
context:
space:
mode:
Diffstat (limited to 'daemons/signal.js')
-rw-r--r--daemons/signal.js61
1 files changed, 61 insertions, 0 deletions
diff --git a/daemons/signal.js b/daemons/signal.js
new file mode 100644
index 0000000..4996c50
--- /dev/null
+++ b/daemons/signal.js
@@ -0,0 +1,61 @@
+const user = process.argv[2];
+const number = require('../app.json')['signal'][user];
+const fs = require('fs');
+
+if (typeof number !== "string") throw new Error("Unable to find info");
+
+const child_process = require("child_process");
+
+(async () => {
+ console.log("Ready");
+
+ let system = require('../data/' + (user === "raindrops" ? "gdapd" : (user === "Moonglow" ? "hrbom" : "other")) + "/general.json");
+ let fronters = require('../data/' + (user === "raindrops" ? "gdapd" : (user === "Moonglow" ? "hrbom" : "other")) + "/fronters.json");
+
+ console.log(system.name);
+ console.log(fronters.members.length + " member(s) at front");
+
+ let name = system.name;
+ let avatar1 = system.avatar_url;
+ let avatar2 = null;
+
+ if (fronters.members.length === 1) {
+ name = fronters.members[0].display_name ?? fronters.members[0].name;
+ avatar1 = fronters.members[0].avatar_url ?? avatar1;
+ } else if (fronters.members.length >= 2) {
+ name = (fronters.members[0].display_name ?? fronters.members[0].name) + " and " + (fronters.members[1].display_name ?? fronters.members[1].name);
+ avatar1 = fronters.members[0].avatar_url ?? avatar1;
+ avatar2 = fronters.members[1].avatar_url ?? avatar2;
+ }
+
+ let pfp;
+
+ if (avatar2) {
+ let img1 = Buffer.from(await (await fetch(avatar1)).arrayBuffer());
+ let img2 = Buffer.from(await (await fetch(avatar2)).arrayBuffer());
+
+ fs.writeFileSync("/tmp/chm-" + user + "-1", img1);
+ fs.writeFileSync("/tmp/chm-" + user + "-2", img2);
+
+ child_process.execSync("convert /tmp/chm-" + user + "-1 -gravity center -resize 512x512 -crop 50%x100% /tmp/chm-" + user + "-1.webp");
+ child_process.execSync("convert /tmp/chm-" + user + "-2 -gravity center -resize 512x512 -crop 50%x100% /tmp/chm-" + user + "-2.webp");
+ child_process.execSync("montage -mode concatenate -tile x1 /tmp/chm-" + user + "-1.webp /tmp/chm-" + user + "-2.webp /tmp/chm-" + user + ".webp");
+
+ pfp = fs.readFileSync("/tmp/chm-" + user + ".webp");
+
+ fs.unlinkSync("/tmp/chm-" + user + "-1");
+ fs.unlinkSync("/tmp/chm-" + user + "-2");
+ fs.unlinkSync("/tmp/chm-" + user + "-1.webp");
+ fs.unlinkSync("/tmp/chm-" + user + "-2.webp");
+ fs.unlinkSync("/tmp/chm-" + user + ".webp");
+ } else {
+ pfp = Buffer.from(await (await fetch(avatar1)).arrayBuffer());
+ }
+
+ fs.writeFileSync("/tmp/chm-" + user + "-pfp-final", pfp);
+
+ child_process.execFileSync("signal-cli", [ "-a", number, "updateProfile", "--given-name", name, "--family-name", "", "--avatar", "/tmp/chm-" + user + "-pfp-final" ]);
+ child_process.execFileSync("signal-cli", [ "-a", number, "updateAccount", "--device-name", "Ponycule to Signal integration (v" + new Date().toISOString().split("T")[0].replaceAll("-", ".") + ")" ]);
+ child_process.execFileSync("signal-cli", [ "-a", number, "sendSyncRequest" ]);
+ fs.unlinkSync("/tmp/chm-" + user + "-pfp-final");
+})();