2024-09-08 01:22:36 +02:00
|
|
|
{ config, pkgs, lib, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.services.domeneshop-dyndns;
|
|
|
|
in {
|
|
|
|
options.services.domeneshop-dyndns = {
|
|
|
|
enable = lib.mkEnableOption "Domeneshop DynDNS";
|
|
|
|
|
|
|
|
domain = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
description = "Domain name to configure";
|
|
|
|
};
|
|
|
|
|
2024-09-08 02:32:11 +02:00
|
|
|
netrcFile = lib.mkOption {
|
2024-09-08 01:22:36 +02:00
|
|
|
type = lib.types.path;
|
2024-09-08 02:32:11 +02:00
|
|
|
description = "Path to the file that contains `machine api.domeneshop.no login <DDNS_TOKEN> password <DDNS_SECRET>` from https://domene.shop/admin?view=api";
|
2024-09-08 01:22:36 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
startAt = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "*/10 * * * *";
|
|
|
|
description = "Systemd onCalendar expression for when to run the timer";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
systemd.services.domeneshop-dyndns = {
|
2024-09-08 02:32:11 +02:00
|
|
|
serviceConfig.LoadCredential = "netrc:${cfg.netrcFile}";
|
2024-09-08 01:22:36 +02:00
|
|
|
startAt = cfg.startAt;
|
|
|
|
|
|
|
|
script = ''
|
|
|
|
DNSNAME="${cfg.domain}"
|
|
|
|
NEW_IP="$(${lib.getExe pkgs.curl} --silent https://ipinfo.io/ip)"
|
|
|
|
OLD_IP="$(${lib.getExe pkgs.getent} hosts "$DNSNAME" | ${lib.getExe pkgs.gawk} '{ print $1 }')"
|
|
|
|
|
|
|
|
if [[ "$NEW_IP" != "$OLD_IP" ]]; then
|
|
|
|
echo "Old IP ($OLD_IP) does not match new IP ($NEW_IP), updating..."
|
2024-09-08 02:32:11 +02:00
|
|
|
${lib.getExe pkgs.curl} --silent --netrc-file "$CREDENTIALS_DIRECTORY/netrc" "https://api.domeneshop.no/v0/dyndns/update?hostname=$DNSNAME&myip=$NEW_IP"
|
2024-09-08 01:22:36 +02:00
|
|
|
else
|
|
|
|
echo "Old IP ($OLD_IP) matches new IP ($NEW_IP), exiting..."
|
|
|
|
fi
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|