Enable e-mail services for auto-upgrade
This commit is contained in:
parent
1260f41dbb
commit
99ed3884f8
|
@ -18,6 +18,7 @@ in
|
||||||
};
|
};
|
||||||
|
|
||||||
config = mkIf cfg.enable {
|
config = mkIf cfg.enable {
|
||||||
|
email.enable = true;
|
||||||
systemd.services.nixos-upgrade.script = mkOverride 50 (
|
systemd.services.nixos-upgrade.script = mkOverride 50 (
|
||||||
let
|
let
|
||||||
nixos-rebuild = "${config.system.build.nixos-rebuild}/bin/nixos-rebuild";
|
nixos-rebuild = "${config.system.build.nixos-rebuild}/bin/nixos-rebuild";
|
||||||
|
|
|
@ -1,7 +1,11 @@
|
||||||
{ config, lib, ... }:
|
{ config, lib, ... }:
|
||||||
with lib;
|
with lib;
|
||||||
|
let
|
||||||
|
cfg = config.email;
|
||||||
|
in
|
||||||
{
|
{
|
||||||
options.email = {
|
options.email = {
|
||||||
|
enable = lib.mkEnableOption "Allow sending system status e-mails via sendmail";
|
||||||
fromAddress = mkOption {
|
fromAddress = mkOption {
|
||||||
type = types.str;
|
type = types.str;
|
||||||
example = "noreply@example.com";
|
example = "noreply@example.com";
|
||||||
|
@ -25,4 +29,21 @@ with lib;
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
config.programs.msmtp = lib.mkIf cfg.enable {
|
||||||
|
enable = true;
|
||||||
|
setSendmail = true;
|
||||||
|
accounts = {
|
||||||
|
default = {
|
||||||
|
auth = true;
|
||||||
|
host = "gvfr.de";
|
||||||
|
passwordeval = "cat /secrets/email_password.txt";
|
||||||
|
user = cfg.fromAddress;
|
||||||
|
from = cfg.fromAddress;
|
||||||
|
port = 465;
|
||||||
|
tls = true;
|
||||||
|
tls_starttls = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -10,24 +10,9 @@ in
|
||||||
enable = lib.mkEnableOption "Send systemd status e-mails";
|
enable = lib.mkEnableOption "Send systemd status e-mails";
|
||||||
};
|
};
|
||||||
|
|
||||||
config.programs.msmtp = lib.mkIf cfg.enable {
|
config = lib.mkIf cfg.enable {
|
||||||
enable = true;
|
email.enable = true;
|
||||||
setSendmail = true;
|
systemd.services."status-email@" = let
|
||||||
accounts = {
|
|
||||||
default = {
|
|
||||||
auth = true;
|
|
||||||
host = "gvfr.de";
|
|
||||||
passwordeval = "cat /secrets/email_password.txt";
|
|
||||||
user = fromAddress;
|
|
||||||
from = fromAddress;
|
|
||||||
port = 465;
|
|
||||||
tls = true;
|
|
||||||
tls_starttls = false;
|
|
||||||
};
|
|
||||||
};
|
|
||||||
};
|
|
||||||
|
|
||||||
config.systemd.services."status-email@" = let
|
|
||||||
sendStatusEmail = pkgs.writeScript "send-status-email" ''
|
sendStatusEmail = pkgs.writeScript "send-status-email" ''
|
||||||
#!${pkgs.bash}/bin/bash
|
#!${pkgs.bash}/bin/bash
|
||||||
|
|
||||||
|
@ -83,7 +68,7 @@ in
|
||||||
ERRMAIL
|
ERRMAIL
|
||||||
'';
|
'';
|
||||||
in
|
in
|
||||||
lib.mkIf cfg.enable {
|
{
|
||||||
unitConfig = {
|
unitConfig = {
|
||||||
Description = "Send a status e-mail for %I";
|
Description = "Send a status e-mail for %I";
|
||||||
};
|
};
|
||||||
|
@ -92,4 +77,5 @@ in
|
||||||
ExecStart = "${sendStatusEmail} %i";
|
ExecStart = "${sendStatusEmail} %i";
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue