2023-03-24 00:07:29 +00:00
|
|
|
{ stdenv, lib, fetchurl, iptables-legacy, libuuid, openssl, pkg-config
|
2024-01-13 08:15:51 +00:00
|
|
|
, which, iproute2, gnused, coreutils, gnugrep, gawk, makeWrapper
|
2021-05-20 23:08:51 +00:00
|
|
|
, nixosTests
|
2024-01-13 08:15:51 +00:00
|
|
|
, firewall ? "iptables", nftables, libmnl, libnftnl
|
2020-04-24 23:36:52 +00:00
|
|
|
}:
|
|
|
|
|
|
|
|
let
|
2024-01-13 08:15:51 +00:00
|
|
|
scriptBinEnv = lib.makeBinPath {
|
|
|
|
iptables = [
|
|
|
|
# needed for dirname in ip{,6}tables_*.sh
|
|
|
|
coreutils
|
|
|
|
# used in miniupnpd_functions.sh:
|
|
|
|
which
|
|
|
|
iproute2
|
|
|
|
iptables-legacy
|
|
|
|
gnused
|
|
|
|
gnugrep
|
|
|
|
gawk
|
|
|
|
];
|
|
|
|
nftables = [
|
|
|
|
# needed for dirname in nft_*.sh & cat in nft_init.sh
|
|
|
|
coreutils
|
|
|
|
# used in miniupnpd_functions.sh:
|
|
|
|
which
|
|
|
|
nftables
|
|
|
|
];
|
|
|
|
}.${firewall};
|
2020-04-24 23:36:52 +00:00
|
|
|
in
|
|
|
|
stdenv.mkDerivation rec {
|
2021-08-05 21:33:18 +00:00
|
|
|
pname = "miniupnpd";
|
2024-01-25 14:12:00 +00:00
|
|
|
version = "2.3.4";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchurl {
|
2022-10-30 15:09:59 +00:00
|
|
|
url = "https://miniupnp.tuxfamily.org/files/miniupnpd-${version}.tar.gz";
|
2024-01-25 14:12:00 +00:00
|
|
|
sha256 = "sha256-5zAzSPyKxCfefwTw7rdX1J3Mg2cxHuJYJVLDj11toIo=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2024-01-13 08:15:51 +00:00
|
|
|
buildInputs = [ iptables-legacy libuuid openssl ]
|
|
|
|
++ lib.optionals (firewall == "nftables") [ libmnl libnftnl ];
|
2021-02-05 17:12:51 +00:00
|
|
|
nativeBuildInputs= [ pkg-config makeWrapper ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2022-10-30 15:09:59 +00:00
|
|
|
# ./configure is not a standard configure file, errors with:
|
|
|
|
# Option not recognized : --prefix=
|
|
|
|
dontAddPrefix = true;
|
2024-01-13 08:15:51 +00:00
|
|
|
configureFlags = [
|
|
|
|
"--firewall=${firewall}"
|
|
|
|
# allow using various config options
|
|
|
|
"--ipv6"
|
|
|
|
"--leasefile"
|
|
|
|
"--regex"
|
|
|
|
"--vendorcfg"
|
|
|
|
# hardening
|
|
|
|
"--portinuse"
|
|
|
|
];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
installFlags = [ "PREFIX=$(out)" "INSTALLPREFIX=$(out)" ];
|
|
|
|
|
2024-01-13 08:15:51 +00:00
|
|
|
postFixup = {
|
|
|
|
# Ideally we'd prefer using system's config.firewall.package here for iptables,
|
|
|
|
# however for some reason switching --prefix to --suffix breaks the script
|
|
|
|
iptables = ''
|
|
|
|
for script in $out/etc/miniupnpd/ip{,6}tables_{init,removeall}.sh
|
|
|
|
do
|
|
|
|
wrapProgram $script --prefix PATH : '${scriptBinEnv}:$PATH'
|
|
|
|
done
|
|
|
|
'';
|
|
|
|
nftables = ''
|
|
|
|
for script in $out/etc/miniupnpd/nft_{delete_chain,flush,init,removeall}.sh
|
|
|
|
do
|
|
|
|
wrapProgram $script --suffix PATH : '${scriptBinEnv}:$PATH'
|
|
|
|
done
|
|
|
|
'';
|
|
|
|
}.${firewall};
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-05-20 23:08:51 +00:00
|
|
|
passthru.tests = {
|
|
|
|
bittorrent-integration = nixosTests.bittorrent;
|
2023-03-24 00:07:29 +00:00
|
|
|
inherit (nixosTests) upnp;
|
2021-05-20 23:08:51 +00:00
|
|
|
};
|
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2022-10-30 15:09:59 +00:00
|
|
|
homepage = "https://miniupnp.tuxfamily.org/";
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "A daemon that implements the UPnP Internet Gateway Device (IGD) specification";
|
|
|
|
platforms = platforms.linux;
|
|
|
|
license = licenses.bsd3;
|
2024-01-13 08:15:51 +00:00
|
|
|
mainProgram = "miniupnpd";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
}
|