|
@@ -1,6 +1,6 @@
|
|
|
--- a/svr-chansession.c
|
|
|
+++ b/svr-chansession.c
|
|
|
-@@ -852,12 +852,12 @@ static void execchild(void *user_data) {
|
|
|
+@@ -881,12 +881,12 @@ static void execchild(void *user_data) {
|
|
|
/* We can only change uid/gid as root ... */
|
|
|
if (getuid() == 0) {
|
|
|
|
|
@@ -9,10 +9,10 @@
|
|
|
(initgroups(ses.authstate.pw_name,
|
|
|
- ses.authstate.pw_gid) < 0)) {
|
|
|
+ ses.authstate.pw_gid) < 0))) {
|
|
|
- dropbear_exit("error changing user group");
|
|
|
+ dropbear_exit("Error changing user group");
|
|
|
}
|
|
|
- if (setuid(ses.authstate.pw_uid) < 0) {
|
|
|
+ if ((ses.authstate.pw_uid != 0) && (setuid(ses.authstate.pw_uid) < 0)) {
|
|
|
- dropbear_exit("error changing user");
|
|
|
+ dropbear_exit("Error changing user");
|
|
|
}
|
|
|
} else {
|