@ngxtm/devkit 3.6.1 → 3.8.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/SKILLS_INDEX.md +2419 -634
- package/cli/update.js +145 -77
- package/merged-commands/3d-web-experience.md +254 -0
- package/merged-commands/ab-test-setup.md +232 -0
- package/merged-commands/accessibility-compliance-accessibility-audit.md +42 -0
- package/merged-commands/active-directory-attacks.md +383 -0
- package/merged-commands/address-github-comments.md +55 -0
- package/merged-commands/aesthetic.md +134 -0
- package/merged-commands/agent-evaluation.md +64 -0
- package/merged-commands/agent-framework-azure-hosted-agents.md +332 -0
- package/merged-commands/agent-manager-skill.md +40 -0
- package/merged-commands/agent-memory-mcp.md +82 -0
- package/merged-commands/agent-memory-systems.md +67 -0
- package/merged-commands/agent-orchestration-improve-agent.md +349 -0
- package/merged-commands/agent-orchestration-multi-agent-optimize.md +239 -0
- package/merged-commands/agent-tool-builder.md +53 -0
- package/merged-commands/agile-product-owner.md +31 -0
- package/merged-commands/ai-agents-architect.md +90 -0
- package/merged-commands/ai-artist.md +75 -0
- package/merged-commands/ai-engineer.md +171 -0
- package/merged-commands/ai-multimodal.md +109 -0
- package/merged-commands/ai-product.md +54 -0
- package/merged-commands/ai-wrapper-product.md +273 -0
- package/merged-commands/airflow-dag-patterns.md +41 -0
- package/merged-commands/algolia-search.md +66 -0
- package/merged-commands/algorithmic-art.md +405 -0
- package/merged-commands/analytics-tracking.md +404 -0
- package/merged-commands/angular-architect.md +97 -0
- package/merged-commands/angular-migration.md +428 -0
- package/merged-commands/anti-reversing-techniques.md +42 -0
- package/merged-commands/api-design-principles.md +37 -0
- package/merged-commands/api-designer.md +101 -0
- package/merged-commands/api-documentation-generator.md +484 -0
- package/merged-commands/api-documenter.md +184 -0
- package/merged-commands/api-fuzzing-bug-bounty.md +433 -0
- package/merged-commands/api-patterns.md +81 -0
- package/merged-commands/api-security-best-practices.md +907 -0
- package/merged-commands/api-testing-observability-api-mock.md +46 -0
- package/merged-commands/app-builder.md +75 -0
- package/merged-commands/app-store-optimization.md +403 -0
- package/merged-commands/application-performance-performance-optimization.md +154 -0
- package/merged-commands/architect-review.md +174 -0
- package/merged-commands/architecture-decision-records.md +441 -0
- package/merged-commands/architecture-designer.md +89 -0
- package/merged-commands/architecture-patterns.md +37 -0
- package/merged-commands/architecture.md +55 -0
- package/merged-commands/arm-cortex-expert.md +306 -0
- package/merged-commands/artifacts-builder.md +74 -0
- package/merged-commands/ask-questions-if-underspecified.md +81 -0
- package/merged-commands/async-python-patterns.md +39 -0
- package/merged-commands/atlassian-mcp.md +100 -0
- package/merged-commands/attack-tree-construction.md +38 -0
- package/merged-commands/auth-implementation-patterns.md +39 -0
- package/merged-commands/automate-whatsapp.md +257 -0
- package/merged-commands/autonomous-agent-patterns.md +761 -0
- package/merged-commands/autonomous-agents.md +68 -0
- package/merged-commands/avalonia-layout-zafiro.md +59 -0
- package/merged-commands/avalonia-viewmodels-zafiro.md +29 -0
- package/merged-commands/avalonia-zafiro-development.md +29 -0
- package/merged-commands/aws-agentic-ai.md +117 -0
- package/merged-commands/aws-cdk-development.md +278 -0
- package/merged-commands/aws-cost-operations.md +317 -0
- package/merged-commands/aws-penetration-testing.md +405 -0
- package/merged-commands/aws-serverless-eda.md +757 -0
- package/merged-commands/aws-serverless.md +323 -0
- package/merged-commands/aws-skills.md +22 -0
- package/merged-commands/azd-deployment.md +296 -0
- package/merged-commands/azure-ai-agents-python.md +277 -0
- package/merged-commands/azure-ai-search-python.md +198 -0
- package/merged-commands/azure-ai-voicelive-skill.md +294 -0
- package/merged-commands/azure-functions.md +42 -0
- package/merged-commands/backend-architect.md +333 -0
- package/merged-commands/backend-dev-guidelines.md +342 -0
- package/merged-commands/backend-development-feature-development.md +180 -0
- package/merged-commands/backend-development.md +155 -0
- package/merged-commands/backend-security-coder.md +156 -0
- package/merged-commands/backtesting-frameworks.md +39 -0
- package/merged-commands/bash-defensive-patterns.md +43 -0
- package/merged-commands/bash-linux.md +199 -0
- package/merged-commands/bash-pro.md +310 -0
- package/merged-commands/bats-testing-patterns.md +34 -0
- package/merged-commands/bazel-build-optimization.md +397 -0
- package/merged-commands/beautiful-prose.md +22 -0
- package/merged-commands/behavioral-modes.md +242 -0
- package/merged-commands/best-practices.md +500 -0
- package/merged-commands/better-auth.md +204 -0
- package/merged-commands/billing-automation.md +42 -0
- package/merged-commands/binary-analysis-patterns.md +450 -0
- package/merged-commands/blockchain-developer.md +208 -0
- package/merged-commands/blockrun.md +292 -0
- package/merged-commands/brainstorming.md +230 -0
- package/merged-commands/brand-guidelines-anthropic.md +73 -0
- package/merged-commands/brand-guidelines-community.md +73 -0
- package/merged-commands/brand-guidelines.md +73 -0
- package/merged-commands/broken-authentication.md +476 -0
- package/merged-commands/browser-automation.md +70 -0
- package/merged-commands/browser-extension-builder.md +261 -0
- package/merged-commands/building-ai-agent-on-cloudflare.md +391 -0
- package/merged-commands/building-mcp-server-on-cloudflare.md +265 -0
- package/merged-commands/bullmq-specialist.md +57 -0
- package/merged-commands/bun-development.md +691 -0
- package/merged-commands/burp-suite-testing.md +380 -0
- package/merged-commands/business-analyst.md +182 -0
- package/merged-commands/busybox-on-windows.md +30 -0
- package/merged-commands/c-pro.md +56 -0
- package/merged-commands/c4-architecture-c4-architecture.md +389 -0
- package/merged-commands/c4-code.md +244 -0
- package/merged-commands/c4-component.md +153 -0
- package/merged-commands/c4-container.md +171 -0
- package/merged-commands/c4-context.md +150 -0
- package/merged-commands/canvas-design.md +130 -0
- package/merged-commands/cc-skill-backend-patterns.md +584 -0
- package/merged-commands/cc-skill-clickhouse-io.md +431 -0
- package/merged-commands/cc-skill-coding-standards.md +522 -0
- package/merged-commands/cc-skill-continuous-learning.md +10 -0
- package/merged-commands/cc-skill-frontend-patterns.md +633 -0
- package/merged-commands/cc-skill-project-guidelines-example.md +352 -0
- package/merged-commands/cc-skill-security-review.md +496 -0
- package/merged-commands/cc-skill-strategic-compact.md +10 -0
- package/merged-commands/changelog-automation.md +38 -0
- package/merged-commands/changelog-generator.md +104 -0
- package/merged-commands/chaos-engineer.md +98 -0
- package/merged-commands/chrome-devtools.md +407 -0
- package/merged-commands/cicd-automation-workflow-automate.md +51 -0
- package/merged-commands/clarity-gate.md +22 -0
- package/merged-commands/claude-ally-health.md +22 -0
- package/merged-commands/claude-code-guide.md +68 -0
- package/merged-commands/claude-d3js-skill.md +820 -0
- package/merged-commands/claude-scientific-skills.md +22 -0
- package/merged-commands/claude-speed-reader.md +22 -0
- package/merged-commands/claude-win11-speckit-update-skill.md +22 -0
- package/merged-commands/clean-code.md +201 -0
- package/merged-commands/clerk-auth.md +56 -0
- package/merged-commands/cli-developer.md +97 -0
- package/merged-commands/cloud-architect.md +135 -0
- package/merged-commands/cloud-penetration-testing.md +501 -0
- package/merged-commands/cloudflare-expert.md +227 -0
- package/merged-commands/code-documentation-code-explain.md +46 -0
- package/merged-commands/code-documentation-doc-generate.md +48 -0
- package/merged-commands/code-documentation.md +263 -0
- package/merged-commands/code-documenter.md +95 -0
- package/merged-commands/code-refactoring-context-restore.md +179 -0
- package/merged-commands/code-refactoring-refactor-clean.md +51 -0
- package/merged-commands/code-refactoring-tech-debt.md +386 -0
- package/merged-commands/code-refactoring.md +209 -0
- package/merged-commands/code-review-ai-ai-review.md +450 -0
- package/merged-commands/code-review-checklist.md +444 -0
- package/merged-commands/code-review-excellence.md +40 -0
- package/merged-commands/code-review.md +121 -0
- package/merged-commands/code-reviewer.md +178 -0
- package/merged-commands/codebase-cleanup-deps-audit.md +51 -0
- package/merged-commands/codebase-cleanup-refactor-clean.md +51 -0
- package/merged-commands/codebase-cleanup-tech-debt.md +386 -0
- package/merged-commands/codex-review.md +37 -0
- package/merged-commands/commit.md +171 -0
- package/merged-commands/competitive-ads-extractor.md +293 -0
- package/merged-commands/competitive-landscape.md +34 -0
- package/merged-commands/competitor-alternatives.md +750 -0
- package/merged-commands/comprehensive-review-full-review.md +146 -0
- package/merged-commands/comprehensive-review-pr-enhance.md +46 -0
- package/merged-commands/computer-use-agents.md +315 -0
- package/merged-commands/concise-planning.md +62 -0
- package/merged-commands/conductor-implement.md +388 -0
- package/merged-commands/conductor-manage.md +39 -0
- package/merged-commands/conductor-new-track.md +433 -0
- package/merged-commands/conductor-revert.md +372 -0
- package/merged-commands/conductor-setup.md +426 -0
- package/merged-commands/conductor-status.md +338 -0
- package/merged-commands/conductor-validator.md +62 -0
- package/merged-commands/content-creator.md +248 -0
- package/merged-commands/content-marketer.md +170 -0
- package/merged-commands/content-research-writer.md +538 -0
- package/merged-commands/context-compression.md +266 -0
- package/merged-commands/context-degradation.md +238 -0
- package/merged-commands/context-driven-development.md +400 -0
- package/merged-commands/context-engineering.md +107 -0
- package/merged-commands/context-fundamentals.md +192 -0
- package/merged-commands/context-management-context-restore.md +179 -0
- package/merged-commands/context-management-context-save.md +177 -0
- package/merged-commands/context-manager.md +185 -0
- package/merged-commands/context-optimization.md +186 -0
- package/merged-commands/context-window-management.md +53 -0
- package/merged-commands/context7-auto-research.md +36 -0
- package/merged-commands/conversation-memory.md +61 -0
- package/merged-commands/copy-editing.md +439 -0
- package/merged-commands/copywriting.md +225 -0
- package/merged-commands/core-components.md +264 -0
- package/merged-commands/cosmos-db-python-skill.md +198 -0
- package/merged-commands/cost-optimization.md +286 -0
- package/merged-commands/cpp-pro.md +59 -0
- package/merged-commands/cqrs-implementation.md +35 -0
- package/merged-commands/create-pr.md +192 -0
- package/merged-commands/crewai.md +243 -0
- package/merged-commands/csharp-developer.md +94 -0
- package/merged-commands/csharp-pro.md +59 -0
- package/merged-commands/culture-index.md +43 -0
- package/merged-commands/customer-support.md +170 -0
- package/merged-commands/daily-news-report.md +356 -0
- package/merged-commands/data-engineer.md +224 -0
- package/merged-commands/data-engineering-data-driven-feature.md +182 -0
- package/merged-commands/data-engineering-data-pipeline.md +201 -0
- package/merged-commands/data-quality-frameworks.md +40 -0
- package/merged-commands/data-scientist.md +199 -0
- package/merged-commands/data-storytelling.md +465 -0
- package/merged-commands/database-admin.md +165 -0
- package/merged-commands/database-architect.md +268 -0
- package/merged-commands/database-cloud-optimization-cost-optimize.md +44 -0
- package/merged-commands/database-design.md +52 -0
- package/merged-commands/database-migration.md +436 -0
- package/merged-commands/database-migrations-migration-observability.md +420 -0
- package/merged-commands/database-migrations-sql-migrations.md +53 -0
- package/merged-commands/database-optimizer.md +167 -0
- package/merged-commands/databases.md +232 -0
- package/merged-commands/dbt-transformation-patterns.md +34 -0
- package/merged-commands/debugger.md +49 -0
- package/merged-commands/debugging-strategies.md +34 -0
- package/merged-commands/debugging-toolkit-smart-debug.md +197 -0
- package/merged-commands/debugging-wizard.md +93 -0
- package/merged-commands/debugging.md +84 -0
- package/merged-commands/deep-research.md +114 -0
- package/merged-commands/defi-protocol-templates.md +466 -0
- package/merged-commands/dependency-management-deps-audit.md +44 -0
- package/merged-commands/dependency-upgrade.md +421 -0
- package/merged-commands/deployment-engineer.md +170 -0
- package/merged-commands/deployment-pipeline-design.md +371 -0
- package/merged-commands/deployment-procedures.md +241 -0
- package/merged-commands/deployment-validation-config-validate.md +496 -0
- package/merged-commands/design-md.md +178 -0
- package/merged-commands/design-orchestration.md +167 -0
- package/merged-commands/developer-growth-analysis.md +322 -0
- package/merged-commands/devops-engineer.md +92 -0
- package/merged-commands/devops-troubleshooter.md +161 -0
- package/merged-commands/devops.md +285 -0
- package/merged-commands/discord-bot-architect.md +277 -0
- package/merged-commands/dispatching-parallel-agents.md +180 -0
- package/merged-commands/distributed-debugging-debug-trace.md +44 -0
- package/merged-commands/distributed-tracing.md +450 -0
- package/merged-commands/django-expert.md +89 -0
- package/merged-commands/django-pro.md +180 -0
- package/merged-commands/doc-coauthoring.md +375 -0
- package/merged-commands/docker-expert.md +409 -0
- package/merged-commands/docs-architect.md +98 -0
- package/merged-commands/docs-seeker.md +102 -0
- package/merged-commands/documentation-generation-doc-generate.md +48 -0
- package/merged-commands/documentation-templates.md +194 -0
- package/merged-commands/docx-official.md +197 -0
- package/merged-commands/docx.md +197 -0
- package/merged-commands/domain-name-brainstormer.md +212 -0
- package/merged-commands/dotnet-architect.md +197 -0
- package/merged-commands/dotnet-backend-patterns.md +37 -0
- package/merged-commands/dotnet-core-expert.md +96 -0
- package/merged-commands/dx-optimizer.md +83 -0
- package/merged-commands/e2e-testing-patterns.md +41 -0
- package/merged-commands/elixir-pro.md +59 -0
- package/merged-commands/email-sequence.md +925 -0
- package/merged-commands/email-systems.md +54 -0
- package/merged-commands/embedded-systems.md +98 -0
- package/merged-commands/embedding-strategies.md +491 -0
- package/merged-commands/employment-contract-templates.md +39 -0
- package/merged-commands/environment-setup-guide.md +479 -0
- package/merged-commands/error-debugging-error-analysis.md +47 -0
- package/merged-commands/error-debugging-error-trace.md +43 -0
- package/merged-commands/error-debugging-multi-agent-review.md +216 -0
- package/merged-commands/error-detective.md +53 -0
- package/merged-commands/error-diagnostics-error-analysis.md +47 -0
- package/merged-commands/error-diagnostics-error-trace.md +48 -0
- package/merged-commands/error-diagnostics-smart-debug.md +197 -0
- package/merged-commands/error-handling-patterns.md +35 -0
- package/merged-commands/ethical-hacking-methodology.md +466 -0
- package/merged-commands/evaluation.md +238 -0
- package/merged-commands/event-sourcing-architect.md +58 -0
- package/merged-commands/event-store-design.md +449 -0
- package/merged-commands/exa-search.md +36 -0
- package/merged-commands/executing-plans.md +76 -0
- package/merged-commands/expo-app-design.md +22 -0
- package/merged-commands/expo-deployment.md +72 -0
- package/merged-commands/fal-audio.md +22 -0
- package/merged-commands/fal-generate.md +22 -0
- package/merged-commands/fal-image-edit.md +22 -0
- package/merged-commands/fal-platform.md +22 -0
- package/merged-commands/fal-upscale.md +22 -0
- package/merged-commands/fal-workflow.md +22 -0
- package/merged-commands/fastapi-expert.md +93 -0
- package/merged-commands/fastapi-pro.md +192 -0
- package/merged-commands/fastapi-router.md +52 -0
- package/merged-commands/fastapi-templates.md +32 -0
- package/merged-commands/feature-forge.md +90 -0
- package/merged-commands/ffuf-claude-skill.md +22 -0
- package/merged-commands/file-organizer.md +250 -0
- package/merged-commands/file-path-traversal.md +486 -0
- package/merged-commands/file-uploads.md +22 -0
- package/merged-commands/find-bugs.md +86 -0
- package/merged-commands/fine-tuning-expert.md +98 -0
- package/merged-commands/finishing-a-development-branch.md +200 -0
- package/merged-commands/firebase.md +56 -0
- package/merged-commands/firecrawl-scraper.md +37 -0
- package/merged-commands/firmware-analyst.md +320 -0
- package/merged-commands/fix-review.md +53 -0
- package/merged-commands/fixing.md +72 -0
- package/merged-commands/flutter-expert.md +200 -0
- package/merged-commands/form-cro.md +441 -0
- package/merged-commands/foundry-iq-agent.md +15 -0
- package/merged-commands/foundry-iq-python.md +275 -0
- package/merged-commands/foundry-nextgen-frontend.md +555 -0
- package/merged-commands/foundry-sdk-python.md +290 -0
- package/merged-commands/fp-ts-errors.md +856 -0
- package/merged-commands/fp-ts-pragmatic.md +598 -0
- package/merged-commands/fp-ts-react.md +796 -0
- package/merged-commands/framework-migration-code-migrate.md +48 -0
- package/merged-commands/framework-migration-deps-upgrade.md +48 -0
- package/merged-commands/framework-migration-legacy-modernize.md +132 -0
- package/merged-commands/free-tool-strategy.md +576 -0
- package/merged-commands/frontend-design.md +272 -0
- package/merged-commands/frontend-dev-guidelines.md +359 -0
- package/merged-commands/frontend-developer.md +171 -0
- package/merged-commands/frontend-development.md +399 -0
- package/merged-commands/frontend-mobile-development-component-scaffold.md +403 -0
- package/merged-commands/frontend-mobile-security-xss-scan.md +322 -0
- package/merged-commands/frontend-security-coder.md +170 -0
- package/merged-commands/frontend-slides.md +770 -0
- package/merged-commands/full-stack-orchestration-full-stack-feature.md +135 -0
- package/merged-commands/fullstack-guardian.md +99 -0
- package/merged-commands/game-developer.md +94 -0
- package/merged-commands/game-development.md +167 -0
- package/merged-commands/gcp-cloud-run.md +288 -0
- package/merged-commands/gdpr-data-handling.md +33 -0
- package/merged-commands/geo-fundamentals.md +156 -0
- package/merged-commands/git-advanced-workflows.md +412 -0
- package/merged-commands/git-pr-workflows-git-workflow.md +140 -0
- package/merged-commands/git-pr-workflows-onboard.md +416 -0
- package/merged-commands/git-pr-workflows-pr-enhance.md +48 -0
- package/merged-commands/git-pushing.md +33 -0
- package/merged-commands/github-actions-templates.md +345 -0
- package/merged-commands/github-workflow-automation.md +846 -0
- package/merged-commands/gitlab-ci-patterns.md +283 -0
- package/merged-commands/gitops-workflow.md +303 -0
- package/merged-commands/go-concurrency-patterns.md +33 -0
- package/merged-commands/godot-gdscript-patterns.md +33 -0
- package/merged-commands/golang-pro.md +179 -0
- package/merged-commands/google-adk-python.md +243 -0
- package/merged-commands/grafana-dashboards.md +381 -0
- package/merged-commands/graphql-architect.md +182 -0
- package/merged-commands/graphql.md +68 -0
- package/merged-commands/haskell-pro.md +56 -0
- package/merged-commands/helm-chart-scaffolding.md +34 -0
- package/merged-commands/hr-pro.md +126 -0
- package/merged-commands/html-injection-testing.md +498 -0
- package/merged-commands/hubspot-integration.md +42 -0
- package/merged-commands/hugging-face-cli.md +198 -0
- package/merged-commands/hugging-face-jobs.md +1038 -0
- package/merged-commands/hybrid-cloud-architect.md +168 -0
- package/merged-commands/hybrid-cloud-networking.md +238 -0
- package/merged-commands/hybrid-search-implementation.md +32 -0
- package/merged-commands/i18n-localization.md +154 -0
- package/merged-commands/idor-testing.md +442 -0
- package/merged-commands/image-enhancer.md +99 -0
- package/merged-commands/imagen.md +77 -0
- package/merged-commands/incident-responder.md +213 -0
- package/merged-commands/incident-response-incident-response.md +168 -0
- package/merged-commands/incident-response-smart-fix.md +29 -0
- package/merged-commands/incident-runbook-templates.md +395 -0
- package/merged-commands/infinite-gratitude.md +26 -0
- package/merged-commands/inngest.md +55 -0
- package/merged-commands/interactive-portfolio.md +223 -0
- package/merged-commands/internal-comms-anthropic.md +32 -0
- package/merged-commands/internal-comms-community.md +32 -0
- package/merged-commands/internal-comms.md +32 -0
- package/merged-commands/invoice-organizer.md +446 -0
- package/merged-commands/ios-developer.md +219 -0
- package/merged-commands/issue-creator.md +137 -0
- package/merged-commands/istio-traffic-management.md +337 -0
- package/merged-commands/iterate-pr.md +150 -0
- package/merged-commands/java-architect.md +95 -0
- package/merged-commands/java-pro.md +177 -0
- package/merged-commands/javascript-mastery.md +645 -0
- package/merged-commands/javascript-pro.md +57 -0
- package/merged-commands/javascript-testing-patterns.md +35 -0
- package/merged-commands/javascript-typescript-typescript-scaffold.md +361 -0
- package/merged-commands/javascript-typescript.md +142 -0
- package/merged-commands/jira-issues.md +181 -0
- package/merged-commands/job-application.md +90 -0
- package/merged-commands/julia-pro.md +209 -0
- package/merged-commands/k8s-manifest-generator.md +35 -0
- package/merged-commands/k8s-security-policies.md +346 -0
- package/merged-commands/kaizen.md +730 -0
- package/merged-commands/kotlin-specialist.md +94 -0
- package/merged-commands/kpi-dashboard-design.md +440 -0
- package/merged-commands/kubernetes-architect.md +170 -0
- package/merged-commands/kubernetes-specialist.md +117 -0
- package/merged-commands/langchain-architecture.md +350 -0
- package/merged-commands/langfuse.md +238 -0
- package/merged-commands/langgraph.md +287 -0
- package/merged-commands/laravel-specialist.md +101 -0
- package/merged-commands/last30days.md +421 -0
- package/merged-commands/launch-strategy.md +344 -0
- package/merged-commands/lead-research-assistant.md +199 -0
- package/merged-commands/learn.md +476 -0
- package/merged-commands/legacy-modernizer.md +53 -0
- package/merged-commands/legal-advisor.md +70 -0
- package/merged-commands/linear-claude-skill.md +543 -0
- package/merged-commands/linkerd-patterns.md +321 -0
- package/merged-commands/lint-and-validate.md +45 -0
- package/merged-commands/linux-privilege-escalation.md +504 -0
- package/merged-commands/linux-shell-scripting.md +504 -0
- package/merged-commands/llm-app-patterns.md +760 -0
- package/merged-commands/llm-application-dev-ai-assistant.md +35 -0
- package/merged-commands/llm-application-dev-langchain-agent.md +246 -0
- package/merged-commands/llm-application-dev-prompt-optimize.md +37 -0
- package/merged-commands/llm-application-dev.md +216 -0
- package/merged-commands/llm-evaluation.md +483 -0
- package/merged-commands/loki-mode.md +721 -0
- package/merged-commands/machine-learning-ops-ml-pipeline.md +314 -0
- package/merged-commands/makepad-skills.md +22 -0
- package/merged-commands/malware-analyst.md +247 -0
- package/merged-commands/markdown-novel-viewer.md +281 -0
- package/merged-commands/market-sizing-analysis.md +425 -0
- package/merged-commands/marketing-ideas.md +221 -0
- package/merged-commands/marketing-psychology.md +255 -0
- package/merged-commands/mcp-builder.md +236 -0
- package/merged-commands/mcp-developer.md +94 -0
- package/merged-commands/mcp-management.md +209 -0
- package/merged-commands/media-processing.md +358 -0
- package/merged-commands/meeting-insights-analyzer.md +327 -0
- package/merged-commands/memory-forensics.md +491 -0
- package/merged-commands/memory-safety-patterns.md +33 -0
- package/merged-commands/memory-systems.md +228 -0
- package/merged-commands/mermaid-expert.md +59 -0
- package/merged-commands/mermaidjs-v11.md +115 -0
- package/merged-commands/metasploit-framework.md +478 -0
- package/merged-commands/micro-saas-launcher.md +212 -0
- package/merged-commands/microservices-architect.md +102 -0
- package/merged-commands/microservices-patterns.md +35 -0
- package/merged-commands/minecraft-bukkit-pro.md +126 -0
- package/merged-commands/ml-engineer.md +168 -0
- package/merged-commands/ml-pipeline-workflow.md +257 -0
- package/merged-commands/ml-pipeline.md +111 -0
- package/merged-commands/mlops-engineer.md +219 -0
- package/merged-commands/mobile-design.md +284 -0
- package/merged-commands/mobile-developer.md +205 -0
- package/merged-commands/mobile-development.md +212 -0
- package/merged-commands/mobile-security-coder.md +184 -0
- package/merged-commands/modern-javascript-patterns.md +35 -0
- package/merged-commands/monitoring-expert.md +92 -0
- package/merged-commands/monorepo-architect.md +61 -0
- package/merged-commands/monorepo-management.md +35 -0
- package/merged-commands/moodle-external-api-development.md +597 -0
- package/merged-commands/mtls-configuration.md +359 -0
- package/merged-commands/multi-agent-brainstorming.md +256 -0
- package/merged-commands/multi-agent-patterns.md +262 -0
- package/merged-commands/multi-cloud-architecture.md +189 -0
- package/merged-commands/multi-platform-apps-multi-platform.md +203 -0
- package/merged-commands/n8n-code-python.md +750 -0
- package/merged-commands/n8n-mcp-tools-expert.md +654 -0
- package/merged-commands/n8n-node-configuration.md +796 -0
- package/merged-commands/nanobanana-ppt-skills.md +22 -0
- package/merged-commands/neon-postgres.md +56 -0
- package/merged-commands/nestjs-expert.md +552 -0
- package/merged-commands/network-101.md +342 -0
- package/merged-commands/network-engineer.md +169 -0
- package/merged-commands/nextjs-app-router-patterns.md +33 -0
- package/merged-commands/nextjs-best-practices.md +203 -0
- package/merged-commands/nextjs-developer.md +97 -0
- package/merged-commands/nextjs-supabase-auth.md +56 -0
- package/merged-commands/nft-standards.md +395 -0
- package/merged-commands/nodejs-backend-patterns.md +35 -0
- package/merged-commands/nodejs-best-practices.md +333 -0
- package/merged-commands/nosql-expert.md +111 -0
- package/merged-commands/notebooklm-skill.md +269 -0
- package/merged-commands/notebooklm.md +269 -0
- package/merged-commands/notion-template-business.md +216 -0
- package/merged-commands/nx-workspace-patterns.md +464 -0
- package/merged-commands/observability-engineer.md +237 -0
- package/merged-commands/observability-monitoring-monitor-setup.md +48 -0
- package/merged-commands/observability-monitoring-slo-implement.md +43 -0
- package/merged-commands/observe-whatsapp.md +109 -0
- package/merged-commands/obsidian-clipper-template-creator.md +64 -0
- package/merged-commands/on-call-handoff-patterns.md +453 -0
- package/merged-commands/onboarding-cro.md +433 -0
- package/merged-commands/openapi-spec-generation.md +33 -0
- package/merged-commands/page-cro.md +343 -0
- package/merged-commands/paid-ads.md +551 -0
- package/merged-commands/pandas-pro.md +96 -0
- package/merged-commands/parallel-agents.md +175 -0
- package/merged-commands/payment-integration.md +77 -0
- package/merged-commands/paypal-integration.md +479 -0
- package/merged-commands/paywall-upgrade-cro.md +570 -0
- package/merged-commands/pci-compliance.md +478 -0
- package/merged-commands/pdf-official.md +294 -0
- package/merged-commands/pdf.md +294 -0
- package/merged-commands/pentest-checklist.md +334 -0
- package/merged-commands/pentest-commands.md +438 -0
- package/merged-commands/performance-engineer.md +180 -0
- package/merged-commands/performance-profiling.md +143 -0
- package/merged-commands/performance-testing-review-ai-review.md +450 -0
- package/merged-commands/performance-testing-review-multi-agent-review.md +216 -0
- package/merged-commands/personal-tool-builder.md +289 -0
- package/merged-commands/php-pro.md +63 -0
- package/merged-commands/plaid-fintech.md +50 -0
- package/merged-commands/plan-writing.md +152 -0
- package/merged-commands/planning-with-files.md +211 -0
- package/merged-commands/planning.md +95 -0
- package/merged-commands/plans-kanban.md +166 -0
- package/merged-commands/playwright-expert.md +87 -0
- package/merged-commands/playwright-skill.md +453 -0
- package/merged-commands/podcast-generation.md +121 -0
- package/merged-commands/popup-cro.md +346 -0
- package/merged-commands/posix-shell-pro.md +304 -0
- package/merged-commands/postgres-best-practices.md +57 -0
- package/merged-commands/postgres-pro.md +98 -0
- package/merged-commands/postgresql.md +230 -0
- package/merged-commands/postmortem-writing.md +386 -0
- package/merged-commands/powershell-windows.md +167 -0
- package/merged-commands/pptx-official.md +484 -0
- package/merged-commands/pptx.md +484 -0
- package/merged-commands/pricing-strategy.md +356 -0
- package/merged-commands/prisma-expert.md +355 -0
- package/merged-commands/privilege-escalation-methods.md +333 -0
- package/merged-commands/problem-solving.md +96 -0
- package/merged-commands/product-manager-toolkit.md +351 -0
- package/merged-commands/product-strategist.md +26 -0
- package/merged-commands/production-code-audit.md +540 -0
- package/merged-commands/programmatic-seo.md +351 -0
- package/merged-commands/projection-patterns.md +33 -0
- package/merged-commands/prometheus-configuration.md +404 -0
- package/merged-commands/prompt-caching.md +61 -0
- package/merged-commands/prompt-engineer.md +272 -0
- package/merged-commands/prompt-engineering-patterns.md +213 -0
- package/merged-commands/prompt-engineering.md +171 -0
- package/merged-commands/prompt-library.md +322 -0
- package/merged-commands/protocol-reverse-engineering.md +29 -0
- package/merged-commands/pydantic-models.md +58 -0
- package/merged-commands/pypict-skill.md +22 -0
- package/merged-commands/python-development-python-scaffold.md +331 -0
- package/merged-commands/python-development.md +139 -0
- package/merged-commands/python-packaging.md +36 -0
- package/merged-commands/python-patterns.md +441 -0
- package/merged-commands/python-performance-optimization.md +36 -0
- package/merged-commands/python-pro.md +158 -0
- package/merged-commands/python-testing-patterns.md +37 -0
- package/merged-commands/qa-regression.md +337 -0
- package/merged-commands/quant-analyst.md +53 -0
- package/merged-commands/radix-ui-design-system.md +847 -0
- package/merged-commands/raffle-winner-picker.md +159 -0
- package/merged-commands/rag-architect.md +100 -0
- package/merged-commands/rag-engineer.md +90 -0
- package/merged-commands/rag-implementation.md +421 -0
- package/merged-commands/rails-expert.md +97 -0
- package/merged-commands/react-best-practices.md +121 -0
- package/merged-commands/react-expert.md +98 -0
- package/merged-commands/react-flow-node.md +66 -0
- package/merged-commands/react-modernization.md +34 -0
- package/merged-commands/react-native-architecture.md +33 -0
- package/merged-commands/react-native-expert.md +88 -0
- package/merged-commands/react-patterns.md +198 -0
- package/merged-commands/react-state-management.md +441 -0
- package/merged-commands/react-ui-patterns.md +289 -0
- package/merged-commands/readme.md +775 -0
- package/merged-commands/receiving-code-review.md +213 -0
- package/merged-commands/red-team-tactics.md +199 -0
- package/merged-commands/red-team-tools.md +310 -0
- package/merged-commands/reference-builder.md +188 -0
- package/merged-commands/referral-program.md +602 -0
- package/merged-commands/remotion-best-practices.md +45 -0
- package/merged-commands/repomix.md +275 -0
- package/merged-commands/requesting-code-review.md +105 -0
- package/merged-commands/research-engineer.md +135 -0
- package/merged-commands/research.md +191 -0
- package/merged-commands/reverse-engineer.md +173 -0
- package/merged-commands/risk-manager.md +61 -0
- package/merged-commands/risk-metrics-calculation.md +33 -0
- package/merged-commands/ruby-pro.md +56 -0
- package/merged-commands/rust-async-patterns.md +33 -0
- package/merged-commands/rust-engineer.md +96 -0
- package/merged-commands/rust-pro.md +178 -0
- package/merged-commands/saga-orchestration.md +496 -0
- package/merged-commands/sales-automator.md +55 -0
- package/merged-commands/salesforce-developer.md +105 -0
- package/merged-commands/salesforce-development.md +51 -0
- package/merged-commands/sast-configuration.md +212 -0
- package/merged-commands/scala-pro.md +82 -0
- package/merged-commands/scanning-tools.md +589 -0
- package/merged-commands/schema-markup.md +360 -0
- package/merged-commands/screen-reader-testing.md +33 -0
- package/merged-commands/screenshots.md +401 -0
- package/merged-commands/scroll-experience.md +263 -0
- package/merged-commands/search-specialist.md +80 -0
- package/merged-commands/secrets-management.md +364 -0
- package/merged-commands/secure-code-guardian.md +93 -0
- package/merged-commands/security-auditor.md +169 -0
- package/merged-commands/security-bluebook-builder.md +22 -0
- package/merged-commands/security-compliance-compliance-check.md +55 -0
- package/merged-commands/security-requirement-extraction.md +33 -0
- package/merged-commands/security-reviewer.md +94 -0
- package/merged-commands/security-scanning-security-dependencies.md +43 -0
- package/merged-commands/security-scanning-security-hardening.md +147 -0
- package/merged-commands/security-scanning-security-sast.md +495 -0
- package/merged-commands/segment-cdp.md +50 -0
- package/merged-commands/senior-architect.md +209 -0
- package/merged-commands/senior-backend.md +209 -0
- package/merged-commands/senior-computer-vision.md +226 -0
- package/merged-commands/senior-data-engineer.md +226 -0
- package/merged-commands/senior-data-scientist.md +226 -0
- package/merged-commands/senior-devops.md +209 -0
- package/merged-commands/senior-frontend.md +209 -0
- package/merged-commands/senior-fullstack.md +209 -0
- package/merged-commands/senior-ml-engineer.md +226 -0
- package/merged-commands/senior-prompt-engineer.md +226 -0
- package/merged-commands/senior-qa.md +209 -0
- package/merged-commands/senior-secops.md +209 -0
- package/merged-commands/senior-security.md +209 -0
- package/merged-commands/seo-audit.md +487 -0
- package/merged-commands/seo-authority-builder.md +136 -0
- package/merged-commands/seo-cannibalization-detector.md +123 -0
- package/merged-commands/seo-content-auditor.md +83 -0
- package/merged-commands/seo-content-planner.md +108 -0
- package/merged-commands/seo-content-refresher.md +118 -0
- package/merged-commands/seo-content-writer.md +96 -0
- package/merged-commands/seo-fundamentals.md +173 -0
- package/merged-commands/seo-keyword-strategist.md +95 -0
- package/merged-commands/seo-meta-optimizer.md +92 -0
- package/merged-commands/seo-snippet-hunter.md +114 -0
- package/merged-commands/seo-structure-architect.md +108 -0
- package/merged-commands/sequential-thinking.md +94 -0
- package/merged-commands/server-management.md +161 -0
- package/merged-commands/service-mesh-expert.md +58 -0
- package/merged-commands/service-mesh-observability.md +395 -0
- package/merged-commands/sharp-edges.md +70 -0
- package/merged-commands/shellcheck-configuration.md +466 -0
- package/merged-commands/shodan-reconnaissance.md +503 -0
- package/merged-commands/shopify-apps.md +42 -0
- package/merged-commands/shopify-development.md +366 -0
- package/merged-commands/shopify-expert.md +102 -0
- package/merged-commands/signup-flow-cro.md +355 -0
- package/merged-commands/similarity-search-patterns.md +33 -0
- package/merged-commands/skill-creator.md +356 -0
- package/merged-commands/skill-developer.md +426 -0
- package/merged-commands/skill-rails-upgrade.md +408 -0
- package/merged-commands/skill-seekers.md +22 -0
- package/merged-commands/skill-share.md +80 -0
- package/merged-commands/slack-bot-builder.md +264 -0
- package/merged-commands/slack-gif-creator.md +254 -0
- package/merged-commands/slo-implementation.md +341 -0
- package/merged-commands/smtp-penetration-testing.md +500 -0
- package/merged-commands/social-content.md +807 -0
- package/merged-commands/software-architecture.md +75 -0
- package/merged-commands/solidity-security.md +34 -0
- package/merged-commands/spark-engineer.md +100 -0
- package/merged-commands/spark-optimization.md +427 -0
- package/merged-commands/spec-miner.md +88 -0
- package/merged-commands/spring-boot-engineer.md +104 -0
- package/merged-commands/sql-injection-testing.md +448 -0
- package/merged-commands/sql-optimization-patterns.md +35 -0
- package/merged-commands/sql-pro.md +173 -0
- package/merged-commands/sqlmap-database-pentesting.md +400 -0
- package/merged-commands/sre-engineer.md +98 -0
- package/merged-commands/ssh-penetration-testing.md +488 -0
- package/merged-commands/startup-analyst.md +328 -0
- package/merged-commands/startup-business-analyst-business-case.md +487 -0
- package/merged-commands/startup-business-analyst-financial-projections.md +353 -0
- package/merged-commands/startup-business-analyst-market-opportunity.md +240 -0
- package/merged-commands/startup-financial-modeling.md +467 -0
- package/merged-commands/startup-metrics-framework.md +34 -0
- package/merged-commands/stitch-ui-design.md +378 -0
- package/merged-commands/stride-analysis-patterns.md +33 -0
- package/merged-commands/stripe-integration.md +454 -0
- package/merged-commands/subagent-driven-development.md +240 -0
- package/merged-commands/superpowers-lab.md +22 -0
- package/merged-commands/swift-expert.md +94 -0
- package/merged-commands/swiftui-expert-skill.md +275 -0
- package/merged-commands/systematic-debugging.md +296 -0
- package/merged-commands/systems-programming-rust-project.md +440 -0
- package/merged-commands/tailwind-design-system.md +33 -0
- package/merged-commands/tailwind-patterns.md +269 -0
- package/merged-commands/tavily-web.md +36 -0
- package/merged-commands/tdd-orchestrator.md +205 -0
- package/merged-commands/tdd-workflow.md +149 -0
- package/merged-commands/tdd-workflows-tdd-cycle.md +221 -0
- package/merged-commands/tdd-workflows-tdd-green.md +73 -0
- package/merged-commands/tdd-workflows-tdd-red.md +164 -0
- package/merged-commands/tdd-workflows-tdd-refactor.md +187 -0
- package/merged-commands/team-collaboration-issue.md +37 -0
- package/merged-commands/team-collaboration-standup-notes.md +44 -0
- package/merged-commands/team-composition-analysis.md +413 -0
- package/merged-commands/telegram-bot-builder.md +254 -0
- package/merged-commands/telegram-mini-app.md +279 -0
- package/merged-commands/template-skill.md +6 -0
- package/merged-commands/temporal-python-pro.md +370 -0
- package/merged-commands/temporal-python-testing.md +170 -0
- package/merged-commands/terraform-engineer.md +97 -0
- package/merged-commands/terraform-module-library.md +261 -0
- package/merged-commands/terraform-skill.md +517 -0
- package/merged-commands/terraform-specialist.md +166 -0
- package/merged-commands/test-automator.md +224 -0
- package/merged-commands/test-driven-development.md +371 -0
- package/merged-commands/test-fixing.md +119 -0
- package/merged-commands/test-master.md +104 -0
- package/merged-commands/testing-patterns.md +259 -0
- package/merged-commands/theme-factory.md +59 -0
- package/merged-commands/threat-mitigation-mapping.md +33 -0
- package/merged-commands/threat-modeling-expert.md +60 -0
- package/merged-commands/threejs-skills.md +22 -0
- package/merged-commands/threejs.md +89 -0
- package/merged-commands/tool-design.md +318 -0
- package/merged-commands/top-web-vulnerabilities.md +543 -0
- package/merged-commands/track-management.md +38 -0
- package/merged-commands/trigger-dev.md +67 -0
- package/merged-commands/turborepo-caching.md +419 -0
- package/merged-commands/tutorial-engineer.md +139 -0
- package/merged-commands/twilio-communications.md +295 -0
- package/merged-commands/typescript-advanced-types.md +35 -0
- package/merged-commands/typescript-expert.md +429 -0
- package/merged-commands/typescript-pro.md +55 -0
- package/merged-commands/ui-design-system.md +32 -0
- package/merged-commands/ui-skills.md +22 -0
- package/merged-commands/ui-styling.md +321 -0
- package/merged-commands/ui-ux-designer.md +209 -0
- package/merged-commands/ui-ux-pro-max.md +351 -0
- package/merged-commands/ui-visual-validator.md +214 -0
- package/merged-commands/unit-testing-test-generate.md +319 -0
- package/merged-commands/unity-developer.md +230 -0
- package/merged-commands/unity-ecs-patterns.md +33 -0
- package/merged-commands/unreal-engine-cpp-pro.md +114 -0
- package/merged-commands/upgrading-expo.md +118 -0
- package/merged-commands/upstash-qstash.md +68 -0
- package/merged-commands/using-git-worktrees.md +217 -0
- package/merged-commands/using-neon.md +84 -0
- package/merged-commands/using-superpowers.md +87 -0
- package/merged-commands/uv-package-manager.md +37 -0
- package/merged-commands/ux-researcher-designer.md +30 -0
- package/merged-commands/varlock-claude-skill.md +22 -0
- package/merged-commands/vector-database-engineer.md +60 -0
- package/merged-commands/vector-index-tuning.md +42 -0
- package/merged-commands/vercel-deploy-claimable.md +120 -0
- package/merged-commands/vercel-deploy.md +22 -0
- package/merged-commands/vercel-deployment.md +79 -0
- package/merged-commands/verification-before-completion.md +139 -0
- package/merged-commands/vexor.md +22 -0
- package/merged-commands/video-downloader.md +106 -0
- package/merged-commands/viral-generator-builder.md +199 -0
- package/merged-commands/voice-agents.md +68 -0
- package/merged-commands/voice-ai-development.md +302 -0
- package/merged-commands/voice-ai-engine-development.md +721 -0
- package/merged-commands/vue-expert-js.md +91 -0
- package/merged-commands/vue-expert.md +374 -0
- package/merged-commands/vulnerability-scanner.md +276 -0
- package/merged-commands/wcag-audit-patterns.md +41 -0
- package/merged-commands/web-artifacts-builder.md +74 -0
- package/merged-commands/web-design-guidelines.md +36 -0
- package/merged-commands/web-frameworks.md +324 -0
- package/merged-commands/web-performance-optimization.md +646 -0
- package/merged-commands/web3-testing.md +427 -0
- package/merged-commands/webapp-testing.md +96 -0
- package/merged-commands/websocket-engineer.md +96 -0
- package/merged-commands/windows-privilege-escalation.md +496 -0
- package/merged-commands/wireshark-analysis.md +497 -0
- package/merged-commands/wordpress-penetration-testing.md +485 -0
- package/merged-commands/wordpress-pro.md +105 -0
- package/merged-commands/workflow-automation.md +68 -0
- package/merged-commands/workflow-orchestration-patterns.md +333 -0
- package/merged-commands/workflow-patterns.md +38 -0
- package/merged-commands/writing-plans.md +116 -0
- package/merged-commands/writing-skills.md +125 -0
- package/merged-commands/x-article-publisher-skill.md +22 -0
- package/merged-commands/xlsx-official.md +289 -0
- package/merged-commands/xlsx.md +289 -0
- package/merged-commands/xss-html-injection.md +499 -0
- package/merged-commands/youtube-transcript.md +415 -0
- package/merged-commands/zapier-make-patterns.md +67 -0
- package/merged-commands/zustand-store.md +68 -0
- package/package.json +1 -1
- package/scripts/generate-index.js +3 -1
- package/scripts/merge-commands.js +21 -0
- package/skills-index.json +2248 -463
|
@@ -0,0 +1,750 @@
|
|
|
1
|
+
---
|
|
2
|
+
name: n8n-code-python
|
|
3
|
+
description: "Write Python code in n8n Code nodes. Use when writing Python in n8n, using _input/_json/_node syntax, working with standard library, or need to understand Python limitations in n8n Code nodes."
|
|
4
|
+
source: "https://github.com/czlonkowski/n8n-skills/tree/main/skills/n8n-code-python"
|
|
5
|
+
risk: safe
|
|
6
|
+
---
|
|
7
|
+
|
|
8
|
+
# Python Code Node (Beta)
|
|
9
|
+
|
|
10
|
+
Expert guidance for writing Python code in n8n Code nodes.
|
|
11
|
+
|
|
12
|
+
---
|
|
13
|
+
|
|
14
|
+
## ⚠️ Important: JavaScript First
|
|
15
|
+
|
|
16
|
+
**Recommendation**: Use **JavaScript for 95% of use cases**. Only use Python when:
|
|
17
|
+
- You need specific Python standard library functions
|
|
18
|
+
- You're significantly more comfortable with Python syntax
|
|
19
|
+
- You're doing data transformations better suited to Python
|
|
20
|
+
|
|
21
|
+
**Why JavaScript is preferred:**
|
|
22
|
+
- Full n8n helper functions ($helpers.httpRequest, etc.)
|
|
23
|
+
- Luxon DateTime library for advanced date/time operations
|
|
24
|
+
- No external library limitations
|
|
25
|
+
- Better n8n documentation and community support
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
## Quick Start
|
|
30
|
+
|
|
31
|
+
```python
|
|
32
|
+
# Basic template for Python Code nodes
|
|
33
|
+
items = _input.all()
|
|
34
|
+
|
|
35
|
+
# Process data
|
|
36
|
+
processed = []
|
|
37
|
+
for item in items:
|
|
38
|
+
processed.append({
|
|
39
|
+
"json": {
|
|
40
|
+
**item["json"],
|
|
41
|
+
"processed": True,
|
|
42
|
+
"timestamp": datetime.now().isoformat()
|
|
43
|
+
}
|
|
44
|
+
})
|
|
45
|
+
|
|
46
|
+
return processed
|
|
47
|
+
```
|
|
48
|
+
|
|
49
|
+
### Essential Rules
|
|
50
|
+
|
|
51
|
+
1. **Consider JavaScript first** - Use Python only when necessary
|
|
52
|
+
2. **Access data**: `_input.all()`, `_input.first()`, or `_input.item`
|
|
53
|
+
3. **CRITICAL**: Must return `[{"json": {...}}]` format
|
|
54
|
+
4. **CRITICAL**: Webhook data is under `_json["body"]` (not `_json` directly)
|
|
55
|
+
5. **CRITICAL LIMITATION**: **No external libraries** (no requests, pandas, numpy)
|
|
56
|
+
6. **Standard library only**: json, datetime, re, base64, hashlib, urllib.parse, math, random, statistics
|
|
57
|
+
|
|
58
|
+
---
|
|
59
|
+
|
|
60
|
+
## Mode Selection Guide
|
|
61
|
+
|
|
62
|
+
Same as JavaScript - choose based on your use case:
|
|
63
|
+
|
|
64
|
+
### Run Once for All Items (Recommended - Default)
|
|
65
|
+
|
|
66
|
+
**Use this mode for:** 95% of use cases
|
|
67
|
+
|
|
68
|
+
- **How it works**: Code executes **once** regardless of input count
|
|
69
|
+
- **Data access**: `_input.all()` or `_items` array (Native mode)
|
|
70
|
+
- **Best for**: Aggregation, filtering, batch processing, transformations
|
|
71
|
+
- **Performance**: Faster for multiple items (single execution)
|
|
72
|
+
|
|
73
|
+
```python
|
|
74
|
+
# Example: Calculate total from all items
|
|
75
|
+
all_items = _input.all()
|
|
76
|
+
total = sum(item["json"].get("amount", 0) for item in all_items)
|
|
77
|
+
|
|
78
|
+
return [{
|
|
79
|
+
"json": {
|
|
80
|
+
"total": total,
|
|
81
|
+
"count": len(all_items),
|
|
82
|
+
"average": total / len(all_items) if all_items else 0
|
|
83
|
+
}
|
|
84
|
+
}]
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
### Run Once for Each Item
|
|
88
|
+
|
|
89
|
+
**Use this mode for:** Specialized cases only
|
|
90
|
+
|
|
91
|
+
- **How it works**: Code executes **separately** for each input item
|
|
92
|
+
- **Data access**: `_input.item` or `_item` (Native mode)
|
|
93
|
+
- **Best for**: Item-specific logic, independent operations, per-item validation
|
|
94
|
+
- **Performance**: Slower for large datasets (multiple executions)
|
|
95
|
+
|
|
96
|
+
```python
|
|
97
|
+
# Example: Add processing timestamp to each item
|
|
98
|
+
item = _input.item
|
|
99
|
+
|
|
100
|
+
return [{
|
|
101
|
+
"json": {
|
|
102
|
+
**item["json"],
|
|
103
|
+
"processed": True,
|
|
104
|
+
"processed_at": datetime.now().isoformat()
|
|
105
|
+
}
|
|
106
|
+
}]
|
|
107
|
+
```
|
|
108
|
+
|
|
109
|
+
---
|
|
110
|
+
|
|
111
|
+
## Python Modes: Beta vs Native
|
|
112
|
+
|
|
113
|
+
n8n offers two Python execution modes:
|
|
114
|
+
|
|
115
|
+
### Python (Beta) - Recommended
|
|
116
|
+
- **Use**: `_input`, `_json`, `_node` helper syntax
|
|
117
|
+
- **Best for**: Most Python use cases
|
|
118
|
+
- **Helpers available**: `_now`, `_today`, `_jmespath()`
|
|
119
|
+
- **Import**: `from datetime import datetime`
|
|
120
|
+
|
|
121
|
+
```python
|
|
122
|
+
# Python (Beta) example
|
|
123
|
+
items = _input.all()
|
|
124
|
+
now = _now # Built-in datetime object
|
|
125
|
+
|
|
126
|
+
return [{
|
|
127
|
+
"json": {
|
|
128
|
+
"count": len(items),
|
|
129
|
+
"timestamp": now.isoformat()
|
|
130
|
+
}
|
|
131
|
+
}]
|
|
132
|
+
```
|
|
133
|
+
|
|
134
|
+
### Python (Native) (Beta)
|
|
135
|
+
- **Use**: `_items`, `_item` variables only
|
|
136
|
+
- **No helpers**: No `_input`, `_now`, etc.
|
|
137
|
+
- **More limited**: Standard Python only
|
|
138
|
+
- **Use when**: Need pure Python without n8n helpers
|
|
139
|
+
|
|
140
|
+
```python
|
|
141
|
+
# Python (Native) example
|
|
142
|
+
processed = []
|
|
143
|
+
|
|
144
|
+
for item in _items:
|
|
145
|
+
processed.append({
|
|
146
|
+
"json": {
|
|
147
|
+
"id": item["json"].get("id"),
|
|
148
|
+
"processed": True
|
|
149
|
+
}
|
|
150
|
+
})
|
|
151
|
+
|
|
152
|
+
return processed
|
|
153
|
+
```
|
|
154
|
+
|
|
155
|
+
**Recommendation**: Use **Python (Beta)** for better n8n integration.
|
|
156
|
+
|
|
157
|
+
---
|
|
158
|
+
|
|
159
|
+
## Data Access Patterns
|
|
160
|
+
|
|
161
|
+
### Pattern 1: _input.all() - Most Common
|
|
162
|
+
|
|
163
|
+
**Use when**: Processing arrays, batch operations, aggregations
|
|
164
|
+
|
|
165
|
+
```python
|
|
166
|
+
# Get all items from previous node
|
|
167
|
+
all_items = _input.all()
|
|
168
|
+
|
|
169
|
+
# Filter, transform as needed
|
|
170
|
+
valid = [item for item in all_items if item["json"].get("status") == "active"]
|
|
171
|
+
|
|
172
|
+
processed = []
|
|
173
|
+
for item in valid:
|
|
174
|
+
processed.append({
|
|
175
|
+
"json": {
|
|
176
|
+
"id": item["json"]["id"],
|
|
177
|
+
"name": item["json"]["name"]
|
|
178
|
+
}
|
|
179
|
+
})
|
|
180
|
+
|
|
181
|
+
return processed
|
|
182
|
+
```
|
|
183
|
+
|
|
184
|
+
### Pattern 2: _input.first() - Very Common
|
|
185
|
+
|
|
186
|
+
**Use when**: Working with single objects, API responses
|
|
187
|
+
|
|
188
|
+
```python
|
|
189
|
+
# Get first item only
|
|
190
|
+
first_item = _input.first()
|
|
191
|
+
data = first_item["json"]
|
|
192
|
+
|
|
193
|
+
return [{
|
|
194
|
+
"json": {
|
|
195
|
+
"result": process_data(data),
|
|
196
|
+
"processed_at": datetime.now().isoformat()
|
|
197
|
+
}
|
|
198
|
+
}]
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
### Pattern 3: _input.item - Each Item Mode Only
|
|
202
|
+
|
|
203
|
+
**Use when**: In "Run Once for Each Item" mode
|
|
204
|
+
|
|
205
|
+
```python
|
|
206
|
+
# Current item in loop (Each Item mode only)
|
|
207
|
+
current_item = _input.item
|
|
208
|
+
|
|
209
|
+
return [{
|
|
210
|
+
"json": {
|
|
211
|
+
**current_item["json"],
|
|
212
|
+
"item_processed": True
|
|
213
|
+
}
|
|
214
|
+
}]
|
|
215
|
+
```
|
|
216
|
+
|
|
217
|
+
### Pattern 4: _node - Reference Other Nodes
|
|
218
|
+
|
|
219
|
+
**Use when**: Need data from specific nodes in workflow
|
|
220
|
+
|
|
221
|
+
```python
|
|
222
|
+
# Get output from specific node
|
|
223
|
+
webhook_data = _node["Webhook"]["json"]
|
|
224
|
+
http_data = _node["HTTP Request"]["json"]
|
|
225
|
+
|
|
226
|
+
return [{
|
|
227
|
+
"json": {
|
|
228
|
+
"combined": {
|
|
229
|
+
"webhook": webhook_data,
|
|
230
|
+
"api": http_data
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}]
|
|
234
|
+
```
|
|
235
|
+
|
|
236
|
+
**See**: [DATA_ACCESS.md](DATA_ACCESS.md) for comprehensive guide
|
|
237
|
+
|
|
238
|
+
---
|
|
239
|
+
|
|
240
|
+
## Critical: Webhook Data Structure
|
|
241
|
+
|
|
242
|
+
**MOST COMMON MISTAKE**: Webhook data is nested under `["body"]`
|
|
243
|
+
|
|
244
|
+
```python
|
|
245
|
+
# ❌ WRONG - Will raise KeyError
|
|
246
|
+
name = _json["name"]
|
|
247
|
+
email = _json["email"]
|
|
248
|
+
|
|
249
|
+
# ✅ CORRECT - Webhook data is under ["body"]
|
|
250
|
+
name = _json["body"]["name"]
|
|
251
|
+
email = _json["body"]["email"]
|
|
252
|
+
|
|
253
|
+
# ✅ SAFER - Use .get() for safe access
|
|
254
|
+
webhook_data = _json.get("body", {})
|
|
255
|
+
name = webhook_data.get("name")
|
|
256
|
+
```
|
|
257
|
+
|
|
258
|
+
**Why**: Webhook node wraps all request data under `body` property. This includes POST data, query parameters, and JSON payloads.
|
|
259
|
+
|
|
260
|
+
**See**: [DATA_ACCESS.md](DATA_ACCESS.md) for full webhook structure details
|
|
261
|
+
|
|
262
|
+
---
|
|
263
|
+
|
|
264
|
+
## Return Format Requirements
|
|
265
|
+
|
|
266
|
+
**CRITICAL RULE**: Always return list of dictionaries with `"json"` key
|
|
267
|
+
|
|
268
|
+
### Correct Return Formats
|
|
269
|
+
|
|
270
|
+
```python
|
|
271
|
+
# ✅ Single result
|
|
272
|
+
return [{
|
|
273
|
+
"json": {
|
|
274
|
+
"field1": value1,
|
|
275
|
+
"field2": value2
|
|
276
|
+
}
|
|
277
|
+
}]
|
|
278
|
+
|
|
279
|
+
# ✅ Multiple results
|
|
280
|
+
return [
|
|
281
|
+
{"json": {"id": 1, "data": "first"}},
|
|
282
|
+
{"json": {"id": 2, "data": "second"}}
|
|
283
|
+
]
|
|
284
|
+
|
|
285
|
+
# ✅ List comprehension
|
|
286
|
+
transformed = [
|
|
287
|
+
{"json": {"id": item["json"]["id"], "processed": True}}
|
|
288
|
+
for item in _input.all()
|
|
289
|
+
if item["json"].get("valid")
|
|
290
|
+
]
|
|
291
|
+
return transformed
|
|
292
|
+
|
|
293
|
+
# ✅ Empty result (when no data to return)
|
|
294
|
+
return []
|
|
295
|
+
|
|
296
|
+
# ✅ Conditional return
|
|
297
|
+
if should_process:
|
|
298
|
+
return [{"json": processed_data}]
|
|
299
|
+
else:
|
|
300
|
+
return []
|
|
301
|
+
```
|
|
302
|
+
|
|
303
|
+
### Incorrect Return Formats
|
|
304
|
+
|
|
305
|
+
```python
|
|
306
|
+
# ❌ WRONG: Dictionary without list wrapper
|
|
307
|
+
return {
|
|
308
|
+
"json": {"field": value}
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
# ❌ WRONG: List without json wrapper
|
|
312
|
+
return [{"field": value}]
|
|
313
|
+
|
|
314
|
+
# ❌ WRONG: Plain string
|
|
315
|
+
return "processed"
|
|
316
|
+
|
|
317
|
+
# ❌ WRONG: Incomplete structure
|
|
318
|
+
return [{"data": value}] # Should be {"json": value}
|
|
319
|
+
```
|
|
320
|
+
|
|
321
|
+
**Why it matters**: Next nodes expect list format. Incorrect format causes workflow execution to fail.
|
|
322
|
+
|
|
323
|
+
**See**: [ERROR_PATTERNS.md](ERROR_PATTERNS.md) #2 for detailed error solutions
|
|
324
|
+
|
|
325
|
+
---
|
|
326
|
+
|
|
327
|
+
## Critical Limitation: No External Libraries
|
|
328
|
+
|
|
329
|
+
**MOST IMPORTANT PYTHON LIMITATION**: Cannot import external packages
|
|
330
|
+
|
|
331
|
+
### What's NOT Available
|
|
332
|
+
|
|
333
|
+
```python
|
|
334
|
+
# ❌ NOT AVAILABLE - Will raise ModuleNotFoundError
|
|
335
|
+
import requests # ❌ No
|
|
336
|
+
import pandas # ❌ No
|
|
337
|
+
import numpy # ❌ No
|
|
338
|
+
import scipy # ❌ No
|
|
339
|
+
from bs4 import BeautifulSoup # ❌ No
|
|
340
|
+
import lxml # ❌ No
|
|
341
|
+
```
|
|
342
|
+
|
|
343
|
+
### What IS Available (Standard Library)
|
|
344
|
+
|
|
345
|
+
```python
|
|
346
|
+
# ✅ AVAILABLE - Standard library only
|
|
347
|
+
import json # ✅ JSON parsing
|
|
348
|
+
import datetime # ✅ Date/time operations
|
|
349
|
+
import re # ✅ Regular expressions
|
|
350
|
+
import base64 # ✅ Base64 encoding/decoding
|
|
351
|
+
import hashlib # ✅ Hashing functions
|
|
352
|
+
import urllib.parse # ✅ URL parsing
|
|
353
|
+
import math # ✅ Math functions
|
|
354
|
+
import random # ✅ Random numbers
|
|
355
|
+
import statistics # ✅ Statistical functions
|
|
356
|
+
```
|
|
357
|
+
|
|
358
|
+
### Workarounds
|
|
359
|
+
|
|
360
|
+
**Need HTTP requests?**
|
|
361
|
+
- ✅ Use **HTTP Request node** before Code node
|
|
362
|
+
- ✅ Or switch to **JavaScript** and use `$helpers.httpRequest()`
|
|
363
|
+
|
|
364
|
+
**Need data analysis (pandas/numpy)?**
|
|
365
|
+
- ✅ Use Python **statistics** module for basic stats
|
|
366
|
+
- ✅ Or switch to **JavaScript** for most operations
|
|
367
|
+
- ✅ Manual calculations with lists and dictionaries
|
|
368
|
+
|
|
369
|
+
**Need web scraping (BeautifulSoup)?**
|
|
370
|
+
- ✅ Use **HTTP Request node** + **HTML Extract node**
|
|
371
|
+
- ✅ Or switch to **JavaScript** with regex/string methods
|
|
372
|
+
|
|
373
|
+
**See**: [STANDARD_LIBRARY.md](STANDARD_LIBRARY.md) for complete reference
|
|
374
|
+
|
|
375
|
+
---
|
|
376
|
+
|
|
377
|
+
## Common Patterns Overview
|
|
378
|
+
|
|
379
|
+
Based on production workflows, here are the most useful Python patterns:
|
|
380
|
+
|
|
381
|
+
### 1. Data Transformation
|
|
382
|
+
Transform all items with list comprehensions
|
|
383
|
+
|
|
384
|
+
```python
|
|
385
|
+
items = _input.all()
|
|
386
|
+
|
|
387
|
+
return [
|
|
388
|
+
{
|
|
389
|
+
"json": {
|
|
390
|
+
"id": item["json"].get("id"),
|
|
391
|
+
"name": item["json"].get("name", "Unknown").upper(),
|
|
392
|
+
"processed": True
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
for item in items
|
|
396
|
+
]
|
|
397
|
+
```
|
|
398
|
+
|
|
399
|
+
### 2. Filtering & Aggregation
|
|
400
|
+
Sum, filter, count with built-in functions
|
|
401
|
+
|
|
402
|
+
```python
|
|
403
|
+
items = _input.all()
|
|
404
|
+
total = sum(item["json"].get("amount", 0) for item in items)
|
|
405
|
+
valid_items = [item for item in items if item["json"].get("amount", 0) > 0]
|
|
406
|
+
|
|
407
|
+
return [{
|
|
408
|
+
"json": {
|
|
409
|
+
"total": total,
|
|
410
|
+
"count": len(valid_items)
|
|
411
|
+
}
|
|
412
|
+
}]
|
|
413
|
+
```
|
|
414
|
+
|
|
415
|
+
### 3. String Processing with Regex
|
|
416
|
+
Extract patterns from text
|
|
417
|
+
|
|
418
|
+
```python
|
|
419
|
+
import re
|
|
420
|
+
|
|
421
|
+
items = _input.all()
|
|
422
|
+
email_pattern = r'\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b'
|
|
423
|
+
|
|
424
|
+
all_emails = []
|
|
425
|
+
for item in items:
|
|
426
|
+
text = item["json"].get("text", "")
|
|
427
|
+
emails = re.findall(email_pattern, text)
|
|
428
|
+
all_emails.extend(emails)
|
|
429
|
+
|
|
430
|
+
# Remove duplicates
|
|
431
|
+
unique_emails = list(set(all_emails))
|
|
432
|
+
|
|
433
|
+
return [{
|
|
434
|
+
"json": {
|
|
435
|
+
"emails": unique_emails,
|
|
436
|
+
"count": len(unique_emails)
|
|
437
|
+
}
|
|
438
|
+
}]
|
|
439
|
+
```
|
|
440
|
+
|
|
441
|
+
### 4. Data Validation
|
|
442
|
+
Validate and clean data
|
|
443
|
+
|
|
444
|
+
```python
|
|
445
|
+
items = _input.all()
|
|
446
|
+
validated = []
|
|
447
|
+
|
|
448
|
+
for item in items:
|
|
449
|
+
data = item["json"]
|
|
450
|
+
errors = []
|
|
451
|
+
|
|
452
|
+
# Validate fields
|
|
453
|
+
if not data.get("email"):
|
|
454
|
+
errors.append("Email required")
|
|
455
|
+
if not data.get("name"):
|
|
456
|
+
errors.append("Name required")
|
|
457
|
+
|
|
458
|
+
validated.append({
|
|
459
|
+
"json": {
|
|
460
|
+
**data,
|
|
461
|
+
"valid": len(errors) == 0,
|
|
462
|
+
"errors": errors if errors else None
|
|
463
|
+
}
|
|
464
|
+
})
|
|
465
|
+
|
|
466
|
+
return validated
|
|
467
|
+
```
|
|
468
|
+
|
|
469
|
+
### 5. Statistical Analysis
|
|
470
|
+
Calculate statistics with statistics module
|
|
471
|
+
|
|
472
|
+
```python
|
|
473
|
+
from statistics import mean, median, stdev
|
|
474
|
+
|
|
475
|
+
items = _input.all()
|
|
476
|
+
values = [item["json"].get("value", 0) for item in items if "value" in item["json"]]
|
|
477
|
+
|
|
478
|
+
if values:
|
|
479
|
+
return [{
|
|
480
|
+
"json": {
|
|
481
|
+
"mean": mean(values),
|
|
482
|
+
"median": median(values),
|
|
483
|
+
"stdev": stdev(values) if len(values) > 1 else 0,
|
|
484
|
+
"min": min(values),
|
|
485
|
+
"max": max(values),
|
|
486
|
+
"count": len(values)
|
|
487
|
+
}
|
|
488
|
+
}]
|
|
489
|
+
else:
|
|
490
|
+
return [{"json": {"error": "No values found"}}]
|
|
491
|
+
```
|
|
492
|
+
|
|
493
|
+
**See**: [COMMON_PATTERNS.md](COMMON_PATTERNS.md) for 10 detailed Python patterns
|
|
494
|
+
|
|
495
|
+
---
|
|
496
|
+
|
|
497
|
+
## Error Prevention - Top 5 Mistakes
|
|
498
|
+
|
|
499
|
+
### #1: Importing External Libraries (Python-Specific!)
|
|
500
|
+
|
|
501
|
+
```python
|
|
502
|
+
# ❌ WRONG: Trying to import external library
|
|
503
|
+
import requests # ModuleNotFoundError!
|
|
504
|
+
|
|
505
|
+
# ✅ CORRECT: Use HTTP Request node or JavaScript
|
|
506
|
+
# Add HTTP Request node before Code node
|
|
507
|
+
# OR switch to JavaScript and use $helpers.httpRequest()
|
|
508
|
+
```
|
|
509
|
+
|
|
510
|
+
### #2: Empty Code or Missing Return
|
|
511
|
+
|
|
512
|
+
```python
|
|
513
|
+
# ❌ WRONG: No return statement
|
|
514
|
+
items = _input.all()
|
|
515
|
+
# Processing...
|
|
516
|
+
# Forgot to return!
|
|
517
|
+
|
|
518
|
+
# ✅ CORRECT: Always return data
|
|
519
|
+
items = _input.all()
|
|
520
|
+
# Processing...
|
|
521
|
+
return [{"json": item["json"]} for item in items]
|
|
522
|
+
```
|
|
523
|
+
|
|
524
|
+
### #3: Incorrect Return Format
|
|
525
|
+
|
|
526
|
+
```python
|
|
527
|
+
# ❌ WRONG: Returning dict instead of list
|
|
528
|
+
return {"json": {"result": "success"}}
|
|
529
|
+
|
|
530
|
+
# ✅ CORRECT: List wrapper required
|
|
531
|
+
return [{"json": {"result": "success"}}]
|
|
532
|
+
```
|
|
533
|
+
|
|
534
|
+
### #4: KeyError on Dictionary Access
|
|
535
|
+
|
|
536
|
+
```python
|
|
537
|
+
# ❌ WRONG: Direct access crashes if missing
|
|
538
|
+
name = _json["user"]["name"] # KeyError!
|
|
539
|
+
|
|
540
|
+
# ✅ CORRECT: Use .get() for safe access
|
|
541
|
+
name = _json.get("user", {}).get("name", "Unknown")
|
|
542
|
+
```
|
|
543
|
+
|
|
544
|
+
### #5: Webhook Body Nesting
|
|
545
|
+
|
|
546
|
+
```python
|
|
547
|
+
# ❌ WRONG: Direct access to webhook data
|
|
548
|
+
email = _json["email"] # KeyError!
|
|
549
|
+
|
|
550
|
+
# ✅ CORRECT: Webhook data under ["body"]
|
|
551
|
+
email = _json["body"]["email"]
|
|
552
|
+
|
|
553
|
+
# ✅ BETTER: Safe access with .get()
|
|
554
|
+
email = _json.get("body", {}).get("email", "no-email")
|
|
555
|
+
```
|
|
556
|
+
|
|
557
|
+
**See**: [ERROR_PATTERNS.md](ERROR_PATTERNS.md) for comprehensive error guide
|
|
558
|
+
|
|
559
|
+
---
|
|
560
|
+
|
|
561
|
+
## Standard Library Reference
|
|
562
|
+
|
|
563
|
+
### Most Useful Modules
|
|
564
|
+
|
|
565
|
+
```python
|
|
566
|
+
# JSON operations
|
|
567
|
+
import json
|
|
568
|
+
data = json.loads(json_string)
|
|
569
|
+
json_output = json.dumps({"key": "value"})
|
|
570
|
+
|
|
571
|
+
# Date/time
|
|
572
|
+
from datetime import datetime, timedelta
|
|
573
|
+
now = datetime.now()
|
|
574
|
+
tomorrow = now + timedelta(days=1)
|
|
575
|
+
formatted = now.strftime("%Y-%m-%d")
|
|
576
|
+
|
|
577
|
+
# Regular expressions
|
|
578
|
+
import re
|
|
579
|
+
matches = re.findall(r'\d+', text)
|
|
580
|
+
cleaned = re.sub(r'[^\w\s]', '', text)
|
|
581
|
+
|
|
582
|
+
# Base64 encoding
|
|
583
|
+
import base64
|
|
584
|
+
encoded = base64.b64encode(data).decode()
|
|
585
|
+
decoded = base64.b64decode(encoded)
|
|
586
|
+
|
|
587
|
+
# Hashing
|
|
588
|
+
import hashlib
|
|
589
|
+
hash_value = hashlib.sha256(text.encode()).hexdigest()
|
|
590
|
+
|
|
591
|
+
# URL parsing
|
|
592
|
+
import urllib.parse
|
|
593
|
+
params = urllib.parse.urlencode({"key": "value"})
|
|
594
|
+
parsed = urllib.parse.urlparse(url)
|
|
595
|
+
|
|
596
|
+
# Statistics
|
|
597
|
+
from statistics import mean, median, stdev
|
|
598
|
+
average = mean([1, 2, 3, 4, 5])
|
|
599
|
+
```
|
|
600
|
+
|
|
601
|
+
**See**: [STANDARD_LIBRARY.md](STANDARD_LIBRARY.md) for complete reference
|
|
602
|
+
|
|
603
|
+
---
|
|
604
|
+
|
|
605
|
+
## Best Practices
|
|
606
|
+
|
|
607
|
+
### 1. Always Use .get() for Dictionary Access
|
|
608
|
+
|
|
609
|
+
```python
|
|
610
|
+
# ✅ SAFE: Won't crash if field missing
|
|
611
|
+
value = item["json"].get("field", "default")
|
|
612
|
+
|
|
613
|
+
# ❌ RISKY: Crashes if field doesn't exist
|
|
614
|
+
value = item["json"]["field"]
|
|
615
|
+
```
|
|
616
|
+
|
|
617
|
+
### 2. Handle None/Null Values Explicitly
|
|
618
|
+
|
|
619
|
+
```python
|
|
620
|
+
# ✅ GOOD: Default to 0 if None
|
|
621
|
+
amount = item["json"].get("amount") or 0
|
|
622
|
+
|
|
623
|
+
# ✅ GOOD: Check for None explicitly
|
|
624
|
+
text = item["json"].get("text")
|
|
625
|
+
if text is None:
|
|
626
|
+
text = ""
|
|
627
|
+
```
|
|
628
|
+
|
|
629
|
+
### 3. Use List Comprehensions for Filtering
|
|
630
|
+
|
|
631
|
+
```python
|
|
632
|
+
# ✅ PYTHONIC: List comprehension
|
|
633
|
+
valid = [item for item in items if item["json"].get("active")]
|
|
634
|
+
|
|
635
|
+
# ❌ VERBOSE: Manual loop
|
|
636
|
+
valid = []
|
|
637
|
+
for item in items:
|
|
638
|
+
if item["json"].get("active"):
|
|
639
|
+
valid.append(item)
|
|
640
|
+
```
|
|
641
|
+
|
|
642
|
+
### 4. Return Consistent Structure
|
|
643
|
+
|
|
644
|
+
```python
|
|
645
|
+
# ✅ CONSISTENT: Always list with "json" key
|
|
646
|
+
return [{"json": result}] # Single result
|
|
647
|
+
return results # Multiple results (already formatted)
|
|
648
|
+
return [] # No results
|
|
649
|
+
```
|
|
650
|
+
|
|
651
|
+
### 5. Debug with print() Statements
|
|
652
|
+
|
|
653
|
+
```python
|
|
654
|
+
# Debug statements appear in browser console (F12)
|
|
655
|
+
items = _input.all()
|
|
656
|
+
print(f"Processing {len(items)} items")
|
|
657
|
+
print(f"First item: {items[0] if items else 'None'}")
|
|
658
|
+
```
|
|
659
|
+
|
|
660
|
+
---
|
|
661
|
+
|
|
662
|
+
## When to Use Python vs JavaScript
|
|
663
|
+
|
|
664
|
+
### Use Python When:
|
|
665
|
+
- ✅ You need `statistics` module for statistical operations
|
|
666
|
+
- ✅ You're significantly more comfortable with Python syntax
|
|
667
|
+
- ✅ Your logic maps well to list comprehensions
|
|
668
|
+
- ✅ You need specific standard library functions
|
|
669
|
+
|
|
670
|
+
### Use JavaScript When:
|
|
671
|
+
- ✅ You need HTTP requests ($helpers.httpRequest())
|
|
672
|
+
- ✅ You need advanced date/time (DateTime/Luxon)
|
|
673
|
+
- ✅ You want better n8n integration
|
|
674
|
+
- ✅ **For 95% of use cases** (recommended)
|
|
675
|
+
|
|
676
|
+
### Consider Other Nodes When:
|
|
677
|
+
- ❌ Simple field mapping → Use **Set** node
|
|
678
|
+
- ❌ Basic filtering → Use **Filter** node
|
|
679
|
+
- ❌ Simple conditionals → Use **IF** or **Switch** node
|
|
680
|
+
- ❌ HTTP requests only → Use **HTTP Request** node
|
|
681
|
+
|
|
682
|
+
---
|
|
683
|
+
|
|
684
|
+
## Integration with Other Skills
|
|
685
|
+
|
|
686
|
+
### Works With:
|
|
687
|
+
|
|
688
|
+
**n8n Expression Syntax**:
|
|
689
|
+
- Expressions use `{{ }}` syntax in other nodes
|
|
690
|
+
- Code nodes use Python directly (no `{{ }}`)
|
|
691
|
+
- When to use expressions vs code
|
|
692
|
+
|
|
693
|
+
**n8n MCP Tools Expert**:
|
|
694
|
+
- How to find Code node: `search_nodes({query: "code"})`
|
|
695
|
+
- Get configuration help: `get_node_essentials("nodes-base.code")`
|
|
696
|
+
- Validate code: `validate_node_operation()`
|
|
697
|
+
|
|
698
|
+
**n8n Node Configuration**:
|
|
699
|
+
- Mode selection (All Items vs Each Item)
|
|
700
|
+
- Language selection (Python vs JavaScript)
|
|
701
|
+
- Understanding property dependencies
|
|
702
|
+
|
|
703
|
+
**n8n Workflow Patterns**:
|
|
704
|
+
- Code nodes in transformation step
|
|
705
|
+
- When to use Python vs JavaScript in patterns
|
|
706
|
+
|
|
707
|
+
**n8n Validation Expert**:
|
|
708
|
+
- Validate Code node configuration
|
|
709
|
+
- Handle validation errors
|
|
710
|
+
- Auto-fix common issues
|
|
711
|
+
|
|
712
|
+
**n8n Code JavaScript**:
|
|
713
|
+
- When to use JavaScript instead
|
|
714
|
+
- Comparison of JavaScript vs Python features
|
|
715
|
+
- Migration from Python to JavaScript
|
|
716
|
+
|
|
717
|
+
---
|
|
718
|
+
|
|
719
|
+
## Quick Reference Checklist
|
|
720
|
+
|
|
721
|
+
Before deploying Python Code nodes, verify:
|
|
722
|
+
|
|
723
|
+
- [ ] **Considered JavaScript first** - Using Python only when necessary
|
|
724
|
+
- [ ] **Code is not empty** - Must have meaningful logic
|
|
725
|
+
- [ ] **Return statement exists** - Must return list of dictionaries
|
|
726
|
+
- [ ] **Proper return format** - Each item: `{"json": {...}}`
|
|
727
|
+
- [ ] **Data access correct** - Using `_input.all()`, `_input.first()`, or `_input.item`
|
|
728
|
+
- [ ] **No external imports** - Only standard library (json, datetime, re, etc.)
|
|
729
|
+
- [ ] **Safe dictionary access** - Using `.get()` to avoid KeyError
|
|
730
|
+
- [ ] **Webhook data** - Access via `["body"]` if from webhook
|
|
731
|
+
- [ ] **Mode selection** - "All Items" for most cases
|
|
732
|
+
- [ ] **Output consistent** - All code paths return same structure
|
|
733
|
+
|
|
734
|
+
---
|
|
735
|
+
|
|
736
|
+
## Additional Resources
|
|
737
|
+
|
|
738
|
+
### Related Files
|
|
739
|
+
- [DATA_ACCESS.md](DATA_ACCESS.md) - Comprehensive Python data access patterns
|
|
740
|
+
- [COMMON_PATTERNS.md](COMMON_PATTERNS.md) - 10 Python patterns for n8n
|
|
741
|
+
- [ERROR_PATTERNS.md](ERROR_PATTERNS.md) - Top 5 errors and solutions
|
|
742
|
+
- [STANDARD_LIBRARY.md](STANDARD_LIBRARY.md) - Complete standard library reference
|
|
743
|
+
|
|
744
|
+
### n8n Documentation
|
|
745
|
+
- Code Node Guide: https://docs.n8n.io/code/code-node/
|
|
746
|
+
- Python in n8n: https://docs.n8n.io/code/builtin/python-modules/
|
|
747
|
+
|
|
748
|
+
---
|
|
749
|
+
|
|
750
|
+
**Ready to write Python in n8n Code nodes - but consider JavaScript first!** Use Python for specific needs, reference the error patterns guide to avoid common mistakes, and leverage the standard library effectively.
|