mirror of
https://github.com/NixOS/nixpkgs.git
synced 2024-11-17 07:13:23 +01:00
Merge pull request #25381 from sargon/nullmailer
nullmailer + service: init at 2.0
This commit is contained in:
commit
ae12ded6bf
4 changed files with 271 additions and 0 deletions
|
@ -256,6 +256,7 @@
|
|||
./services/mail/spamassassin.nix
|
||||
./services/mail/rspamd.nix
|
||||
./services/mail/rmilter.nix
|
||||
./services/mail/nullmailer.nix
|
||||
./services/misc/apache-kafka.nix
|
||||
./services/misc/autofs.nix
|
||||
./services/misc/autorandr.nix
|
||||
|
|
217
nixos/modules/services/mail/nullmailer.nix
Normal file
217
nixos/modules/services/mail/nullmailer.nix
Normal file
|
@ -0,0 +1,217 @@
|
|||
{ config, lib, pkgs, ... }:
|
||||
|
||||
with lib;
|
||||
|
||||
{
|
||||
|
||||
options = {
|
||||
|
||||
services.nullmailer = {
|
||||
enable = mkOption {
|
||||
type = types.bool;
|
||||
default = false;
|
||||
description = "Whether to enable nullmailer daemon.";
|
||||
};
|
||||
|
||||
user = mkOption {
|
||||
type = types.string;
|
||||
default = "nullmailer";
|
||||
description = ''
|
||||
User to use to run nullmailer-send.
|
||||
'';
|
||||
};
|
||||
|
||||
group = mkOption {
|
||||
type = types.string;
|
||||
default = "nullmailer";
|
||||
description = ''
|
||||
Group to use to run nullmailer-send.
|
||||
'';
|
||||
};
|
||||
|
||||
setSendmail = mkOption {
|
||||
type = types.bool;
|
||||
default = true;
|
||||
description = "Whether to set the system sendmail to nullmailer's.";
|
||||
};
|
||||
|
||||
config = {
|
||||
adminaddr = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
If set, all recipients to users at either "localhost" (the literal string)
|
||||
or the canonical host name (from the me control attribute) are remapped to this address.
|
||||
This is provided to allow local daemons to be able to send email to
|
||||
"somebody@localhost" and have it go somewhere sensible instead of being bounced
|
||||
by your relay host. To send to multiple addresses,
|
||||
put them all on one line separated by a comma.
|
||||
'';
|
||||
};
|
||||
|
||||
allmailfrom = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
If set, content will override the envelope sender on all messages.
|
||||
'';
|
||||
};
|
||||
|
||||
defaultdomain = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The content of this attribute is appended to any host name that
|
||||
does not contain a period (except localhost), including defaulthost
|
||||
and idhost. Defaults to the value of the me attribute, if it exists,
|
||||
otherwise the literal name defauldomain.
|
||||
'';
|
||||
};
|
||||
|
||||
defaulthost = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The content of this attribute is appended to any address that
|
||||
is missing a host name. Defaults to the value of the me control
|
||||
attribute, if it exists, otherwise the literal name defaulthost.
|
||||
'';
|
||||
};
|
||||
|
||||
doublebounceto = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
If the original sender was empty (the original message was a
|
||||
delivery status or disposition notification), the double bounce
|
||||
is sent to the address in this attribute.
|
||||
'';
|
||||
};
|
||||
|
||||
helohost = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
Sets the environment variable $HELOHOST which is used by the
|
||||
SMTP protocol module to set the parameter given to the HELO command.
|
||||
Defaults to the value of the me configuration attribute.
|
||||
'';
|
||||
};
|
||||
|
||||
idhost = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The content of this attribute is used when building the message-id
|
||||
string for the message. Defaults to the canonicalized value of defaulthost.
|
||||
'';
|
||||
};
|
||||
|
||||
maxpause = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The maximum time to pause between successive queue runs, in seconds.
|
||||
Defaults to 24 hours (86400).
|
||||
'';
|
||||
};
|
||||
|
||||
me = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The fully-qualifiled host name of the computer running nullmailer.
|
||||
Defaults to the literal name me.
|
||||
'';
|
||||
};
|
||||
|
||||
pausetime = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The minimum time to pause between successive queue runs when there
|
||||
are messages in the queue, in seconds. Defaults to 1 minute (60).
|
||||
Each time this timeout is reached, the timeout is doubled to a
|
||||
maximum of maxpause. After new messages are injected, the timeout
|
||||
is reset. If this is set to 0, nullmailer-send will exit
|
||||
immediately after going through the queue once (one-shot mode).
|
||||
'';
|
||||
};
|
||||
|
||||
remotes = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
If set, content will override the envelope sender on all messages.
|
||||
'';
|
||||
};
|
||||
|
||||
sendtimeout = mkOption {
|
||||
type = types.nullOr types.str;
|
||||
default = null;
|
||||
description = ''
|
||||
The time to wait for a remote module listed above to complete sending
|
||||
a message before killing it and trying again, in seconds.
|
||||
Defaults to 1 hour (3600). If this is set to 0, nullmailer-send
|
||||
will wait forever for messages to complete sending.
|
||||
'';
|
||||
};
|
||||
};
|
||||
};
|
||||
};
|
||||
|
||||
config = let
|
||||
cfg = config.services.nullmailer;
|
||||
in mkIf cfg.enable {
|
||||
|
||||
environment = {
|
||||
systemPackages = [ pkgs.nullmailer ];
|
||||
etc = let
|
||||
getval = attr: builtins.getAttr attr cfg.config;
|
||||
attrs = builtins.attrNames cfg.config;
|
||||
attrs' = builtins.filter (attr: ! isNull (getval attr)) attrs;
|
||||
in foldl' (as: attr: as // { "nullmailer/${attr}".text = getval attr; }) {} attrs';
|
||||
};
|
||||
|
||||
users = {
|
||||
extraUsers = singleton {
|
||||
name = cfg.user;
|
||||
description = "Nullmailer relay-only mta user";
|
||||
group = cfg.group;
|
||||
};
|
||||
|
||||
extraGroups = singleton {
|
||||
name = cfg.group;
|
||||
};
|
||||
};
|
||||
|
||||
systemd.services.nullmailer = {
|
||||
description = "nullmailer";
|
||||
wantedBy = [ "multi-user.target" ];
|
||||
after = [ "network.target" ];
|
||||
|
||||
preStart = ''
|
||||
mkdir -p /var/spool/nullmailer/{queue,tmp}
|
||||
rm -f var/spool/nullmailer/trigger && mkfifo -m 660 /var/spool/nullmailer/trigger
|
||||
chown ${cfg.user} /var/spool/nullmailer/*
|
||||
'';
|
||||
|
||||
serviceConfig = {
|
||||
User = cfg.user;
|
||||
Group = cfg.group;
|
||||
PermissionsStartOnly=true;
|
||||
ExecStart = "${pkgs.nullmailer}/bin/nullmailer-send";
|
||||
Restart = "always";
|
||||
};
|
||||
};
|
||||
|
||||
services.mail.sendmailSetuidWrapper = mkIf cfg.setSendmail {
|
||||
program = "sendmail";
|
||||
source = "${pkgs.nullmailer}/bin/sendmail";
|
||||
owner = cfg.user;
|
||||
group = cfg.group;
|
||||
setuid = true;
|
||||
setgid = true;
|
||||
};
|
||||
};
|
||||
}
|
51
pkgs/servers/mail/nullmailer/default.nix
Normal file
51
pkgs/servers/mail/nullmailer/default.nix
Normal file
|
@ -0,0 +1,51 @@
|
|||
{ stdenv, fetchurl, lib, tls ? true, gnutls ? null }:
|
||||
|
||||
assert tls -> gnutls != null;
|
||||
|
||||
stdenv.mkDerivation rec {
|
||||
|
||||
version = "2.0";
|
||||
name = "nullmailer-${version}";
|
||||
|
||||
src = fetchurl {
|
||||
url = "http://untroubled.org/nullmailer/nullmailer-${version}.tar.gz";
|
||||
sha256 = "112ghdln8q9yljc8kp9mc3843mh0fyb4rig2v4q2dzy1l324q3yp";
|
||||
};
|
||||
|
||||
buildInputs = stdenv.lib.optional tls gnutls;
|
||||
|
||||
configureFlags = [
|
||||
"--sysconfdir=/etc"
|
||||
"--localstatedir=/var"
|
||||
] ++ stdenv.lib.optional tls "--enable-tls";
|
||||
|
||||
installFlags = [ "DESTDIR=$(out)" ];
|
||||
|
||||
# We have to remove the ''var'' directory, since nix can't handle named pipes
|
||||
# and we can't use it in the store anyway. Same for ''etc''.
|
||||
# The second line is need, because the installer of nullmailer will copy its
|
||||
# own prepared version of ''etc'' and ''var'' and also uses the prefix path (configure phase)
|
||||
# for hardcoded absolute references to its own binary farm, e.g. sendmail binary is
|
||||
# calling nullmailer-inject binary. Since we can't configure inside the store of
|
||||
# the derivation we need both directories in the root, but don't want to put them there
|
||||
# during install, hence we have to fix mumbling inside the install directory.
|
||||
# This is kind of a hack, but the only way I know of, yet.
|
||||
postInstall = ''
|
||||
rm -rf $out/var/ $out/etc/
|
||||
mv $out/$out/* $out/
|
||||
rmdir $out/$out
|
||||
'';
|
||||
|
||||
enableParallelBuilding = true;
|
||||
|
||||
meta = {
|
||||
homepage = "http://untroubled.org/nullmailer/";
|
||||
description = ''
|
||||
A sendmail/qmail/etc replacement MTA for hosts which relay to a fixed set of smart relays.
|
||||
It is designed to be simple to configure, secure, and easily extendable.
|
||||
'';
|
||||
license = lib.licenses.gpl2;
|
||||
platforms = lib.platforms.all;
|
||||
maintainers = with lib.maintainers ; [ sargon ];
|
||||
};
|
||||
}
|
|
@ -12747,6 +12747,8 @@ with pkgs;
|
|||
inherit (callPackages ../data/fonts/noto-fonts {})
|
||||
noto-fonts noto-fonts-cjk noto-fonts-emoji;
|
||||
|
||||
nullmailer = callPackage ../servers/mail/nullmailer { };
|
||||
|
||||
numix-icon-theme = callPackage ../data/icons/numix-icon-theme { };
|
||||
|
||||
numix-icon-theme-circle = callPackage ../data/icons/numix-icon-theme-circle { };
|
||||
|
|
Loading…
Reference in a new issue