Harbor fails to validate the maintainer role permissions when creating/updating/deleting project configurations - API call:
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.
Will be fixed in v2.9.5, v2.10.3 and v2.11.0
There are no workarounds available.
Thanks to Ravid Mazon(rmazon@paloaltonetworks.com), Jay Chen (jaychen@paloaltonetworks.com) Palo Alto Networks for reporting this issue.
{
    "nvd_published_at": "2024-08-02T01:15:23Z",
    "severity": "HIGH",
    "cwe_ids": [
        "CWE-269"
    ],
    "github_reviewed_at": "2024-07-31T16:53:13Z",
    "github_reviewed": true
}