2022-10-30 15:09:59 +00:00
|
|
|
{ lib, stdenv, fetchurl, glibc, zlib, libxcrypt
|
2021-01-05 17:05:55 +00:00
|
|
|
, enableStatic ? stdenv.hostPlatform.isStatic
|
2022-09-09 14:08:57 +00:00
|
|
|
, enableSCP ? false
|
2020-04-24 23:36:52 +00:00
|
|
|
, sftpPath ? "/run/current-system/sw/libexec/sftp-server"
|
|
|
|
}:
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
let
|
|
|
|
# NOTE: DROPBEAR_PATH_SSH_PROGRAM is only necessary when enableSCP is true,
|
|
|
|
# but it is enabled here always anyways for consistency
|
|
|
|
dflags = {
|
|
|
|
SFTPSERVER_PATH = sftpPath;
|
|
|
|
DROPBEAR_PATH_SSH_PROGRAM = "${placeholder "out"}/bin/dbclient";
|
|
|
|
};
|
|
|
|
|
|
|
|
in
|
|
|
|
|
2020-04-24 23:36:52 +00:00
|
|
|
stdenv.mkDerivation rec {
|
2021-08-05 21:33:18 +00:00
|
|
|
pname = "dropbear";
|
2022-12-17 10:02:37 +00:00
|
|
|
version = "2022.83";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
src = fetchurl {
|
2021-08-05 21:33:18 +00:00
|
|
|
url = "https://matt.ucc.asn.au/dropbear/releases/dropbear-${version}.tar.bz2";
|
2022-12-17 10:02:37 +00:00
|
|
|
sha256 = "sha256-vFoSH/vJS1FxrV6+Ab5CdG1Qqnl8lUmkY5iUoWdJRDs=";
|
2020-04-24 23:36:52 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
dontDisableStatic = enableStatic;
|
|
|
|
configureFlags = lib.optional enableStatic "LDFLAGS=-static";
|
|
|
|
|
2022-09-09 14:08:57 +00:00
|
|
|
CFLAGS = lib.pipe (lib.attrNames dflags) [
|
|
|
|
(builtins.map (name: "-D${name}=\\\"${dflags.${name}}\\\""))
|
|
|
|
(lib.concatStringsSep " ")
|
|
|
|
];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
# https://www.gnu.org/software/make/manual/html_node/Libraries_002fSearch.html
|
|
|
|
preConfigure = ''
|
2022-09-09 14:08:57 +00:00
|
|
|
makeFlagsArray=(
|
|
|
|
VPATH=$(cat $NIX_CC/nix-support/orig-libc)/lib
|
|
|
|
PROGRAMS="${lib.concatStringsSep " " ([ "dropbear" "dbclient" "dropbearkey" "dropbearconvert" ] ++ lib.optionals enableSCP ["scp"])}"
|
|
|
|
)
|
|
|
|
'';
|
|
|
|
|
|
|
|
postInstall = lib.optionalString enableSCP ''
|
|
|
|
ln -rs $out/bin/scp $out/bin/dbscp
|
2020-04-24 23:36:52 +00:00
|
|
|
'';
|
|
|
|
|
|
|
|
patches = [
|
|
|
|
# Allow sessions to inherit the PATH from the parent dropbear.
|
|
|
|
# Otherwise they only get the usual /bin:/usr/bin kind of PATH
|
|
|
|
./pass-path.patch
|
|
|
|
];
|
|
|
|
|
2022-10-30 15:09:59 +00:00
|
|
|
buildInputs = [ zlib libxcrypt ] ++ lib.optionals enableStatic [ glibc.static zlib.static ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-01-15 22:18:51 +00:00
|
|
|
meta = with lib; {
|
2020-04-24 23:36:52 +00:00
|
|
|
description = "A small footprint implementation of the SSH 2 protocol";
|
2022-12-17 10:02:37 +00:00
|
|
|
homepage = "https://matt.ucc.asn.au/dropbear/dropbear.html";
|
|
|
|
changelog = "https://github.com/mkj/dropbear/raw/DROPBEAR_${version}/CHANGES";
|
2020-04-24 23:36:52 +00:00
|
|
|
license = licenses.mit;
|
|
|
|
maintainers = with maintainers; [ abbradar ];
|
|
|
|
platforms = platforms.linux;
|
|
|
|
};
|
|
|
|
}
|