Home

Description

Budibase is a low code platform for creating internal tools, workflows, and admin panels. In 3.31.4 and earlier, the Budibase server's authorized() middleware that protects every server-side API endpoint can be completely bypassed by appending a webhook path pattern to the query string of any request. The isWebhookEndpoint() function uses an unanchored regex that tests against ctx.request.url, which in Koa includes the full URL with query parameters. When the regex matches, the authorized() middleware immediately calls return next(), skipping all authentication, authorization, role checks, and CSRF protection. This means a completely unauthenticated, remote attacker can access any server-side API endpoint by simply appending ?/webhooks/trigger (or any webhook pattern variant) to the URL.

PUBLISHED Reserved 2026-03-09 | Published 2026-03-09 | Updated 2026-03-10 | Assigner GitHub_M




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

Problem types

CWE-74: Improper Neutralization of Special Elements in Output Used by a Downstream Component ('Injection')

Product status

<= 3.31.4
affected

References

github.com/...dibase/security/advisories/GHSA-gw94-hprh-4wj8 exploit

github.com/...dibase/security/advisories/GHSA-gw94-hprh-4wj8

cve.org (CVE-2026-31816)

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

Download JSON