diff --git a/hosts/common/optional/nixos-containers/baseddata-worker.nix b/hosts/common/optional/nixos-containers/baseddata-worker.nix index 3e7a98c..f6f5038 100644 --- a/hosts/common/optional/nixos-containers/baseddata-worker.nix +++ b/hosts/common/optional/nixos-containers/baseddata-worker.nix @@ -17,6 +17,14 @@ in { ]; }; + services.restic.backups = { + daily = { + paths = [ + baseddataData + ]; + }; + }; + networking.nat.enable = true; networking.nat.internalInterfaces = ["ve-+"]; networking.nat.externalInterface = "br0"; diff --git a/hosts/common/optional/nixos-containers/docker.nix b/hosts/common/optional/nixos-containers/docker.nix index af4e4a2..a8ba7a0 100644 --- a/hosts/common/optional/nixos-containers/docker.nix +++ b/hosts/common/optional/nixos-containers/docker.nix @@ -23,8 +23,6 @@ in { paths = [ dockerContainerData ]; - exclude = [ - ]; }; }; diff --git a/hosts/common/optional/nixos-containers/metrics-server.nix b/hosts/common/optional/nixos-containers/metrics-server.nix index 29e062e..e777228 100644 --- a/hosts/common/optional/nixos-containers/metrics-server.nix +++ b/hosts/common/optional/nixos-containers/metrics-server.nix @@ -21,8 +21,6 @@ in { paths = [ metricsServerContainerData ]; - exclude = [ - ]; }; }; diff --git a/hosts/common/optional/nixos-containers/nix-bitcoin.nix b/hosts/common/optional/nixos-containers/nix-bitcoin.nix index 95eccd2..8946f1d 100644 --- a/hosts/common/optional/nixos-containers/nix-bitcoin.nix +++ b/hosts/common/optional/nixos-containers/nix-bitcoin.nix @@ -10,6 +10,7 @@ containerIp = configVars.networking.addresses.bitcoin-node.ip; mempoolPort = configVars.networking.addresses.bitcoin-node.services.mempool.port; bitcoinNodeContainerData = configVars.locations.bitcoinNodeContainerData; + bitcoindData = configVars.locations.bitcoindData; gatewayIp = configVars.networking.addresses.gateway.ip; allowip = configVars.networking.addresses.bitcoin-node.services.bitcoind.allowip; pubKeys = lib.filesystem.listFilesRecursive ../../users/keys; @@ -19,10 +20,7 @@ in { daily = { paths = [ bitcoinNodeContainerData - ]; - exclude = [ - "${bitcoinNodeContainerData}/bitcoind" - "${bitcoinNodeContainerData}/electrs" + bitcoindData ]; }; }; @@ -48,6 +46,10 @@ in { hostPath = bitcoinNodeContainerData; isReadOnly = false; }; + "/var/lib/bitcoind" = { + hostPath = bitcoindData; + isReadOnly = false; + }; }; config = { diff --git a/hosts/common/optional/nixos-containers/pihole.nix b/hosts/common/optional/nixos-containers/pihole.nix index 781a4e9..edcc740 100644 --- a/hosts/common/optional/nixos-containers/pihole.nix +++ b/hosts/common/optional/nixos-containers/pihole.nix @@ -21,8 +21,6 @@ in { paths = [ piholeContainerData ]; - exclude = [ - ]; }; }; diff --git a/hosts/common/optional/nixos-containers/semitamaps-worker.nix b/hosts/common/optional/nixos-containers/semitamaps-worker.nix index 7e24e52..23d7ab8 100644 --- a/hosts/common/optional/nixos-containers/semitamaps-worker.nix +++ b/hosts/common/optional/nixos-containers/semitamaps-worker.nix @@ -24,6 +24,14 @@ in { ]; }; + services.restic.backups = { + daily = { + paths = [ + semitamapsData + ]; + }; + }; + containers."${containerName}" = { enableTun = true; diff --git a/hosts/merlin/default.nix b/hosts/merlin/default.nix index 9442dea..fa692fa 100644 --- a/hosts/merlin/default.nix +++ b/hosts/merlin/default.nix @@ -12,6 +12,8 @@ btrfsMountDevice = "/dev/disk/by-id/wwn-0x5001b448b5f7cc7f-part2"; impermanence = true; + homeshareDataLocation = configVars.locations.homeshareDataLocation; + piholeIp = configVars.networking.addresses.pihole.ip; gatewayIp = configVars.networking.addresses.gateway.ip; merlinIp = configVars.networking.addresses.merlin.ip; @@ -110,6 +112,14 @@ in { ]; }; + services.restic.backups = { + daily = { + paths = [ + homeshareDataLocation + ]; + }; + }; + # Enable OpenGL hardware.graphics = { enable = true; diff --git a/vars/default.nix b/vars/default.nix index 4cd2aab..3acbb18 100644 --- a/vars/default.nix +++ b/vars/default.nix @@ -8,16 +8,16 @@ mediaDataMountPoint = "/media/media"; photosDataMountPoint = "/media/photos"; personalDataMountPoint = "/media/personal"; - homeshareDataLocation = "/mnt/main-ssd/homeshare"; metricsServerContainerData = "/mnt/main-ssd/metrics-server"; dockerContainerData = "/mnt/main-ssd/docker"; piholeContainerData = "/mnt/main-ssd/docker/pihole"; - bitcoinNodeContainerData = "/mnt/main-ssd/nix-bitcoin"; - backupContainerData = "/mnt/main-ssd/backup"; - postgresContainerData = "/mnt/main-ssd/postgresql"; - semitamapsData = "/mnt/main-ssd/semitamaps-data"; baseddataData = "/mnt/main-ssd/baseddata-data"; + bitcoinNodeContainerData = "/mnt/main-ssd/nix-bitcoin"; + bitcoindData = "/mnt/btcnode/bitcoind"; + backupContainerData = "/mnt/deepzfs/backup"; + postgresContainerData = "/mnt/nvme-zpool/postgresql"; + semitamapsData = "/mnt/nvme-zpool/semitamaps-data"; }; }