2019-04-12 23:06:11 +00:00
|
|
|
{ config, lib, pkgs, ... }:
|
|
|
|
|
|
|
|
let
|
|
|
|
|
2021-10-03 16:06:03 +00:00
|
|
|
inherit (lib) concatMapStringsSep concatStringsSep isInt isList literalExpression;
|
2023-05-10 23:59:39 +00:00
|
|
|
inherit (lib) mapAttrs mapAttrsToList mkDefault mkEnableOption mkIf mkOption mkRenamedOptionModule optional types;
|
2019-04-12 23:06:11 +00:00
|
|
|
|
|
|
|
cfg = config.services.automysqlbackup;
|
|
|
|
pkg = pkgs.automysqlbackup;
|
|
|
|
user = "automysqlbackup";
|
|
|
|
group = "automysqlbackup";
|
|
|
|
|
|
|
|
toStr = val:
|
|
|
|
if isList val then "( ${concatMapStringsSep " " (val: "'${val}'") val} )"
|
|
|
|
else if isInt val then toString val
|
|
|
|
else if true == val then "'yes'"
|
|
|
|
else if false == val then "'no'"
|
|
|
|
else "'${toString val}'";
|
|
|
|
|
|
|
|
configFile = pkgs.writeText "automysqlbackup.conf" ''
|
|
|
|
#version=${pkg.version}
|
|
|
|
# DONT'T REMOVE THE PREVIOUS VERSION LINE!
|
|
|
|
#
|
|
|
|
${concatStringsSep "\n" (mapAttrsToList (name: value: "CONFIG_${name}=${toStr value}") cfg.config)}
|
|
|
|
'';
|
|
|
|
|
|
|
|
in
|
|
|
|
{
|
2023-05-10 23:59:39 +00:00
|
|
|
imports = [
|
|
|
|
(mkRenamedOptionModule [ "services" "automysqlbackup" "config" ] [ "services" "automysqlbackup" "settings" ])
|
|
|
|
];
|
|
|
|
|
2019-04-12 23:06:11 +00:00
|
|
|
# interface
|
|
|
|
options = {
|
|
|
|
services.automysqlbackup = {
|
|
|
|
|
|
|
|
enable = mkEnableOption (lib.mdDoc "AutoMySQLBackup");
|
|
|
|
|
|
|
|
calendar = mkOption {
|
|
|
|
type = types.str;
|
|
|
|
default = "01:15:00";
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
Configured when to run the backup service systemd unit (DayOfWeek Year-Month-Day Hour:Minute:Second).
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
2023-05-10 23:59:39 +00:00
|
|
|
settings = mkOption {
|
2019-08-08 21:35:52 +00:00
|
|
|
type = with types; attrsOf (oneOf [ str int bool (listOf str) ]);
|
2019-04-12 23:06:11 +00:00
|
|
|
default = {};
|
|
|
|
description = lib.mdDoc ''
|
|
|
|
automysqlbackup configuration. Refer to
|
|
|
|
{file}`''${pkgs.automysqlbackup}/etc/automysqlbackup.conf`
|
|
|
|
for details on supported values.
|
|
|
|
'';
|
2021-10-03 16:06:03 +00:00
|
|
|
example = literalExpression ''
|
2019-04-12 23:06:11 +00:00
|
|
|
{
|
|
|
|
db_names = [ "nextcloud" "matomo" ];
|
|
|
|
table_exclude = [ "nextcloud.oc_users" "nextcloud.oc_whats_new" ];
|
|
|
|
mailcontent = "log";
|
|
|
|
mail_address = "admin@example.org";
|
|
|
|
}
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
# implementation
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
|
|
|
|
assertions = [
|
|
|
|
{ assertion = !config.services.mysqlBackup.enable;
|
|
|
|
message = "Please choose one of services.mysqlBackup or services.automysqlbackup.";
|
|
|
|
}
|
|
|
|
];
|
|
|
|
|
|
|
|
services.automysqlbackup.config = mapAttrs (name: mkDefault) {
|
|
|
|
mysql_dump_username = user;
|
|
|
|
mysql_dump_host = "localhost";
|
2021-08-08 21:47:05 +00:00
|
|
|
mysql_dump_socket = "/run/mysqld/mysqld.sock";
|
2019-04-12 23:06:11 +00:00
|
|
|
backup_dir = "/var/backup/mysql";
|
|
|
|
db_exclude = [ "information_schema" "performance_schema" ];
|
|
|
|
mailcontent = "stdout";
|
|
|
|
mysql_dump_single_transaction = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.timers.automysqlbackup = {
|
|
|
|
description = "automysqlbackup timer";
|
|
|
|
wantedBy = [ "timers.target" ];
|
|
|
|
timerConfig = {
|
|
|
|
OnCalendar = cfg.calendar;
|
|
|
|
AccuracySec = "5m";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
systemd.services.automysqlbackup = {
|
|
|
|
description = "automysqlbackup service";
|
|
|
|
serviceConfig = {
|
|
|
|
User = user;
|
|
|
|
Group = group;
|
|
|
|
ExecStart = "${pkg}/bin/automysqlbackup ${configFile}";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
environment.systemPackages = [ pkg ];
|
|
|
|
|
2019-10-12 20:25:28 +00:00
|
|
|
users.users.${user} = {
|
|
|
|
group = group;
|
|
|
|
isSystemUser = true;
|
|
|
|
};
|
2019-04-12 23:06:11 +00:00
|
|
|
users.groups.${group} = { };
|
|
|
|
|
|
|
|
systemd.tmpfiles.rules = [
|
|
|
|
"d '${cfg.config.backup_dir}' 0750 ${user} ${group} - -"
|
|
|
|
];
|
|
|
|
|
|
|
|
services.mysql.ensureUsers = optional (config.services.mysql.enable && cfg.config.mysql_dump_host == "localhost") {
|
|
|
|
name = user;
|
2023-05-10 23:57:48 +00:00
|
|
|
ensurePermissions = {
|
|
|
|
"*.*" = "SELECT, SHOW VIEW, TRIGGER, LOCK TABLES, EVENT";
|
|
|
|
|
|
|
|
# https://forums.mysql.com/read.php?10,668311,668315#msg-668315
|
|
|
|
"function sys.extract_table_from_file_name" = "execute";
|
|
|
|
"function sys.format_path" = "execute";
|
|
|
|
"function sys.format_statement" = "execute";
|
|
|
|
"function sys.extract_schema_from_file_name" = "execute";
|
|
|
|
"function sys.ps_thread_account" = "execute";
|
|
|
|
"function sys.format_time" = "execute";
|
|
|
|
"function sys.format_bytes" = "execute";
|
|
|
|
};
|
2019-04-12 23:06:11 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
};
|
|
|
|
}
|