CVE-2024-25124: Permissive Cross-domain Policy with Untrusted Domains
Fiber is a web framework written in go. Prior to version 2.52.1, the CORS middleware allows for insecure configurations that could potentially expose the application to multiple CORS-related vulnerabilities. Specifically, it allows setting the Access-Control-Allow-Origin header to a wildcard (*
) while also having the Access-Control-Allow-Credentials set to true, which goes against recommended security best practices. The impact of this misconfiguration is high as it can lead to unauthorized access to sensitive user data and expose the system to various types of attacks listed in the PortSwigger article linked in the references. Version 2.52.1 contains a patch for this issue. As a workaround, users may manually validate the CORS configurations in their implementation to ensure that they do not allow a wildcard origin when credentials are enabled. The browser fetch api, as well as browsers and utilities that enforce CORS policies, are not affected by this.
References
- blog.portswigger.net/2016/10/exploiting-cors-misconfigurations-for.html
- codeql.github.com/codeql-query-help/javascript/js-cors-misconfiguration-for-credentials
- developer.mozilla.org/en-US/docs/Web/HTTP/CORS/Errors/CORSNotSupportingCredentials
- fetch.spec.whatwg.org/
- github.com/advisories/GHSA-fmg4-x8pw-hjhg
- github.com/gofiber/fiber/commit/f0cd3b44b086544a37886232d0530601f2406c23
- github.com/gofiber/fiber/releases/tag/v2.52.1
- github.com/gofiber/fiber/security/advisories/GHSA-fmg4-x8pw-hjhg
- nvd.nist.gov/vuln/detail/CVE-2024-25124
- saturncloud.io/blog/cors-cannot-use-wildcard-in-accesscontrolalloworigin-when-credentials-flag-is-true
Detect and mitigate CVE-2024-25124 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →