Home

Description

Budibase is an open-source low-code platform. Prior to 3.39.0, /api/public/v1/roles/assign is guarded by the builderOrAdmin middleware, which passes any user who is a builder for the app id in the x-budibase-app-id header. That check admits both global builders and workspace-scoped builders (builder.apps set but builder.global unset). The controller then spreads the request body into the SDK call, and the SDK grants builder.global=true or admin.global=true on whichever user ids the caller supplies. Bob, a workspace-scoped builder with an API key, promotes himself or any other user to global admin with one POST. The whole flow is tenant-wide privilege escalation from an app-level role, available to anyone with an Enterprise license that unlocks the EXPANDED_PUBLIC_API feature. This vulnerability is fixed in 3.39.0.

PUBLISHED Reserved 2026-05-20 | Published 2026-05-27 | Updated 2026-05-27 | Assigner GitHub_M




CRITICAL: 9.0CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:C/C:H/I:H/A:L

Problem types

CWE-915: Improperly Controlled Modification of Dynamically-Determined Object Attributes

Product status

< 3.39.0
affected

References

github.com/...dibase/security/advisories/GHSA-6xp4-cf37-ppjh exploit

github.com/...dibase/security/advisories/GHSA-6xp4-cf37-ppjh

cve.org (CVE-2026-48150)

nvd.nist.gov (CVE-2026-48150)

Download JSON