GHSA-fxq4-r6mr-9x64

Suggest an improvement
Source
https://github.com/advisories/GHSA-fxq4-r6mr-9x64
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2021/04/GHSA-fxq4-r6mr-9x64/GHSA-fxq4-r6mr-9x64.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-fxq4-r6mr-9x64
Published
2021-04-08T16:46:00Z
Modified
2024-12-02T05:34:30.141378Z
Summary
CSRF Vuln can expose user's QRcode
Details

Impact

When a user is setting up two-factor authentication using an authenticator app, a QRcode is generated and made available via a GET request to /tf-qrcode. Since GETs do not have any CSRF protection, it is possible a malicious 3rd party could access the QRcode and therefore gain access to two-factor authentication codes. Note that the /tf-qrcode endpoint is ONLY accessible while the user is initially setting up their device. Once setup is complete, there is no vulnerability.

Patches

This is fixed in the upcoming 4.0.0 release.

Workarounds

You can provide your own URL for fetching the QRcode by defining SECURITYTWOFACTORQRCODEURL and providing your own implementation (that presumably required a POST with CSRF protection). This would require changing the two-factor setup template as well.

References

None.

For more information

If you have any questions or comments about this advisory: * Read this pull request: #423

Database specific
{
    "cwe_ids": [
        "CWE-352"
    ],
    "nvd_published_at": null,
    "severity": "LOW",
    "github_reviewed": true,
    "github_reviewed_at": "2021-04-08T16:45:47Z"
}
References

Affected packages

PyPI / flask-security-too

Package

Name
flask-security-too
View open source insights on deps.dev
Purl
pkg:pypi/flask-security-too

Affected ranges

Type
ECOSYSTEM
Events
Introduced
3.2.0
Fixed
3.4.5

Affected versions

3.*
3.2.0
3.3.0rc1
3.3.0rc2
3.3.0rc3
3.3.0
3.3.1
3.3.2
3.3.3
3.4.0
3.4.1
3.4.2
3.4.3
3.4.4

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2021/04/GHSA-fxq4-r6mr-9x64/GHSA-fxq4-r6mr-9x64.json"