This upgrades smtprelay from 1.7.0 -> 1.11.2: - https://github.com/decke/smtprelay/releases/tag/v1.8.0 - https://github.com/decke/smtprelay/releases/tag/v1.9.0 - https://github.com/decke/smtprelay/releases/tag/v1.10.0 - https://github.com/decke/smtprelay/releases/tag/v1.11.1 - https://github.com/decke/smtprelay/releases/tag/v1.11.2 Change-Id: Ia0641f67fcc4672302a51b3ad422e447ea32b203 Reviewed-on: https://cl.tvl.fyi/c/depot/+/13115 Tested-by: BuildkiteCI Reviewed-by: tazjin <tazjin@tvl.su>
61 lines
1.5 KiB
Nix
61 lines
1.5 KiB
Nix
# NixOS module for configuring the simple SMTP relay.
|
|
{ depot, pkgs, config, lib, ... }:
|
|
|
|
let
|
|
inherit (builtins) attrValues mapAttrs;
|
|
inherit (lib)
|
|
concatStringsSep
|
|
mkEnableOption
|
|
mkIf
|
|
mkOption
|
|
types
|
|
;
|
|
|
|
cfg = config.services.depot.smtprelay;
|
|
description = "Simple SMTP relay";
|
|
|
|
# Configuration values that are always overridden.
|
|
#
|
|
# - logging is pinned to stdout for journald compatibility
|
|
# - secret config is loaded through systemd's credential loading facility
|
|
overrideArgs = {
|
|
logfile = "";
|
|
config = "$CREDENTIALS_DIRECTORY/secrets";
|
|
};
|
|
|
|
# Creates the command line argument string for the service.
|
|
prepareArgs = args:
|
|
concatStringsSep " "
|
|
(attrValues (mapAttrs (key: value: "-${key} \"${toString value}\"")
|
|
(args // overrideArgs)));
|
|
in
|
|
{
|
|
options.services.depot.smtprelay = {
|
|
enable = mkEnableOption description;
|
|
|
|
args = mkOption {
|
|
type = types.attrsOf types.str;
|
|
description = "Key value pairs for command line arguments";
|
|
};
|
|
|
|
secretsFile = mkOption {
|
|
type = types.str;
|
|
default = config.age.secretsDir + "/smtprelay";
|
|
};
|
|
};
|
|
|
|
config = mkIf cfg.enable {
|
|
systemd.services.smtprelay = {
|
|
inherit description;
|
|
script = "${pkgs.smtprelay}/bin/smtprelay ${prepareArgs cfg.args}";
|
|
wantedBy = [ "multi-user.target" ];
|
|
|
|
serviceConfig = {
|
|
Restart = "always";
|
|
StateDirectory = "smtprelay";
|
|
DynamicUser = true;
|
|
LoadCredential = "secrets:${cfg.secretsFile}";
|
|
};
|
|
};
|
|
};
|
|
}
|