First published: Thu Apr 20 2017(Updated: )
SquirrelMail 1.4.22 (and other versions before 20170427_0200-SVN) allows post-authentication remote code execution via a sendmail.cf file that is mishandled in a popen call. It's possible to exploit this vulnerability to execute arbitrary shell commands on the remote server. The problem is in the Deliver_SendMail.class.php with the initStream function that uses escapeshellcmd() to sanitize the sendmail command before executing it. The use of escapeshellcmd() is not correct in this case since it doesn't escape whitespaces, allowing the injection of arbitrary command parameters. The problem is in -f$envelopefrom within the sendmail command line. Hence, if the target server uses sendmail and SquirrelMail is configured to use it as a command-line program, it's possible to trick sendmail into using an attacker-provided configuration file that triggers the execution of an arbitrary command. For exploitation, the attacker must upload a sendmail.cf file as an email attachment, and inject the sendmail.cf filename with the -C option within the "Options > Personal Informations > Email Address" setting.
Credit: cve@mitre.org
Affected Software | Affected Version | How to fix |
---|---|---|
SquirrelMail | =1.4.22 |
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
CVE-2017-7692 has a critical severity rating due to the possibility of post-authentication remote code execution.
To fix CVE-2017-7692, upgrade SquirrelMail to version 1.4.22 or later, ensuring you apply any available patches.
SquirrelMail versions before 20170427_0200-SVN, including 1.4.22, are vulnerable to CVE-2017-7692.
CVE-2017-7692 can be exploited to execute arbitrary shell commands on the remote server after authentication.
CVE-2017-7692 affects SquirrelMail software regardless of the underlying operating system, as long as it is running an affected version.