@bradygaster/squad-sdk 0.8.19 → 0.8.21
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/README.md +296 -296
- package/dist/adapter/client.js +1 -1
- package/dist/adapter/client.js.map +1 -1
- package/dist/agents/charter-compiler.d.ts +4 -0
- package/dist/agents/charter-compiler.d.ts.map +1 -1
- package/dist/agents/charter-compiler.js +8 -0
- package/dist/agents/charter-compiler.js.map +1 -1
- package/dist/agents/history-shadow.js +30 -30
- package/dist/agents/index.js +1 -1
- package/dist/agents/index.js.map +1 -1
- package/dist/agents/lifecycle.js +1 -1
- package/dist/agents/lifecycle.js.map +1 -1
- package/dist/build/github-dist.js +42 -42
- package/dist/builders/index.d.ts +156 -0
- package/dist/builders/index.d.ts.map +1 -0
- package/dist/builders/index.js +404 -0
- package/dist/builders/index.js.map +1 -0
- package/dist/builders/types.d.ts +187 -0
- package/dist/builders/types.d.ts.map +1 -0
- package/dist/builders/types.js +12 -0
- package/dist/builders/types.js.map +1 -0
- package/dist/config/init.d.ts +6 -22
- package/dist/config/init.d.ts.map +1 -1
- package/dist/config/init.js +273 -185
- package/dist/config/init.js.map +1 -1
- package/dist/coordinator/coordinator.js +1 -1
- package/dist/coordinator/coordinator.js.map +1 -1
- package/dist/coordinator/index.js +1 -1
- package/dist/coordinator/index.js.map +1 -1
- package/dist/index.d.ts +3 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +3 -0
- package/dist/index.js.map +1 -1
- package/dist/runtime/otel-api.d.ts +38 -0
- package/dist/runtime/otel-api.d.ts.map +1 -0
- package/dist/runtime/otel-api.js +94 -0
- package/dist/runtime/otel-api.js.map +1 -0
- package/dist/runtime/otel-bridge.js +1 -1
- package/dist/runtime/otel-bridge.js.map +1 -1
- package/dist/runtime/otel.d.ts +1 -1
- package/dist/runtime/otel.d.ts.map +1 -1
- package/dist/runtime/otel.js +28 -12
- package/dist/runtime/otel.js.map +1 -1
- package/dist/runtime/squad-observer.js +1 -1
- package/dist/runtime/squad-observer.js.map +1 -1
- package/dist/sharing/consult.js +78 -78
- package/dist/streams/filter.d.ts +33 -0
- package/dist/streams/filter.d.ts.map +1 -0
- package/dist/streams/filter.js +29 -0
- package/dist/streams/filter.js.map +1 -0
- package/dist/streams/index.d.ts +9 -0
- package/dist/streams/index.d.ts.map +1 -0
- package/dist/streams/index.js +9 -0
- package/dist/streams/index.js.map +1 -0
- package/dist/streams/resolver.d.ts +40 -0
- package/dist/streams/resolver.d.ts.map +1 -0
- package/dist/streams/resolver.js +162 -0
- package/dist/streams/resolver.js.map +1 -0
- package/dist/streams/types.d.ts +44 -0
- package/dist/streams/types.d.ts.map +1 -0
- package/dist/streams/types.js +10 -0
- package/dist/streams/types.js.map +1 -0
- package/dist/tools/index.js +1 -1
- package/dist/tools/index.js.map +1 -1
- package/dist/types.d.ts +20 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +208 -207
- package/templates/casting-history.json +4 -4
- package/templates/casting-policy.json +35 -35
- package/templates/casting-registry.json +3 -3
- package/templates/ceremonies.md +41 -41
- package/templates/charter.md +53 -53
- package/templates/constraint-tracking.md +38 -38
- package/templates/copilot-instructions.md +46 -46
- package/templates/history.md +10 -10
- package/templates/identity/now.md +9 -9
- package/templates/identity/wisdom.md +15 -15
- package/templates/mcp-config.md +98 -98
- package/templates/multi-agent-format.md +28 -28
- package/templates/orchestration-log.md +27 -27
- package/templates/plugin-marketplace.md +49 -49
- package/templates/raw-agent-output.md +37 -37
- package/templates/roster.md +60 -60
- package/templates/routing.md +54 -54
- package/templates/run-output.md +50 -50
- package/templates/scribe-charter.md +119 -119
- package/templates/skill.md +24 -24
- package/templates/skills/project-conventions/SKILL.md +56 -56
- package/templates/squad.agent.md +1146 -1146
- package/templates/workflows/squad-ci.yml +24 -24
- package/templates/workflows/squad-docs.yml +50 -50
- package/templates/workflows/squad-heartbeat.yml +316 -316
- package/templates/workflows/squad-insider-release.yml +61 -61
- package/templates/workflows/squad-issue-assign.yml +161 -161
- package/templates/workflows/squad-label-enforce.yml +181 -181
- package/templates/workflows/squad-preview.yml +55 -55
- package/templates/workflows/squad-promote.yml +120 -121
- package/templates/workflows/squad-release.yml +77 -77
- package/templates/workflows/squad-triage.yml +260 -260
- package/templates/workflows/sync-squad-labels.yml +169 -169
- package/dist/runtime/event-bus-otel-bridge.d.ts +0 -19
- package/dist/runtime/event-bus-otel-bridge.d.ts.map +0 -1
- package/dist/runtime/event-bus-otel-bridge.js +0 -61
- package/dist/runtime/event-bus-otel-bridge.js.map +0 -1
- package/templates/workflows/squad-main-guard.yml +0 -129
|
@@ -1,28 +1,28 @@
|
|
|
1
|
-
# Multi-Agent Artifact Format
|
|
2
|
-
|
|
3
|
-
When multiple agents contribute to a final artifact (document, analysis, design), use this format. The assembled result must include:
|
|
4
|
-
|
|
5
|
-
- Termination condition
|
|
6
|
-
- Constraint budgets (if active)
|
|
7
|
-
- Reviewer verdicts (if any)
|
|
8
|
-
- Raw agent outputs appendix
|
|
9
|
-
|
|
10
|
-
## Assembly Structure
|
|
11
|
-
|
|
12
|
-
The assembled result goes at the top. Below it, include:
|
|
13
|
-
|
|
14
|
-
```
|
|
15
|
-
## APPENDIX: RAW AGENT OUTPUTS
|
|
16
|
-
|
|
17
|
-
### {Name} ({Role}) — Raw Output
|
|
18
|
-
{Paste agent's verbatim response here, unedited}
|
|
19
|
-
|
|
20
|
-
### {Name} ({Role}) — Raw Output
|
|
21
|
-
{Paste agent's verbatim response here, unedited}
|
|
22
|
-
```
|
|
23
|
-
|
|
24
|
-
## Appendix Rules
|
|
25
|
-
|
|
26
|
-
This appendix is for diagnostic integrity. Do not edit, summarize, or polish the raw outputs. The Coordinator may not rewrite raw agent outputs; it may only paste them verbatim and assemble the final artifact above.
|
|
27
|
-
|
|
28
|
-
See `.squad/templates/run-output.md` for the complete output format template.
|
|
1
|
+
# Multi-Agent Artifact Format
|
|
2
|
+
|
|
3
|
+
When multiple agents contribute to a final artifact (document, analysis, design), use this format. The assembled result must include:
|
|
4
|
+
|
|
5
|
+
- Termination condition
|
|
6
|
+
- Constraint budgets (if active)
|
|
7
|
+
- Reviewer verdicts (if any)
|
|
8
|
+
- Raw agent outputs appendix
|
|
9
|
+
|
|
10
|
+
## Assembly Structure
|
|
11
|
+
|
|
12
|
+
The assembled result goes at the top. Below it, include:
|
|
13
|
+
|
|
14
|
+
```
|
|
15
|
+
## APPENDIX: RAW AGENT OUTPUTS
|
|
16
|
+
|
|
17
|
+
### {Name} ({Role}) — Raw Output
|
|
18
|
+
{Paste agent's verbatim response here, unedited}
|
|
19
|
+
|
|
20
|
+
### {Name} ({Role}) — Raw Output
|
|
21
|
+
{Paste agent's verbatim response here, unedited}
|
|
22
|
+
```
|
|
23
|
+
|
|
24
|
+
## Appendix Rules
|
|
25
|
+
|
|
26
|
+
This appendix is for diagnostic integrity. Do not edit, summarize, or polish the raw outputs. The Coordinator may not rewrite raw agent outputs; it may only paste them verbatim and assemble the final artifact above.
|
|
27
|
+
|
|
28
|
+
See `.squad/templates/run-output.md` for the complete output format template.
|
|
@@ -1,27 +1,27 @@
|
|
|
1
|
-
# Orchestration Log Entry
|
|
2
|
-
|
|
3
|
-
> One file per agent spawn. Saved to `.squad/orchestration-log/{timestamp}-{agent-name}.md`
|
|
4
|
-
|
|
5
|
-
---
|
|
6
|
-
|
|
7
|
-
### {timestamp} — {task summary}
|
|
8
|
-
|
|
9
|
-
| Field | Value |
|
|
10
|
-
|-------|-------|
|
|
11
|
-
| **Agent routed** | {Name} ({Role}) |
|
|
12
|
-
| **Why chosen** | {Routing rationale — what in the request matched this agent} |
|
|
13
|
-
| **Mode** | {`background` / `sync`} |
|
|
14
|
-
| **Why this mode** | {Brief reason — e.g., "No hard data dependencies" or "User needs to approve architecture"} |
|
|
15
|
-
| **Files authorized to read** | {Exact file paths the agent was told to read} |
|
|
16
|
-
| **File(s) agent must produce** | {Exact file paths the agent is expected to create or modify} |
|
|
17
|
-
| **Outcome** | {Completed / Rejected by {Reviewer} / Escalated} |
|
|
18
|
-
|
|
19
|
-
---
|
|
20
|
-
|
|
21
|
-
## Rules
|
|
22
|
-
|
|
23
|
-
1. **One file per agent spawn.** Named `{timestamp}-{agent-name}.md`.
|
|
24
|
-
2. **Log BEFORE spawning.** The entry must exist before the agent runs.
|
|
25
|
-
3. **Update outcome AFTER the agent completes.** Fill in the Outcome field.
|
|
26
|
-
4. **Never delete or edit past entries.** Append-only.
|
|
27
|
-
5. **If a reviewer rejects work,** log the rejection as a new entry with the revision agent.
|
|
1
|
+
# Orchestration Log Entry
|
|
2
|
+
|
|
3
|
+
> One file per agent spawn. Saved to `.squad/orchestration-log/{timestamp}-{agent-name}.md`
|
|
4
|
+
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
### {timestamp} — {task summary}
|
|
8
|
+
|
|
9
|
+
| Field | Value |
|
|
10
|
+
|-------|-------|
|
|
11
|
+
| **Agent routed** | {Name} ({Role}) |
|
|
12
|
+
| **Why chosen** | {Routing rationale — what in the request matched this agent} |
|
|
13
|
+
| **Mode** | {`background` / `sync`} |
|
|
14
|
+
| **Why this mode** | {Brief reason — e.g., "No hard data dependencies" or "User needs to approve architecture"} |
|
|
15
|
+
| **Files authorized to read** | {Exact file paths the agent was told to read} |
|
|
16
|
+
| **File(s) agent must produce** | {Exact file paths the agent is expected to create or modify} |
|
|
17
|
+
| **Outcome** | {Completed / Rejected by {Reviewer} / Escalated} |
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
## Rules
|
|
22
|
+
|
|
23
|
+
1. **One file per agent spawn.** Named `{timestamp}-{agent-name}.md`.
|
|
24
|
+
2. **Log BEFORE spawning.** The entry must exist before the agent runs.
|
|
25
|
+
3. **Update outcome AFTER the agent completes.** Fill in the Outcome field.
|
|
26
|
+
4. **Never delete or edit past entries.** Append-only.
|
|
27
|
+
5. **If a reviewer rejects work,** log the rejection as a new entry with the revision agent.
|
|
@@ -1,49 +1,49 @@
|
|
|
1
|
-
# Plugin Marketplace
|
|
2
|
-
|
|
3
|
-
Plugins are curated agent templates, skills, instructions, and prompts shared by the community via GitHub repositories (e.g., `github/awesome-copilot`, `anthropics/skills`). They provide ready-made expertise for common domains — cloud platforms, frameworks, testing strategies, etc.
|
|
4
|
-
|
|
5
|
-
## Marketplace State
|
|
6
|
-
|
|
7
|
-
Registered marketplace sources are stored in `.squad/plugins/marketplaces.json`:
|
|
8
|
-
|
|
9
|
-
```json
|
|
10
|
-
{
|
|
11
|
-
"marketplaces": [
|
|
12
|
-
{
|
|
13
|
-
"name": "awesome-copilot",
|
|
14
|
-
"source": "github/awesome-copilot",
|
|
15
|
-
"added_at": "2026-02-14T00:00:00Z"
|
|
16
|
-
}
|
|
17
|
-
]
|
|
18
|
-
}
|
|
19
|
-
```
|
|
20
|
-
|
|
21
|
-
## CLI Commands
|
|
22
|
-
|
|
23
|
-
Users manage marketplaces via the CLI:
|
|
24
|
-
- `squad plugin marketplace add {owner/repo}` — Register a GitHub repo as a marketplace source
|
|
25
|
-
- `squad plugin marketplace remove {name}` — Remove a registered marketplace
|
|
26
|
-
- `squad plugin marketplace list` — List registered marketplaces
|
|
27
|
-
- `squad plugin marketplace browse {name}` — List available plugins in a marketplace
|
|
28
|
-
|
|
29
|
-
## When to Browse
|
|
30
|
-
|
|
31
|
-
During the **Adding Team Members** flow, AFTER allocating a name but BEFORE generating the charter:
|
|
32
|
-
|
|
33
|
-
1. Read `.squad/plugins/marketplaces.json`. If the file doesn't exist or `marketplaces` is empty, skip silently.
|
|
34
|
-
2. For each registered marketplace, search for plugins whose name or description matches the new member's role or domain keywords.
|
|
35
|
-
3. Present matching plugins to the user: *"Found '{plugin-name}' in {marketplace} marketplace — want me to install it as a skill for {CastName}?"*
|
|
36
|
-
4. If the user accepts, install the plugin (see below). If they decline or skip, proceed without it.
|
|
37
|
-
|
|
38
|
-
## How to Install a Plugin
|
|
39
|
-
|
|
40
|
-
1. Read the plugin content from the marketplace repository (the plugin's `SKILL.md` or equivalent).
|
|
41
|
-
2. Copy it into the agent's skills directory: `.squad/skills/{plugin-name}/SKILL.md`
|
|
42
|
-
3. If the plugin includes charter-level instructions (role boundaries, tool preferences), merge those into the agent's `charter.md`.
|
|
43
|
-
4. Log the installation in the agent's `history.md`: *"📦 Plugin '{plugin-name}' installed from {marketplace}."*
|
|
44
|
-
|
|
45
|
-
## Graceful Degradation
|
|
46
|
-
|
|
47
|
-
- **No marketplaces configured:** Skip the marketplace check entirely. No warning, no prompt.
|
|
48
|
-
- **Marketplace unreachable:** Warn the user (*"⚠ Couldn't reach {marketplace} — continuing without it"*) and proceed with team member creation normally.
|
|
49
|
-
- **No matching plugins:** Inform the user (*"No matching plugins found in configured marketplaces"*) and proceed.
|
|
1
|
+
# Plugin Marketplace
|
|
2
|
+
|
|
3
|
+
Plugins are curated agent templates, skills, instructions, and prompts shared by the community via GitHub repositories (e.g., `github/awesome-copilot`, `anthropics/skills`). They provide ready-made expertise for common domains — cloud platforms, frameworks, testing strategies, etc.
|
|
4
|
+
|
|
5
|
+
## Marketplace State
|
|
6
|
+
|
|
7
|
+
Registered marketplace sources are stored in `.squad/plugins/marketplaces.json`:
|
|
8
|
+
|
|
9
|
+
```json
|
|
10
|
+
{
|
|
11
|
+
"marketplaces": [
|
|
12
|
+
{
|
|
13
|
+
"name": "awesome-copilot",
|
|
14
|
+
"source": "github/awesome-copilot",
|
|
15
|
+
"added_at": "2026-02-14T00:00:00Z"
|
|
16
|
+
}
|
|
17
|
+
]
|
|
18
|
+
}
|
|
19
|
+
```
|
|
20
|
+
|
|
21
|
+
## CLI Commands
|
|
22
|
+
|
|
23
|
+
Users manage marketplaces via the CLI:
|
|
24
|
+
- `squad plugin marketplace add {owner/repo}` — Register a GitHub repo as a marketplace source
|
|
25
|
+
- `squad plugin marketplace remove {name}` — Remove a registered marketplace
|
|
26
|
+
- `squad plugin marketplace list` — List registered marketplaces
|
|
27
|
+
- `squad plugin marketplace browse {name}` — List available plugins in a marketplace
|
|
28
|
+
|
|
29
|
+
## When to Browse
|
|
30
|
+
|
|
31
|
+
During the **Adding Team Members** flow, AFTER allocating a name but BEFORE generating the charter:
|
|
32
|
+
|
|
33
|
+
1. Read `.squad/plugins/marketplaces.json`. If the file doesn't exist or `marketplaces` is empty, skip silently.
|
|
34
|
+
2. For each registered marketplace, search for plugins whose name or description matches the new member's role or domain keywords.
|
|
35
|
+
3. Present matching plugins to the user: *"Found '{plugin-name}' in {marketplace} marketplace — want me to install it as a skill for {CastName}?"*
|
|
36
|
+
4. If the user accepts, install the plugin (see below). If they decline or skip, proceed without it.
|
|
37
|
+
|
|
38
|
+
## How to Install a Plugin
|
|
39
|
+
|
|
40
|
+
1. Read the plugin content from the marketplace repository (the plugin's `SKILL.md` or equivalent).
|
|
41
|
+
2. Copy it into the agent's skills directory: `.squad/skills/{plugin-name}/SKILL.md`
|
|
42
|
+
3. If the plugin includes charter-level instructions (role boundaries, tool preferences), merge those into the agent's `charter.md`.
|
|
43
|
+
4. Log the installation in the agent's `history.md`: *"📦 Plugin '{plugin-name}' installed from {marketplace}."*
|
|
44
|
+
|
|
45
|
+
## Graceful Degradation
|
|
46
|
+
|
|
47
|
+
- **No marketplaces configured:** Skip the marketplace check entirely. No warning, no prompt.
|
|
48
|
+
- **Marketplace unreachable:** Warn the user (*"⚠ Couldn't reach {marketplace} — continuing without it"*) and proceed with team member creation normally.
|
|
49
|
+
- **No matching plugins:** Inform the user (*"No matching plugins found in configured marketplaces"*) and proceed.
|
|
@@ -1,37 +1,37 @@
|
|
|
1
|
-
# Raw Agent Output — Appendix Format
|
|
2
|
-
|
|
3
|
-
> This template defines the format for the `## APPENDIX: RAW AGENT OUTPUTS` section
|
|
4
|
-
> in any multi-agent artifact.
|
|
5
|
-
|
|
6
|
-
## Rules
|
|
7
|
-
|
|
8
|
-
1. **Verbatim only.** Paste the agent's response exactly as returned. No edits.
|
|
9
|
-
2. **No summarizing.** Do not condense, paraphrase, or rephrase any part of the output.
|
|
10
|
-
3. **No rewriting.** Do not fix typos, grammar, formatting, or style.
|
|
11
|
-
4. **No code fences around the entire output.** The raw output is pasted as-is, not wrapped in ``` blocks.
|
|
12
|
-
5. **One section per agent.** Each agent that contributed gets its own heading.
|
|
13
|
-
6. **Order matches work order.** List agents in the order they were spawned.
|
|
14
|
-
7. **Include all outputs.** Even if an agent's work was rejected, include their output for diagnostic traceability.
|
|
15
|
-
|
|
16
|
-
## Format
|
|
17
|
-
|
|
18
|
-
```markdown
|
|
19
|
-
## APPENDIX: RAW AGENT OUTPUTS
|
|
20
|
-
|
|
21
|
-
### {Name} ({Role}) — Raw Output
|
|
22
|
-
|
|
23
|
-
{Paste agent's verbatim response here, unedited}
|
|
24
|
-
|
|
25
|
-
### {Name} ({Role}) — Raw Output
|
|
26
|
-
|
|
27
|
-
{Paste agent's verbatim response here, unedited}
|
|
28
|
-
```
|
|
29
|
-
|
|
30
|
-
## Why This Exists
|
|
31
|
-
|
|
32
|
-
The appendix provides diagnostic integrity. It lets anyone verify:
|
|
33
|
-
- What each agent actually said (vs. what the Coordinator assembled)
|
|
34
|
-
- Whether the Coordinator faithfully represented agent work
|
|
35
|
-
- What was lost or changed in synthesis
|
|
36
|
-
|
|
37
|
-
Without raw outputs, multi-agent collaboration is unauditable.
|
|
1
|
+
# Raw Agent Output — Appendix Format
|
|
2
|
+
|
|
3
|
+
> This template defines the format for the `## APPENDIX: RAW AGENT OUTPUTS` section
|
|
4
|
+
> in any multi-agent artifact.
|
|
5
|
+
|
|
6
|
+
## Rules
|
|
7
|
+
|
|
8
|
+
1. **Verbatim only.** Paste the agent's response exactly as returned. No edits.
|
|
9
|
+
2. **No summarizing.** Do not condense, paraphrase, or rephrase any part of the output.
|
|
10
|
+
3. **No rewriting.** Do not fix typos, grammar, formatting, or style.
|
|
11
|
+
4. **No code fences around the entire output.** The raw output is pasted as-is, not wrapped in ``` blocks.
|
|
12
|
+
5. **One section per agent.** Each agent that contributed gets its own heading.
|
|
13
|
+
6. **Order matches work order.** List agents in the order they were spawned.
|
|
14
|
+
7. **Include all outputs.** Even if an agent's work was rejected, include their output for diagnostic traceability.
|
|
15
|
+
|
|
16
|
+
## Format
|
|
17
|
+
|
|
18
|
+
```markdown
|
|
19
|
+
## APPENDIX: RAW AGENT OUTPUTS
|
|
20
|
+
|
|
21
|
+
### {Name} ({Role}) — Raw Output
|
|
22
|
+
|
|
23
|
+
{Paste agent's verbatim response here, unedited}
|
|
24
|
+
|
|
25
|
+
### {Name} ({Role}) — Raw Output
|
|
26
|
+
|
|
27
|
+
{Paste agent's verbatim response here, unedited}
|
|
28
|
+
```
|
|
29
|
+
|
|
30
|
+
## Why This Exists
|
|
31
|
+
|
|
32
|
+
The appendix provides diagnostic integrity. It lets anyone verify:
|
|
33
|
+
- What each agent actually said (vs. what the Coordinator assembled)
|
|
34
|
+
- Whether the Coordinator faithfully represented agent work
|
|
35
|
+
- What was lost or changed in synthesis
|
|
36
|
+
|
|
37
|
+
Without raw outputs, multi-agent collaboration is unauditable.
|
package/templates/roster.md
CHANGED
|
@@ -1,60 +1,60 @@
|
|
|
1
|
-
# Team Roster
|
|
2
|
-
|
|
3
|
-
> {One-line project description}
|
|
4
|
-
|
|
5
|
-
## Coordinator
|
|
6
|
-
|
|
7
|
-
| Name | Role | Notes |
|
|
8
|
-
|------|------|-------|
|
|
9
|
-
| Squad | Coordinator | Routes work, enforces handoffs and reviewer gates. Does not generate domain artifacts. |
|
|
10
|
-
|
|
11
|
-
## Members
|
|
12
|
-
|
|
13
|
-
| Name | Role | Charter | Status |
|
|
14
|
-
|------|------|---------|--------|
|
|
15
|
-
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
16
|
-
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
17
|
-
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
18
|
-
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
19
|
-
| Scribe | Session Logger | `.squad/agents/scribe/charter.md` | 📋 Silent |
|
|
20
|
-
| Ralph | Work Monitor | — | 🔄 Monitor |
|
|
21
|
-
|
|
22
|
-
## Coding Agent
|
|
23
|
-
|
|
24
|
-
<!-- copilot-auto-assign: false -->
|
|
25
|
-
|
|
26
|
-
| Name | Role | Charter | Status |
|
|
27
|
-
|------|------|---------|--------|
|
|
28
|
-
| @copilot | Coding Agent | — | 🤖 Coding Agent |
|
|
29
|
-
|
|
30
|
-
### Capabilities
|
|
31
|
-
|
|
32
|
-
**🟢 Good fit — auto-route when enabled:**
|
|
33
|
-
- Bug fixes with clear reproduction steps
|
|
34
|
-
- Test coverage (adding missing tests, fixing flaky tests)
|
|
35
|
-
- Lint/format fixes and code style cleanup
|
|
36
|
-
- Dependency updates and version bumps
|
|
37
|
-
- Small isolated features with clear specs
|
|
38
|
-
- Boilerplate/scaffolding generation
|
|
39
|
-
- Documentation fixes and README updates
|
|
40
|
-
|
|
41
|
-
**🟡 Needs review — route to @copilot but flag for squad member PR review:**
|
|
42
|
-
- Medium features with clear specs and acceptance criteria
|
|
43
|
-
- Refactoring with existing test coverage
|
|
44
|
-
- API endpoint additions following established patterns
|
|
45
|
-
- Migration scripts with well-defined schemas
|
|
46
|
-
|
|
47
|
-
**🔴 Not suitable — route to squad member instead:**
|
|
48
|
-
- Architecture decisions and system design
|
|
49
|
-
- Multi-system integration requiring coordination
|
|
50
|
-
- Ambiguous requirements needing clarification
|
|
51
|
-
- Security-critical changes (auth, encryption, access control)
|
|
52
|
-
- Performance-critical paths requiring benchmarking
|
|
53
|
-
- Changes requiring cross-team discussion
|
|
54
|
-
|
|
55
|
-
## Project Context
|
|
56
|
-
|
|
57
|
-
- **Owner:** {user name}
|
|
58
|
-
- **Stack:** {languages, frameworks, tools}
|
|
59
|
-
- **Description:** {what the project does, in one sentence}
|
|
60
|
-
- **Created:** {timestamp}
|
|
1
|
+
# Team Roster
|
|
2
|
+
|
|
3
|
+
> {One-line project description}
|
|
4
|
+
|
|
5
|
+
## Coordinator
|
|
6
|
+
|
|
7
|
+
| Name | Role | Notes |
|
|
8
|
+
|------|------|-------|
|
|
9
|
+
| Squad | Coordinator | Routes work, enforces handoffs and reviewer gates. Does not generate domain artifacts. |
|
|
10
|
+
|
|
11
|
+
## Members
|
|
12
|
+
|
|
13
|
+
| Name | Role | Charter | Status |
|
|
14
|
+
|------|------|---------|--------|
|
|
15
|
+
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
16
|
+
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
17
|
+
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
18
|
+
| {Name} | {Role} | `.squad/agents/{name}/charter.md` | ✅ Active |
|
|
19
|
+
| Scribe | Session Logger | `.squad/agents/scribe/charter.md` | 📋 Silent |
|
|
20
|
+
| Ralph | Work Monitor | — | 🔄 Monitor |
|
|
21
|
+
|
|
22
|
+
## Coding Agent
|
|
23
|
+
|
|
24
|
+
<!-- copilot-auto-assign: false -->
|
|
25
|
+
|
|
26
|
+
| Name | Role | Charter | Status |
|
|
27
|
+
|------|------|---------|--------|
|
|
28
|
+
| @copilot | Coding Agent | — | 🤖 Coding Agent |
|
|
29
|
+
|
|
30
|
+
### Capabilities
|
|
31
|
+
|
|
32
|
+
**🟢 Good fit — auto-route when enabled:**
|
|
33
|
+
- Bug fixes with clear reproduction steps
|
|
34
|
+
- Test coverage (adding missing tests, fixing flaky tests)
|
|
35
|
+
- Lint/format fixes and code style cleanup
|
|
36
|
+
- Dependency updates and version bumps
|
|
37
|
+
- Small isolated features with clear specs
|
|
38
|
+
- Boilerplate/scaffolding generation
|
|
39
|
+
- Documentation fixes and README updates
|
|
40
|
+
|
|
41
|
+
**🟡 Needs review — route to @copilot but flag for squad member PR review:**
|
|
42
|
+
- Medium features with clear specs and acceptance criteria
|
|
43
|
+
- Refactoring with existing test coverage
|
|
44
|
+
- API endpoint additions following established patterns
|
|
45
|
+
- Migration scripts with well-defined schemas
|
|
46
|
+
|
|
47
|
+
**🔴 Not suitable — route to squad member instead:**
|
|
48
|
+
- Architecture decisions and system design
|
|
49
|
+
- Multi-system integration requiring coordination
|
|
50
|
+
- Ambiguous requirements needing clarification
|
|
51
|
+
- Security-critical changes (auth, encryption, access control)
|
|
52
|
+
- Performance-critical paths requiring benchmarking
|
|
53
|
+
- Changes requiring cross-team discussion
|
|
54
|
+
|
|
55
|
+
## Project Context
|
|
56
|
+
|
|
57
|
+
- **Owner:** {user name}
|
|
58
|
+
- **Stack:** {languages, frameworks, tools}
|
|
59
|
+
- **Description:** {what the project does, in one sentence}
|
|
60
|
+
- **Created:** {timestamp}
|
package/templates/routing.md
CHANGED
|
@@ -1,54 +1,54 @@
|
|
|
1
|
-
# Work Routing
|
|
2
|
-
|
|
3
|
-
How to decide who handles what.
|
|
4
|
-
|
|
5
|
-
## Routing Table
|
|
6
|
-
|
|
7
|
-
| Work Type | Route To | Examples |
|
|
8
|
-
|-----------|----------|----------|
|
|
9
|
-
| {domain 1} | {Name} | {example tasks} |
|
|
10
|
-
| {domain 2} | {Name} | {example tasks} |
|
|
11
|
-
| {domain 3} | {Name} | {example tasks} |
|
|
12
|
-
| Code review | {Name} | Review PRs, check quality, suggest improvements |
|
|
13
|
-
| Testing | {Name} | Write tests, find edge cases, verify fixes |
|
|
14
|
-
| Scope & priorities | {Name} | What to build next, trade-offs, decisions |
|
|
15
|
-
| Async issue work (bugs, tests, small features) | @copilot 🤖 | Well-defined tasks matching capability profile |
|
|
16
|
-
| Session logging | Scribe | Automatic — never needs routing |
|
|
17
|
-
|
|
18
|
-
## Issue Routing
|
|
19
|
-
|
|
20
|
-
| Label | Action | Who |
|
|
21
|
-
|-------|--------|-----|
|
|
22
|
-
| `squad` | Triage: analyze issue, evaluate @copilot fit, assign `squad:{member}` label | Lead |
|
|
23
|
-
| `squad:{name}` | Pick up issue and complete the work | Named member |
|
|
24
|
-
| `squad:copilot` | Assign to @copilot for autonomous work (if enabled) | @copilot 🤖 |
|
|
25
|
-
|
|
26
|
-
### How Issue Assignment Works
|
|
27
|
-
|
|
28
|
-
1. When a GitHub issue gets the `squad` label, the **Lead** triages it — analyzing content, evaluating @copilot's capability profile, assigning the right `squad:{member}` label, and commenting with triage notes.
|
|
29
|
-
2. **@copilot evaluation:** The Lead checks if the issue matches @copilot's capability profile (🟢 good fit / 🟡 needs review / 🔴 not suitable). If it's a good fit, the Lead may route to `squad:copilot` instead of a squad member.
|
|
30
|
-
3. When a `squad:{member}` label is applied, that member picks up the issue in their next session.
|
|
31
|
-
4. When `squad:copilot` is applied and auto-assign is enabled, `@copilot` is assigned on the issue and picks it up autonomously.
|
|
32
|
-
5. Members can reassign by removing their label and adding another member's label.
|
|
33
|
-
6. The `squad` label is the "inbox" — untriaged issues waiting for Lead review.
|
|
34
|
-
|
|
35
|
-
### Lead Triage Guidance for @copilot
|
|
36
|
-
|
|
37
|
-
When triaging, the Lead should ask:
|
|
38
|
-
|
|
39
|
-
1. **Is this well-defined?** Clear title, reproduction steps or acceptance criteria, bounded scope → likely 🟢
|
|
40
|
-
2. **Does it follow existing patterns?** Adding a test, fixing a known bug, updating a dependency → likely 🟢
|
|
41
|
-
3. **Does it need design judgment?** Architecture, API design, UX decisions → likely 🔴
|
|
42
|
-
4. **Is it security-sensitive?** Auth, encryption, access control → always 🔴
|
|
43
|
-
5. **Is it medium complexity with specs?** Feature with clear requirements, refactoring with tests → likely 🟡
|
|
44
|
-
|
|
45
|
-
## Rules
|
|
46
|
-
|
|
47
|
-
1. **Eager by default** — spawn all agents who could usefully start work, including anticipatory downstream work.
|
|
48
|
-
2. **Scribe always runs** after substantial work, always as `mode: "background"`. Never blocks.
|
|
49
|
-
3. **Quick facts → coordinator answers directly.** Don't spawn an agent for "what port does the server run on?"
|
|
50
|
-
4. **When two agents could handle it**, pick the one whose domain is the primary concern.
|
|
51
|
-
5. **"Team, ..." → fan-out.** Spawn all relevant agents in parallel as `mode: "background"`.
|
|
52
|
-
6. **Anticipate downstream work.** If a feature is being built, spawn the tester to write test cases from requirements simultaneously.
|
|
53
|
-
7. **Issue-labeled work** — when a `squad:{member}` label is applied to an issue, route to that member. The Lead handles all `squad` (base label) triage.
|
|
54
|
-
8. **@copilot routing** — when evaluating issues, check @copilot's capability profile in `team.md`. Route 🟢 good-fit tasks to `squad:copilot`. Flag 🟡 needs-review tasks for PR review. Keep 🔴 not-suitable tasks with squad members.
|
|
1
|
+
# Work Routing
|
|
2
|
+
|
|
3
|
+
How to decide who handles what.
|
|
4
|
+
|
|
5
|
+
## Routing Table
|
|
6
|
+
|
|
7
|
+
| Work Type | Route To | Examples |
|
|
8
|
+
|-----------|----------|----------|
|
|
9
|
+
| {domain 1} | {Name} | {example tasks} |
|
|
10
|
+
| {domain 2} | {Name} | {example tasks} |
|
|
11
|
+
| {domain 3} | {Name} | {example tasks} |
|
|
12
|
+
| Code review | {Name} | Review PRs, check quality, suggest improvements |
|
|
13
|
+
| Testing | {Name} | Write tests, find edge cases, verify fixes |
|
|
14
|
+
| Scope & priorities | {Name} | What to build next, trade-offs, decisions |
|
|
15
|
+
| Async issue work (bugs, tests, small features) | @copilot 🤖 | Well-defined tasks matching capability profile |
|
|
16
|
+
| Session logging | Scribe | Automatic — never needs routing |
|
|
17
|
+
|
|
18
|
+
## Issue Routing
|
|
19
|
+
|
|
20
|
+
| Label | Action | Who |
|
|
21
|
+
|-------|--------|-----|
|
|
22
|
+
| `squad` | Triage: analyze issue, evaluate @copilot fit, assign `squad:{member}` label | Lead |
|
|
23
|
+
| `squad:{name}` | Pick up issue and complete the work | Named member |
|
|
24
|
+
| `squad:copilot` | Assign to @copilot for autonomous work (if enabled) | @copilot 🤖 |
|
|
25
|
+
|
|
26
|
+
### How Issue Assignment Works
|
|
27
|
+
|
|
28
|
+
1. When a GitHub issue gets the `squad` label, the **Lead** triages it — analyzing content, evaluating @copilot's capability profile, assigning the right `squad:{member}` label, and commenting with triage notes.
|
|
29
|
+
2. **@copilot evaluation:** The Lead checks if the issue matches @copilot's capability profile (🟢 good fit / 🟡 needs review / 🔴 not suitable). If it's a good fit, the Lead may route to `squad:copilot` instead of a squad member.
|
|
30
|
+
3. When a `squad:{member}` label is applied, that member picks up the issue in their next session.
|
|
31
|
+
4. When `squad:copilot` is applied and auto-assign is enabled, `@copilot` is assigned on the issue and picks it up autonomously.
|
|
32
|
+
5. Members can reassign by removing their label and adding another member's label.
|
|
33
|
+
6. The `squad` label is the "inbox" — untriaged issues waiting for Lead review.
|
|
34
|
+
|
|
35
|
+
### Lead Triage Guidance for @copilot
|
|
36
|
+
|
|
37
|
+
When triaging, the Lead should ask:
|
|
38
|
+
|
|
39
|
+
1. **Is this well-defined?** Clear title, reproduction steps or acceptance criteria, bounded scope → likely 🟢
|
|
40
|
+
2. **Does it follow existing patterns?** Adding a test, fixing a known bug, updating a dependency → likely 🟢
|
|
41
|
+
3. **Does it need design judgment?** Architecture, API design, UX decisions → likely 🔴
|
|
42
|
+
4. **Is it security-sensitive?** Auth, encryption, access control → always 🔴
|
|
43
|
+
5. **Is it medium complexity with specs?** Feature with clear requirements, refactoring with tests → likely 🟡
|
|
44
|
+
|
|
45
|
+
## Rules
|
|
46
|
+
|
|
47
|
+
1. **Eager by default** — spawn all agents who could usefully start work, including anticipatory downstream work.
|
|
48
|
+
2. **Scribe always runs** after substantial work, always as `mode: "background"`. Never blocks.
|
|
49
|
+
3. **Quick facts → coordinator answers directly.** Don't spawn an agent for "what port does the server run on?"
|
|
50
|
+
4. **When two agents could handle it**, pick the one whose domain is the primary concern.
|
|
51
|
+
5. **"Team, ..." → fan-out.** Spawn all relevant agents in parallel as `mode: "background"`.
|
|
52
|
+
6. **Anticipate downstream work.** If a feature is being built, spawn the tester to write test cases from requirements simultaneously.
|
|
53
|
+
7. **Issue-labeled work** — when a `squad:{member}` label is applied to an issue, route to that member. The Lead handles all `squad` (base label) triage.
|
|
54
|
+
8. **@copilot routing** — when evaluating issues, check @copilot's capability profile in `team.md`. Route 🟢 good-fit tasks to `squad:copilot`. Flag 🟡 needs-review tasks for PR review. Keep 🔴 not-suitable tasks with squad members.
|
package/templates/run-output.md
CHANGED
|
@@ -1,50 +1,50 @@
|
|
|
1
|
-
# Run Output — {task title}
|
|
2
|
-
|
|
3
|
-
> Final assembled artifact from a multi-agent run.
|
|
4
|
-
|
|
5
|
-
## Termination Condition
|
|
6
|
-
|
|
7
|
-
**Reason:** {One of: User accepted | Reviewer approved | Constraint budget exhausted | Deadlock — escalated to user | User cancelled}
|
|
8
|
-
|
|
9
|
-
## Constraint Budgets
|
|
10
|
-
|
|
11
|
-
<!-- Track all active constraints inline. Remove this section if no constraints are active. -->
|
|
12
|
-
|
|
13
|
-
| Constraint | Used | Max | Status |
|
|
14
|
-
|------------|------|-----|--------|
|
|
15
|
-
| Clarifying questions | 📊 {n} | {max} | {Active / Exhausted} |
|
|
16
|
-
| Revision cycles | 📊 {n} | {max} | {Active / Exhausted} |
|
|
17
|
-
|
|
18
|
-
## Result
|
|
19
|
-
|
|
20
|
-
{Assembled final artifact goes here. This is the Coordinator's synthesis of agent outputs.}
|
|
21
|
-
|
|
22
|
-
---
|
|
23
|
-
|
|
24
|
-
## Reviewer Verdict
|
|
25
|
-
|
|
26
|
-
<!-- Include one block per review. Remove this section if no review occurred. -->
|
|
27
|
-
|
|
28
|
-
### Review by {Name} ({Role})
|
|
29
|
-
|
|
30
|
-
| Field | Value |
|
|
31
|
-
|-------|-------|
|
|
32
|
-
| **Verdict** | {Approved / Rejected} |
|
|
33
|
-
| **What's wrong** | {Specific issue — not vague} |
|
|
34
|
-
| **Why it matters** | {Impact if not fixed} |
|
|
35
|
-
| **Who fixes it** | {Name of agent assigned to revise — MUST NOT be the original author} |
|
|
36
|
-
| **Revision budget** | 📊 {used} / {max} revision cycles remaining |
|
|
37
|
-
|
|
38
|
-
---
|
|
39
|
-
|
|
40
|
-
## APPENDIX: RAW AGENT OUTPUTS
|
|
41
|
-
|
|
42
|
-
<!-- Paste each agent's verbatim response below. Do NOT edit, summarize, rewrite, or wrap in code fences. One section per agent. -->
|
|
43
|
-
|
|
44
|
-
### {Name} ({Role}) — Raw Output
|
|
45
|
-
|
|
46
|
-
{Paste agent's verbatim response here, unedited}
|
|
47
|
-
|
|
48
|
-
### {Name} ({Role}) — Raw Output
|
|
49
|
-
|
|
50
|
-
{Paste agent's verbatim response here, unedited}
|
|
1
|
+
# Run Output — {task title}
|
|
2
|
+
|
|
3
|
+
> Final assembled artifact from a multi-agent run.
|
|
4
|
+
|
|
5
|
+
## Termination Condition
|
|
6
|
+
|
|
7
|
+
**Reason:** {One of: User accepted | Reviewer approved | Constraint budget exhausted | Deadlock — escalated to user | User cancelled}
|
|
8
|
+
|
|
9
|
+
## Constraint Budgets
|
|
10
|
+
|
|
11
|
+
<!-- Track all active constraints inline. Remove this section if no constraints are active. -->
|
|
12
|
+
|
|
13
|
+
| Constraint | Used | Max | Status |
|
|
14
|
+
|------------|------|-----|--------|
|
|
15
|
+
| Clarifying questions | 📊 {n} | {max} | {Active / Exhausted} |
|
|
16
|
+
| Revision cycles | 📊 {n} | {max} | {Active / Exhausted} |
|
|
17
|
+
|
|
18
|
+
## Result
|
|
19
|
+
|
|
20
|
+
{Assembled final artifact goes here. This is the Coordinator's synthesis of agent outputs.}
|
|
21
|
+
|
|
22
|
+
---
|
|
23
|
+
|
|
24
|
+
## Reviewer Verdict
|
|
25
|
+
|
|
26
|
+
<!-- Include one block per review. Remove this section if no review occurred. -->
|
|
27
|
+
|
|
28
|
+
### Review by {Name} ({Role})
|
|
29
|
+
|
|
30
|
+
| Field | Value |
|
|
31
|
+
|-------|-------|
|
|
32
|
+
| **Verdict** | {Approved / Rejected} |
|
|
33
|
+
| **What's wrong** | {Specific issue — not vague} |
|
|
34
|
+
| **Why it matters** | {Impact if not fixed} |
|
|
35
|
+
| **Who fixes it** | {Name of agent assigned to revise — MUST NOT be the original author} |
|
|
36
|
+
| **Revision budget** | 📊 {used} / {max} revision cycles remaining |
|
|
37
|
+
|
|
38
|
+
---
|
|
39
|
+
|
|
40
|
+
## APPENDIX: RAW AGENT OUTPUTS
|
|
41
|
+
|
|
42
|
+
<!-- Paste each agent's verbatim response below. Do NOT edit, summarize, rewrite, or wrap in code fences. One section per agent. -->
|
|
43
|
+
|
|
44
|
+
### {Name} ({Role}) — Raw Output
|
|
45
|
+
|
|
46
|
+
{Paste agent's verbatim response here, unedited}
|
|
47
|
+
|
|
48
|
+
### {Name} ({Role}) — Raw Output
|
|
49
|
+
|
|
50
|
+
{Paste agent's verbatim response here, unedited}
|