Commit 7bfdb025 authored by Thomas Gerbet's avatar Thomas Gerbet
Browse files

dropbear: 2020.81 -> 2022.82

parent 83733b55
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -16,11 +16,11 @@ in

stdenv.mkDerivation rec {
  pname = "dropbear";
  version = "2020.81";
  version = "2022.82";

  src = fetchurl {
    url = "https://matt.ucc.asn.au/dropbear/releases/dropbear-${version}.tar.bz2";
    sha256 = "0fy5ma4cfc2pk25mcccc67b2mf1rnb2c06ilb7ddnxbpnc85s8s8";
    sha256 = "sha256-OgONK7wCvyi73SDAEgkfdBo+xcvkYGkYEdcUh2qtddE=";
  };

  dontDisableStatic = enableStatic;
+19 −16
Original line number Diff line number Diff line
diff --git a/svr-chansession.c b/svr-chansession.c
index e44299e..7ef750a 100644
index 9ae2e60..2db7598 100644
--- a/svr-chansession.c
+++ b/svr-chansession.c
@@ -893,6 +893,8 @@ static void addchildpid(struct ChanSess *chansess, pid_t pid) {
 static void execchild(void *user_data) {
 	struct ChanSess *chansess = user_data;
@@ -948,6 +948,8 @@ static void addchildpid(struct ChanSess *chansess, pid_t pid) {
 static void execchild(const void *user_data) {
 	const struct ChanSess *chansess = user_data;
 	char *usershell = NULL;
+	const char *path = DEFAULT_PATH;
+	const char *path = (getuid() == 0) ? DEFAULT_ROOT_PATH : DEFAULT_PATH;
+	const char *ldpath = NULL;
 
 	/* with uClinux we'll have vfork()ed, so don't want to overwrite the
 	 * hostkey. can't think of a workaround to clear it */
@@ -905,6 +907,10 @@ static void execchild(void *user_data) {
 	char *cp = NULL;
 	char *envcp = getenv("LANG");
 	if (envcp != NULL) {
@@ -965,6 +967,11 @@ static void execchild(const void *user_data) {
 	seedrandom();
 #endif
 
+	if (getenv("PATH"))
+	if (getenv("PATH")) {
+		path = getenv("PATH");
+	}
+	ldpath = getenv("LD_LIBRARY_PATH");
+
 	/* clear environment */
 	/* clear environment if -e was not set */
 	/* if we're debugging using valgrind etc, we need to keep the LD_PRELOAD
 	 * etc. This is hazardous, so should only be used for debugging. */
@@ -948,7 +954,10 @@ static void execchild(void *user_data) {
@@ -1012,10 +1019,9 @@ static void execchild(const void *user_data) {
 	addnewvar("LOGNAME", ses.authstate.pw_name);
 	addnewvar("HOME", ses.authstate.pw_dir);
 	addnewvar("SHELL", get_user_shell());
-	if (getuid() == 0) {
-		addnewvar("PATH", DEFAULT_ROOT_PATH);
-	} else {
-		addnewvar("PATH", DEFAULT_PATH);
+	addnewvar("PATH", path);
+	if (ldpath != NULL) {
+		addnewvar("LD_LIBRARY_PATH", ldpath);
+	}
 	if (chansess->term != NULL) {
 		addnewvar("TERM", chansess->term);
 	}
 	if (cp != NULL) {
 		addnewvar("LANG", cp);