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.
History

No history.

cve-icon MITRE

Status: PUBLISHED

Assigner: GitHub_M

Published: 2024-03-15T19:55:39.720Z

Updated: 2024-08-28T16:21:59.965Z

Reserved: 2024-03-07T14:33:30.036Z

Link: CVE-2024-28253

cve-icon Vulnrichment

Updated: 2024-08-02T00:48:49.667Z

cve-icon NVD

Status : Awaiting Analysis

Published: 2024-03-15T20:15:09.807

Modified: 2024-03-17T22:38:29.433

Link: CVE-2024-28253

cve-icon Redhat

No data.