{ container, lib, config, ... } @args: with lib; let
	cfg = config.container.module.ddns;
in {
	options = {
		container.module.ddns = {
			enable = mkEnableOption "Dynamic dns client.";
			address = mkOption {
				default = "10.1.0.31";
				type    = types.str;
			};
			storage = mkOption {
				default = "${config.container.storage}/ddns";
				type    = types.str;
			};
		};
	};

	config = mkIf cfg.enable {
		systemd.tmpfiles.rules = container.mkContainerDir cfg [
			"data"
		];

		containers.ddns = container.mkContainer cfg {
			bindMounts = {
				"/data" = {
					hostPath   = "${cfg.storage}/data";
					isReadOnly = true;
				};
			};

			config = { ... }: container.mkContainerConfig cfg {
				services.cloudflare-dyndns = {
					enable        = true;
					apiTokenFile  = "/data/token";
					deleteMissing = false;
					ipv4          = true;
					ipv6          = false;
					proxied       = false;
					domains = let
						domain = config.container.domain;
					in [ domain ] ++ map (sub: "${sub}.${domain}") [
						"cloud"
						"git"
						"mail"
						"office"
						"paste"
						"play"
						"vpn"
					];
				};
			};
		};
	};
}