CVE-2024-22278 – github.com/goharbor/harbor
Package
Manager: go
Name: github.com/goharbor/harbor
Vulnerable Version: >=0 <2.9.5 || >=2.10.0 <2.10.3
Severity
Level: High
CVSS v3.1: CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:C/C:L/I:L/A:N
CVSS v4.0: CVSS:4.0/AV:N/AC:L/AT:N/PR:H/UI:N/VC:L/VI:L/VA:H/SC:L/SI:L/SA:N
EPSS: 0.00119 pctl0.31487
Details
Harbor fails to validate the user permissions when updating project configurations ### Impact Harbor fails to validate the maintainer role permissions when creating/updating/deleting project configurations - API call: - PUT /projects/{project_name_or_id}/metadatas/{meta_name} - POST /projects/{project_name_or_id}/metadatas/{meta_name} - DELETE /projects/{project_name_or_id}/metadatas/{meta_name} By sending a request to create/update/delete a metadata with an name that belongs to a project that the currently authenticated and granted to the maintainer role user doesn’t have access to, the attacker could modify configurations in the current project. BTW: the maintainer role in Harbor was intended for individuals who closely support the project admin in maintaining the project but lack configuration management permissions. However, the maintainer role can utilize the metadata API to circumvent this limitation. It's important to note that any potential attacker must be authenticated and granted a specific project maintainer role to modify configurations, limiting their scope to only that project. ### Patches Will be fixed in v2.9.5, v2.10.3 and v2.11.0 ### Workarounds There are no workarounds available. ### Credit Thanks to Ravid Mazon(rmazon@paloaltonetworks.com), Jay Chen (jaychen@paloaltonetworks.com) Palo Alto Networks for reporting this issue.
Metadata
Created: 2024-07-31T16:53:13Z
Modified: 2024-11-18T16:26:57Z
Source: https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2024/07/GHSA-hw28-333w-qxp3/GHSA-hw28-333w-qxp3.json
CWE IDs: ["CWE-269"]
Alternative ID: GHSA-hw28-333w-qxp3
Finding: F159
Auto approve: 1