Mend.io Vulnerability Database
The largest open source vulnerability database
What is a Vulnerability ID?
New vulnerability? Tell us about it!
CVE-2026-47387
Published:June 05, 2026
Updated:June 06, 2026
Summary The shared form-view submit handler in NocoDB writes the form's "redirect_url" to "window.location.href" after a same-host check that does not validate the URL scheme. A user with "editor" role (or above) on any base can plant a "javascript:" URL in the form's "redirect_url"; when an authenticated viewer opens the share-link and submits the form, the payload executes in the NocoDB origin and can read the session token from "localStorage["nocodb-gui-v2"]". Details The vulnerable sink is in "packages/nc-gui/composables/useSharedFormViewStore.ts": - "isValidRedirectUrl" validated only "typeof === 'string'" and non-empty trim — no scheme check. - The submit branch built an anchor element, compared "anchor.host" to "window.location.host", and either pushState-reloaded (same host) or assigned "window.location.href = redirectUrl" (otherwise). - For non-network schemes such as "javascript:", "data:", "vbscript:", and "file:", "anchor.host" is the empty string, so the same-host check is false and the code falls into the external-redirect branch — executing the URL same-origin in the NocoDB tab. The "redirect_url" field is writable by any user with "editor" role on the base via the form-view PATCH endpoint, and the value is returned verbatim by the public shared-view meta endpoint, so no further privilege is required to weaponize a public form share. Impact - Same-origin script execution in the viewer's NocoDB tab. The payload runs in the NocoDB origin and can read the session token at "localStorage["nocodb-gui-v2"].token". - Action under the viewer's identity. With the token, an attacker can call authenticated APIs as the viewer, scoped to whatever workspaces, bases, and operations that viewer is permitted to use. - Single-click viewer flow. Form share-links are the intended distribution channel for forms, so the phishing surface is on-brand; the form can be configured with a single hidden pre-filled required field to reduce the viewer flow to one click. Credit This issue was reported by "@kah-ja" (https://github.com/kah-ja) ("turingpoint.de" (https://turingpoint.de)).
Affected Packages
https://github.com/nocodb/nocodb.git (GITHUB):
Affected version(s) >=crea <2026.05.1
Fix Suggestion:
Update to version 2026.05.1
nocodb (NPM):
Affected version(s) >=0.0.1 <2026.05.1
Fix Suggestion:
Update to version 2026.05.1
Do you need more information?
Contact Us
CVSS v4
Base Score:
8.4
Attack Vector
NETWORK
Attack Complexity
LOW
Attack Requirements
NONE
Privileges Required
LOW
User Interaction
ACTIVE
Vulnerable System Confidentiality
HIGH
Vulnerable System Integrity
HIGH
Vulnerable System Availability
NONE
Subsequent System Confidentiality
NONE
Subsequent System Integrity
NONE
Subsequent System Availability
NONE
CVSS v3
Base Score:
7.3
Attack Vector
NETWORK
Attack Complexity
LOW
Privileges Required
LOW
User Interaction
REQUIRED
Scope
UNCHANGED
Confidentiality
HIGH
Integrity
HIGH
Availability
NONE
Weakness Type (CWE)
Improper Neutralization of Input During Web Page Generation ('Cross-site Scripting')