// Pulumi Neo AI-powered infrastructure automation agent. Use when working with Pulumi Neo for conversational infrastructure management, creating Neo tasks, monitoring task progress, infrastructure analysis, maintenance operations, or automating multi-step cloud workflows through natural language.
| name | pulumi-neo |
| description | Pulumi Neo AI-powered infrastructure automation agent. Use when working with Pulumi Neo for conversational infrastructure management, creating Neo tasks, monitoring task progress, infrastructure analysis, maintenance operations, or automating multi-step cloud workflows through natural language. |
Pulumi Neo is an AI agent for platform engineers that enables conversational infrastructure management through natural language.
# Get current Pulumi organization from CLI
pulumi org get-default
# If no default org or using self-managed backend, ask user for organization name
If pulumi org get-default returns an error or shows a non-cloud backend, prompt the user for their Pulumi Cloud organization name.
RECOMMENDED: Use MCP tools directly - they work natively with Claude Code:
mcp__pulumi__neo-bridge # Create and interact with Neo tasks
mcp__pulumi__neo-get-tasks # List existing tasks
mcp__pulumi__neo-continue-task # Continue polling a task
If using the Python script, ALWAYS add --no-poll:
# REQUIRED: --no-poll prevents blocking (script will hang without it)
python scripts/neo_task.py --org <org> --message "Your message" --no-poll
# Check events separately
python scripts/neo_task.py --org <org> --task-id <task-id> --get-events
WARNING: Never run the script without --no-poll in Claude Code - the polling loop will block indefinitely.
The script handles Neo task creation, polling, and management:
# Create a task and poll for updates (interactive/terminal use)
python scripts/neo_task.py --org <org-name> --message "Help me optimize my Pulumi stack"
# Create task without polling (CI/CD or programmatic use)
python scripts/neo_task.py --org <org-name> --message "Analyze this" --no-poll
# Create task with stack context
python scripts/neo_task.py --org <org-name> \
--message "Analyze this stack" \
--stack-name prod --stack-project my-infra --no-poll
# Create task with repository context
python scripts/neo_task.py --org <org-name> \
--message "Review this infrastructure code" \
--repo-name my-repo --repo-org my-github-org --no-poll
# List existing tasks
python scripts/neo_task.py --org <org-name> --list
# Fetch current events (single request, no polling)
python scripts/neo_task.py --org <org-name> --task-id <task-id> --get-events
# Poll an existing task for updates (interactive)
python scripts/neo_task.py --org <org-name> --task-id <task-id>
# Send approval for a pending request
python scripts/neo_task.py --org <org-name> --task-id <task-id> --approve
# Cancel a pending request
python scripts/neo_task.py --org <org-name> --task-id <task-id> --cancel
Tasks are created with a natural language message describing what you want Neo to do:
Provide context to Neo by attaching entities:
| Entity Type | Use Case |
|---|---|
stack | Reference a Pulumi stack (name + project) |
repository | Reference a code repository (name + org + forge) |
pull_request | Reference a PR (number + merged status + repository) |
policy_issue | Reference a governance policy issue (id) |
| Status | Description |
|---|---|
pending | Task is queued |
running | Neo is processing the task |
waiting_for_approval | Neo needs user confirmation to proceed |
completed | Task finished successfully |
failed | Task encountered an error |
When Neo requires confirmation for an operation:
waiting_for_approvalapproval_request_idpython scripts/neo_task.py --org myorg \
--message "What security improvements can I make to my AWS infrastructure?" \
--stack-name prod --stack-project aws-infra
python scripts/neo_task.py --org myorg \
--message "Help me fix the policy violations in my production stack"
python scripts/neo_task.py --org myorg \
--message "Create a new Pulumi TypeScript project for a containerized web app on AWS ECS"
python scripts/neo_task.py --org myorg \
--message "Review the infrastructure changes in this PR" \
--repo-name infra --repo-org myorg --repo-forge github
# Verify token is set
echo $PULUMI_ACCESS_TOKEN
# Test authentication
curl -H "Authorization: token $PULUMI_ACCESS_TOKEN" \
https://api.pulumi.com/api/user
pulumi org get-default