claude-code-workflow 7.2.30 → 7.3.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/.claude/commands/workflow-skill.md +130 -0
- package/.claude/skills/ccw-chain/SKILL.md +44 -71
- package/.claude/skills/ccw-chain/chains/ccw-cycle.json +13 -3
- package/.claude/skills/ccw-chain/chains/ccw-exploration.json +33 -22
- package/.claude/skills/ccw-chain/chains/ccw-issue.json +23 -12
- package/.claude/skills/ccw-chain/chains/ccw-lightweight.json +23 -9
- package/.claude/skills/ccw-chain/chains/ccw-main.json +15 -2
- package/.claude/skills/ccw-chain/chains/ccw-standard.json +28 -16
- package/.claude/skills/ccw-chain/chains/ccw-team.json +7 -2
- package/.claude/skills/ccw-chain/chains/ccw-with-file.json +25 -9
- package/.claude/skills/chain-loader/phases/01-analyze-skill.md +53 -53
- package/.claude/skills/chain-loader/specs/chain-schema.md +30 -3
- package/.claude/skills/chain-loader/templates/chain-json.md +63 -63
- package/.claude/skills/workflow-plan/SKILL.md +1 -0
- package/.claude/skills/workflow-plan/phases/01-session-discovery.md +19 -2
- package/.claude/skills/workflow-plan/phases/02-context-gathering.md +2 -2
- package/.claude/skills/workflow-plan/phases/04-task-generation.md +9 -1
- package/.codex/skills/analyze-with-file/SKILL.md +383 -134
- package/.codex/skills/brainstorm/SKILL.md +3 -3
- package/.codex/skills/brainstorm-with-file/SKILL.md +208 -88
- package/.codex/skills/clean/SKILL.md +1 -1
- package/.codex/skills/csv-wave-pipeline/SKILL.md +2 -2
- package/.codex/skills/investigate/orchestrator.md +24 -0
- package/.codex/skills/issue-discover/SKILL.md +374 -361
- package/.codex/skills/issue-discover/phases/01-issue-new.md +1 -1
- package/.codex/skills/issue-discover/phases/02-discover.md +2 -2
- package/.codex/skills/issue-discover/phases/03-discover-by-prompt.md +1 -1
- package/.codex/skills/issue-discover/phases/04-quick-execute.md +2 -2
- package/.codex/skills/parallel-dev-cycle/SKILL.md +44 -37
- package/.codex/skills/project-documentation-workflow/SKILL.md +1 -1
- package/.codex/skills/review-cycle/SKILL.md +31 -12
- package/.codex/skills/roadmap-with-file/SKILL.md +141 -133
- package/.codex/skills/security-audit/orchestrator.md +29 -0
- package/.codex/skills/session-sync/SKILL.md +1 -1
- package/.codex/skills/ship/orchestrator.md +24 -0
- package/.codex/skills/spec-add/SKILL.md +5 -5
- package/.codex/skills/spec-generator/SKILL.md +33 -2
- package/.codex/skills/spec-generator/phases/01-5-requirement-clarification.md +3 -3
- package/.codex/skills/spec-generator/phases/01-discovery.md +1 -1
- package/.codex/skills/spec-generator/phases/02-product-brief.md +1 -1
- package/.codex/skills/spec-generator/phases/03-requirements.md +1 -1
- package/.codex/skills/spec-generator/phases/04-architecture.md +1 -1
- package/.codex/skills/spec-generator/phases/05-epics-stories.md +1 -1
- package/.codex/skills/spec-generator/phases/06-readiness-check.md +1 -1
- package/.codex/skills/spec-generator/phases/07-issue-export.md +1 -1
- package/.codex/skills/spec-setup/SKILL.md +669 -669
- package/.codex/skills/team-arch-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-brainstorm/SKILL.md +259 -259
- package/.codex/skills/team-coordinate/SKILL.md +359 -359
- package/.codex/skills/team-coordinate/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-designer/SKILL.md +27 -1
- package/.codex/skills/team-designer/phases/01-requirements-analysis.md +2 -2
- package/.codex/skills/team-designer/phases/02-scaffold-generation.md +1 -1
- package/.codex/skills/team-designer/phases/04-validation.md +1 -1
- package/.codex/skills/team-executor/SKILL.md +218 -218
- package/.codex/skills/team-frontend/SKILL.md +227 -227
- package/.codex/skills/team-frontend-debug/SKILL.md +278 -278
- package/.codex/skills/team-frontend-debug/roles/coordinator/commands/analyze.md +2 -2
- package/.codex/skills/team-interactive-craft/SKILL.md +220 -220
- package/.codex/skills/team-interactive-craft/roles/coordinator/role.md +209 -209
- package/.codex/skills/team-issue/SKILL.md +269 -269
- package/.codex/skills/team-issue/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-lifecycle-v4/SKILL.md +305 -305
- package/.codex/skills/team-motion-design/SKILL.md +222 -222
- package/.codex/skills/team-motion-design/roles/coordinator/role.md +210 -210
- package/.codex/skills/team-perf-opt/SKILL.md +258 -258
- package/.codex/skills/team-perf-opt/specs/team-config.json +1 -1
- package/.codex/skills/team-planex/SKILL.md +216 -216
- package/.codex/skills/team-quality-assurance/SKILL.md +229 -229
- package/.codex/skills/team-review/SKILL.md +227 -227
- package/.codex/skills/team-roadmap-dev/SKILL.md +238 -238
- package/.codex/skills/team-roadmap-dev/roles/coordinator/commands/roadmap-discuss.md +5 -5
- package/.codex/skills/team-tech-debt/SKILL.md +206 -206
- package/.codex/skills/team-tech-debt/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-testing/SKILL.md +237 -237
- package/.codex/skills/team-ui-polish/SKILL.md +218 -218
- package/.codex/skills/team-ui-polish/roles/coordinator/role.md +213 -213
- package/.codex/skills/team-uidesign/SKILL.md +219 -219
- package/.codex/skills/team-uidesign/roles/coordinator/role.md +2 -2
- package/.codex/skills/team-ultra-analyze/SKILL.md +260 -260
- package/.codex/skills/team-ultra-analyze/roles/coordinator/commands/monitor.md +1 -1
- package/.codex/skills/team-ultra-analyze/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/SKILL.md +227 -227
- package/.codex/skills/team-ux-improve/roles/coordinator/role.md +1 -1
- package/.codex/skills/team-ux-improve/specs/team-config.json +1 -1
- package/.codex/skills/team-visual-a11y/SKILL.md +319 -319
- package/.codex/skills/team-visual-a11y/roles/coordinator/role.md +213 -213
- package/.codex/skills/workflow-execute/SKILL.md +5 -5
- package/.codex/skills/workflow-lite-planex/SKILL.md +3 -3
- package/.codex/skills/workflow-plan/SKILL.md +3 -3
- package/.codex/skills/workflow-tdd-plan/SKILL.md +4 -4
- package/.codex/skills/workflow-test-fix-cycle/SKILL.md +403 -402
- package/ccw/dist/cli.d.ts.map +1 -1
- package/ccw/dist/cli.js +16 -0
- package/ccw/dist/cli.js.map +1 -1
- package/ccw/dist/commands/chain-loader.d.ts +2 -0
- package/ccw/dist/commands/chain-loader.d.ts.map +1 -0
- package/ccw/dist/commands/chain-loader.js +11 -0
- package/ccw/dist/commands/chain-loader.js.map +1 -0
- package/ccw/dist/commands/install.d.ts.map +1 -1
- package/ccw/dist/commands/install.js +52 -1
- package/ccw/dist/commands/install.js.map +1 -1
- package/ccw/dist/commands/launcher.d.ts +2 -0
- package/ccw/dist/commands/launcher.d.ts.map +1 -0
- package/ccw/dist/commands/launcher.js +434 -0
- package/ccw/dist/commands/launcher.js.map +1 -0
- package/ccw/dist/tools/chain-loader.d.ts.map +1 -1
- package/ccw/dist/tools/chain-loader.js +457 -45
- package/ccw/dist/tools/chain-loader.js.map +1 -1
- package/ccw/dist/tools/skill-context-loader.d.ts.map +1 -1
- package/ccw/dist/tools/skill-context-loader.js +12 -26
- package/ccw/dist/tools/skill-context-loader.js.map +1 -1
- package/ccw/dist/types/chain-types.d.ts +41 -1
- package/ccw/dist/types/chain-types.d.ts.map +1 -1
- package/ccw/dist/utils/chain-visualizer.d.ts +13 -0
- package/ccw/dist/utils/chain-visualizer.d.ts.map +1 -0
- package/ccw/dist/utils/chain-visualizer.js +164 -0
- package/ccw/dist/utils/chain-visualizer.js.map +1 -0
- package/package.json +1 -1
- package/.claude/commands/cli/cli-init.md +0 -441
- package/.claude/commands/cli/codex-review.md +0 -361
- package/.claude/commands/flow-create.md +0 -663
- package/.claude/skills/ccw-chain/phases/analyze-with-file.md +0 -788
- package/.claude/skills/ccw-chain/phases/brainstorm/SKILL.md +0 -408
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/01-mode-routing.md +0 -207
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/02-artifacts.md +0 -567
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/03-role-analysis.md +0 -748
- package/.claude/skills/ccw-chain/phases/brainstorm/phases/04-synthesis.md +0 -827
- package/.claude/skills/ccw-chain/phases/brainstorm-with-file.md +0 -482
- package/.claude/skills/ccw-chain/phases/collaborative-plan-with-file.md +0 -639
- package/.claude/skills/ccw-chain/phases/debug-with-file.md +0 -656
- package/.claude/skills/ccw-chain/phases/integration-test-cycle.md +0 -936
- package/.claude/skills/ccw-chain/phases/issue-convert-to-plan.md +0 -720
- package/.claude/skills/ccw-chain/phases/issue-discover.md +0 -483
- package/.claude/skills/ccw-chain/phases/issue-execute.md +0 -629
- package/.claude/skills/ccw-chain/phases/issue-from-brainstorm.md +0 -382
- package/.claude/skills/ccw-chain/phases/issue-plan.md +0 -343
- package/.claude/skills/ccw-chain/phases/issue-queue.md +0 -464
- package/.claude/skills/ccw-chain/phases/refactor-cycle.md +0 -852
- package/.claude/skills/ccw-chain/phases/review-cycle/SKILL.md +0 -132
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-fix.md +0 -760
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-module.md +0 -764
- package/.claude/skills/ccw-chain/phases/review-cycle/phases/review-session.md +0 -775
- package/.claude/skills/ccw-chain/phases/roadmap-with-file.md +0 -544
- package/.claude/skills/ccw-chain/phases/spec-generator/SKILL.md +0 -338
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-5-requirement-clarification.md +0 -404
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/01-discovery.md +0 -257
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/02-product-brief.md +0 -274
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/03-requirements.md +0 -184
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/04-architecture.md +0 -248
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/05-epics-stories.md +0 -178
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-5-auto-fix.md +0 -144
- package/.claude/skills/ccw-chain/phases/spec-generator/phases/06-readiness-check.md +0 -480
- package/.claude/skills/ccw-chain/phases/team-planex.md +0 -123
- package/.claude/skills/ccw-chain/phases/ui-design-explore-auto.md +0 -678
- package/.claude/skills/ccw-chain/phases/unified-execute-with-file.md +0 -870
- package/.claude/skills/ccw-chain/phases/workflow-execute/SKILL.md +0 -625
- package/.claude/skills/ccw-chain/phases/workflow-execute/phases/06-review.md +0 -215
- package/.claude/skills/ccw-chain/phases/workflow-lite-plan.md +0 -616
- package/.claude/skills/ccw-chain/phases/workflow-multi-cli-plan.md +0 -424
- package/.claude/skills/ccw-chain/phases/workflow-plan/SKILL.md +0 -466
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/01-session-discovery.md +0 -99
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/02-context-gathering.md +0 -338
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/03-conflict-resolution.md +0 -422
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/04-task-generation.md +0 -440
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/05-plan-verify.md +0 -395
- package/.claude/skills/ccw-chain/phases/workflow-plan/phases/06-replan.md +0 -594
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/SKILL.md +0 -527
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/01-session-discovery.md +0 -57
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/02-context-gathering.md +0 -407
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/03-test-coverage-analysis.md +0 -172
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/04-conflict-resolution.md +0 -426
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/05-tdd-task-generation.md +0 -473
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/06-tdd-structure-validation.md +0 -189
- package/.claude/skills/ccw-chain/phases/workflow-tdd-plan/phases/07-tdd-verify.md +0 -635
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/SKILL.md +0 -482
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/01-session-start.md +0 -60
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/02-test-context-gather.md +0 -493
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/03-test-concept-enhanced.md +0 -150
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/04-test-task-generate.md +0 -346
- package/.claude/skills/ccw-chain/phases/workflow-test-fix/phases/05-test-cycle-execute.md +0 -538
- package/.claude/skills/ccw-chain/specs/intent-patterns.md +0 -60
- package/.claude/skills/team-edict.zip +0 -0
|
@@ -1,227 +1,227 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: team-review
|
|
3
|
-
description: "Unified team skill for code review. 3-role pipeline: scanner, reviewer, fixer. Triggers on team-review."
|
|
4
|
-
allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), mcp__ace-tool__search_context(*)
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
# Team Review
|
|
8
|
-
|
|
9
|
-
Orchestrate multi-agent code review: scanner -> reviewer -> fixer. Toolchain + LLM scan, deep analysis with root cause enrichment, and automated fix with rollback-on-failure.
|
|
10
|
-
|
|
11
|
-
## Architecture
|
|
12
|
-
|
|
13
|
-
```
|
|
14
|
-
Skill(skill="team-review", args="task description")
|
|
15
|
-
|
|
|
16
|
-
SKILL.md (this file) = Router
|
|
17
|
-
|
|
|
18
|
-
+--------------+--------------+
|
|
19
|
-
| |
|
|
20
|
-
no --role flag --role <name>
|
|
21
|
-
| |
|
|
22
|
-
Coordinator Worker
|
|
23
|
-
roles/coordinator/role.md roles/<name>/role.md
|
|
24
|
-
|
|
|
25
|
-
+-- analyze -> dispatch -> spawn workers -> STOP
|
|
26
|
-
|
|
|
27
|
-
+-------+-------+-------+
|
|
28
|
-
v v v
|
|
29
|
-
[scan] [review] [fix]
|
|
30
|
-
team-worker agents, each loads roles/<role>/role.md
|
|
31
|
-
```
|
|
32
|
-
|
|
33
|
-
## Role Registry
|
|
34
|
-
|
|
35
|
-
| Role | Path | Prefix | Inner Loop |
|
|
36
|
-
|------|------|--------|------------|
|
|
37
|
-
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
38
|
-
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | SCAN-* | false |
|
|
39
|
-
| reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | REV-* | false |
|
|
40
|
-
| fixer | [roles/fixer/role.md](roles/fixer/role.md) | FIX-* | true |
|
|
41
|
-
|
|
42
|
-
## Role Router
|
|
43
|
-
|
|
44
|
-
Parse `$ARGUMENTS`:
|
|
45
|
-
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
46
|
-
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
47
|
-
|
|
48
|
-
## Delegation Lock
|
|
49
|
-
|
|
50
|
-
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
51
|
-
|
|
52
|
-
Before calling ANY tool, apply this check:
|
|
53
|
-
|
|
54
|
-
| Tool Call | Verdict | Reason |
|
|
55
|
-
|-----------|---------|--------|
|
|
56
|
-
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
57
|
-
| `list_agents` | ALLOWED | Agent health check |
|
|
58
|
-
| `request_user_input` | ALLOWED | User interaction |
|
|
59
|
-
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
60
|
-
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
61
|
-
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
62
|
-
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
63
|
-
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
64
|
-
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
65
|
-
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
66
|
-
|
|
67
|
-
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
68
|
-
|
|
69
|
-
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
70
|
-
|
|
71
|
-
---
|
|
72
|
-
|
|
73
|
-
## Shared Constants
|
|
74
|
-
|
|
75
|
-
- **Session prefix**: `RV`
|
|
76
|
-
- **Session path**: `.workflow/.team/RV-<slug>-<date>/`
|
|
77
|
-
- **Team name**: `review`
|
|
78
|
-
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
79
|
-
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
80
|
-
|
|
81
|
-
## Worker Spawn Template
|
|
82
|
-
|
|
83
|
-
Coordinator spawns workers using this template:
|
|
84
|
-
|
|
85
|
-
```
|
|
86
|
-
spawn_agent({
|
|
87
|
-
agent_type: "team_worker",
|
|
88
|
-
task_name: "<task-id>",
|
|
89
|
-
fork_context: false,
|
|
90
|
-
items: [
|
|
91
|
-
{ type: "text", text: `## Role Assignment
|
|
92
|
-
role: <role>
|
|
93
|
-
role_spec: <skill_root>/roles/<role>/role.md
|
|
94
|
-
session: <session-folder>
|
|
95
|
-
session_id: <session-id>
|
|
96
|
-
requirement: <task-description>
|
|
97
|
-
inner_loop: <true|false>
|
|
98
|
-
|
|
99
|
-
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
100
|
-
|
|
101
|
-
{ type: "text", text: `## Task Context
|
|
102
|
-
task_id: <task-id>
|
|
103
|
-
title: <task-title>
|
|
104
|
-
description: <task-description>
|
|
105
|
-
pipeline_phase: <pipeline-phase>` },
|
|
106
|
-
|
|
107
|
-
{ type: "text", text: `## Upstream Context
|
|
108
|
-
<prev_context>` }
|
|
109
|
-
]
|
|
110
|
-
})
|
|
111
|
-
```
|
|
112
|
-
|
|
113
|
-
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
### Model Selection Guide
|
|
117
|
-
|
|
118
|
-
| Role | model | reasoning_effort | Rationale |
|
|
119
|
-
|------|-------|-------------------|-----------|
|
|
120
|
-
| Scanner (SCAN-*) | (default) | medium | Toolchain scanning + pattern matching, less reasoning |
|
|
121
|
-
| Reviewer (REV-*) | (default) | high | Deep root cause analysis requires full reasoning |
|
|
122
|
-
| Fixer (FIX-*) | (default) | high | Code modification needs precision |
|
|
123
|
-
|
|
124
|
-
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
125
|
-
```
|
|
126
|
-
spawn_agent({
|
|
127
|
-
agent_type: "team_worker",
|
|
128
|
-
task_name: "<task-id>",
|
|
129
|
-
fork_context: false,
|
|
130
|
-
model: "<model-override>",
|
|
131
|
-
reasoning_effort: "<effort-level>",
|
|
132
|
-
items: [...]
|
|
133
|
-
})
|
|
134
|
-
```
|
|
135
|
-
|
|
136
|
-
## User Commands
|
|
137
|
-
|
|
138
|
-
| Command | Action |
|
|
139
|
-
|---------|--------|
|
|
140
|
-
| `check` / `status` | View pipeline status graph |
|
|
141
|
-
| `resume` / `continue` | Advance to next step |
|
|
142
|
-
| `--full` | Enable scan + review + fix pipeline |
|
|
143
|
-
| `--fix` | Fix-only mode (skip scan/review) |
|
|
144
|
-
| `-q` / `--quick` | Quick scan only |
|
|
145
|
-
| `--dimensions=sec,cor,prf,mnt` | Custom dimensions |
|
|
146
|
-
| `-y` / `--yes` | Skip confirmations |
|
|
147
|
-
|
|
148
|
-
## v4 Agent Coordination
|
|
149
|
-
|
|
150
|
-
### Message Semantics
|
|
151
|
-
|
|
152
|
-
| Intent | API | Example |
|
|
153
|
-
|--------|-----|---------|
|
|
154
|
-
| Send scan findings to running reviewer | `send_message` | Queue scan results to REV-* as supplementary context |
|
|
155
|
-
| Not used in this skill | `assign_task` | No resident agents -- sequential 3-stage pipeline |
|
|
156
|
-
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
157
|
-
|
|
158
|
-
### Pipeline Pattern
|
|
159
|
-
|
|
160
|
-
This is a **sequential 3-stage pipeline** (scan -> review -> fix). No parallel phases. Each stage completes before the next starts. The coordinator may skip stages (0 findings -> skip review+fix; user declines fix -> skip fix).
|
|
161
|
-
|
|
162
|
-
### Agent Health Check
|
|
163
|
-
|
|
164
|
-
Use `list_agents({})` in handleResume and handleComplete:
|
|
165
|
-
|
|
166
|
-
```
|
|
167
|
-
// Reconcile session state with actual running agents
|
|
168
|
-
const running = list_agents({})
|
|
169
|
-
// Compare with tasks.json active_agents
|
|
170
|
-
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
171
|
-
```
|
|
172
|
-
|
|
173
|
-
### Named Agent Targeting
|
|
174
|
-
|
|
175
|
-
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
176
|
-
- `send_message({ target: "REV-001", items: [...] })` -- queue scan findings to running reviewer
|
|
177
|
-
- `close_agent({ target: "SCAN-001" })` -- cleanup by name after completion
|
|
178
|
-
|
|
179
|
-
## Completion Action
|
|
180
|
-
|
|
181
|
-
When pipeline completes, coordinator presents:
|
|
182
|
-
|
|
183
|
-
```
|
|
184
|
-
request_user_input({
|
|
185
|
-
questions: [{
|
|
186
|
-
question: "Review pipeline complete. What would you like to do?",
|
|
187
|
-
header: "Completion",
|
|
188
|
-
multiSelect: false,
|
|
189
|
-
options: [
|
|
190
|
-
{ label: "Archive & Clean (Recommended)", description: "Archive session, clean up" },
|
|
191
|
-
{ label: "Keep Active", description: "Keep session for follow-up work" },
|
|
192
|
-
{ label: "Export Results", description: "Export deliverables to target directory" }
|
|
193
|
-
]
|
|
194
|
-
}]
|
|
195
|
-
})
|
|
196
|
-
```
|
|
197
|
-
|
|
198
|
-
## Session Directory
|
|
199
|
-
|
|
200
|
-
```
|
|
201
|
-
.workflow/.team/RV-<slug>-<date>/
|
|
202
|
-
├── .msg/messages.jsonl # Team message bus
|
|
203
|
-
├── .msg/meta.json # Session state + cross-role state
|
|
204
|
-
├── wisdom/ # Cross-task knowledge
|
|
205
|
-
├── scan/ # Scanner output
|
|
206
|
-
├── review/ # Reviewer output
|
|
207
|
-
└── fix/ # Fixer output
|
|
208
|
-
```
|
|
209
|
-
|
|
210
|
-
## Specs Reference
|
|
211
|
-
|
|
212
|
-
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
213
|
-
- [specs/dimensions.md](specs/dimensions.md) — Review dimension definitions (SEC/COR/PRF/MNT)
|
|
214
|
-
- [specs/finding-schema.json](specs/finding-schema.json) — Finding data schema
|
|
215
|
-
- [specs/team-config.json](specs/team-config.json) — Team configuration
|
|
216
|
-
|
|
217
|
-
## Error Handling
|
|
218
|
-
|
|
219
|
-
| Scenario | Resolution |
|
|
220
|
-
|----------|------------|
|
|
221
|
-
| Unknown --role value | Error with available role list |
|
|
222
|
-
| Role not found | Error with expected path (roles/<name>/role.md) |
|
|
223
|
-
| CLI tool fails | Worker fallback to direct implementation |
|
|
224
|
-
| Scanner finds 0 findings | Report clean, skip review + fix |
|
|
225
|
-
| User declines fix | Delete FIX tasks, complete with review-only results |
|
|
226
|
-
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
227
|
-
| Completion action fails | Default to Keep Active |
|
|
1
|
+
---
|
|
2
|
+
name: team-review
|
|
3
|
+
description: "Unified team skill for code review. 3-role pipeline: scanner, reviewer, fixer. Triggers on team-review."
|
|
4
|
+
allowed-tools: spawn_agent(*), wait_agent(*), send_message(*), assign_task(*), close_agent(*), list_agents(*), report_agent_job_result(*), request_user_input(*), Read(*), Write(*), Edit(*), Bash(*), Glob(*), Grep(*), mcp__ace-tool__search_context(*)
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
# Team Review
|
|
8
|
+
|
|
9
|
+
Orchestrate multi-agent code review: scanner -> reviewer -> fixer. Toolchain + LLM scan, deep analysis with root cause enrichment, and automated fix with rollback-on-failure.
|
|
10
|
+
|
|
11
|
+
## Architecture
|
|
12
|
+
|
|
13
|
+
```
|
|
14
|
+
Skill(skill="team-review", args="task description")
|
|
15
|
+
|
|
|
16
|
+
SKILL.md (this file) = Router
|
|
17
|
+
|
|
|
18
|
+
+--------------+--------------+
|
|
19
|
+
| |
|
|
20
|
+
no --role flag --role <name>
|
|
21
|
+
| |
|
|
22
|
+
Coordinator Worker
|
|
23
|
+
roles/coordinator/role.md roles/<name>/role.md
|
|
24
|
+
|
|
|
25
|
+
+-- analyze -> dispatch -> spawn workers -> STOP
|
|
26
|
+
|
|
|
27
|
+
+-------+-------+-------+
|
|
28
|
+
v v v
|
|
29
|
+
[scan] [review] [fix]
|
|
30
|
+
team-worker agents, each loads roles/<role>/role.md
|
|
31
|
+
```
|
|
32
|
+
|
|
33
|
+
## Role Registry
|
|
34
|
+
|
|
35
|
+
| Role | Path | Prefix | Inner Loop |
|
|
36
|
+
|------|------|--------|------------|
|
|
37
|
+
| coordinator | [roles/coordinator/role.md](roles/coordinator/role.md) | — | — |
|
|
38
|
+
| scanner | [roles/scanner/role.md](roles/scanner/role.md) | SCAN-* | false |
|
|
39
|
+
| reviewer | [roles/reviewer/role.md](roles/reviewer/role.md) | REV-* | false |
|
|
40
|
+
| fixer | [roles/fixer/role.md](roles/fixer/role.md) | FIX-* | true |
|
|
41
|
+
|
|
42
|
+
## Role Router
|
|
43
|
+
|
|
44
|
+
Parse `$ARGUMENTS`:
|
|
45
|
+
- Has `--role <name>` -> Read `roles/<name>/role.md`, execute Phase 2-4
|
|
46
|
+
- No `--role` -> `roles/coordinator/role.md`, execute entry router
|
|
47
|
+
|
|
48
|
+
## Delegation Lock
|
|
49
|
+
|
|
50
|
+
**Coordinator is a PURE ORCHESTRATOR. It coordinates, it does NOT do.**
|
|
51
|
+
|
|
52
|
+
Before calling ANY tool, apply this check:
|
|
53
|
+
|
|
54
|
+
| Tool Call | Verdict | Reason |
|
|
55
|
+
|-----------|---------|--------|
|
|
56
|
+
| `spawn_agent`, `wait_agent`, `close_agent`, `send_message`, `assign_task` | ALLOWED | Orchestration |
|
|
57
|
+
| `list_agents` | ALLOWED | Agent health check |
|
|
58
|
+
| `request_user_input` | ALLOWED | User interaction |
|
|
59
|
+
| `mcp__ccw-tools__team_msg` | ALLOWED | Message bus |
|
|
60
|
+
| `Read/Write` on `.workflow/.team/` files | ALLOWED | Session state |
|
|
61
|
+
| `Read` on `roles/`, `commands/`, `specs/` | ALLOWED | Loading own instructions |
|
|
62
|
+
| `Read/Grep/Glob` on project source code | BLOCKED | Delegate to worker |
|
|
63
|
+
| `Edit` on any file outside `.workflow/` | BLOCKED | Delegate to worker |
|
|
64
|
+
| `Bash("ccw cli ...")` | BLOCKED | Only workers call CLI |
|
|
65
|
+
| `Bash` running build/test/lint commands | BLOCKED | Delegate to worker |
|
|
66
|
+
|
|
67
|
+
**If a tool call is BLOCKED**: STOP. Create a task, spawn a worker.
|
|
68
|
+
|
|
69
|
+
**No exceptions for "simple" tasks.** Even a single-file read-and-report MUST go through spawn_agent.
|
|
70
|
+
|
|
71
|
+
---
|
|
72
|
+
|
|
73
|
+
## Shared Constants
|
|
74
|
+
|
|
75
|
+
- **Session prefix**: `RV`
|
|
76
|
+
- **Session path**: `.workflow/.team/RV-<slug>-<date>/`
|
|
77
|
+
- **Team name**: `review`
|
|
78
|
+
- **CLI tools**: `ccw cli --mode analysis` (read-only), `ccw cli --mode write` (modifications)
|
|
79
|
+
- **Message bus**: `mcp__ccw-tools__team_msg(session_id=<session-id>, ...)`
|
|
80
|
+
|
|
81
|
+
## Worker Spawn Template
|
|
82
|
+
|
|
83
|
+
Coordinator spawns workers using this template:
|
|
84
|
+
|
|
85
|
+
```
|
|
86
|
+
spawn_agent({
|
|
87
|
+
agent_type: "team_worker",
|
|
88
|
+
task_name: "<task-id>",
|
|
89
|
+
fork_context: false,
|
|
90
|
+
items: [
|
|
91
|
+
{ type: "text", text: `## Role Assignment
|
|
92
|
+
role: <role>
|
|
93
|
+
role_spec: <skill_root>/roles/<role>/role.md
|
|
94
|
+
session: <session-folder>
|
|
95
|
+
session_id: <session-id>
|
|
96
|
+
requirement: <task-description>
|
|
97
|
+
inner_loop: <true|false>
|
|
98
|
+
|
|
99
|
+
Read role_spec file (<skill_root>/roles/<role>/role.md) to load Phase 2-4 domain instructions.` },
|
|
100
|
+
|
|
101
|
+
{ type: "text", text: `## Task Context
|
|
102
|
+
task_id: <task-id>
|
|
103
|
+
title: <task-title>
|
|
104
|
+
description: <task-description>
|
|
105
|
+
pipeline_phase: <pipeline-phase>` },
|
|
106
|
+
|
|
107
|
+
{ type: "text", text: `## Upstream Context
|
|
108
|
+
<prev_context>` }
|
|
109
|
+
]
|
|
110
|
+
})
|
|
111
|
+
```
|
|
112
|
+
|
|
113
|
+
After spawning, use `wait_agent({ targets: [...], timeout_ms: 900000 })` to collect results, then `close_agent({ target })` each worker.
|
|
114
|
+
|
|
115
|
+
|
|
116
|
+
### Model Selection Guide
|
|
117
|
+
|
|
118
|
+
| Role | model | reasoning_effort | Rationale |
|
|
119
|
+
|------|-------|-------------------|-----------|
|
|
120
|
+
| Scanner (SCAN-*) | (default) | medium | Toolchain scanning + pattern matching, less reasoning |
|
|
121
|
+
| Reviewer (REV-*) | (default) | high | Deep root cause analysis requires full reasoning |
|
|
122
|
+
| Fixer (FIX-*) | (default) | high | Code modification needs precision |
|
|
123
|
+
|
|
124
|
+
Override model/reasoning_effort in spawn_agent when cost optimization is needed:
|
|
125
|
+
```
|
|
126
|
+
spawn_agent({
|
|
127
|
+
agent_type: "team_worker",
|
|
128
|
+
task_name: "<task-id>",
|
|
129
|
+
fork_context: false,
|
|
130
|
+
model: "<model-override>",
|
|
131
|
+
reasoning_effort: "<effort-level>",
|
|
132
|
+
items: [...]
|
|
133
|
+
})
|
|
134
|
+
```
|
|
135
|
+
|
|
136
|
+
## User Commands
|
|
137
|
+
|
|
138
|
+
| Command | Action |
|
|
139
|
+
|---------|--------|
|
|
140
|
+
| `check` / `status` | View pipeline status graph |
|
|
141
|
+
| `resume` / `continue` | Advance to next step |
|
|
142
|
+
| `--full` | Enable scan + review + fix pipeline |
|
|
143
|
+
| `--fix` | Fix-only mode (skip scan/review) |
|
|
144
|
+
| `-q` / `--quick` | Quick scan only |
|
|
145
|
+
| `--dimensions=sec,cor,prf,mnt` | Custom dimensions |
|
|
146
|
+
| `-y` / `--yes` | Skip confirmations |
|
|
147
|
+
|
|
148
|
+
## v4 Agent Coordination
|
|
149
|
+
|
|
150
|
+
### Message Semantics
|
|
151
|
+
|
|
152
|
+
| Intent | API | Example |
|
|
153
|
+
|--------|-----|---------|
|
|
154
|
+
| Send scan findings to running reviewer | `send_message` | Queue scan results to REV-* as supplementary context |
|
|
155
|
+
| Not used in this skill | `assign_task` | No resident agents -- sequential 3-stage pipeline |
|
|
156
|
+
| Check running agents | `list_agents` | Verify agent health during resume |
|
|
157
|
+
|
|
158
|
+
### Pipeline Pattern
|
|
159
|
+
|
|
160
|
+
This is a **sequential 3-stage pipeline** (scan -> review -> fix). No parallel phases. Each stage completes before the next starts. The coordinator may skip stages (0 findings -> skip review+fix; user declines fix -> skip fix).
|
|
161
|
+
|
|
162
|
+
### Agent Health Check
|
|
163
|
+
|
|
164
|
+
Use `list_agents({})` in handleResume and handleComplete:
|
|
165
|
+
|
|
166
|
+
```
|
|
167
|
+
// Reconcile session state with actual running agents
|
|
168
|
+
const running = list_agents({})
|
|
169
|
+
// Compare with tasks.json active_agents
|
|
170
|
+
// Reset orphaned tasks (in_progress but agent gone) to pending
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
### Named Agent Targeting
|
|
174
|
+
|
|
175
|
+
Workers are spawned with `task_name: "<task-id>"` enabling direct addressing:
|
|
176
|
+
- `send_message({ target: "REV-001", items: [...] })` -- queue scan findings to running reviewer
|
|
177
|
+
- `close_agent({ target: "SCAN-001" })` -- cleanup by name after completion
|
|
178
|
+
|
|
179
|
+
## Completion Action
|
|
180
|
+
|
|
181
|
+
When pipeline completes, coordinator presents:
|
|
182
|
+
|
|
183
|
+
```
|
|
184
|
+
functions.request_user_input({
|
|
185
|
+
questions: [{
|
|
186
|
+
question: "Review pipeline complete. What would you like to do?",
|
|
187
|
+
header: "Completion",
|
|
188
|
+
multiSelect: false,
|
|
189
|
+
options: [
|
|
190
|
+
{ label: "Archive & Clean (Recommended)", description: "Archive session, clean up" },
|
|
191
|
+
{ label: "Keep Active", description: "Keep session for follow-up work" },
|
|
192
|
+
{ label: "Export Results", description: "Export deliverables to target directory" }
|
|
193
|
+
]
|
|
194
|
+
}]
|
|
195
|
+
})
|
|
196
|
+
```
|
|
197
|
+
|
|
198
|
+
## Session Directory
|
|
199
|
+
|
|
200
|
+
```
|
|
201
|
+
.workflow/.team/RV-<slug>-<date>/
|
|
202
|
+
├── .msg/messages.jsonl # Team message bus
|
|
203
|
+
├── .msg/meta.json # Session state + cross-role state
|
|
204
|
+
├── wisdom/ # Cross-task knowledge
|
|
205
|
+
├── scan/ # Scanner output
|
|
206
|
+
├── review/ # Reviewer output
|
|
207
|
+
└── fix/ # Fixer output
|
|
208
|
+
```
|
|
209
|
+
|
|
210
|
+
## Specs Reference
|
|
211
|
+
|
|
212
|
+
- [specs/pipelines.md](specs/pipelines.md) — Pipeline definitions and task registry
|
|
213
|
+
- [specs/dimensions.md](specs/dimensions.md) — Review dimension definitions (SEC/COR/PRF/MNT)
|
|
214
|
+
- [specs/finding-schema.json](specs/finding-schema.json) — Finding data schema
|
|
215
|
+
- [specs/team-config.json](specs/team-config.json) — Team configuration
|
|
216
|
+
|
|
217
|
+
## Error Handling
|
|
218
|
+
|
|
219
|
+
| Scenario | Resolution |
|
|
220
|
+
|----------|------------|
|
|
221
|
+
| Unknown --role value | Error with available role list |
|
|
222
|
+
| Role not found | Error with expected path (roles/<name>/role.md) |
|
|
223
|
+
| CLI tool fails | Worker fallback to direct implementation |
|
|
224
|
+
| Scanner finds 0 findings | Report clean, skip review + fix |
|
|
225
|
+
| User declines fix | Delete FIX tasks, complete with review-only results |
|
|
226
|
+
| Fast-advance conflict | Coordinator reconciles on next callback |
|
|
227
|
+
| Completion action fails | Default to Keep Active |
|