Vulnerability Description
OpenMetadata is a unified platform for discovery, observability, and governance powered by a central metadata repository, in-depth lineage, and seamless team collaboration. Similarly to the GHSL-2023-250 issue, `AlertUtil::validateExpression` is also called from `EventSubscriptionRepository.prepare()`, which can lead to Remote Code Execution. `prepare()` is called from `EntityRepository.prepareInternal()` which, in turn, gets called from `EntityResource.createOrUpdate()`. Note that, even though there is an authorization check (`authorizer.authorize()`), it gets called after `prepareInternal()` gets called and, therefore, after the SpEL expression has been evaluated. In order to reach this method, an attacker can send a PUT request to `/api/v1/events/subscriptions` which gets handled by `EventSubscriptionResource.createOrUpdateEventSubscription()`. This vulnerability was discovered with the help of CodeQL's Expression language injection (Spring) query. This issue may lead to Remote Code Execution and has been addressed in version 1.2.4. Users are advised to upgrade. There are no known workarounds for this vulnerability. This issue is also tracked as `GHSL-2023-251`.
CVSS Score
HIGH
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| Open-Metadata | Openmetadata | < 1.2.4 |
Related Weaknesses (CWE)
References
- https://codeql.github.com/codeql-query-help/java/java-spel-expression-injectionNot Applicable
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/security/advisories/GHSA-8p5r-6mvvExploitVendor Advisory
- https://codeql.github.com/codeql-query-help/java/java-spel-expression-injectionNot Applicable
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45dProduct
- https://github.com/open-metadata/OpenMetadata/security/advisories/GHSA-8p5r-6mvvExploitVendor Advisory
FAQ
What is CVE-2024-28847?
CVE-2024-28847 is a vulnerability with a CVSS score of 8.8 (HIGH). OpenMetadata is a unified platform for discovery, observability, and governance powered by a central metadata repository, in-depth lineage, and seamless team collaboration. Similarly to the GHSL-2023-...
How severe is CVE-2024-28847?
CVE-2024-28847 has been rated HIGH with a CVSS base score of 8.8/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2024-28847?
Check the references section above for vendor advisories and patch information. Affected products include: Open-Metadata Openmetadata.