mirror of
				git://git.openwrt.org/openwrt/openwrt.git
				synced 2025-10-24 10:34:27 -04:00 
			
		
		
		
	
		
			
				
	
	
		
			21 lines
		
	
	
		
			853 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			21 lines
		
	
	
		
			853 B
		
	
	
	
		
			Diff
		
	
	
	
	
	
| Index: dropbear-0.49/svr-chansession.c
 | |
| ===================================================================
 | |
| --- dropbear-0.49.orig/svr-chansession.c	2007-06-04 13:21:39.455978448 +0200
 | |
| +++ dropbear-0.49/svr-chansession.c	2007-06-04 13:21:39.751933456 +0200
 | |
| @@ -908,12 +908,12 @@
 | |
|  	/* We can only change uid/gid as root ... */
 | |
|  	if (getuid() == 0) {
 | |
|  
 | |
| -		if ((setgid(ses.authstate.pw->pw_gid) < 0) ||
 | |
| +		if ((ses.authstate.pw->pw_gid != 0) && ((setgid(ses.authstate.pw->pw_gid) < 0) ||
 | |
|  			(initgroups(ses.authstate.pw->pw_name, 
 | |
| -						ses.authstate.pw->pw_gid) < 0)) {
 | |
| +						ses.authstate.pw->pw_gid) < 0))) {
 | |
|  			dropbear_exit("error changing user group");
 | |
|  		}
 | |
| -		if (setuid(ses.authstate.pw->pw_uid) < 0) {
 | |
| +		if ((ses.authstate.pw->pw_uid != 0) && (setuid(ses.authstate.pw->pw_uid) < 0)) {
 | |
|  			dropbear_exit("error changing user");
 | |
|  		}
 | |
|  	} else {
 |