Council v2
/install council-v2
Council v2
A hardened OpenClaw skill for multi-model council reviews. It dispatches independent reviewers, collects structured JSON, and applies a mechanical synthesis protocol so the final verdict is driven by votes and critical findings — not orchestrator vibes.
Primary entrypoint: bash skills/council-v2/scripts/council.sh review \x3Ctype> [file]
When to Use
Use when a single model reviewing its own work is not enough:
- Code review before merge or deployment
- Plan review before committing resources
- Architecture review for important technical decisions
- Decision review when multiple plausible options exist
- Security-sensitive or irreversible choices
- Pre-flight review, adversarial critique, or second-opinion work
When Not to Use
Do not use for:
- One-line fixes or trivial edits
- Low-stakes decisions where overhead exceeds risk
- Purely factual lookups with no judgment call
- Work already reviewed recently with no material change
Council Shape
Two tiers are supported:
- Standard — 3 reviewers for routine code, plan, and decision reviews
- Full — 5 reviewers for high-stakes, security-sensitive, or irreversible choices
Tier selection heuristic
Use Standard when: routine code changes, internal plans, reversible decisions, low blast radius. Use Full when: security-critical, production-facing architecture, irreversible commitments, high cost of being wrong, or when you want maximum coverage.
When in doubt, start Standard. Escalate to Full if the Standard result is split or if critical findings surface that need more perspectives.
Cost note
Full Council runs 5 model calls instead of 3. That is ~1.7x the token cost of Standard. Use Full when the cost of a bad decision exceeds the cost of the extra API calls — which for security, architecture, and irreversible choices, it almost always does.
Detailed role composition and synthesis rules live in:
references/review-types.mdreferences/role-prompts.mdreferences/synthesis-rules.md
Review Types
| Type | Typical use |
|---|---|
code |
Source files, scripts, patches, PR diffs |
plan |
Proposals, project plans, rollout plans |
architecture |
Systems design, infra decisions, workflows |
decision |
A/B/C choices with tradeoffs |
Definitions: references/review-types.md
Quick Start
# Standard code review
bash skills/council-v2/scripts/council.sh review code src/auth.py
# Force full plan review
bash skills/council-v2/scripts/council.sh review plan proposal.md --tier full
# Architecture review from stdin
cat design.md | bash skills/council-v2/scripts/council.sh review architecture --tier full
# Decision review with options
bash skills/council-v2/scripts/council.sh review decision options.md --options "SQLite,Postgres,Cloud SQL"
# Emit orchestration plan as JSON
bash skills/council-v2/scripts/council.sh review code src/auth.py --format json
How It Works
- Loads content from file or stdin
- Selects Standard or Full tier
- Builds reviewer prompts from
references/role-prompts.md - Emits an orchestration plan suitable for
sessions_spawn - Collects reviewer JSON outputs
- Runs
python3 scripts/synthesize.py ... - Returns synthesis with mechanical result, minority report, and conditions
Interpreting Results
The synthesizer returns structured JSON and a meaningful exit code:
| Exit code | Meaning | What to do |
|---|---|---|
0 |
Approve — clear majority, no criticals | Ship it |
1 |
Reject or Blocked — majority rejected or a critical finding blocked | Address the critical findings or rethink the approach |
2 |
Approve with conditions — mixed or conditional majority | Fix the flagged conditions, then re-review or proceed with documented risk |
3 |
Error — invalid input or synthesis failure | Check reviewer JSON for malformed output; see error handling below |
Reading the synthesis output
- mechanical_result: The vote-driven verdict. This is the answer.
- critical_blocks: Any critical findings that auto-blocked approval. Address these first.
- conditions: Aggregated recommendations from warning-level findings. These are your fix list.
- minority_report: The strongest dissent from the majority. Read this even if you agree with the majority — it is often where the best insight lives.
- anti_consensus_check: Fires on unanimous decisions. Treat the counterargument seriously.
Error Handling
Reviewer returns invalid JSON
synthesize.py validates every reviewer output against required fields. If a reviewer
returns malformed JSON, synthesis exits with code 3 and prints an error message.
What to do:
- Check the raw reviewer output for the failing model
- Re-run that single reviewer (the orchestration plan shows which models to dispatch)
- If the model consistently fails, substitute it — see model override flags below
Provider is down or times out
If a provider fails to respond, the review set will be incomplete. Run synthesis on whatever outputs you have — a 2-of-3 Standard review is still useful. Note the missing reviewer in your assessment.
Model override flags
Override any model at the command line:
bash skills/council-v2/scripts/council.sh review code src/auth.py \
--opus claude-sonnet-4 \
--gpt gpt-4.1 \
--grok grok-3
Available flags: --opus, --gpt, --grok, --deepseek, --gemini
Model Diversity
The council's value comes from different providers with different training data and different biases reviewing the same decision. The specific model versions (Opus, GPT-5.4, Grok 4, etc.) matter less than the diversity. Swap in whatever top-tier models you have access to — what matters is that they are not all from the same provider.
Retrospectives
scripts/retro.sh generates a structured retrospective template for reviewing past
council decisions against actual outcomes.
# Review the 5 most recent decisions in a directory
bash skills/council-v2/scripts/retro.sh ./council-outputs/ 5
When to run retros
Run monthly, or after any decision where the outcome surprised you. The retro surfaces:
- Which reviewers provided signal vs. noise
- Whether critical findings were real or false alarms
- Whether synthesis preserved minority views accurately
- Prompt changes to consider for role-prompts.md
Feed retro findings back into references/role-prompts.md to calibrate the council.
Notes
- Requires
bash,python3, and OpenClaw reviewer dispatch capability - Model aliases can be overridden — see model override flags above
- Synthesis rules are documented in
references/synthesis-rules.md
References
references/review-types.md— review type definitions and tier recommendationsreferences/role-prompts.md— reviewer role prompts and shared output instructionsreferences/schema.md— JSON schemas for reviewer output and synthesis outputreferences/synthesis-rules.md— mechanical synthesis protocol and edge cases
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install council-v2 - 安装完成后,直接呼叫该 Skill 的名称或使用
/council-v2触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
Council v2 是什么?
Multi-model council review that spawns 3-5 independent AI reviewers and applies mechanical synthesis — votes decide, not orchestrator opinion. Use when you n... 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 235 次。
如何安装 Council v2?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install council-v2」即可一键安装,无需额外配置。
Council v2 是免费的吗?
是的,Council v2 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
Council v2 支持哪些平台?
Council v2 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 Council v2?
由 Don Zurbrick(@zurbrick)开发并维护,当前版本 v2.0.3。