blob: 5b1c409d225a9ce84787e84273a65c9b6c4565e0 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
|
{
stalwart-mail,
callPackage,
nixLib,
}: let
spamfilter = callPackage ./spam-filter.nix {};
mail-send = callPackage ./mail-send.nix {};
in
stalwart-mail.overrideAttrs (final: prev: {
pname = "stalwart-mail-patched";
passthru = nixLib.warnMerge (prev.passthru or {}) {
inherit spamfilter;
} "stalwart-mail passthru";
# The NixOS build tests should check if this works.
# And this shaves of around 50% of the build time.
doCheck = false;
# We are already overriding it, so shaving of some unused features is okay.
buildNoDefaultFeatures = true;
buildFeatures = [
# "sqlite"
# "postgres"
# "mysql"
"rocks"
# "elastic"
# "s3"
"redis"
];
postUnpack =
(prev.postUnpack or "")
+ ''
cp --recursive "${mail-send}" ./source/crates/mail-send
chmod --recursive +w "./source/crates/mail-send"
'';
cargoPatches =
(prev.cargoPatches or [])
++ [
# `stalwart-mail` uses their bundled store, which makes it impossible to use our
# own CA certificate (e.g., for tests). Thus use a native version.
./patches/crates-Use-the-platform-CA-bundle-instead-of-the-bun.patch
];
# Check that the enterprise feature is really disabled.
postCheck =
(prev.postCheck or "")
+
# bash
''
if grep "enterprise" ./target/*/release/stalwart-mail.d; then
echo "ERROR: Proprietary 'enterprise' feature active."
exit 1
fi
'';
meta.mainProgram = prev.meta.mainProgram or "stalwart-mail";
})
|