40 lines
848 B
Nix
40 lines
848 B
Nix
{ pkgs, config, lib, ... }:
|
|
with lib;
|
|
let
|
|
borgJob = name: {
|
|
environment = {
|
|
BORG_RSH = "ssh -i ${config.sops.secrets.gitea_backup_ssh_key.path}";
|
|
};
|
|
repo = "ssh://zh2088@zh2088.rsync.net/./backups/forgejo/${name}";
|
|
compression = "zstd,10";
|
|
startAt = "*-*-* 2,6,10,14,18,22:30:00";
|
|
extraInitArgs = "--make-parent-dirs";
|
|
archiveBaseName = name;
|
|
|
|
encryption = {
|
|
mode = "repokey-blake2";
|
|
passCommand = "cat ${config.sops.secrets.gitea_backup_pass.path}";
|
|
};
|
|
|
|
prune = {
|
|
keep = {
|
|
within = "1d";
|
|
daily = 7;
|
|
weekly = 4;
|
|
monthly = -1;
|
|
};
|
|
};
|
|
};
|
|
in
|
|
{
|
|
services = {
|
|
borgbackup.jobs = {
|
|
repos = borgJob "forgejo" // {
|
|
paths = [ "/var/lib/forgejo/dump" ];
|
|
};
|
|
};
|
|
};
|
|
|
|
|
|
environment.systemPackages = [ pkgs.borgbackup ];
|
|
}
|