SpEL Injection in `PUT /api/v1/policies` in OpenMetadata
Description
OpenMetadata is a unified platform for discovery, observability, and governance powered by a central metadata repository, in-depth lineage, and seamless team collaboration. CompiledRule::validateExpression is also called from PolicyRepository.prepare. 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/policies which gets handled by PolicyResource.createOrUpdate(). This vulnerability was discovered with the help of CodeQL's Expression language injection (Spring) query and is also tracked as GHSL-2023-252. This issue may lead to Remote Code Execution and has been addressed in version 1.3.1. Users are advised to upgrade. There are no known workarounds for this vulnerability.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
org.open-metadata:openmetadata-serviceMaven | < 1.3.1 | 1.3.1 |
Affected products
1- Range: < 1.3.1
Patches
0No patches discovered yet.
Vulnerability mechanics
AI mechanics synthesis has not run for this CVE yet.
References
9- github.com/advisories/GHSA-7vf4-x5m2-r6grghsaADVISORY
- nvd.nist.gov/vuln/detail/CVE-2024-28253ghsaADVISORY
- securitylab.github.com/advisories/GHSL-2023-235_GHSL-2023-237_Open_MetadataghsaADVISORY
- codeql.github.com/codeql-query-help/java/java-spel-expression-injectionghsax_refsource_MISCWEB
- github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45d370cc3c9fc8/openmetadata-service/src/main/java/org/openmetadata/service/jdbi3/EntityRepository.javaghsax_refsource_MISCWEB
- github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45d370cc3c9fc8/openmetadata-service/src/main/java/org/openmetadata/service/resources/EntityResource.javaghsax_refsource_MISCWEB
- github.com/open-metadata/OpenMetadata/blob/b6b337e09a05101506a5faba4b45d370cc3c9fc8/openmetadata-service/src/main/java/org/openmetadata/service/resources/policies/PolicyResource.javaghsax_refsource_MISCWEB
- github.com/open-metadata/OpenMetadata/blob/main/openmetadata-service/src/main/java/org/openmetadata/service/jdbi3/PolicyRepository.javaghsax_refsource_MISCWEB
- github.com/open-metadata/OpenMetadata/security/advisories/GHSA-7vf4-x5m2-r6grghsax_refsource_CONFIRMWEB
News mentions
0No linked articles in our index yet.