dotfiles/home/utils/services.nix

83 lines
2.3 KiB
Nix

{ pkgs, scripts }:
let
notify_script = (pkgs.writers.writePython3Bin "telegram-notify.py"
{
libraries = [ pkgs.python3Packages.python-telegram-bot ];
} ''
import telegram
import asyncio
import sys
import socket
import json
import subprocess
import tempfile
async def run():
text = subprocess.check_output(
[
"journalctl",
"--user",
"-u",
sys.argv[1],
"--since",
"-1h",
"--no-pager"
]
).decode("utf-8")
with open("/home/server/.secrets/Telegram/token.json") as f:
credentials = json.load(f)
token = credentials["token"]
chat_id = credentials["chat_id"]
with open("/home/server/mail.log", "a") as f:
f.write(text)
f.write("\n===========================================\n")
bot = telegram.Bot(token=token)
hostname = socket.gethostname()
await bot.send_message(
chat_id,
f"{hostname} encountered an error in the service: {sys.argv[1]}"
)
with tempfile.NamedTemporaryFile(suffix=".txt") as tmp_file:
tmp_file.write(text.encode("utf-8"))
tmp_file.seek(0)
await bot.send_document(chat_id, document=tmp_file)
if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.run_until_complete(asyncio.wait([loop.create_task(run())]))
loop.close()
'');
mkTimer = name: cfg: {
Install.WantedBy = [ "timers.target" ];
Timer = {
Persistent = true;
OnCalendar = cfg.when;
Unit = "${name}.service";
};
};
mkService = name: cfg: {
Unit.Description = name;
Unit.OnFailure = "status_notify@${name}.service";
# Install = { WantedBy = [ "default.target" ]; };
Service = { ExecStart = cfg.script; };
};
in
{
systemd.user.services = pkgs.lib.mapAttrs mkService scripts
// (pkgs.lib.mapAttrs mkService {
"status_notify@" = {
script = "${notify_script}/bin/telegram-notify.py %i";
};
});
systemd.user.timers = pkgs.lib.mapAttrs mkTimer scripts;
# Don't forget to enable these timers! Or reboot, after which it should also be activated automatically
# systemctl --user enable --now <script>.timer
}