201 lines
4.9 KiB
Nix
201 lines
4.9 KiB
Nix
{
|
|
stdenv,
|
|
lib,
|
|
fetchurl,
|
|
makeWrapper,
|
|
gnused,
|
|
db,
|
|
openssl,
|
|
cyrus_sasl,
|
|
libnsl,
|
|
coreutils,
|
|
findutils,
|
|
gnugrep,
|
|
gawk,
|
|
icu,
|
|
pcre2,
|
|
m4,
|
|
fetchpatch,
|
|
buildPackages,
|
|
nixosTests,
|
|
withLDAP ? true,
|
|
openldap,
|
|
withPgSQL ? false,
|
|
postgresql,
|
|
withMySQL ? false,
|
|
libmysqlclient,
|
|
withSQLite ? false,
|
|
sqlite,
|
|
}:
|
|
|
|
let
|
|
ccargs = lib.concatStringsSep " " (
|
|
[
|
|
"-DUSE_TLS"
|
|
"-DUSE_SASL_AUTH"
|
|
"-DUSE_CYRUS_SASL"
|
|
"-I${cyrus_sasl.dev}/include/sasl"
|
|
"-DHAS_DB_BYPASS_MAKEDEFS_CHECK"
|
|
]
|
|
++ lib.optional withPgSQL "-DHAS_PGSQL"
|
|
++ lib.optionals withMySQL [
|
|
"-DHAS_MYSQL"
|
|
"-I${libmysqlclient.dev}/include/mysql"
|
|
"-L${libmysqlclient}/lib/mysql"
|
|
]
|
|
++ lib.optional withSQLite "-DHAS_SQLITE"
|
|
++ lib.optionals withLDAP [
|
|
"-DHAS_LDAP"
|
|
"-DUSE_LDAP_SASL"
|
|
]
|
|
);
|
|
auxlibs = lib.concatStringsSep " " (
|
|
[
|
|
"-ldb"
|
|
"-lnsl"
|
|
"-lresolv"
|
|
"-lsasl2"
|
|
"-lcrypto"
|
|
"-lssl"
|
|
]
|
|
++ lib.optional withPgSQL "-lpq"
|
|
++ lib.optional withMySQL "-lmysqlclient"
|
|
++ lib.optional withSQLite "-lsqlite3"
|
|
++ lib.optional withLDAP "-lldap"
|
|
);
|
|
|
|
in
|
|
stdenv.mkDerivation rec {
|
|
pname = "postfix";
|
|
version = "3.9.1";
|
|
|
|
src = fetchurl {
|
|
url = "https://de.postfix.org/ftpmirror/official/postfix-${version}.tar.gz";
|
|
hash = "sha256-xIiUTrA2JXbRj1+MxLmzKjW8s11xuUfarJdkr0dw9kM=";
|
|
};
|
|
|
|
nativeBuildInputs = [
|
|
makeWrapper
|
|
m4
|
|
];
|
|
buildInputs =
|
|
[
|
|
db
|
|
openssl
|
|
cyrus_sasl
|
|
icu
|
|
libnsl
|
|
pcre2
|
|
]
|
|
++ lib.optional withPgSQL postgresql
|
|
++ lib.optional withMySQL libmysqlclient
|
|
++ lib.optional withSQLite sqlite
|
|
++ lib.optional withLDAP openldap;
|
|
|
|
hardeningDisable = [ "format" ];
|
|
hardeningEnable = [ "pie" ];
|
|
|
|
patches = [
|
|
./postfix-script-shell.patch
|
|
./postfix-3.0-no-warnings.patch
|
|
./post-install-script.patch
|
|
./relative-symlinks.patch
|
|
|
|
# glibc 2.34 compat
|
|
(fetchpatch {
|
|
url = "https://src.fedoraproject.org/rpms/postfix/raw/2f9d42453e67ebc43f786d98262a249037f80a77/f/postfix-3.6.2-glibc-234-build-fix.patch";
|
|
sha256 = "sha256-xRUL5gaoIt6HagGlhsGwvwrAfYvzMgydsltYMWvl9BI=";
|
|
})
|
|
];
|
|
|
|
postPatch =
|
|
lib.optionalString (stdenv.hostPlatform != stdenv.buildPlatform) ''
|
|
sed -e 's!bin/postconf!${buildPackages.postfix}/bin/postconf!' -i postfix-install
|
|
''
|
|
+ ''
|
|
sed -e '/^PATH=/d' -i postfix-install
|
|
sed -e "s|@PACKAGE@|$out|" -i conf/post-install
|
|
|
|
# post-install need skip permissions check/set on all symlinks following to /nix/store
|
|
sed -e "s|@NIX_STORE@|$NIX_STORE|" -i conf/post-install
|
|
'';
|
|
|
|
postConfigure = ''
|
|
export command_directory=$out/sbin
|
|
export config_directory=/etc/postfix
|
|
export meta_directory=$out/etc/postfix
|
|
export daemon_directory=$out/libexec/postfix
|
|
export data_directory=/var/lib/postfix/data
|
|
export html_directory=$out/share/postfix/doc/html
|
|
export mailq_path=$out/bin/mailq
|
|
export manpage_directory=$out/share/man
|
|
export newaliases_path=$out/bin/newaliases
|
|
export queue_directory=/var/lib/postfix/queue
|
|
export readme_directory=$out/share/postfix/doc
|
|
export sendmail_path=$out/bin/sendmail
|
|
|
|
makeFlagsArray+=(AR=$AR _AR=$AR RANLIB=$RANLIB _RANLIB=$RANLIB)
|
|
|
|
make makefiles CCARGS='${ccargs}' AUXLIBS='${auxlibs}'
|
|
'';
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
NIX_LDFLAGS = lib.optionalString withLDAP "-llber";
|
|
|
|
installTargets = [ "non-interactive-package" ];
|
|
|
|
installFlags = [ "install_root=installdir" ];
|
|
|
|
postInstall = ''
|
|
mkdir -p $out
|
|
mv -v installdir/$out/* $out/
|
|
cp -rv installdir/etc $out
|
|
sed -e '/^PATH=/d' -i $out/libexec/postfix/post-install
|
|
wrapProgram $out/libexec/postfix/post-install \
|
|
--prefix PATH ":" ${
|
|
lib.makeBinPath [
|
|
coreutils
|
|
findutils
|
|
gnugrep
|
|
]
|
|
}
|
|
wrapProgram $out/libexec/postfix/postfix-script \
|
|
--prefix PATH ":" ${
|
|
lib.makeBinPath [
|
|
coreutils
|
|
findutils
|
|
gnugrep
|
|
gawk
|
|
gnused
|
|
]
|
|
}
|
|
|
|
# Avoid dev-only outputs from being retained in final closure.
|
|
# `makedefs.out` is a documenttation-only file. It should be safe
|
|
# to store invalid store paths there.
|
|
sed -e "s|$NIX_STORE/[a-z0-9]\{32\}-|$NIX_STORE/eeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee-|g" -i $out/etc/postfix/makedefs.out
|
|
'';
|
|
|
|
passthru = {
|
|
tests = { inherit (nixosTests) postfix postfix-raise-smtpd-tls-security-level; };
|
|
|
|
updateScript = ./update.sh;
|
|
};
|
|
|
|
meta = with lib; {
|
|
homepage = "http://www.postfix.org/";
|
|
changelog = "https://www.postfix.org/announcements/postfix-${version}.html";
|
|
description = "Fast, easy to administer, and secure mail server";
|
|
license = with licenses; [
|
|
ipl10
|
|
epl20
|
|
];
|
|
platforms = platforms.linux;
|
|
maintainers = with maintainers; [
|
|
globin
|
|
dotlambda
|
|
lewo
|
|
];
|
|
};
|
|
}
|