Help us improve
Share bugs, ideas, or general feedback.
From n8n-skills
Configures any n8n node (HTTP, webhooks, database, Slack, AI, triggers) with operation-first parameter shapes and validation. Activates on node-builder calls and parameter configuration.
npx claudepluginhub n8n-io/skills --plugin n8n-skillsHow this skill is triggered — by the user, by Claude, or both
Slash command
/n8n-skills:n8n-node-configurationThe summary Claude sees in its skill listing — used to decide when to auto-load this skill
Each n8n node has its own parameter shape, often with conditional fields (parameter X only matters when parameter Y has value Z). Shapes evolve between versions. Guessing produces cryptic validation errors.
Guides n8n node configuration for specific resources and operations, covering required fields, property dependencies, get_node detail levels, and common patterns.
Guides n8n node configuration by operation, revealing required fields, property dependencies, get_node detail levels, and common patterns.
Provides operation-aware guidance for configuring n8n nodes, detailing required fields per operation, property dependencies, displayOptions visibility, and optimal get_node detail levels.
Share bugs, ideas, or general feedback.
Each n8n node has its own parameter shape, often with conditional fields (parameter X only matters when parameter Y has value Z). Shapes evolve between versions. Guessing produces cryptic validation errors.
Don't guess, use the get_node_types tool.
Call get_node_types with discriminators (resource, operation, mode) before configuring a node. Without discriminators you get the generic shape, missing operation-specific parameters and required fields. Build against the exact shape. Don't guess from memory.
The live get_node_types output is the canonical parameter shape. The references in this skill cover patterns, gotchas, security rules, and decision-making (when to use which operation, why credentials over text fields, engine retry caps, etc.) not parameter names or field structures. If a reference example conflicts with what get_node_types returns, trust the tool. Markdown drifts; the type def is generated from the live source.
resource and operation first, and conditional parameters become visible. Most "field doesn't exist" errors are really "you haven't set the parent operation yet."operation, re-derive from the new shape. Stale parameters from the previous operation trip validation.1. search_nodes(['<capability keyword>'])
→ returns matching node IDs + discriminators
2. Pick the right (resource, operation) for the task.
3. get_node_types([{ name: '...', resource: '...', operation: '...' }])
→ returns exact parameter shape including conditional fields
4. Build the node config from that shape.
5. validate_workflow → fix errors.
6. get_workflow_details → inspect the saved config; confirm parameters landed.
7. test_workflow with pinned data → confirm runtime behavior.
Skipping any step compounds the next. The most common skip is step 3, leading to "Cannot read property X" errors that are really "you didn't pass the discriminators."
Most nodes have a top-level shape like:
{
resource: '<thing being operated on>', // 'message', 'spreadsheet', 'user', etc.
operation: '<verb>', // 'send', 'append', 'lookup', etc.
// ...operation-specific parameters
}
The (resource, operation) pair determines what other parameters exist (e.g., Slack (message, send) differs from (user, info)).
Pattern:
resource and operation first.get_node_types with those discriminators if you didn't initially.Some parameters depend on others in non-obvious ways:
Examples:
authentication: 'genericCredentialType' requires genericAuthType and credentials, but 'predefinedCredentialType' requires a different shape.operation: 'executeQuery' requires query, while operation: 'select' requires table and columns.messageType: 'block' enables block-builder fields absent from messageType: 'text'.Always inspect via get_node_types for the specific operation. Don't reuse a config from a different operation and expect it to validate.
Per-category gotchas. Read the file for the node type you're configuring:
| File | When to read |
|---|---|
references/HTTP_NODES.md | Configuring HTTP Request: auth, pagination, query/body parameters, retries |
references/WEBHOOK_NODES.md | Configuring Webhook trigger or Respond to Webhook: body parsing, response shape, async patterns |
references/COMMS_NODES.md | Slack, Gmail, Discord, email: credential types, message shapes, attachments |
references/DATABASE_NODES.md | Postgres, MySQL, Mongo, Supabase: query vs operation, parameter binding, error handling |
references/AI_NODES.md | AI Agent node config knobs: streaming, vision, maxIterations, retries on the model sub-node. Defers design (prompts, tools, memory, structured output) to n8n-agents |
references/TRIGGER_NODES.md | Webhook, Schedule, Manual, Execute Workflow Trigger: input schemas, polling vs realtime |
references/SWITCH_FALLBACK.md | Configuring a Switch node: unnamed outputs / missing fallback silently drop unmatched items |
| Anti-pattern | What goes wrong | Fix |
|---|---|---|
| Building node config from memory of how the node looked last year | Parameter shape has drifted, validation fails with cryptic errors | Always get_node_types per session per node |
Skipping discriminators in get_node_types | Get generic shape, miss operation-specific required fields | Always pass resource + operation (and mode where present) |
| Copying a node config from one operation to another and tweaking | Stale parameters trip validation, and conditional fields don't apply | Re-derive from the new operation's shape |
| Hardcoding tokens / credentials in node text fields | Leaks on export. See n8n-credentials-and-security | Always credentials |
Not testing the node with test_workflow after configuring | Runtime errors only surface on real data | Always test with pinned data before publish |