Launch Week Day 1: Announcing Security Design Review
UNKNOWN npm

NocoDB has Stored Cross-site Scripting via Formula Cell

GHSA-vx5p-q85x-xm3c · CVE-2026-28357

Published · Modified

Description

Summary

A stored XSS vulnerability exists in the Formula virtual cell. Formula results containing URI::() patterns are rendered via v-html without sanitization, allowing injected HTML to execute.

Details

The replaceUrlsWithLink() function in urlUtils.ts converts URI::(url) patterns to <a> tags but passes all other HTML through unchanged. A user with Creator role (minimum role for formula field creation) can craft a formula like CONCAT("URI::(https://example.com)", "<img src=x onerror=...>") to inject arbitrary scripts rendered for all viewers.

Impact

Credential theft via script execution in the context of users viewing the table.

Credit

This issue was reported by @Akokonunes.

Ready to move

Start Securing

Free, no credit card | First findings in minutes