feat(rpi4): setup acme and cfdyndns
This commit is contained in:
parent
b1ea42c5a2
commit
66321a27b8
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1,2 +1,3 @@
|
|||
.env
|
||||
.pre-commit-config.yaml
|
||||
secrets
|
||||
|
|
94
modules/cfdyndns.nix
Normal file
94
modules/cfdyndns.nix
Normal file
|
@ -0,0 +1,94 @@
|
|||
{ config, pkgs, lib, ... }:
|
||||
|
||||
# apikeyFile implementation inspired by grafana config
|
||||
with lib;
|
||||
|
||||
let
|
||||
cfg = config.services.custom.cfdyndns;
|
||||
in
|
||||
{
|
||||
options = {
|
||||
services.custom.cfdyndns = {
|
||||
enable = mkEnableOption "Cloudflare Dynamic DNS Client";
|
||||
|
||||
email = mkOption {
|
||||
type = types.str;
|
||||
description = ''
|
||||
The email address to use to authenticate to CloudFlare.
|
||||
'';
|
||||
};
|
||||
|
||||
apikey = mkOption {
|
||||
default = null;
|
||||
type = types.nullOr types.str;
|
||||
description = ''
|
||||
The API Key to use to authenticate to CloudFlare.
|
||||
'';
|
||||
};
|
||||
|
||||
apikeyFile = mkOption {
|
||||
default = null;
|
||||
type = types.nullOr types.path;
|
||||
description = ''
|
||||
The API Key to use to authenticate to CloudFlare.
|
||||
'';
|
||||
};
|
||||
|
||||
records = mkOption {
|
||||
default = [];
|
||||
example = [ "host.tld" ];
|
||||
type = types.listOf types.str;
|
||||
description = ''
|
||||
The records to update in CloudFlare.
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = mkIf cfg.enable {
|
||||
assertions = [
|
||||
{
|
||||
assertion = cfg.apikey != null -> cfg.apikeyFile == null;
|
||||
message = "Cannot set both apikey and apikeyFile";
|
||||
}
|
||||
];
|
||||
|
||||
systemd.services.cfdyndns = {
|
||||
description = "CloudFlare Dynamic DNS Client";
|
||||
after = [ "network.target" ];
|
||||
wantedBy = [ "multi-user.target" ];
|
||||
startAt = "5 minutes";
|
||||
script = ''
|
||||
${optionalString (cfg.apikey != null) ''
|
||||
export CLOUDFLARE_APIKEY="${cfg.apikey}"
|
||||
''}
|
||||
${optionalString (cfg.apikeyFile != null) ''
|
||||
export CLOUDFLARE_APIKEY="$(cat ${escapeShellArg cfg.apikeyFile})"
|
||||
''}
|
||||
${pkgs.cfdyndns}/bin/cfdyndns
|
||||
'';
|
||||
serviceConfig = {
|
||||
Type = "simple";
|
||||
User = config.ids.uids.cfdyndns;
|
||||
Group = config.ids.gids.cfdyndns;
|
||||
};
|
||||
environment = {
|
||||
CLOUDFLARE_EMAIL = "${cfg.email}";
|
||||
CLOUDFLARE_RECORDS = "${concatStringsSep "," cfg.records}";
|
||||
};
|
||||
};
|
||||
|
||||
users.users = {
|
||||
cfdyndns = {
|
||||
group = "cfdyndns";
|
||||
uid = config.ids.uids.cfdyndns;
|
||||
};
|
||||
};
|
||||
|
||||
users.groups = {
|
||||
cfdyndns = {
|
||||
gid = config.ids.gids.cfdyndns;
|
||||
};
|
||||
};
|
||||
};
|
||||
}
|
19
rpi4.nix
19
rpi4.nix
|
@ -7,6 +7,7 @@
|
|||
./system/nix.nix
|
||||
./system/i18n.nix
|
||||
./services/jellyfin.nix
|
||||
./modules/cfdyndns.nix
|
||||
];
|
||||
|
||||
nixpkgs.config.allowUnfree = true;
|
||||
|
@ -22,6 +23,24 @@
|
|||
];
|
||||
hardware.enableAllFirmware = true;
|
||||
|
||||
networking.domain = "home.felschr.com";
|
||||
|
||||
networking.firewall.allowedTCPPorts = [
|
||||
80 443
|
||||
];
|
||||
|
||||
security.acme = {
|
||||
acceptTerms = true;
|
||||
email = "felschr@pm.me";
|
||||
};
|
||||
|
||||
services.custom.cfdyndns = {
|
||||
enable = true;
|
||||
email = "felschr@pm.me";
|
||||
apikeyFile = "/etc/nixos/secrets/cfdyndns-apikey";
|
||||
records = [ "home.felschr.com" ];
|
||||
};
|
||||
|
||||
programs.zsh.enable = true;
|
||||
|
||||
services.openssh.enable = true;
|
||||
|
|
Loading…
Reference in a new issue