{ pkgs, lib, config, hostName, ... }: with builtins; { services.sanoid = { enable = true; extraArgs = [ "--verbose" ]; datasets = { "${hostName}/home" = { autosnap = true; autoprune = true; hourly = 12; daily = 7; monthly = 0; yearly = 0; recursive = true; }; "${hostName}/var" = { autosnap = true; autoprune = true; hourly = 12; daily = 7; monthly = 0; yearly = 0; recursive = true; }; }; }; # Tigger backups when disks are plugged services.udev.extraRules = '' ACTION=="add", SUBSYSTEM=="block", KERNEL=="sd*", ATTRS{size}=="1953525168", ENV{SYSTEMD_WANTS}+="zfs-usb-backup@WD10JPVT.service" ''; systemd.services."zfs-usb@" = { description = "ZFS over USB: %I"; unitConfig = { #ConditionPathExists = [ "/dev/disk/by-label/%I" ]; }; serviceConfig = { Type = "oneshot"; RemainAfterExit = true; PrivateTmp = true; ExecStartPre = [ # Scan the zpools, using stable paths "/run/booted-system/sw/bin/zpool import -d /dev/disk/by-id/" ]; ExecStart = # Import the zpool "/bin/sh -xc '/run/booted-system/sw/bin/zpool import -lFd /dev/disk/by-id/ %I || /run/booted-system/sw/bin/zpool reopen %I || /run/booted-system/sw/bin/zpool clear -nFX %I'"; }; }; systemd.services."zfs-usb-backup@" = { description = "ZFS backup over USB: %I"; after = [ "zfs-usb@%i.service" ]; wants = [ "zfs-usb@%i.service" ]; serviceConfig = rec { Type = "oneshot"; RemainAfterExit = true; PrivateTmp = true; CacheDirectory = [ "zfs-usb-backup-%I" ]; RuntimeDirectory = [ "zfs-usb-backup-%I" ]; User = "julm"; Group = "users"; ExecStartPre = [ "+/run/booted-system/sw/bin/zfs allow ${User} bookmark,hold,mount,send ${hostName}/home" "+/run/booted-system/sw/bin/zfs allow ${User} bookmark,hold,mount,send ${hostName}/var" "+/run/booted-system/sw/bin/zfs allow ${User} bookmark,create,destroy,load-key,mount,mountpoint,receive,rollback,snapshot %I/${User}" ]; ExecStart = pkgs.writeShellScript "zfs-usb-backup" '' set -eu DESTPOOL=$1 install -D -m 444 /dev/stdin /tmp/sanoid/sanoid.conf <