2023-10-28 17:04:37 -07:00
|
|
|
{ config, pkgs, system, lib, stdenv, ...}:
|
|
|
|
|
|
|
|
let
|
|
|
|
cfg = config.programs.alaska_backup_script;
|
|
|
|
in
|
|
|
|
{
|
2023-10-28 19:43:56 -07:00
|
|
|
|
2023-10-28 17:04:37 -07:00
|
|
|
options.programs.alaska_backup_script = {
|
|
|
|
enable = lib.mkEnableOption (lib.mdDoc "Alaska Backup Script service");
|
|
|
|
|
|
|
|
run_nightly = lib.mkOption {
|
|
|
|
type = lib.types.bool;
|
|
|
|
default = false;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Whether to enable the service to auto-run the script
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
tmp_mount_point = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
|
|
|
default = /Aurora/backup_drive_mount_point;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The point used as the mount point of the primary external backup
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
backup1_drive_label = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "AlaskaBackup";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The drive label used as the primary backup device
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
nextcloud = {
|
|
|
|
root_dir = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
|
|
|
default = /Aurora/nextcloud;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The root of the nextcloud file directory
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
db_server = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "127.0.0.1";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The server to connect to with the nextcloud db credentials and backup
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
db_name = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "nextcloud";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The nextcloud database to copy
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
db_user = lib.mkOption {
|
|
|
|
type = lib.types.str;
|
|
|
|
default = "nextcloud";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The nextcloud database user to use for backups.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
db_passfile = lib.mkOption {
|
|
|
|
type = lib.types.path;
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
The filepath to the nextcloud database user password.
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = lib.mkIf cfg.enable {
|
|
|
|
|
2023-10-28 19:43:56 -07:00
|
|
|
systemd.services.alaska_backup_script_onfail = {
|
|
|
|
description = "Clean up permissions on script fail";
|
|
|
|
path = with pkgs; [
|
|
|
|
config.services.nextcloud.occ
|
|
|
|
umount
|
|
|
|
];
|
|
|
|
script = ''
|
2023-10-28 17:04:37 -07:00
|
|
|
nextcloud-occ maintenance:mode --off
|
|
|
|
|
|
|
|
echo "Unmounting the external drive"
|
|
|
|
umount ${cfg.tmp_mount_point}
|
2023-10-28 19:43:56 -07:00
|
|
|
'';
|
2023-10-28 17:04:37 -07:00
|
|
|
};
|
|
|
|
|
2023-10-28 19:43:56 -07:00
|
|
|
systemd.services.alaska_backup_script = {
|
|
|
|
description = "Alaska Nightly Backup Service";
|
|
|
|
onFailure = [ "alaska_backup_script_onfail.service" ];
|
|
|
|
path = with pkgs; [
|
|
|
|
config.services.nextcloud.occ
|
|
|
|
config.services.postgresql.package
|
|
|
|
rsync
|
|
|
|
mount
|
|
|
|
umount
|
|
|
|
];
|
|
|
|
script = ''
|
|
|
|
# ${pkgs.lib.makeBinPath [ pkgs.screen ]}/screen -dmS AlaskaBackupJob \
|
|
|
|
# ${pkgs.lib.makeBinPath [ pkgs.bash ]}/bash -c "
|
|
|
|
echo "Created the temporary mount point if it does not exit"
|
|
|
|
mkdir -p ${builtins.toString cfg.tmp_mount_point}
|
|
|
|
|
|
|
|
echo "Mounting the external backup drive"
|
|
|
|
mount /dev/disk/by-label/${cfg.backup1_drive_label} ${builtins.toString cfg.tmp_mount_point}
|
|
|
|
|
|
|
|
echo "Puttin nextcloud into maintenance mode so that changes cannot happen during the backup"
|
|
|
|
nextcloud-occ maintenance:mode --on
|
|
|
|
|
|
|
|
echo "Backing up the nextcloud database"
|
|
|
|
password='cat ${builtins.toString cfg.nextcloud.db_passfile}'
|
|
|
|
PGPASSWORD="$password" pg_dump \
|
|
|
|
${builtins.toString cfg.nextcloud.db_name} -h ${builtins.toString cfg.nextcloud.db_server} \
|
|
|
|
-U ${builtins.toString cfg.nextcloud.db_user} \
|
|
|
|
-f ${builtins.toString cfg.tmp_mount_point}/nextcloud-sqlbkp_`date +"%Y%m%d"`.bak
|
2023-10-28 17:04:37 -07:00
|
|
|
|
2023-10-28 19:43:56 -07:00
|
|
|
echo "Backing up the nextcloud files"
|
|
|
|
# -a archive | -v verbose
|
|
|
|
rsync -av ${builtins.toString cfg.nextcloud.root_dir} \
|
2023-11-15 20:40:01 -08:00
|
|
|
${builtins.toString cfg.tmp_mount_point}/nextcloud \
|
|
|
|
--exclude '*/appdata_*' --exclude "*/files_trashbin/*" --exclude "*/files_versions/*"
|
2023-10-28 19:43:56 -07:00
|
|
|
|
|
|
|
echo "Get nextcloud out of maintenance mode so that normal operations can resume"
|
|
|
|
nextcloud-occ maintenance:mode --off
|
|
|
|
|
|
|
|
echo "Unmounting the external drive"
|
2023-11-14 20:08:44 -08:00
|
|
|
umount ${builtins.toString cfg.tmp_mount_point}
|
2023-10-28 19:43:56 -07:00
|
|
|
|
|
|
|
echo "Job completed"
|
|
|
|
# "
|
|
|
|
'';
|
|
|
|
startAt = "Sun 14:00:00";
|
|
|
|
|
|
|
|
# serviceConfig = {
|
|
|
|
# Type = "oneshot";
|
|
|
|
# };
|
2023-10-28 17:04:37 -07:00
|
|
|
};
|
2023-10-28 19:43:56 -07:00
|
|
|
|
|
|
|
# config.systemd.timers.alaska_backup_script = lib.mkIf cfg.run_nightly {
|
|
|
|
# wantedBy = [ "timers.target" ];
|
|
|
|
# partOf = [ "alaska_backup_script.service" ];
|
|
|
|
# timerConfig.OnCalendar
|
|
|
|
# };
|
2023-10-28 17:04:37 -07:00
|
|
|
};
|
|
|
|
}
|