blob: 40c8fd9a0e7ef40ec4a7e882ab479e57fe799516 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
|
# To initialize repo
# borg init --encryption=keyfile /staging/backup
# Key file also stored in pass
{ config, lib, pkgs, ... }:
let
repo = /staging/backup
in
{
systemd.services.borg-backup = {
description = "Run backups.";
path = with pkgs [ borgbackup ];
startAt = "*-*-* 02:30:00";
environment = {
BORG_KEYS_DIR = "/opt/secret/borg-backup-keys/";
REPOSITORY = "/staging/backup";
};
serviceConfig = {
RemainAfterExit = true;
};
script = ''
echo "Creating backup"
borg create -v --stats \
--compression lzma,6 \
$REPOSITORY::'storage-{now:%Y-%m-%d}' \
/storage
borg create -v --stats \
--compression lzma,6 \
$REPOSITORY::'{hostname}-{now:%Y-%m-%d}' \
/opt /home
echo "Pruning old versions"
borg prune -v --list $REPOSITORY --prefix 'storage-' \
--keep-daily=7 --keep-weekly=4 --keep-monthly=6
borg prune -v --list $REPOSITORY --prefix '{hostname}-' \
--keep-daily=7 --keep-weekly=4 --keep-monthly=6
'';
};
};
|