2021-01-19 07:50:56 +01:00
|
|
|
{ stdenv, lib, fetchurl, perl, pkg-config, systemd, openssl
|
2021-06-24 22:17:11 +02:00
|
|
|
, bzip2, zlib, lz4, inotify-tools, pam, libcap, coreutils
|
2018-09-18 21:46:43 +02:00
|
|
|
, clucene_core_2, icu, openldap, libsodium, libstemmer, cyrus_sasl
|
dovecot, opensmtpd: add link to test in `meta.tests`
Rationale
---------
Currently, tests are hard to discover. For instance, someone updating
`dovecot` might not notice that the interaction of `dovecot` with
`opensmtpd` is handled in the `opensmtpd.nix` test.
And even for someone updating `opensmtpd`, it requires manual work to go
check in `nixos/tests` whether there is actually a test, especially
given not so many packages in `nixpkgs` have tests and this is thus most
of the time useless.
Finally, for the reviewer, it is much easier to check that the “Tested
via one or more NixOS test(s)” has been checked if the file modified
already includes the list of relevant tests.
Implementation
--------------
Currently, this commit only adds the metadata in the package. Each
element of the `meta.tests` attribute is a derivation that, when it
builds successfully, means the test has passed (ie. following the same
convention as NixOS tests).
Future Work
-----------
In the future, the tools could be made aware of this `meta.tests`
attribute, and for instance a `--with-tests` could be added to
`nix-build` so that it also builds all the tests. Or a `--without-tests`
to build without all the tests. @Profpatsch described in his NixCon talk
such systems.
Another thing that would help in the future would be the possibility to
reasonably easily have cross-derivation nix tests without the whole
NixOS VM stack. @7c6f434c already proposed such a system.
This RFC currently handles none of these concerns. Only the addition of
`meta.tests` as metadata to be used by maintainers to remember to run
relevant tests.
2018-08-04 05:18:28 +02:00
|
|
|
, nixosTests
|
2022-07-06 16:28:45 +02:00
|
|
|
, fetchpatch
|
2016-03-11 15:45:01 +01:00
|
|
|
# Auth modules
|
2019-09-22 09:38:09 +02:00
|
|
|
, withMySQL ? false, libmysqlclient
|
2016-03-11 15:45:01 +01:00
|
|
|
, withPgSQL ? false, postgresql
|
|
|
|
, withSQLite ? true, sqlite
|
2021-06-21 16:18:51 +02:00
|
|
|
, withLua ? false, lua5_3
|
2016-03-11 15:45:01 +01:00
|
|
|
}:
|
2011-10-25 22:34:19 +02:00
|
|
|
|
2012-06-13 09:09:03 +02:00
|
|
|
stdenv.mkDerivation rec {
|
2020-05-18 18:40:40 +02:00
|
|
|
pname = "dovecot";
|
2022-06-14 12:49:22 +02:00
|
|
|
version = "2.3.19.1";
|
2011-10-25 22:34:19 +02:00
|
|
|
|
2021-01-19 07:50:56 +01:00
|
|
|
nativeBuildInputs = [ perl pkg-config ];
|
2018-01-28 04:37:29 +01:00
|
|
|
buildInputs =
|
2018-09-18 21:46:43 +02:00
|
|
|
[ openssl bzip2 zlib lz4 clucene_core_2 icu openldap libsodium libstemmer cyrus_sasl.dev ]
|
2016-03-11 15:45:01 +01:00
|
|
|
++ lib.optionals (stdenv.isLinux) [ systemd pam libcap inotify-tools ]
|
2019-09-22 09:38:09 +02:00
|
|
|
++ lib.optional withMySQL libmysqlclient
|
2016-03-11 15:45:01 +01:00
|
|
|
++ lib.optional withPgSQL postgresql
|
2021-06-21 16:18:51 +02:00
|
|
|
++ lib.optional withSQLite sqlite
|
|
|
|
++ lib.optional withLua lua5_3;
|
2011-10-25 22:34:19 +02:00
|
|
|
|
|
|
|
src = fetchurl {
|
2021-03-05 00:33:21 +01:00
|
|
|
url = "https://dovecot.org/releases/${lib.versions.majorMinor version}/${pname}-${version}.tar.gz";
|
2022-06-14 12:49:22 +02:00
|
|
|
hash = "sha256-21q82H1zCWWeprRbLLbunF+XSGsrcZpd0Fp1nh9qXFE=";
|
2011-10-25 22:34:19 +02:00
|
|
|
};
|
|
|
|
|
2018-12-10 23:48:42 +01:00
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
2021-06-24 22:17:11 +02:00
|
|
|
postPatch = ''
|
|
|
|
sed -i -E \
|
|
|
|
-e 's!/bin/sh\b!${stdenv.shell}!g' \
|
|
|
|
-e 's!([^[:alnum:]/_-])/bin/([[:alnum:]]+)\b!\1${coreutils}/bin/\2!g' \
|
|
|
|
-e 's!([^[:alnum:]/_-])(head|sleep|cat)\b!\1${coreutils}/bin/\2!g' \
|
|
|
|
src/lib-program-client/test-program-client-local.c
|
|
|
|
|
|
|
|
patchShebangs src/lib-smtp/test-bin/*.sh
|
|
|
|
sed -i -s -E 's!\bcat\b!${coreutils}/bin/cat!g' src/lib-smtp/test-bin/*.sh
|
|
|
|
|
2016-03-11 15:45:01 +01:00
|
|
|
patchShebangs src/config/settings-get.pl
|
2021-06-24 22:17:11 +02:00
|
|
|
'' + lib.optionalString stdenv.isLinux ''
|
|
|
|
export systemdsystemunitdir=$out/etc/systemd/system
|
|
|
|
'';
|
2016-03-11 15:45:01 +01:00
|
|
|
|
|
|
|
# We need this for sysconfdir, see remark below.
|
|
|
|
installFlags = [ "DESTDIR=$(out)" ];
|
|
|
|
|
|
|
|
postInstall = ''
|
|
|
|
cp -r $out/$out/* $out
|
|
|
|
rm -rf $out/$(echo "$out" | cut -d "/" -f2)
|
|
|
|
'';
|
|
|
|
|
|
|
|
patches = [
|
|
|
|
# Make dovecot look for plugins in /etc/dovecot/modules
|
|
|
|
# so we can symlink plugins from several packages there.
|
|
|
|
# The symlinking needs to be done in NixOS.
|
2019-12-15 03:45:47 +01:00
|
|
|
./2.3.x-module_dir.patch
|
2022-07-06 16:28:45 +02:00
|
|
|
# fix CVE-2022-30550
|
|
|
|
(fetchpatch {
|
|
|
|
url = "https://github.com/dovecot/core/compare/7bad6a24%5E..a1022072.patch";
|
|
|
|
hash = "sha256-aSyRcQreyA9j8QwkODHqPpRuS3vzouVatEWCqhh+r+8=";
|
|
|
|
})
|
2016-03-11 15:45:01 +01:00
|
|
|
];
|
|
|
|
|
2012-07-30 18:58:54 +02:00
|
|
|
configureFlags = [
|
2016-03-11 15:45:01 +01:00
|
|
|
# It will hardcode this for /var/lib/dovecot.
|
|
|
|
# http://bugs.debian.org/cgi-bin/bugreport.cgi?bug=626211
|
2012-07-30 18:58:54 +02:00
|
|
|
"--localstatedir=/var"
|
2016-03-11 15:45:01 +01:00
|
|
|
# We need this so utilities default to reading /etc/dovecot/dovecot.conf file.
|
|
|
|
"--sysconfdir=/etc"
|
2012-07-30 18:58:54 +02:00
|
|
|
"--with-ldap"
|
2016-03-11 15:45:01 +01:00
|
|
|
"--with-ssl=openssl"
|
|
|
|
"--with-zlib"
|
|
|
|
"--with-bzlib"
|
2018-01-28 04:37:29 +01:00
|
|
|
"--with-lz4"
|
2016-03-11 15:45:01 +01:00
|
|
|
"--with-ldap"
|
|
|
|
"--with-lucene"
|
|
|
|
"--with-icu"
|
2018-12-10 23:48:42 +01:00
|
|
|
] ++ lib.optionals (stdenv.hostPlatform != stdenv.buildPlatform) [
|
|
|
|
"i_cv_epoll_works=${if stdenv.isLinux then "yes" else "no"}"
|
|
|
|
"i_cv_posix_fallocate_works=${if stdenv.isDarwin then "no" else "yes"}"
|
|
|
|
"i_cv_inotify_works=${if stdenv.isLinux then "yes" else "no"}"
|
|
|
|
"i_cv_signed_size_t=no"
|
|
|
|
"i_cv_signed_time_t=yes"
|
|
|
|
"i_cv_c99_vsnprintf=yes"
|
|
|
|
"lib_cv_va_copy=yes"
|
|
|
|
"i_cv_mmap_plays_with_write=yes"
|
|
|
|
"i_cv_gmtime_max_time_t=${toString stdenv.hostPlatform.parsed.cpu.bits}"
|
|
|
|
"i_cv_signed_time_t=yes"
|
|
|
|
"i_cv_fd_passing=yes"
|
|
|
|
"lib_cv_va_copy=yes"
|
|
|
|
"lib_cv___va_copy=yes"
|
|
|
|
"lib_cv_va_val_copy=yes"
|
2021-06-21 16:21:41 +02:00
|
|
|
] ++ lib.optional stdenv.isLinux "--with-systemd"
|
|
|
|
++ lib.optional stdenv.isDarwin "--enable-static"
|
2016-03-11 15:45:01 +01:00
|
|
|
++ lib.optional withMySQL "--with-mysql"
|
|
|
|
++ lib.optional withPgSQL "--with-pgsql"
|
2021-06-21 16:18:51 +02:00
|
|
|
++ lib.optional withSQLite "--with-sqlite"
|
|
|
|
++ lib.optional withLua "--with-lua";
|
2011-10-28 00:03:41 +02:00
|
|
|
|
2021-06-24 22:17:11 +02:00
|
|
|
doCheck = !stdenv.isDarwin;
|
|
|
|
|
2021-06-21 15:18:52 +02:00
|
|
|
meta = with lib; {
|
2020-03-08 08:02:20 +01:00
|
|
|
homepage = "https://dovecot.org/";
|
2011-10-25 22:34:19 +02:00
|
|
|
description = "Open source IMAP and POP3 email server written with security primarily in mind";
|
2021-06-21 15:18:52 +02:00
|
|
|
license = with licenses; [ mit publicDomain lgpl21Only bsd3 bsdOriginal ];
|
2021-10-14 10:59:33 +02:00
|
|
|
maintainers = with maintainers; [ fpletz globin ajs124 ];
|
2021-06-21 15:18:52 +02:00
|
|
|
platforms = platforms.unix;
|
2018-11-11 14:55:23 +01:00
|
|
|
};
|
|
|
|
passthru.tests = {
|
|
|
|
opensmtpd-interaction = nixosTests.opensmtpd;
|
2021-01-04 17:45:28 +01:00
|
|
|
inherit (nixosTests) dovecot;
|
2011-10-25 22:34:19 +02:00
|
|
|
};
|
|
|
|
}
|