A flaw in the SeaTable node's row:search and row:get operations allowed user-controlled input to be concatenated directly into SQL query strings without escaping or parameterization. In workflows where external user input is passed via expressions into the SeaTable node's search or row retrieval parameters, an attacker could manipulate the constructed query to retrieve unintended rows from the connected SeaTable base, bypassing row-level filtering logic implemented in the workflow.
Exploitation requires a specific workflow configuration:
- The SeaTable node must be used with user-controlled input passed via expressions (e.g., from a form or webhook) into the searchTerm or rowId parameters.
The issue has been fixed in n8n versions 1.123.32, 2.17.4, and 2.18.1. Users should upgrade to one of these versions or later to remediate the vulnerability.
If upgrading is not immediately possible, administrators should consider the following temporary mitigations:
- Limit workflow creation and editing permissions to fully trusted users only.
- Disable the SeaTable node by adding n8n-nodes-base.seaTable to the NODES_EXCLUDE environment variable.
- Avoid passing unvalidated external user input into SeaTable node search or row retrieval parameters via expressions.
These workarounds do not fully remediate the risk and should only be used as short-term mitigation measures.
{
"github_reviewed": true,
"github_reviewed_at": "2026-04-29T21:10:58Z",
"cwe_ids": [
"CWE-89"
],
"severity": "MODERATE",
"nvd_published_at": "2026-05-04T19:16:05Z"
}