diff options
Diffstat (limited to 'hosts')
-rw-r--r-- | hosts/common/server/navidrome.nix | 24 | ||||
-rw-r--r-- | hosts/roles/music-server.nix | 31 | ||||
-rw-r--r-- | hosts/tahoe/default.nix | 6 |
3 files changed, 35 insertions, 26 deletions
diff --git a/hosts/common/server/navidrome.nix b/hosts/common/server/navidrome.nix deleted file mode 100644 index e37ccfe..0000000 --- a/hosts/common/server/navidrome.nix +++ /dev/null @@ -1,24 +0,0 @@ -{ config, pkgs, lib, ... }: - -{ - services.navidrome = { - enable = true; - settings = { - MusicFolder = "/data/fast/music"; - Address = "0.0.0.0"; - httpPort = "4533"; - }; - }; - - services.restic.backups = { - navidrome = { - paths = [ "/var/lib/navidrome/" ]; - repository = "/data/slow/backups/systems"; - passwordFile = config.age.secrets.restic-repo-systems.path; - timerConfig = { OnCalendar = "00:35"; }; - initialize = true; - extraBackupArgs = [ "--tag navidrome" ]; - pruneOpts = [ "--keep-daily 7" "--keep-weekly 4 --keep-monthly 6" ]; - }; - }; -} diff --git a/hosts/roles/music-server.nix b/hosts/roles/music-server.nix new file mode 100644 index 0000000..0b41b05 --- /dev/null +++ b/hosts/roles/music-server.nix @@ -0,0 +1,31 @@ +{ config, pkgs, lib, ... }: +let cfg = config.my.roles.music-server; + +in { + options.my.roles.music-server = { + enable = lib.mkEnableOption "Music server"; + }; + + config = lib.mkIf cfg.enable { + services.navidrome = { + enable = true; + settings = { + MusicFolder = "/data/fast/music"; + Address = "0.0.0.0"; + httpPort = "4533"; + }; + }; + + services.restic.backups = { + navidrome = { + paths = [ "/var/lib/navidrome/" ]; + repository = "/data/slow/backups/systems"; + passwordFile = config.age.secrets.restic-repo-systems.path; + timerConfig = { OnCalendar = "00:35"; }; + initialize = true; + extraBackupArgs = [ "--tag navidrome" ]; + pruneOpts = [ "--keep-daily 7" "--keep-weekly 4 --keep-monthly 6" ]; + }; + }; + }; +} diff --git a/hosts/tahoe/default.nix b/hosts/tahoe/default.nix index 5a746dd..9e41ed2 100644 --- a/hosts/tahoe/default.nix +++ b/hosts/tahoe/default.nix @@ -1,6 +1,6 @@ { config, pkgs, hostname, ... }: - -{ +let my = import ../roles; +in { imports = [ # Include the results of the hardware scan. ./hardware-configuration.nix ../profiles/nas.nix @@ -25,6 +25,8 @@ }; }; + my.roles = { music-server.enable = true; }; + networking.private-wireguard.enable = true; networking.firewall.enable = false; |