From agent-alchemy-claude-tools
Reference for Claude Code Agent Teams: TeamCreate/TeamDelete tools, lifecycle, spawning teammates, orchestration, messaging, and hooks. For multi-agent coding workflows.
npx claudepluginhub sequenzia/agent-alchemy --plugin agent-alchemy-claude-toolsThis skill uses the workspace's default tool permissions.
A shared reference for Claude Code's Agent Teams features. Load this skill when building skills or agents that create teams, spawn teammates, coordinate multi-agent workflows, or integrate with team hooks.
Coordinates multiple Claude Code instances as agent teams for workflows needing inter-agent communication. Covers TeamCreate, SendMessage types, task coordination, hooks, and orchestration patterns.
Orchestrates Claude Code agent teams: spawn teammates, assign tasks with dependencies, manage communication via messages or broadcasts, configure modes, and set quality gate hooks.
Orchestrates Claude Code agent teams for parallel multi-agent workflows on complex tasks using TeamCreate, SendMessage, TaskUpdate, and shared task lists. Enable with --enable-teams flag.
Share bugs, ideas, or general feedback.
A shared reference for Claude Code's Agent Teams features. Load this skill when building skills or agents that create teams, spawn teammates, coordinate multi-agent workflows, or integrate with team hooks.
This skill covers team lifecycle, tool parameters, spawning mechanics, and file structure. For deeper topics, load the reference files listed in Loading Reference Files.
Cross-reference: For Claude Code Tasks (TaskCreate, TaskGet, TaskUpdate, TaskList), see the companion skill:
Read ${CLAUDE_PLUGIN_ROOT}/skills/claude-code-tasks/SKILL.md
Creates a new named team and registers the caller as team lead.
| Parameter | Type | Required | Description |
|---|---|---|---|
team_name | string | Yes | Unique team identifier. Used in file paths, environment variables, and member discovery. Use kebab-case (e.g., analysis-team). |
description | string | No | Human-readable description of the team's purpose. Shown in team config and used by teammates to understand their team's mission. |
agent_type | string | No | The type of agent running as team lead. Informational; stored in config.json for member discovery. |
Return behavior: Returns a confirmation with the team name. The team is immediately ready for member spawning after creation. Teams have a 1:1 correspondence with task lists — creating a team also creates a task list at ~/.claude/tasks/{team-name}/. A config.json file is created at ~/.claude/teams/{team-name}/config.json with team metadata including lead identity, description, and a members array where each member has name, agentId, and agentType.
Constraints:
Deletes a team and cleans up its resources. Takes no parameters — the team name is determined from the current session's team context.
Prerequisites: All team members must be shut down before deletion. Attempting to delete a team with active members will fail.
Cleanup behavior: Removes the team directory (~/.claude/teams/{team-name}/) and the task directory (~/.claude/tasks/{team-name}/), clears inbox directories, and deregisters the team.
The full lifecycle of an agent team follows seven steps:
Create Team --> Create Tasks --> Spawn Teammates --> Assign Tasks --> Work --> Shutdown --> Cleanup
stateDiagram-v2
[*] --> Created: TeamCreate
Created --> TasksReady: TaskCreate
TasksReady --> Spawning: Agent tool (team_name, name)
Spawning --> Assigning: TaskUpdate (owner)
Spawning --> Spawning: Spawn more members
Assigning --> Working: Teammates active
Working --> Assigning: More tasks to assign
Working --> ShuttingDown: All work complete
ShuttingDown --> Cleanup: All members stopped
Cleanup --> [*]: TeamDelete
classDef active fill:#e8f5e9,color:#000
classDef transition fill:#fff3e0,color:#000
class Created,TasksReady,Cleanup transition
class Spawning,Assigning,Working,ShuttingDown active
1. Create team: Team lead calls TeamCreate with a name. The team config file is written, a task list is created, and the lead is registered.
2. Create tasks: Team lead uses TaskCreate to add tasks. Tasks auto-use the team's task list at ~/.claude/tasks/{team-name}/.
3. Spawn teammates: Team lead uses the Agent tool with team_name and name parameters to spawn teammates. Each teammate runs as an isolated Claude Code session. Members can be spawned incrementally as work demands change.
4. Assign tasks: Team lead uses TaskUpdate with owner to assign tasks to specific teammates.
5. Teammates work: Members complete assigned tasks, communicate via SendMessage, and report results. The team lead monitors progress, assigns new work, and handles issues. Members go idle between turns — this is normal, not an error.
6. Shutdown: When all work is complete, the team lead sends shutdown_request messages to each member. Members acknowledge with shutdown_response and terminate. The lead waits for all members to confirm shutdown.
7. Cleanup: After all members have stopped, the team lead calls TeamDelete to remove the team and task directories.
Teammates are spawned using the Agent tool with the team_name parameter. Each teammate runs as a separate Claude Code session.
Plugin tool name: In Claude Code plugin frontmatter (
allowed-toolsin skills,toolsin agents), the Agent tool is listed asTask. Both names refer to the same spawning capability with identical parameters (prompt,team_name,name,description,subagent_type,run_in_background). UseTaskin frontmatter definitions andAgentorTaskin skill/agent body instructions.
| Parameter | Type | Required | Description |
|---|---|---|---|
prompt | string | Yes | The task/prompt for the teammate. This is the initial instruction the teammate receives. |
team_name | string | Yes | Associates the spawned agent with this team. Must match an existing team name. |
name | string | Yes | Human-readable name for the teammate (e.g., "researcher-1"). Appears in team config and messages. |
description | string | Yes | Short (3-5 word) description of the agent's task. |
subagent_type | string | No | Model tier for the teammate: "default" (Opus), "fast" (Sonnet). Choose based on task complexity. |
run_in_background | boolean | No | If true, the spawning agent does not block waiting for the teammate to finish. Essential for parallel teammate workflows. Default: false. |
| Type | Model Tier | Best For |
|---|---|---|
"default" | Opus | Complex reasoning, synthesis, architecture decisions, autonomous multi-step work |
"fast" | Sonnet | Parallel exploration, data gathering, straightforward implementation, high-volume tasks |
Each teammate runs in its own Claude Code session with:
SendMessage (file-based inbox delivery)For parallel teammates, spawn all with run_in_background: true:
Task(prompt="Analyze module A", team_name="analysis-team", name="analyzer-1",
description="Analyze module A", run_in_background=true)
Task(prompt="Analyze module B", team_name="analysis-team", name="analyzer-2",
description="Analyze module B", run_in_background=true)
Task(prompt="Analyze module C", team_name="analysis-team", name="analyzer-3",
description="Analyze module C", run_in_background=true)
Note: In skill/agent instructions, this tool may be referenced as either Task or Agent. Both are equivalent.
The team lead continues running and can coordinate via messages while teammates work.
Understanding idle state is critical for correct team coordination.
Idle is normal, not an error. When a teammate finishes its current task and has no pending messages, it enters an idle state. This is expected behavior between work assignments.
Key rules:
SendMessage when readyshutdown_request when the teammate's role is fully completeAnti-pattern: Immediately shutting down teammates when they go idle. This wastes the spawning cost and prevents reuse for follow-up tasks.
Claude Code automatically sets these environment variables in every teammate session:
| Variable | Description | Example Value |
|---|---|---|
CLAUDE_CODE_TEAM_NAME | Name of the team this agent belongs to | analysis-team |
CLAUDE_CODE_AGENT_NAME | This agent's name within the team | researcher-1 |
CLAUDE_CODE_AGENT_TYPE | Role of this agent (lead or member) | member |
CLAUDE_CODE_TASK_LIST_ID | The task list ID associated with this team | abc123 |
These variables allow teammates to:
Claude Code supports multiple backends for running teammate sessions.
| Backend | Environment | Characteristics |
|---|---|---|
| in-process | Default | Runs within the same process group. Simplest setup. No external dependencies. Suitable for most workflows. |
| tmux | Terminal | Each teammate runs in a separate tmux pane. Requires tmux installed. Provides visual monitoring of teammate sessions. Good for debugging and development. |
| iTerm2 | macOS | Each teammate runs in a separate iTerm2 tab. macOS only. Provides native tab-based visual monitoring. Requires iTerm2 application. |
tmux to be installed.The backend is configured at the Claude Code application level, not per-team or per-spawn call.
Agent Teams use a file-based coordination system rooted in the user's home directory.
~/.claude/
├── teams/
│ └── {team-name}/
│ └── config.json # Team metadata, member roster, lead identity
├── tasks/
│ └── {team-name}/
│ ├── {task-id}.json # Individual task files for team members
│ └── ...
└── inboxes/
└── {team-name}/
├── {agent-name}/ # Per-agent inbox directory
│ ├── msg-001.json # Delivered message files
│ └── ...
└── ...
The team configuration file at ~/.claude/teams/{team-name}/config.json contains:
Other teammates discover team membership by reading this file.
Messages sent via SendMessage are written as JSON files to the recipient's inbox directory. Claude Code monitors these directories and delivers messages automatically — teammates do not poll for messages.
Each teammate's assigned work is tracked as task files under ~/.claude/tasks/{team-name}/. These follow the standard Claude Code Tasks format (same as non-team tasks). The task directory is removed when TeamDelete is called.
SendMessage is the communication tool for inter-agent messaging within a team. It supports five message types, each with different routing and semantics.
| Type | Routing | Purpose |
|---|---|---|
message | Direct (one recipient) | Send a targeted message to a specific teammate by name |
broadcast | All members | Send to every team member simultaneously. Costs N messages for N members. |
shutdown_request | Direct (one recipient) | Request a teammate to shut down gracefully. Includes a request_id. |
shutdown_response | Direct (requester) | Teammate acknowledges shutdown. Includes matching request_id. |
plan_approval_response | Direct (requester) | Approve or reject a teammate's proposed plan with optional feedback. |
Message delivery is automatic — Claude Code writes message files to recipient inboxes and notifies them. No polling required.
Key rules:
TaskUpdate insteadmessage over broadcast in almost all casesPeer DM visibility: Team leads can see direct messages between team members for oversight and coordination purposes.
For complete field tables, usage guidance, and examples for each message type, load the messaging protocol reference:
Read ${CLAUDE_PLUGIN_ROOT}/skills/claude-code-teams/references/messaging-protocol.md
This skill provides an overview of Agent Teams. For detailed coverage of specific topics, load these reference files as needed:
Complete documentation of all 5 SendMessage types with field tables, delivery mechanics, and usage patterns.
Read ${CLAUDE_PLUGIN_ROOT}/skills/claude-code-teams/references/messaging-protocol.md
Proven multi-agent workflow patterns including Parallel Specialists, Pipeline, Swarm, Research-then-Implement, and Plan Approval Gate. Each pattern includes structure, task design, and communication flow.
Read ${CLAUDE_PLUGIN_ROOT}/skills/claude-code-teams/references/orchestration-patterns.md
TeammateIdle and TaskCompleted hook events for quality gates and automation. Includes hook schemas, exit code behavior, and practical examples.
Read ${CLAUDE_PLUGIN_ROOT}/skills/claude-code-teams/references/hooks-integration.md