CVE-2006-4019 : Détail

CVE-2006-4019

23.82%V3
Network
2006-08-11
19h00 +00:00
2018-10-17
18h57 +00:00
Notifications pour un CVE
Restez informé de toutes modifications pour un CVE spécifique.
Gestion des notifications

Descriptions du CVE

Dynamic variable evaluation vulnerability in compose.php in SquirrelMail 1.4.0 to 1.4.7 allows remote attackers to overwrite arbitrary program variables and read or write the attachments and preferences of other users.

Informations du CVE

Métriques

Métriques Score Gravité CVSS Vecteur Source
V2 6.4 AV:N/AC:L/Au:N/C:P/I:P/A:N [email protected]

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 : 43839

Date de publication : 2016-08-10 22h00 +00:00
Auteur : GulfTech Security
EDB Vérifié : No

SquirrelMail Arbitrary Variable Overwrite Vendor: SquirrelMail Product: SquirrelMail Version: <= 1.4.7 Website: http://www.squirrelmail.org BID: 19486 CVE: CVE-2006-4019 OSVDB: 27917 SECUNIA: 21354 Description: SquirrelMail is a standards-based webmail package written in php. It includes built-in pure PHP support for the IMAP and SMTP protocols. Unfortunately there is a fairly serious variable handling issue in one of the core SquirrelMail scripts that can allow an attacker to take control of variables used within the script, and influence functions and actions within the script. This is due to the unsafe handling of "expired sessions" when composing a message. An updated version of SquirrelMail can be downloaded from their official website. Users are advised to update their SquirrelMail installations as soon as possible. Arbitrary Variable Overwriting: SquirrelMail contains a vulnerability that may allow an authenticated user to overwrite important variables used by SquirrelMail, and ultimately read and or write arbitrary files to the system. Due to the nature of the vulnerability though other attacks may be possible. Again the attacker must first be authenticated, but in a real world scenario it usually is not that hard for an attacker to gain access to an email account that has a weak password via a dictionary attack or other methods. To see how this attack is possible first let's look at auth.php lines 50-67 // First we store some information in the new session to prevent // information-loss. // $session_expired_post = $_POST; $session_expired_location = $PHP_SELF; if (!sqsession_is_registered('session_expired_post')) { sqsession_register($session_expired_post,'session_expired_post'); } if (!sqsession_is_registered('session_expired_location')) { sqsession_register($session_expired_location,'session_expired_location'); } // signout page will deal with users who aren't logged // in on its own; don't show error here // if (strpos($PHP_SELF, 'signout.php') !== FALSE) { return; } The above is executed on most pages as part of the authentication schema. It is fairly easy to see that an attacker can ultimately control the value of $_SESSION['session_expired_post'] by supplying a "post" to SquirrelMail containing whatever variables they would like to overwrite. The above code may be unsafe, but in itself is not vulnerable. To see where the vulnerability takes place we must look at compose.php lines 294 - 319 if (sqsession_is_registered('session_expired_post')) { sqgetGlobalVar('session_expired_post', $session_expired_post, SQ_SESSION); /* * extra check for username so we don't display previous post data from * another user during this session. */ if ($session_expired_post['username'] != $username) { unset($session_expired_post); sqsession_unregister('session_expired_post'); session_write_close(); } else { foreach ($session_expired_post as $postvar => $val) { if (isset($val)) { $$postvar = $val; } else { $$postvar = ''; } } $compose_messages = unserialize(urldecode($restoremessages)); sqsession_register($compose_messages,'compose_messages'); sqsession_register($composesession,'composesession'); if (isset($send)) { unset($send); } $session_expired = true; } In the above code we see a foreach loop that dynamically evaluates all the elements of $_SESSION['session_expired_post'] but first a check is done to make sure the username stored in $_SESSION['session_expired_post'] is the same as the currently logged in user. For an attacker this check is easy to bypass because all the data contained in $_SESSION['session_expired_post'] is supplied by the attacker. From here an attacker can now overwrite any variable which leads to a number of possible attack vectors. Solution: SquirrelMail 1.4.8 has been released to address these issues. I would like to thank Thijs Kinkhorst and the rest of the SquirrelMail team for a prompt resolution to this issue Credits: James Bercegay of the GulfTech Security Research Team

Products Mentioned

Configuraton 0

Squirrelmail>>Squirrelmail >> Version 1.4.0

Squirrelmail>>Squirrelmail >> Version 1.4.1

Squirrelmail>>Squirrelmail >> Version 1.4.2

Squirrelmail>>Squirrelmail >> Version 1.4.3

Squirrelmail>>Squirrelmail >> Version 1.4.3_r3

    Squirrelmail>>Squirrelmail >> Version 1.4.3_rc1

      Squirrelmail>>Squirrelmail >> Version 1.4.3a

        Squirrelmail>>Squirrelmail >> Version 1.4.4

        Squirrelmail>>Squirrelmail >> Version 1.4.4_rc1

          Squirrelmail>>Squirrelmail >> Version 1.4.5

          Squirrelmail>>Squirrelmail >> Version 1.4.6

          Squirrelmail>>Squirrelmail >> Version 1.4.6_rc1

            Squirrelmail>>Squirrelmail >> Version 1.4.7

            Squirrelmail>>Squirrelmail >> Version 1.4_rc1

              Squirrelmail>>Squirrelmail >> Version 1.44

                Références

                http://secunia.com/advisories/21586
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://www.vupen.com/english/advisories/2007/2732
                Tags : vdb-entry, x_refsource_VUPEN
                http://www.debian.org/security/2006/dsa-1154
                Tags : vendor-advisory, x_refsource_DEBIAN
                http://secunia.com/advisories/21354
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://secunia.com/advisories/22487
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://securitytracker.com/id?1016689
                Tags : vdb-entry, x_refsource_SECTRACK
                http://www.vupen.com/english/advisories/2006/3271
                Tags : vdb-entry, x_refsource_VUPEN
                http://secunia.com/advisories/21444
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://secunia.com/advisories/22080
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://www.securityfocus.com/bid/19486
                Tags : vdb-entry, x_refsource_BID
                http://www.redhat.com/support/errata/RHSA-2006-0668.html
                Tags : vendor-advisory, x_refsource_REDHAT
                http://secunia.com/advisories/22104
                Tags : third-party-advisory, x_refsource_SECUNIA
                http://marc.info/?l=full-disclosure&m=115532449024178&w=2
                Tags : mailing-list, x_refsource_FULLDISC
                http://www.osvdb.org/27917
                Tags : vdb-entry, x_refsource_OSVDB
                http://www.securityfocus.com/bid/25159
                Tags : vdb-entry, x_refsource_BID
                http://www.mandriva.com/security/advisories?name=MDKSA-2006:147
                Tags : vendor-advisory, x_refsource_MANDRIVA
                http://secunia.com/advisories/26235
                Tags : third-party-advisory, x_refsource_SECUNIA