2021-05-20 23:08:51 +00:00
|
|
|
{ stdenv, lib, fetchurl, ncurses, perl, help2man
|
2022-09-30 11:47:45 +00:00
|
|
|
, apparmorRulesFromClosure, fetchpatch
|
2021-05-20 23:08:51 +00:00
|
|
|
}:
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
stdenv.mkDerivation rec {
|
2021-08-27 14:25:00 +00:00
|
|
|
pname = "inetutils";
|
2022-09-09 14:08:57 +00:00
|
|
|
version = "2.3";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchurl {
|
2021-08-27 14:25:00 +00:00
|
|
|
url = "mirror://gnu/${pname}/${pname}-${version}.tar.xz";
|
2022-09-09 14:08:57 +00:00
|
|
|
sha256 = "sha256-CwG7COKWI8TjuUDyM8lhRR2a+MUGYwGt12pSqV1Rdyw=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
2021-05-20 23:08:51 +00:00
|
|
|
outputs = ["out" "apparmor"];
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
patches = [
|
|
|
|
# https://git.congatec.com/yocto/meta-openembedded/commit/3402bfac6b595c622e4590a8ff5eaaa854e2a2a3
|
|
|
|
./inetutils-1_9-PATH_PROCNET_DEV.patch
|
2022-09-30 11:47:45 +00:00
|
|
|
(fetchpatch {
|
|
|
|
name = "CVE-2022-39028.patch";
|
|
|
|
url = "https://sources.debian.org/data/main/i/inetutils/2%3A2.3-5/debian/patches/inetutils-telnetd-EC_EL_null_deref.patch";
|
|
|
|
sha256 = "sha256-NYNDbEk3q3EhQdJaR12JBbnjJIRRpOcKLBF/EJJPiGU=";
|
|
|
|
})
|
2020-04-24 23:36:52 +00:00
|
|
|
];
|
|
|
|
|
|
|
|
nativeBuildInputs = [ help2man perl /* for `whois' */ ];
|
|
|
|
buildInputs = [ ncurses /* for `talk' */ ];
|
|
|
|
|
|
|
|
# Don't use help2man if cross-compiling
|
|
|
|
# https://lists.gnu.org/archive/html/bug-sed/2017-01/msg00001.html
|
|
|
|
# https://git.congatec.com/yocto/meta-openembedded/blob/3402bfac6b595c622e4590a8ff5eaaa854e2a2a3/meta-networking/recipes-connectivity/inetutils/inetutils_1.9.1.bb#L44
|
|
|
|
preConfigure = let
|
|
|
|
isCross = stdenv.hostPlatform != stdenv.buildPlatform;
|
|
|
|
in lib.optionalString isCross ''
|
|
|
|
export HELP2MAN=true
|
|
|
|
'';
|
|
|
|
|
|
|
|
configureFlags = [ "--with-ncurses-include-dir=${ncurses.dev}/include" ]
|
|
|
|
++ lib.optionals stdenv.hostPlatform.isMusl [ # Musl doesn't define rcmd
|
|
|
|
"--disable-rcp"
|
|
|
|
"--disable-rsh"
|
|
|
|
"--disable-rlogin"
|
|
|
|
"--disable-rexec"
|
|
|
|
] ++ lib.optional stdenv.isDarwin "--disable-servers";
|
|
|
|
|
|
|
|
# Test fails with "UNIX socket name too long", probably because our
|
|
|
|
# $TMPDIR is too long.
|
|
|
|
doCheck = false;
|
|
|
|
|
|
|
|
installFlags = [ "SUIDMODE=" ];
|
|
|
|
|
2021-05-20 23:08:51 +00:00
|
|
|
postInstall = ''
|
|
|
|
mkdir $apparmor
|
|
|
|
cat >$apparmor/bin.ping <<EOF
|
|
|
|
$out/bin/ping {
|
|
|
|
include <abstractions/base>
|
|
|
|
include <abstractions/consoles>
|
|
|
|
include <abstractions/nameservice>
|
|
|
|
include "${apparmorRulesFromClosure { name = "ping"; } [stdenv.cc.libc]}"
|
|
|
|
include <local/bin.ping>
|
|
|
|
capability net_raw,
|
|
|
|
network inet raw,
|
|
|
|
network inet6 raw,
|
|
|
|
mr $out/bin/ping,
|
|
|
|
}
|
|
|
|
EOF
|
|
|
|
'';
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
meta = with lib; {
|
|
|
|
description = "Collection of common network programs";
|
|
|
|
|
|
|
|
longDescription =
|
|
|
|
'' The GNU network utilities suite provides the
|
|
|
|
following tools: ftp(d), hostname, ifconfig, inetd, logger, ping, rcp,
|
|
|
|
rexec(d), rlogin(d), rsh(d), syslogd, talk(d), telnet(d), tftp(d),
|
|
|
|
traceroute, uucpd, and whois.
|
|
|
|
'';
|
|
|
|
|
|
|
|
homepage = "https://www.gnu.org/software/inetutils/";
|
|
|
|
license = licenses.gpl3Plus;
|
|
|
|
|
|
|
|
maintainers = with maintainers; [ matthewbauer ];
|
|
|
|
platforms = platforms.unix;
|
|
|
|
};
|
|
|
|
}
|