39 lines
809 B
Nix
39 lines
809 B
Nix
{ pkgs, config, ... }:
|
|
let
|
|
borgJob = name: {
|
|
environment = {
|
|
BORG_RSH = "ssh -i ${config.sops.secrets.bsky-backup-ssh-key.path}";
|
|
};
|
|
repo = "ssh://zh2088@zh2088.rsync.net/./backups/bsky/${name}";
|
|
compression = "zstd,10";
|
|
startAt = "*-*-* 2:30:00";
|
|
extraInitArgs = "--make-parent-dirs";
|
|
archiveBaseName = name;
|
|
|
|
encryption = {
|
|
mode = "repokey-blake2";
|
|
passCommand = "cat ${config.sops.secrets.bsky-backup-pass.path}";
|
|
};
|
|
|
|
prune = {
|
|
keep = {
|
|
within = "1d";
|
|
daily = 7;
|
|
weekly = 4;
|
|
monthly = -1;
|
|
};
|
|
};
|
|
};
|
|
in
|
|
{
|
|
services = {
|
|
borgbackup.jobs = {
|
|
bsky-pds = borgJob "bsky-pds" // {
|
|
paths = [ "/var/lib/pds" ];
|
|
};
|
|
};
|
|
};
|
|
|
|
environment.systemPackages = [ pkgs.borgbackup ];
|
|
|
|
}
|