nixpkgs/nixos/modules/services/backup/borgmatic.nix

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

59 lines
1.8 KiB
Nix
Raw Normal View History

2021-02-17 04:49:52 +00:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.services.borgmatic;
2022-05-03 00:31:14 +00:00
settingsFormat = pkgs.formats.yaml { };
cfgfile = settingsFormat.generate "config.yaml" cfg.settings;
2021-02-17 04:49:52 +00:00
in {
options.services.borgmatic = {
enable = mkEnableOption "borgmatic";
settings = mkOption {
description = lib.mdDoc ''
2021-02-17 04:49:52 +00:00
See https://torsion.org/borgmatic/docs/reference/configuration/
'';
type = types.submodule {
2022-05-03 00:31:14 +00:00
freeformType = settingsFormat.type;
2021-02-17 04:49:52 +00:00
options.location = {
source_directories = mkOption {
type = types.listOf types.str;
description = lib.mdDoc ''
2021-02-17 04:49:52 +00:00
List of source directories to backup (required). Globs and
tildes are expanded.
'';
example = [ "/home" "/etc" "/var/log/syslog*" ];
};
repositories = mkOption {
type = types.listOf types.str;
description = lib.mdDoc ''
2021-02-17 04:49:52 +00:00
Paths to local or remote repositories (required). Tildes are
expanded. Multiple repositories are backed up to in
sequence. Borg placeholders can be used. See the output of
"borg help placeholders" for details. See ssh_command for
SSH options like identity file or port. If systemd service
is used, then add local repository paths in the systemd
service file to the ReadWritePaths list.
'';
example = [
"user@backupserver:sourcehostname.borg"
"user@backupserver:{fqdn}"
];
};
};
};
};
};
config = mkIf cfg.enable {
environment.systemPackages = [ pkgs.borgmatic ];
environment.etc."borgmatic/config.yaml".source = cfgfile;
systemd.packages = [ pkgs.borgmatic ];
};
}