From n8n-skills
Configures n8n nodes by fetching canonical parameter shapes via `get_node_types`. Covers operation-first setup, conditional fields, and build-then-validate flow for HTTP, database, comms, AI, and trigger nodes.
How 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.
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."
validate_node_config as a side-channelvalidate_node_config([{ type, typeVersion, parameters, isToolNode? }]) runs the same Zod schema as validate_workflow on isolated node configs. Schema-level only; doesn't replace validate_workflow (still the publish gate). Cleaner signal for:
validate_workflow per tweak.For tool subnodes (wired via ai_tool), set isToolNode: true so the correct displayOptions branch evaluates.
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 |
references/MERGE_NODE.md | Configuring a Merge node, or you see useDataOfInput, numberOfInputs, or branches converging |
| 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 |
npx claudepluginhub n8n-io/skills --plugin n8n-skillsGuides operation-aware n8n node configuration with property dependencies, displayOptions, and progressive discovery. Use when setting up node parameters or determining required fields per operation.
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.