nixos/modules/restic-server/default.nix
2022-02-28 17:16:23 +01:00

37 lines
836 B
Nix

{ inputs, custom, pkgs, ... }:
let
repository = "/mnt/restic-server";
in
{
environment.systemPackages = with pkgs; [
restic
];
fileSystems.${repository} = {
device = "10.7.89.108:restic-server";
fsType = "nfs";
};
services.restic.server = {
enable = true;
dataDir = repository;
extraFlags = [ "--no-auth" ];
};
networking.firewall.allowedTCPPorts = [ 8000 ];
systemd.services.restic-prune = {
serviceConfig.Type = "oneshot";
script = ''
${pkgs.restic}/bin/restic \
--repo ${repository} \
--password-file "/home/${custom.username}/.nixos/secrets/passwords/restic.key" \
prune \
'';
};
systemd.timers.restic-prune = {
wantedBy = [ "timers.target" ];
partOf = [ "restic-prune.service" ];
timerConfig.OnCalendar = [ "*-*-* 12:00:00" ];
};
}