2021-03-19 17:17:44 +00:00
|
|
|
{ lib
|
|
|
|
, stdenv
|
|
|
|
, fetchurl
|
2022-01-07 04:07:37 +00:00
|
|
|
, buildPackages
|
2021-03-19 17:17:44 +00:00
|
|
|
, coreutils
|
|
|
|
, pam
|
|
|
|
, groff
|
|
|
|
, sssd
|
|
|
|
, nixosTests
|
2020-04-24 23:36:52 +00:00
|
|
|
, sendmailPath ? "/run/wrappers/bin/sendmail"
|
|
|
|
, withInsults ? false
|
|
|
|
, withSssd ? false
|
|
|
|
}:
|
|
|
|
|
2024-01-25 14:12:00 +00:00
|
|
|
stdenv.mkDerivation (finalAttrs: {
|
2020-04-24 23:36:52 +00:00
|
|
|
pname = "sudo";
|
2024-04-21 15:54:59 +00:00
|
|
|
# be sure to check if nixos/modules/security/sudo.nix needs updating when bumping
|
|
|
|
# e.g. links to man pages, value constraints etc.
|
2024-01-25 14:12:00 +00:00
|
|
|
version = "1.9.15p5";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
__structuredAttrs = true;
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
src = fetchurl {
|
2024-01-25 14:12:00 +00:00
|
|
|
url = "https://www.sudo.ws/dist/sudo-${finalAttrs.version}.tar.gz";
|
|
|
|
hash = "sha256-VY0QuaGZH7O5+n+nsH7EQFt677WzywsIcdvIHjqI5Vg=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
prePatch = ''
|
|
|
|
# do not set sticky bit in nix store
|
|
|
|
substituteInPlace src/Makefile.in --replace 04755 0755
|
|
|
|
'';
|
|
|
|
|
|
|
|
configureFlags = [
|
|
|
|
"--with-env-editor"
|
|
|
|
"--with-editor=/run/current-system/sw/bin/nano"
|
|
|
|
"--with-rundir=/run/sudo"
|
|
|
|
"--with-vardir=/var/db/sudo"
|
|
|
|
"--with-logpath=/var/log/sudo.log"
|
|
|
|
"--with-iologdir=/var/log/sudo-io"
|
|
|
|
"--with-sendmail=${sendmailPath}"
|
|
|
|
"--enable-tmpfiles.d=no"
|
2024-09-19 14:19:46 +00:00
|
|
|
"--with-passprompt=[sudo] password for %p: " # intentional trailing space
|
2022-10-30 15:09:59 +00:00
|
|
|
] ++ lib.optionals withInsults [
|
2020-04-24 23:36:52 +00:00
|
|
|
"--with-insults"
|
|
|
|
"--with-all-insults"
|
2022-10-30 15:09:59 +00:00
|
|
|
] ++ lib.optionals withSssd [
|
2020-04-24 23:36:52 +00:00
|
|
|
"--with-sssd"
|
|
|
|
"--with-sssd-lib=${sssd}/lib"
|
|
|
|
];
|
|
|
|
|
|
|
|
postConfigure =
|
|
|
|
''
|
2021-03-19 17:17:44 +00:00
|
|
|
cat >> pathnames.h <<'EOF'
|
|
|
|
#undef _PATH_MV
|
|
|
|
#define _PATH_MV "${coreutils}/bin/mv"
|
|
|
|
EOF
|
|
|
|
makeFlags="install_uid=$(id -u) install_gid=$(id -g)"
|
|
|
|
installFlags="sudoers_uid=$(id -u) sudoers_gid=$(id -g) sysconfdir=$out/etc rundir=$TMPDIR/dummy vardir=$TMPDIR/dummy DESTDIR=/"
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
|
2022-01-07 04:07:37 +00:00
|
|
|
depsBuildBuild = [ buildPackages.stdenv.cc ];
|
2020-04-24 23:36:52 +00:00
|
|
|
nativeBuildInputs = [ groff ];
|
|
|
|
buildInputs = [ pam ];
|
|
|
|
|
|
|
|
enableParallelBuilding = true;
|
|
|
|
|
|
|
|
doCheck = false; # needs root
|
|
|
|
|
2021-03-19 17:17:44 +00:00
|
|
|
postInstall = ''
|
|
|
|
rm $out/share/doc/sudo/ChangeLog
|
|
|
|
'';
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2020-10-11 12:50:04 +00:00
|
|
|
passthru.tests = { inherit (nixosTests) sudo; };
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
meta = with lib; {
|
2024-06-20 14:57:18 +00:00
|
|
|
description = "Command to run commands as root";
|
2020-04-24 23:36:52 +00:00
|
|
|
longDescription =
|
|
|
|
''
|
2021-03-19 17:17:44 +00:00
|
|
|
Sudo (su "do") allows a system administrator to delegate
|
|
|
|
authority to give certain users (or groups of users) the ability
|
|
|
|
to run some (or all) commands as root or another user while
|
|
|
|
providing an audit trail of the commands and their arguments.
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
homepage = "https://www.sudo.ws/";
|
2024-01-02 11:29:13 +00:00
|
|
|
# From https://www.sudo.ws/about/license/
|
|
|
|
license = with licenses; [ sudo bsd2 bsd3 zlib ];
|
2024-07-27 06:49:29 +00:00
|
|
|
maintainers = with maintainers; [ rhendric ];
|
2024-06-20 14:57:18 +00:00
|
|
|
platforms = platforms.linux ++ platforms.freebsd;
|
2024-01-25 14:12:00 +00:00
|
|
|
mainProgram = "sudo";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
2024-01-25 14:12:00 +00:00
|
|
|
})
|