Cross-site scripting in error reports
SimpleSAMLphp allows users to report errors and failures to the system administrators via a web form. This web form gathers some contextual information automatically, but it also allows the user to provide their email address for follow-ups and a free-text explanation of what happened. Once submitted, the report is sent as an email to the administrative email address configured in the software.
www/erroreport.php script allows error reports to be submitted and sent to the system administrator. Starting
with SimpleSAMLphp 1.18.0, a new
SimpleSAML\Utils\EMail class was introduced to handle sending emails, implemented as
a wrapper of an external dependency.
This new wrapper allows us to use Twig templates in order to create the email sent with an error report. Since Twig
provides automatic escaping of variables, manual escaping of the free-text field in
www/errorreport.php was removed
to avoid double escaping. However, for those not using the new user interface yet, an email template is hardcoded into
the class itself in plain PHP. Since no escaping is provided in this template, it is then possible to inject HTML
inside the template by manually crafting the contents of the free-text field.
SimpleSAMLphp versions 1.18.0 to 1.18.3, both inclusive.
An attacker may take advantage of this issue to manually craft a modified email sent via the error reporting mechanism, such as this email might trick a system administrator into performing an action, such as introducing their credentials into a phishing web site that resembles the original.
Upgrade the SimpleSAMLphp installation to version 1.18.4.
This vulnerability was discovered and reported by Frederic Vleminckx on January 22, 2020.