CVE-2024-28239
MEDIUM5.4EPSS 0.23%URL Redirection to Untrusted Site in OAuth2/OpenID in directus
Description
### Summary The authentication API has a `redirect` parameter that can be exploited as an open redirect vulnerability as the user tries to log in via the API URL https://docs.directus.io/reference/authentication.html#login-using-sso-providers /auth/login/google?redirect for example. ### Details There's a redirect that is done after successful login via the Auth API GET request to `directus/auth/login/google?redirect=http://malicious-fishing-site.com`, which I think is here: https://github.com/directus/directus/blob/main/api/src/auth/drivers/oauth2.ts#L394. While credentials don't seem to be passed to the attacker site, the user can be phished into clicking a legitimate directus site and be taken to a malicious site made to look like a an error message "Your password needs to be updated" to phish out the current password. ### PoC Turn on any auth provider in Directus instance. Form a link to `directus-instance/auth/login/:provider_id?redirect=http://malicious-fishing-site.com`, login and get taken to malicious-site. Tested on the `ory` OAuth2 integration. ### Impact Users who login via OAuth2 into Directus.
Affected packages (1)
- npm/directusfrom 0, < 10.10.0
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM5.4 | CVSS:3.1/AV:N/AC:L/PR:N/UI:R/S:U/C:L/I:L/A:N |
References (5)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2024-28239
- PATCHhttps://github.com/directus/directus
- WEBhttps://docs.directus.io/reference/authentication.html#login-using-sso-providers
- WEBhttps://github.com/directus/directus/commit/5477d7d61babd7ffc2f835d399bf79611b15b203
- WEBhttps://github.com/directus/directus/security/advisories/GHSA-fr3w-2p22-6w7p