![Advisory Published](https://public.secalerts.co/assets/images/icon-advisory-published.svg)
5/1/2023
![Updated](https://public.secalerts.co/assets/images/icon-updated.svg)
21/11/2024
CVE-2022-46177: Discourse password reset link can lead to in account takeover if user changes to a new email
First published: Thu Jan 05 2023(Updated: )
Discourse is an option source discussion platform. Prior to version 2.8.14 on the `stable` branch and version 3.0.0.beta16 on the `beta` and `tests-passed` branches, when a user requests for a password reset link email, then changes their primary email, the old reset email is still valid. When the old reset email is used to reset the password, the Discourse account's primary email would be re-linked to the old email. If the old email address is compromised or has transferred ownership, this leads to an account takeover. This is however mitigated by the SiteSetting `email_token_valid_hours` which is currently 48 hours. Users should upgrade to versions 2.8.14 or 3.0.0.beta15 to receive a patch. As a workaround, lower `email_token_valid_hours ` as needed.
Credit: security-advisories@github.com security-advisories@github.com
Affected Software | Affected Version | How to fix |
---|
Discourse | <2.8.14 | |
Discourse | =1.1.0-beta1 | |
Discourse | =1.1.0-beta2 | |
Discourse | =1.1.0-beta3 | |
Discourse | =1.1.0-beta4 | |
Discourse | =1.1.0-beta5 | |
Discourse | =1.1.0-beta6 | |
Discourse | =1.1.0-beta6b | |
Discourse | =1.1.0-beta7 | |
Discourse | =1.1.0-beta8 | |
Discourse | =1.2.0-beta1 | |
Discourse | =1.2.0-beta2 | |
Discourse | =1.2.0-beta3 | |
Discourse | =1.2.0-beta4 | |
Discourse | =1.2.0-beta5 | |
Discourse | =1.2.0-beta6 | |
Discourse | =1.2.0-beta7 | |
Discourse | =1.2.0-beta8 | |
Discourse | =1.2.0-beta9 | |
Discourse | =1.3.0-beta1 | |
Discourse | =1.3.0-beta10 | |
Discourse | =1.3.0-beta11 | |
Discourse | =1.3.0-beta2 | |
Discourse | =1.3.0-beta3 | |
Discourse | =1.3.0-beta4 | |
Discourse | =1.3.0-beta5 | |
Discourse | =1.3.0-beta6 | |
Discourse | =1.3.0-beta7 | |
Discourse | =1.3.0-beta8 | |
Discourse | =1.3.0-beta9 | |
Discourse | =1.4.0-beta1 | |
Discourse | =1.4.0-beta10 | |
Discourse | =1.4.0-beta11 | |
Discourse | =1.4.0-beta12 | |
Discourse | =1.4.0-beta2 | |
Discourse | =1.4.0-beta3 | |
Discourse | =1.4.0-beta4 | |
Discourse | =1.4.0-beta5 | |
Discourse | =1.4.0-beta6 | |
Discourse | =1.4.0-beta7 | |
Discourse | =1.4.0-beta8 | |
Discourse | =1.4.0-beta9 | |
Discourse | =1.5.0-beta1 | |
Discourse | =1.5.0-beta10 | |
Discourse | =1.5.0-beta11 | |
Discourse | =1.5.0-beta12 | |
Discourse | =1.5.0-beta13 | |
Discourse | =1.5.0-beta13b | |
Discourse | =1.5.0-beta14 | |
Discourse | =1.5.0-beta2 | |
Discourse | =1.5.0-beta3 | |
Discourse | =1.5.0-beta4 | |
Discourse | =1.5.0-beta5 | |
Discourse | =1.5.0-beta6 | |
Discourse | =1.5.0-beta7 | |
Discourse | =1.5.0-beta8 | |
Discourse | =1.5.0-beta9 | |
Discourse | =1.6.0-beta1 | |
Discourse | =1.6.0-beta10 | |
Discourse | =1.6.0-beta11 | |
Discourse | =1.6.0-beta12 | |
Discourse | =1.6.0-beta2 | |
Discourse | =1.6.0-beta3 | |
Discourse | =1.6.0-beta4 | |
Discourse | =1.6.0-beta5 | |
Discourse | =1.6.0-beta6 | |
Discourse | =1.6.0-beta7 | |
Discourse | =1.6.0-beta8 | |
Discourse | =1.6.0-beta9 | |
Discourse | =1.7.0-beta1 | |
Discourse | =1.7.0-beta10 | |
Discourse | =1.7.0-beta11 | |
Discourse | =1.7.0-beta2 | |
Discourse | =1.7.0-beta3 | |
Discourse | =1.7.0-beta4 | |
Discourse | =1.7.0-beta5 | |
Discourse | =1.7.0-beta6 | |
Discourse | =1.7.0-beta7 | |
Discourse | =1.7.0-beta8 | |
Discourse | =1.7.0-beta9 | |
Discourse | =1.8.0-beta1 | |
Discourse | =1.8.0-beta10 | |
Discourse | =1.8.0-beta11 | |
Discourse | =1.8.0-beta12 | |
Discourse | =1.8.0-beta13 | |
Discourse | =1.8.0-beta2 | |
Discourse | =1.8.0-beta3 | |
Discourse | =1.8.0-beta4 | |
Discourse | =1.8.0-beta5 | |
Discourse | =1.8.0-beta6 | |
Discourse | =1.8.0-beta7 | |
Discourse | =1.8.0-beta8 | |
Discourse | =1.8.0-beta9 | |
Discourse | =1.9.0-beta1 | |
Discourse | =1.9.0-beta10 | |
Discourse | =1.9.0-beta11 | |
Discourse | =1.9.0-beta12 | |
Discourse | =1.9.0-beta13 | |
Discourse | =1.9.0-beta14 | |
Discourse | =1.9.0-beta15 | |
Discourse | =1.9.0-beta16 | |
Discourse | =1.9.0-beta17 | |
Discourse | =1.9.0-beta2 | |
Discourse | =1.9.0-beta3 | |
Discourse | =1.9.0-beta4 | |
Discourse | =1.9.0-beta5 | |
Discourse | =1.9.0-beta6 | |
Discourse | =1.9.0-beta7 | |
Discourse | =1.9.0-beta8 | |
Discourse | =1.9.0-beta9 | |
Discourse | =2.0.0-beta1 | |
Discourse | =2.0.0-beta10 | |
Discourse | =2.0.0-beta2 | |
Discourse | =2.0.0-beta3 | |
Discourse | =2.0.0-beta4 | |
Discourse | =2.0.0-beta5 | |
Discourse | =2.0.0-beta6 | |
Discourse | =2.0.0-beta7 | |
Discourse | =2.0.0-beta8 | |
Discourse | =2.0.0-beta9 | |
Discourse | =2.1.0-beta1 | |
Discourse | =2.1.0-beta2 | |
Discourse | =2.1.0-beta3 | |
Discourse | =2.1.0-beta4 | |
Discourse | =2.1.0-beta5 | |
Discourse | =2.1.0-beta6 | |
Discourse | =2.2.0-beta1 | |
Discourse | =2.2.0-beta10 | |
Discourse | =2.2.0-beta2 | |
Discourse | =2.2.0-beta3 | |
Discourse | =2.2.0-beta4 | |
Discourse | =2.2.0-beta5 | |
Discourse | =2.2.0-beta6 | |
Discourse | =2.2.0-beta7 | |
Discourse | =2.2.0-beta8 | |
Discourse | =2.2.0-beta9 | |
Discourse | =2.3.0-beta1 | |
Discourse | =2.3.0-beta10 | |
Discourse | =2.3.0-beta11 | |
Discourse | =2.3.0-beta2 | |
Discourse | =2.3.0-beta3 | |
Discourse | =2.3.0-beta4 | |
Discourse | =2.3.0-beta5 | |
Discourse | =2.3.0-beta6 | |
Discourse | =2.3.0-beta7 | |
Discourse | =2.3.0-beta8 | |
Discourse | =2.3.0-beta9 | |
Discourse | =2.4.0-beta1 | |
Discourse | =2.4.0-beta10 | |
Discourse | =2.4.0-beta11 | |
Discourse | =2.4.0-beta2 | |
Discourse | =2.4.0-beta3 | |
Discourse | =2.4.0-beta4 | |
Discourse | =2.4.0-beta5 | |
Discourse | =2.4.0-beta6 | |
Discourse | =2.4.0-beta7 | |
Discourse | =2.4.0-beta8 | |
Discourse | =2.4.0-beta9 | |
Discourse | =2.5.0-beta1 | |
Discourse | =2.5.0-beta2 | |
Discourse | =2.5.0-beta3 | |
Discourse | =2.5.0-beta4 | |
Discourse | =2.5.0-beta5 | |
Discourse | =2.5.0-beta6 | |
Discourse | =2.5.0-beta7 | |
Discourse | =2.6.0-beta1 | |
Discourse | =2.6.0-beta2 | |
Discourse | =2.6.0-beta3 | |
Discourse | =2.6.0-beta4 | |
Discourse | =2.6.0-beta5 | |
Discourse | =2.6.0-beta6 | |
Discourse | =2.7.0-beta1 | |
Discourse | =2.7.0-beta2 | |
Discourse | =2.7.0-beta3 | |
Discourse | =2.7.0-beta4 | |
Discourse | =2.7.0-beta5 | |
Discourse | =2.7.0-beta6 | |
Discourse | =2.7.0-beta7 | |
Discourse | =2.7.0-beta8 | |
Discourse | =2.7.0-beta9 | |
Discourse | =2.8.0-beta1 | |
Discourse | =2.8.0-beta10 | |
Discourse | =2.8.0-beta11 | |
Discourse | =2.8.0-beta2 | |
Discourse | =2.8.0-beta3 | |
Discourse | =2.8.0-beta4 | |
Discourse | =2.8.0-beta5 | |
Discourse | =2.8.0-beta6 | |
Discourse | =2.8.0-beta7 | |
Discourse | =2.8.0-beta8 | |
Discourse | =2.8.0-beta9 | |
Discourse | =2.9.0-beta1 | |
Discourse | =2.9.0-beta10 | |
Discourse | =2.9.0-beta11 | |
Discourse | =2.9.0-beta12 | |
Discourse | =2.9.0-beta13 | |
Discourse | =2.9.0-beta14 | |
Discourse | =2.9.0-beta2 | |
Discourse | =2.9.0-beta3 | |
Discourse | =2.9.0-beta4 | |
Discourse | =2.9.0-beta5 | |
Discourse | =2.9.0-beta6 | |
Discourse | =2.9.0-beta7 | |
Discourse | =2.9.0-beta8 | |
Discourse | =2.9.0-beta9 | |
Discourse | =3.0.0-beta15 | |
Never miss a vulnerability like this again
Sign up to SecAlerts for real-time vulnerability data matched to your software, aggregated from hundreds of sources.
Frequently Asked Questions
What is the severity of CVE-2022-46177?
CVE-2022-46177 has been classified with a severity level that can potentially lead to unauthorized access due to outdated password reset mechanisms.
How do I fix CVE-2022-46177?
To fix CVE-2022-46177, upgrade Discourse to version 2.8.14 or later for stable branches, or 3.0.0.beta16 or later for beta branches.
What types of systems are affected by CVE-2022-46177?
CVE-2022-46177 affects versions of Discourse prior to 2.8.14 on stable and 3.0.0.beta16 on beta branches.
What is the impact of CVE-2022-46177?
The impact of CVE-2022-46177 is that users may receive password reset links for their previously registered email addresses even after changing their primary email.
Are there any known exploits for CVE-2022-46177?
Currently, there are no known publicly available exploits specifically targeting CVE-2022-46177.
- agent/type
- agent/remedy
- collector/mitre-cve
- source/MITRE
- agent/title
- agent/severity
- agent/weakness
- agent/references
- agent/first-publish-date
- agent/description
- agent/last-modified-date
- agent/author
- agent/softwarecombine
- agent/event
- agent/source
- agent/tags
- collector/nvd-api
- source/NVD
- agent/software-canonical-lookup
- agent/software-canonical-lookup-request
- collector/nvd-index
- vendor/discourse
- canonical/discourse
- version/discourse/1.1.0-beta1
- version/discourse/1.1.0-beta2
- version/discourse/1.1.0-beta3
- version/discourse/1.1.0-beta4
- version/discourse/1.1.0-beta5
- version/discourse/1.1.0-beta6
- version/discourse/1.1.0-beta6b
- version/discourse/1.1.0-beta7
- version/discourse/1.1.0-beta8
- version/discourse/1.2.0-beta1
- version/discourse/1.2.0-beta2
- version/discourse/1.2.0-beta3
- version/discourse/1.2.0-beta4
- version/discourse/1.2.0-beta5
- version/discourse/1.2.0-beta6
- version/discourse/1.2.0-beta7
- version/discourse/1.2.0-beta8
- version/discourse/1.2.0-beta9
- version/discourse/1.3.0-beta1
- version/discourse/1.3.0-beta10
- version/discourse/1.3.0-beta11
- version/discourse/1.3.0-beta2
- version/discourse/1.3.0-beta3
- version/discourse/1.3.0-beta4
- version/discourse/1.3.0-beta5
- version/discourse/1.3.0-beta6
- version/discourse/1.3.0-beta7
- version/discourse/1.3.0-beta8
- version/discourse/1.3.0-beta9
- version/discourse/1.4.0-beta1
- version/discourse/1.4.0-beta10
- version/discourse/1.4.0-beta11
- version/discourse/1.4.0-beta12
- version/discourse/1.4.0-beta2
- version/discourse/1.4.0-beta3
- version/discourse/1.4.0-beta4
- version/discourse/1.4.0-beta5
- version/discourse/1.4.0-beta6
- version/discourse/1.4.0-beta7
- version/discourse/1.4.0-beta8
- version/discourse/1.4.0-beta9
- version/discourse/1.5.0-beta1
- version/discourse/1.5.0-beta10
- version/discourse/1.5.0-beta11
- version/discourse/1.5.0-beta12
- version/discourse/1.5.0-beta13
- version/discourse/1.5.0-beta13b
- version/discourse/1.5.0-beta14
- version/discourse/1.5.0-beta2
- version/discourse/1.5.0-beta3
- version/discourse/1.5.0-beta4
- version/discourse/1.5.0-beta5
- version/discourse/1.5.0-beta6
- version/discourse/1.5.0-beta7
- version/discourse/1.5.0-beta8
- version/discourse/1.5.0-beta9
- version/discourse/1.6.0-beta1
- version/discourse/1.6.0-beta10
- version/discourse/1.6.0-beta11
- version/discourse/1.6.0-beta12
- version/discourse/1.6.0-beta2
- version/discourse/1.6.0-beta3
- version/discourse/1.6.0-beta4
- version/discourse/1.6.0-beta5
- version/discourse/1.6.0-beta6
- version/discourse/1.6.0-beta7
- version/discourse/1.6.0-beta8
- version/discourse/1.6.0-beta9
- version/discourse/1.7.0-beta1
- version/discourse/1.7.0-beta10
- version/discourse/1.7.0-beta11
- version/discourse/1.7.0-beta2
- version/discourse/1.7.0-beta3
- version/discourse/1.7.0-beta4
- version/discourse/1.7.0-beta5
- version/discourse/1.7.0-beta6
- version/discourse/1.7.0-beta7
- version/discourse/1.7.0-beta8
- version/discourse/1.7.0-beta9
- version/discourse/1.8.0-beta1
- version/discourse/1.8.0-beta10
- version/discourse/1.8.0-beta11
- version/discourse/1.8.0-beta12
- version/discourse/1.8.0-beta13
- version/discourse/1.8.0-beta2
- version/discourse/1.8.0-beta3
- version/discourse/1.8.0-beta4
- version/discourse/1.8.0-beta5
- version/discourse/1.8.0-beta6
- version/discourse/1.8.0-beta7
- version/discourse/1.8.0-beta8
- version/discourse/1.8.0-beta9
- version/discourse/1.9.0-beta1
- version/discourse/1.9.0-beta10
- version/discourse/1.9.0-beta11
- version/discourse/1.9.0-beta12
- version/discourse/1.9.0-beta13
- version/discourse/1.9.0-beta14
- version/discourse/1.9.0-beta15
- version/discourse/1.9.0-beta16
- version/discourse/1.9.0-beta17
- version/discourse/1.9.0-beta2
- version/discourse/1.9.0-beta3
- version/discourse/1.9.0-beta4
- version/discourse/1.9.0-beta5
- version/discourse/1.9.0-beta6
- version/discourse/1.9.0-beta7
- version/discourse/1.9.0-beta8
- version/discourse/1.9.0-beta9
- version/discourse/2.0.0-beta1
- version/discourse/2.0.0-beta10
- version/discourse/2.0.0-beta2
- version/discourse/2.0.0-beta3
- version/discourse/2.0.0-beta4
- version/discourse/2.0.0-beta5
- version/discourse/2.0.0-beta6
- version/discourse/2.0.0-beta7
- version/discourse/2.0.0-beta8
- version/discourse/2.0.0-beta9
- version/discourse/2.1.0-beta1
- version/discourse/2.1.0-beta2
- version/discourse/2.1.0-beta3
- version/discourse/2.1.0-beta4
- version/discourse/2.1.0-beta5
- version/discourse/2.1.0-beta6
- version/discourse/2.2.0-beta1
- version/discourse/2.2.0-beta10
- version/discourse/2.2.0-beta2
- version/discourse/2.2.0-beta3
- version/discourse/2.2.0-beta4
- version/discourse/2.2.0-beta5
- version/discourse/2.2.0-beta6
- version/discourse/2.2.0-beta7
- version/discourse/2.2.0-beta8
- version/discourse/2.2.0-beta9
- version/discourse/2.3.0-beta1
- version/discourse/2.3.0-beta10
- version/discourse/2.3.0-beta11
- version/discourse/2.3.0-beta2
- version/discourse/2.3.0-beta3
- version/discourse/2.3.0-beta4
- version/discourse/2.3.0-beta5
- version/discourse/2.3.0-beta6
- version/discourse/2.3.0-beta7
- version/discourse/2.3.0-beta8
- version/discourse/2.3.0-beta9
- version/discourse/2.4.0-beta1
- version/discourse/2.4.0-beta10
- version/discourse/2.4.0-beta11
- version/discourse/2.4.0-beta2
- version/discourse/2.4.0-beta3
- version/discourse/2.4.0-beta4
- version/discourse/2.4.0-beta5
- version/discourse/2.4.0-beta6
- version/discourse/2.4.0-beta7
- version/discourse/2.4.0-beta8
- version/discourse/2.4.0-beta9
- version/discourse/2.5.0-beta1
- version/discourse/2.5.0-beta2
- version/discourse/2.5.0-beta3
- version/discourse/2.5.0-beta4
- version/discourse/2.5.0-beta5
- version/discourse/2.5.0-beta6
- version/discourse/2.5.0-beta7
- version/discourse/2.6.0-beta1
- version/discourse/2.6.0-beta2
- version/discourse/2.6.0-beta3
- version/discourse/2.6.0-beta4
- version/discourse/2.6.0-beta5
- version/discourse/2.6.0-beta6
- version/discourse/2.7.0-beta1
- version/discourse/2.7.0-beta2
- version/discourse/2.7.0-beta3
- version/discourse/2.7.0-beta4
- version/discourse/2.7.0-beta5
- version/discourse/2.7.0-beta6
- version/discourse/2.7.0-beta7
- version/discourse/2.7.0-beta8
- version/discourse/2.7.0-beta9
- version/discourse/2.8.0-beta1
- version/discourse/2.8.0-beta10
- version/discourse/2.8.0-beta11
- version/discourse/2.8.0-beta2
- version/discourse/2.8.0-beta3
- version/discourse/2.8.0-beta4
- version/discourse/2.8.0-beta5
- version/discourse/2.8.0-beta6
- version/discourse/2.8.0-beta7
- version/discourse/2.8.0-beta8
- version/discourse/2.8.0-beta9
- version/discourse/2.9.0-beta1
- version/discourse/2.9.0-beta10
- version/discourse/2.9.0-beta11
- version/discourse/2.9.0-beta12
- version/discourse/2.9.0-beta13
- version/discourse/2.9.0-beta14
- version/discourse/2.9.0-beta2
- version/discourse/2.9.0-beta3
- version/discourse/2.9.0-beta4
- version/discourse/2.9.0-beta5
- version/discourse/2.9.0-beta6
- version/discourse/2.9.0-beta7
- version/discourse/2.9.0-beta8
- version/discourse/2.9.0-beta9
- version/discourse/3.0.0-beta15
Contact
SecAlerts Pty Ltd.
132 Wickham Terrace
Fortitude Valley,
QLD 4006, Australia
info@secalerts.coBy using SecAlerts services, you agree to our services end-user license agreement. This website is safeguarded by reCAPTCHA and governed by the Google Privacy Policy and Terms of Service. All names, logos, and brands of products are owned by their respective owners, and any usage of these names, logos, and brands for identification purposes only does not imply endorsement. If you possess any content that requires removal, please get in touch with us.
© 2025 SecAlerts Pty Ltd.
ABN: 70 645 966 203, ACN: 645 966 203