HTML injection in email and account expiry notifications
GHSA-c5f8-35qr-q4fm · CVE-2021-21333 · PYSEC-2021-134
Published · Modified
Description
Impact
The notification emails sent for notifications for missed messages or for an expiring account are subject to HTML injection. In the case of the notification for missed messages, this could allow an attacker to insert forged content into the email.
The account expiry feature is not enabled by default and the HTML injection is not controllable by an attacker.
Patches
This issue is fixed in #9200.
Workarounds
For the missed messages notifications:
The notif.html, notif_mail.html, and room.html templates can be overridden with custom templates that manually escapes the variables using JInja2's escape filter. See the email.template_dir setting.
For the account expiry notifications:
Account expiry can be disabled via the
account_validity.enabledsetting.The
notice_expiry.htmltemplate can be overridden with a custom template that manually escapes the variables using JInja2'sescapefilter. See theemail.template_dirsetting.
References
- WEB https://github.com/matrix-org/synapse/security/advisories/GHSA-c5f8-35qr-q4fm
- ADVISORY https://nvd.nist.gov/vuln/detail/CVE-2021-21333
- WEB https://github.com/matrix-org/synapse/pull/9200
- WEB https://github.com/matrix-org/synapse/commit/e54746bdf7d5c831eabe4dcea76a7626f1de73df
- PACKAGE https://github.com/matrix-org/synapse
- WEB https://github.com/matrix-org/synapse/releases/tag/v1.27.0
- WEB https://github.com/pypa/advisory-database/tree/main/vulns/matrix-synapse/PYSEC-2021-134.yaml
- WEB https://lists.fedoraproject.org/archives/list/package-announce@lists.fedoraproject.org/message/TNNAJOZNMVMXM6AS7RFFKB4QLUJ4IFEY
Ready to move
Start Securing
Free, no credit card | First findings in minutes