Install
openclaw skills install clawteam-skillMulti-agent swarm coordination via the ClawTeam CLI. Use when the user wants to create agent teams, spawn multiple agents to work in parallel, coordinate tasks with dependencies, broadcast messages between agents, monitor progress via kanban board, or launch pre-built team templates (hedge-fund, code-review, research-paper). ClawTeam uses git worktree isolation + tmux + filesystem-based messaging. Trigger phrases: team, swarm, multi-agent, clawteam, spawn agents, parallel agents, agent team.
openclaw skills install clawteam-skillClawTeam is a CLI tool (clawteam) for orchestrating multiple AI agents as self-organizing swarms. It uses git worktree isolation, tmux windows, and filesystem-based messaging. OpenClaw is the default agent backend.
Source: https://github.com/win4r/ClawTeam-OpenClaw
This skill is based on the upstream ClawTeam project and includes additional safety/approval optimizations for real-world operations:
Approve/Reject buttons.approve / reject).These changes are intentional enhancements, not a verbatim copy.
CLI binary: clawteam (must be preinstalled and available in PATH)
This skill is instruction-only. It does not install clawteam automatically.
Install from a trusted source and pin a version/tag when possible.
# Example only: verify upstream release/tag before install
pipx install "git+https://github.com/win4r/ClawTeam-OpenClaw.git@<trusted-tag>"
# Verify binary and version
which clawteam
clawteam --version
Recommended preflight before first real run:
# Use a disposable repo/worktree first
clawteam config health
clawteam team spawn-team dry-run -d "safety check" -n leader
clawteam team cleanup dry-run --force
# Launch a pre-built team from a template
clawteam launch hedge-fund --team fund1
clawteam launch code-review --team review1
clawteam launch research-paper --team paper1
# 1. Create team with leader
clawteam team spawn-team my-team -d "Build a web app" -n leader
# 2. Create tasks with dependencies
clawteam task create my-team "Design API schema" -o architect
# Returns task ID, e.g., abc123
clawteam task create my-team "Implement auth" -o backend --blocked-by abc123
clawteam task create my-team "Build frontend" -o frontend --blocked-by abc123
clawteam task create my-team "Write tests" -o tester
# 3. Spawn agents (each gets its own tmux window + git worktree)
clawteam spawn -t my-team -n architect --task "Design the API schema for a web app"
clawteam spawn -t my-team -n backend --task "Implement OAuth2 authentication"
clawteam spawn -t my-team -n frontend --task "Build React dashboard"
# 4. Monitor
clawteam board show my-team # Kanban view
clawteam board attach my-team # Tmux tiled view (all agents side-by-side)
clawteam board serve --port 8080 # Web dashboard
| Command | Description |
|---|---|
clawteam team spawn-team <name> -d "<desc>" -n <leader> | Create team |
clawteam team discover | List all teams |
clawteam team status <team> | Show team members and info |
clawteam team cleanup <team> --force | Delete team and all data |
| Command | Description |
|---|---|
clawteam task create <team> "<subject>" -o <owner> [-d "<desc>"] [--blocked-by <id>] | Create task |
clawteam task list <team> [--owner <name>] | List tasks (filterable) |
clawteam task update <team> <id> --status <status> | Update status |
clawteam task get <team> <id> | Get single task |
clawteam task stats <team> | Timing statistics |
clawteam task wait <team> | Block until all tasks complete |
Task statuses: pending, in_progress, completed, blocked
Dependency auto-resolution: When a blocking task completes, dependent tasks automatically change from blocked to pending.
Task locking: When a task moves to in_progress, it is locked by the calling agent. Other agents cannot claim it unless they use --force. Stale locks from dead agents are automatically released.
Use the default command (openclaw) unless the user explicitly requests another backend. Keep normal permission and trust prompts enabled.
# Default (RECOMMENDED): spawns openclaw tui in tmux with prompt
clawteam spawn -t <team> -n <name> --task "<task description>"
# Explicit backend (still uses openclaw by default)
clawteam spawn tmux -t <team> -n <name> --task "<task>"
clawteam spawn subprocess -t <team> -n <name> --task "<task>"
# With git worktree isolation
clawteam spawn -t <team> -n <name> --task "<task>" --workspace --repo /path/to/repo
High-impact note: spawn subprocess and custom backend modes can execute arbitrary code through delegated commands. Use only in trusted repositories/environments.
Each spawned agent gets:
board attach)clawteam/{team}/{agent})CLAWTEAM_AGENT_NAME, CLAWTEAM_TEAM_NAME, etc.Spawn safety features:
| Command | Description |
|---|---|
clawteam inbox send <team> <to> "<msg>" --from <sender> | Point-to-point message |
clawteam inbox broadcast <team> "<msg>" --from <sender> | Broadcast to all |
clawteam inbox peek <team> -a <agent> | Peek without consuming |
clawteam inbox receive <team> | Consume messages |
clawteam inbox log <team> | View message history |
| Command | Description |
|---|---|
clawteam board show <team> | Kanban board (rich terminal) |
clawteam board overview | All teams overview |
clawteam board live <team> | Live-refreshing board |
clawteam board attach <team> | Tmux tiled view |
clawteam board serve --port 8080 | Web dashboard |
| Command | Description |
|---|---|
clawteam cost report <team> --input-tokens <N> --output-tokens <N> --cost-cents <N> | Report usage |
clawteam cost show <team> | Show summary |
clawteam cost budget <team> <dollars> | Set budget |
| Command | Description |
|---|---|
clawteam template list | List available templates |
clawteam template show <name> | Show template details |
clawteam launch <template> [--team-name <name>] [--goal "<goal>"] | Launch from template |
Built-in templates: hedge-fund, code-review, research-paper
clawteam config show # Show all settings
clawteam config set transport file # Set transport backend
clawteam config health # System health check
Do not enable permission-skipping settings in shared or production environments. Keep permission prompts enabled for auditability.
This skill itself does not directly read or manage Feishu/Telegram tokens. Channel credentials are managed by the OpenClaw channel plugins/runtime.
| Command | Description |
|---|---|
clawteam lifecycle idle <team> --agent <name> | Report agent idle |
clawteam session save <team> --session-id <id> | Save session for resume |
clawteam plan submit <team> "<plan>" --from <agent> | Submit plan for approval (team-scoped storage) |
clawteam workspace list <team> | List git worktrees |
clawteam workspace merge <team> --agent <name> | Merge agent branch |
Add --json before any subcommand for machine-readable output:
clawteam --json task list my-team
clawteam --json team status my-team
clawteam team spawn-team webapp -d "Build web app" -n leaderclawteam task create with --blocked-by for dependenciesclawteam spawn for each workerclawteam inbox broadcast for team-wide updatesclawteam cost show, clawteam task stats, merge worktrees, then clawteam team cleanup webapp --forceWhen YOU are the leader agent, follow this pattern to safely manage a swarm with user oversight:
1. Understand the user's goal
2. Break it into independent subtasks
3. Identify dependencies between tasks (what must finish before what)
4. Decide how many worker agents are needed
# Create team
clawteam team spawn-team <team> -d "<goal description>" -n leader
# Create tasks with dependency chains
clawteam task create <team> "Design API" -o architect
# Save the returned task ID (e.g., abc123)
clawteam task create <team> "Build backend" -o backend --blocked-by abc123
clawteam task create <team> "Build frontend" -o frontend --blocked-by abc123
clawteam task create <team> "Integration tests" -o tester --blocked-by <backend-id>,<frontend-id>
# Each spawn launches an openclaw tui in its own tmux window
clawteam spawn -t <team> -n architect --task "Design REST API schema for <goal>"
clawteam spawn -t <team> -n backend --task "Implement backend based on API schema"
clawteam spawn -t <team> -n frontend --task "Build React frontend"
clawteam spawn -t <team> -n tester --task "Write and run integration tests"
Use a bounded monitor loop (for example, max 40 iterations with 30s interval = 20 minutes), then stop and report status.
# Poll task status every 30-60 seconds with an upper bound
max_rounds=40
for ((round=1; round<=max_rounds; round++)); do
clawteam --json task list <team> | python3 -c "
import sys, json
tasks = json.load(sys.stdin)
done = sum(1 for t in tasks if t['status'] == 'completed')
total = len(tasks)
print(f'{done}/{total} complete')
if done == total: print('ALL DONE'); sys.exit(0)
"
# Check for messages from workers
clawteam inbox receive <team>
# Send a mid-progress update when roughly half the tasks are done
sleep 30
done
# Timeout branch: ask user whether to continue monitoring
echo "Monitor timeout reached; request user confirmation to continue."
Before merge/cleanup, ask for user confirmation. Include the final output, a summary, and cost/timing stats.
# After all tasks complete — do ALL of these steps:
clawteam board show <team> # Final status
clawteam cost show <team> # Total cost — include in report to user
clawteam task stats <team> # Timing stats — include in report to user
# Ask user for confirmation before merge and cleanup
# Merge each worker's branch back to main (after confirmation)
for agent in <agent1> <agent2> ...; do
clawteam workspace merge <team> --agent $agent
done
clawteam team cleanup <team> --force # Clean up after confirmation
# Then: send the final deliverables to the user
--blocked-by to chain them; ClawTeam auto-unblocksinbox sendin_progress too long, send a nudge via inbox sendspawn subprocess, workspace merge, team cleanup --force, board serve.Render approval UI based on the current message source (channel-aware behavior):
feishu source: always use Feishu interactive card (schema: "2.0") with approval_decision button callback.telegram source: use inline keyboard buttons (Approve / Reject) with callback payload carrying approval_id and decision.approve or reject.approval_id (unique, one-time)action (what will be executed)risk_level (low/medium/high)scope (files/commands/resources affected)deadline (approval timeout)Feishu template (same-row buttons, recommended):
{
"schema": "2.0",
"config": { "wide_screen_mode": true },
"header": {
"title": { "tag": "plain_text", "content": "Remote Approval" },
"template": "orange"
},
"body": {
"elements": [
{
"tag": "markdown",
"content": "**approval_id**: `<id>`\n**action**: <action>\n**risk_level**: <level>\n**scope**: <scope>\n**deadline**: <time>"
},
{ "tag": "hr" },
{
"tag": "column_set",
"flex_mode": "none",
"horizontal_align": "left",
"columns": [
{
"tag": "column",
"width": "auto",
"elements": [
{
"tag": "button",
"text": { "tag": "plain_text", "content": "Approve" },
"type": "primary",
"value": { "action": "approval_decision", "approval_id": "<id>", "decision": "approve" }
}
]
},
{
"tag": "column",
"width": "auto",
"elements": [
{
"tag": "button",
"text": { "tag": "plain_text", "content": "Reject" },
"type": "default",
"value": { "action": "approval_decision", "approval_id": "<id>", "decision": "reject" }
}
]
}
]
}
]
}
}
Source detection hint:
channel=feishu or channel=telegram).agent:*:feishu:* -> Feishu modeagent:*:telegram:* -> Telegram modeAll state stored in ~/.clawteam/:
~/.clawteam/teams/<team>/config.json~/.clawteam/tasks/<team>/task-<id>.json (with fcntl file locking for concurrent safety)~/.clawteam/plans/<team>/<agent>-<plan_id>.md (team-scoped, isolated per team)~/.clawteam/teams/<team>/inboxes/<agent>/msg-*.json~/.clawteam/costs/<team>/