@arthai/agents 1.0.4 → 1.0.6

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.
Files changed (131) hide show
  1. package/README.md +55 -3
  2. package/VERSION +1 -1
  3. package/agents/troubleshooter.md +132 -0
  4. package/bin/cli.js +366 -0
  5. package/bundles/canvas.json +1 -1
  6. package/bundles/compass.json +1 -1
  7. package/bundles/counsel.json +1 -0
  8. package/bundles/cruise.json +1 -1
  9. package/bundles/forge.json +12 -1
  10. package/bundles/prism.json +1 -0
  11. package/bundles/scalpel.json +5 -2
  12. package/bundles/sentinel.json +8 -2
  13. package/bundles/shield.json +1 -0
  14. package/bundles/spark.json +1 -0
  15. package/compiler.sh +14 -0
  16. package/dist/plugins/canvas/.claude-plugin/plugin.json +1 -1
  17. package/dist/plugins/canvas/VERSION +1 -0
  18. package/dist/plugins/canvas/commands/planning.md +100 -11
  19. package/dist/plugins/canvas/hooks/hooks.json +16 -0
  20. package/dist/plugins/canvas/hooks/project-setup.sh +109 -0
  21. package/dist/plugins/canvas/templates/CLAUDE.md.managed-block +123 -0
  22. package/dist/plugins/canvas/templates/CLAUDE.md.template +111 -0
  23. package/dist/plugins/compass/.claude-plugin/plugin.json +1 -1
  24. package/dist/plugins/compass/VERSION +1 -0
  25. package/dist/plugins/compass/commands/planning.md +100 -11
  26. package/dist/plugins/compass/hooks/hooks.json +16 -0
  27. package/dist/plugins/compass/hooks/project-setup.sh +109 -0
  28. package/dist/plugins/compass/templates/CLAUDE.md.managed-block +123 -0
  29. package/dist/plugins/compass/templates/CLAUDE.md.template +111 -0
  30. package/dist/plugins/counsel/.claude-plugin/plugin.json +1 -1
  31. package/dist/plugins/counsel/VERSION +1 -0
  32. package/dist/plugins/counsel/hooks/hooks.json +10 -0
  33. package/dist/plugins/counsel/hooks/project-setup.sh +109 -0
  34. package/dist/plugins/counsel/templates/CLAUDE.md.managed-block +123 -0
  35. package/dist/plugins/counsel/templates/CLAUDE.md.template +111 -0
  36. package/dist/plugins/cruise/.claude-plugin/plugin.json +1 -1
  37. package/dist/plugins/cruise/VERSION +1 -0
  38. package/dist/plugins/cruise/hooks/hooks.json +16 -0
  39. package/dist/plugins/cruise/hooks/project-setup.sh +109 -0
  40. package/dist/plugins/cruise/templates/CLAUDE.md.managed-block +123 -0
  41. package/dist/plugins/cruise/templates/CLAUDE.md.template +111 -0
  42. package/dist/plugins/forge/.claude-plugin/plugin.json +1 -1
  43. package/dist/plugins/forge/VERSION +1 -0
  44. package/dist/plugins/forge/agents/troubleshooter.md +132 -0
  45. package/dist/plugins/forge/commands/implement.md +99 -1
  46. package/dist/plugins/forge/commands/planning.md +100 -11
  47. package/dist/plugins/forge/hooks/escalation-guard.sh +177 -0
  48. package/dist/plugins/forge/hooks/hooks.json +22 -0
  49. package/dist/plugins/forge/hooks/project-setup.sh +109 -0
  50. package/dist/plugins/forge/templates/CLAUDE.md.managed-block +123 -0
  51. package/dist/plugins/forge/templates/CLAUDE.md.template +111 -0
  52. package/dist/plugins/prime/.claude-plugin/plugin.json +1 -1
  53. package/dist/plugins/prime/VERSION +1 -0
  54. package/dist/plugins/prime/agents/troubleshooter.md +132 -0
  55. package/dist/plugins/prime/commands/calibrate.md +20 -0
  56. package/dist/plugins/prime/commands/ci-fix.md +36 -0
  57. package/dist/plugins/prime/commands/fix.md +23 -0
  58. package/dist/plugins/prime/commands/implement.md +99 -1
  59. package/dist/plugins/prime/commands/planning.md +100 -11
  60. package/dist/plugins/prime/commands/qa-incident.md +54 -0
  61. package/dist/plugins/prime/commands/restart.md +186 -30
  62. package/dist/plugins/prime/hooks/escalation-guard.sh +177 -0
  63. package/dist/plugins/prime/hooks/hooks.json +60 -0
  64. package/dist/plugins/prime/hooks/post-config-change-restart-reminder.sh +86 -0
  65. package/dist/plugins/prime/hooks/post-server-crash-watch.sh +120 -0
  66. package/dist/plugins/prime/hooks/pre-server-port-guard.sh +110 -0
  67. package/dist/plugins/prime/hooks/project-setup.sh +109 -0
  68. package/dist/plugins/prime/hooks/sync-agents.sh +99 -12
  69. package/dist/plugins/prime/templates/CLAUDE.md.managed-block +123 -0
  70. package/dist/plugins/prime/templates/CLAUDE.md.template +111 -0
  71. package/dist/plugins/prism/.claude-plugin/plugin.json +1 -1
  72. package/dist/plugins/prism/VERSION +1 -0
  73. package/dist/plugins/prism/commands/qa-incident.md +54 -0
  74. package/dist/plugins/prism/hooks/hooks.json +12 -0
  75. package/dist/plugins/prism/hooks/project-setup.sh +109 -0
  76. package/dist/plugins/prism/templates/CLAUDE.md.managed-block +123 -0
  77. package/dist/plugins/prism/templates/CLAUDE.md.template +111 -0
  78. package/dist/plugins/scalpel/.claude-plugin/plugin.json +1 -1
  79. package/dist/plugins/scalpel/VERSION +1 -0
  80. package/dist/plugins/scalpel/agents/troubleshooter.md +132 -0
  81. package/dist/plugins/scalpel/commands/ci-fix.md +36 -0
  82. package/dist/plugins/scalpel/commands/fix.md +23 -0
  83. package/dist/plugins/scalpel/hooks/escalation-guard.sh +177 -0
  84. package/dist/plugins/scalpel/hooks/hooks.json +24 -0
  85. package/dist/plugins/scalpel/hooks/project-setup.sh +109 -0
  86. package/dist/plugins/scalpel/templates/CLAUDE.md.managed-block +123 -0
  87. package/dist/plugins/scalpel/templates/CLAUDE.md.template +111 -0
  88. package/dist/plugins/sentinel/.claude-plugin/plugin.json +1 -1
  89. package/dist/plugins/sentinel/VERSION +1 -0
  90. package/dist/plugins/sentinel/agents/troubleshooter.md +132 -0
  91. package/dist/plugins/sentinel/commands/restart.md +186 -30
  92. package/dist/plugins/sentinel/hooks/escalation-guard.sh +177 -0
  93. package/dist/plugins/sentinel/hooks/hooks.json +64 -0
  94. package/dist/plugins/sentinel/hooks/post-config-change-restart-reminder.sh +86 -0
  95. package/dist/plugins/sentinel/hooks/post-server-crash-watch.sh +120 -0
  96. package/dist/plugins/sentinel/hooks/pre-server-port-guard.sh +110 -0
  97. package/dist/plugins/sentinel/hooks/project-setup.sh +109 -0
  98. package/dist/plugins/sentinel/templates/CLAUDE.md.managed-block +123 -0
  99. package/dist/plugins/sentinel/templates/CLAUDE.md.template +111 -0
  100. package/dist/plugins/shield/.claude-plugin/plugin.json +1 -1
  101. package/dist/plugins/shield/VERSION +1 -0
  102. package/dist/plugins/shield/hooks/hooks.json +22 -12
  103. package/dist/plugins/shield/hooks/project-setup.sh +109 -0
  104. package/dist/plugins/shield/templates/CLAUDE.md.managed-block +123 -0
  105. package/dist/plugins/shield/templates/CLAUDE.md.template +111 -0
  106. package/dist/plugins/spark/.claude-plugin/plugin.json +1 -1
  107. package/dist/plugins/spark/VERSION +1 -0
  108. package/dist/plugins/spark/commands/calibrate.md +20 -0
  109. package/dist/plugins/spark/hooks/hooks.json +10 -0
  110. package/dist/plugins/spark/hooks/project-setup.sh +109 -0
  111. package/dist/plugins/spark/templates/CLAUDE.md.managed-block +123 -0
  112. package/dist/plugins/spark/templates/CLAUDE.md.template +111 -0
  113. package/hook-defs.json +31 -0
  114. package/hooks/escalation-guard.sh +177 -0
  115. package/hooks/post-config-change-restart-reminder.sh +86 -0
  116. package/hooks/post-server-crash-watch.sh +120 -0
  117. package/hooks/pre-server-port-guard.sh +110 -0
  118. package/hooks/project-setup.sh +109 -0
  119. package/hooks/sync-agents.sh +99 -12
  120. package/install.sh +2 -2
  121. package/package.json +1 -1
  122. package/portable.manifest +7 -1
  123. package/skills/calibrate/SKILL.md +20 -0
  124. package/skills/ci-fix/SKILL.md +36 -0
  125. package/skills/fix/SKILL.md +23 -0
  126. package/skills/implement/SKILL.md +99 -1
  127. package/skills/license/SKILL.md +159 -0
  128. package/skills/planning/SKILL.md +100 -11
  129. package/skills/publish/SKILL.md +3 -0
  130. package/skills/qa-incident/SKILL.md +54 -0
  131. package/skills/restart/SKILL.md +187 -31
@@ -22,8 +22,9 @@ if [ ! -d "$AGENTS_DIR/.git" ]; then
22
22
  exit 0
23
23
  fi
24
24
 
25
- # Exit silently if no license
26
- if [ ! -f "$LICENSE_FILE" ]; then
25
+ # Exit silently if no license found in any path
26
+ ARTHAI_LICENSE_PATH="$REAL_HOME/.arthai/license"
27
+ if [ ! -f "$LICENSE_FILE" ] && [ ! -f "$ARTHAI_LICENSE_PATH" ] && [ -z "${ARTHAI_LICENSE_KEY:-}" ]; then
27
28
  exit 0
28
29
  fi
29
30
 
@@ -108,6 +109,27 @@ fi
108
109
 
109
110
  # --- Step 2: Check license (with revocation enforcement) ---
110
111
  NOW=$(date +%s)
112
+ WORKER_URL="https://license-worker.muddassar-shaikh.workers.dev"
113
+
114
+ # Resolve license key: ~/.claude-agents/.license takes priority (existing clone-install users),
115
+ # fall back to ~/.arthai/license (npm activate users).
116
+ ARTHAI_LICENSE_KEY_VALUE="${ARTHAI_LICENSE_KEY:-}"
117
+ RESOLVED_KEY=""
118
+ if [ -n "$ARTHAI_LICENSE_KEY_VALUE" ]; then
119
+ RESOLVED_KEY="$ARTHAI_LICENSE_KEY_VALUE"
120
+ elif [ -f "$LICENSE_FILE" ]; then
121
+ RESOLVED_KEY=$(cat "$LICENSE_FILE" 2>/dev/null | tr -d '[:space:]' || echo "")
122
+ elif [ -f "$REAL_HOME/.arthai/license" ]; then
123
+ RESOLVED_KEY=$(cat "$REAL_HOME/.arthai/license" 2>/dev/null | tr -d '[:space:]' || echo "")
124
+ fi
125
+
126
+ # Validate key format before using it in any JSON payload — prevents JSON injection
127
+ # via a crafted key value in the env var or license file.
128
+ KEY_FORMAT='^ARTH-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}-[A-Z0-9]{4}$'
129
+ if [ -n "$RESOLVED_KEY" ] && ! echo "$RESOLVED_KEY" | grep -qE "$KEY_FORMAT"; then
130
+ # Key has invalid format — don't use it for Worker call or local check
131
+ RESOLVED_KEY=""
132
+ fi
111
133
 
112
134
  # Detect if authorized-keys.txt changed in the pull — force re-check if so
113
135
  AK_HASH_FILE="$AGENTS_DIR/.ak-hash"
@@ -128,6 +150,49 @@ fi
128
150
  # Store current hash for next comparison
129
151
  [ -n "$AK_CURRENT_HASH" ] && echo "$AK_CURRENT_HASH" > "$AK_HASH_FILE" 2>/dev/null || true
130
152
 
153
+ # validate_with_worker: call Worker /validate with the resolved key.
154
+ # Sets WORKER_RESULT: "valid", "invalid" (definitive), or "network_error".
155
+ validate_with_worker() {
156
+ local key="$1"
157
+ if [ -z "$key" ]; then
158
+ WORKER_RESULT="invalid"
159
+ return
160
+ fi
161
+
162
+ local payload="{\"key\":\"$key\"}"
163
+ local response
164
+ local curl_exit
165
+
166
+ # Pass payload via stdin (--data @-) so the key is not visible in the process list
167
+ response=$(printf '%s' "$payload" | curl \
168
+ --silent \
169
+ --max-time 10 \
170
+ --connect-timeout 5 \
171
+ --request POST \
172
+ --header "Content-Type: application/json" \
173
+ --data "@-" \
174
+ "$WORKER_URL/validate" 2>/dev/null)
175
+ curl_exit=$?
176
+
177
+ if [ $curl_exit -ne 0 ] || [ -z "$response" ]; then
178
+ WORKER_RESULT="network_error"
179
+ return
180
+ fi
181
+
182
+ # Parse "valid" field from JSON — minimal grep-based parse, no jq dependency
183
+ local valid_field
184
+ valid_field=$(echo "$response" | grep -o '"valid"[[:space:]]*:[[:space:]]*[a-z]*' | head -1 | grep -o '[a-z]*$')
185
+
186
+ if [ "$valid_field" = "true" ]; then
187
+ WORKER_RESULT="valid"
188
+ elif [ "$valid_field" = "false" ]; then
189
+ WORKER_RESULT="invalid"
190
+ else
191
+ # Unexpected response format — treat as network error (fail safe)
192
+ WORKER_RESULT="network_error"
193
+ fi
194
+ }
195
+
131
196
  LICENSE_VALID=true
132
197
  if [ -f "$LICENSE_CACHE" ]; then
133
198
  LAST_CHECK=$(cat "$LICENSE_CACHE" 2>/dev/null || echo "0")
@@ -136,19 +201,41 @@ if [ -f "$LICENSE_CACHE" ]; then
136
201
  # Cache is fresh, skip validation
137
202
  :
138
203
  else
139
- # Re-validate
140
- if ! "$AGENTS_DIR/install.sh" --check-license-only 2>/dev/null; then
204
+ # Re-validate: try Worker first, fall back to local only on network error
205
+ validate_with_worker "$RESOLVED_KEY"
206
+ if [ "$WORKER_RESULT" = "valid" ]; then
207
+ echo "$NOW" > "$LICENSE_CACHE"
208
+ elif [ "$WORKER_RESULT" = "invalid" ]; then
209
+ # Worker says definitively invalid — no local fallback, clear cache
210
+ rm -f "$LICENSE_CACHE" 2>/dev/null || true
141
211
  LICENSE_VALID=false
142
212
  else
143
- echo "$NOW" > "$LICENSE_CACHE"
213
+ # Network error — fall back to local authorized-keys.txt check
214
+ echo "License server unavailable. Retrying with local validation..." >&2
215
+ if ! "$AGENTS_DIR/install.sh" --check-license-only 2>/dev/null; then
216
+ LICENSE_VALID=false
217
+ else
218
+ echo "$NOW" > "$LICENSE_CACHE"
219
+ fi
144
220
  fi
145
221
  fi
146
222
  else
147
- # First check (or cache was invalidated by AK change)
148
- if ! "$AGENTS_DIR/install.sh" --check-license-only 2>/dev/null; then
223
+ # First check (or cache was invalidated by AK change): try Worker first
224
+ validate_with_worker "$RESOLVED_KEY"
225
+ if [ "$WORKER_RESULT" = "valid" ]; then
226
+ echo "$NOW" > "$LICENSE_CACHE"
227
+ elif [ "$WORKER_RESULT" = "invalid" ]; then
228
+ # Worker says definitively invalid — no local fallback, ensure cache stays clear
229
+ rm -f "$LICENSE_CACHE" 2>/dev/null || true
149
230
  LICENSE_VALID=false
150
231
  else
151
- echo "$NOW" > "$LICENSE_CACHE"
232
+ # Network error — fall back to local authorized-keys.txt check
233
+ echo "License server unavailable. Retrying with local validation..." >&2
234
+ if ! "$AGENTS_DIR/install.sh" --check-license-only 2>/dev/null; then
235
+ LICENSE_VALID=false
236
+ else
237
+ echo "$NOW" > "$LICENSE_CACHE"
238
+ fi
152
239
  fi
153
240
  fi
154
241
 
@@ -182,12 +269,12 @@ if ! $LICENSE_VALID; then
182
269
 
183
270
  # Remove CLAUDE.md managed block
184
271
  CLAUDEMD="$PROJECT_DIR/CLAUDE.md"
185
- if [ -f "$CLAUDEMD" ] && grep -qF "<!-- >>> claude-agents toolkit -->" "$CLAUDEMD" 2>/dev/null; then
272
+ if [ -f "$CLAUDEMD" ] && grep -qF "<!-- >>> claude-agents toolkit (DO NOT EDIT THIS BLOCK) >>> -->" "$CLAUDEMD" 2>/dev/null; then
186
273
  tmp=$(mktemp)
187
274
  in_block=false
188
275
  skip_next_blank=false
189
276
  while IFS= read -r line; do
190
- if echo "$line" | grep -qF "<!-- >>> claude-agents toolkit -->"; then
277
+ if echo "$line" | grep -qF "<!-- >>> claude-agents toolkit (DO NOT EDIT THIS BLOCK) >>> -->"; then
191
278
  in_block=true
192
279
  continue
193
280
  fi
@@ -218,8 +305,8 @@ if ! $LICENSE_VALID; then
218
305
  rm -f "$LICENSE_CACHE" 2>/dev/null || true
219
306
  fi
220
307
 
221
- echo " License revoked. Toolkit has been disabled for this project."
222
- echo " Contact support to renew your license."
308
+ echo "Invalid license key. Toolkit has been disabled for this project."
309
+ echo " Check your key or get one at arthai.dev/pricing"
223
310
  exit 0
224
311
  fi
225
312
 
@@ -0,0 +1,123 @@
1
+ ## Engineering Principles (MANDATORY — applies to ALL work)
2
+
3
+ ### Research Before Fixing
4
+ - **Never guess.** Before changing code, read the relevant source files, docs, and configs.
5
+ - Understand WHY something is broken before attempting a fix.
6
+ - If your first fix doesn't work, STOP. Don't try another guess. Re-read the code.
7
+ - Use explore-light (Haiku, 1x cost) to scan the codebase before expensive agents investigate.
8
+
9
+ ### No Over-Engineering
10
+ - **Do exactly what's needed.** Don't add abstractions, utilities, or frameworks unless the code already uses them.
11
+ - Match existing patterns — run explore-light to find how similar code is structured before writing new code.
12
+ - A bug fix touches the minimum files possible. A feature matches the existing architecture.
13
+ - If you're creating a new class/helper/utility that nothing else in the codebase uses, you're over-engineering.
14
+
15
+ ### Test Before Shipping
16
+ - **Run tests locally before pushing.** Never push untested code.
17
+ - If the project has `/precheck`, run it. If it has `/qa`, run it in commit mode.
18
+ - After fixing a bug, verify the fix AND verify nothing else broke (differential testing).
19
+ - If 3+ consecutive fix attempts fail, STOP. Step back and reassess the root cause from scratch.
20
+
21
+ ### Deployment Safety
22
+ - **Never modify production systems without explicit confirmation.**
23
+ - Don't change deploy targets, CI pipeline structure, or infrastructure config silently.
24
+ - Don't overwrite existing files during deployment without asking.
25
+ - If a deployment breaks something, investigate before attempting to fix. Don't cascade.
26
+
27
+ ## Toolkit Awareness (MANDATORY — READ THIS FIRST)
28
+
29
+ You have a **claude-agents toolkit** installed in this project. It provides specialized
30
+ agents, skills, and hooks that handle domain-specific work better and cheaper.
31
+
32
+ **You are the ORCHESTRATOR.** The triage router fires on every message with a routing
33
+ table and SPEED score. Use it to decide: toolkit or you?
34
+
35
+ ### When to use the toolkit (SPEED score 2+):
36
+ - **Multi-step workflows**: `/pr`, `/deploy`, `/planning`, `/implement`, `/qa`, `/ci-fix`
37
+ encode battle-tested sequences you'd otherwise do manually and forget steps
38
+ - **Domain expertise**: SRE, QA, frontend, backend agents have project context baked in
39
+ - **Cost savings**: Haiku/Sonnet agents handle 80% of tasks at 1/60th the cost of Opus
40
+ - **Parallelism**: Team skills spawn multiple agents working simultaneously
41
+
42
+ ### When to use YOU directly (SPEED score 0-1):
43
+ - **Quick lookups**: Read/Grep/Glob for finding a file, checking a value, reading code
44
+ - **Small targeted edits**: 1-2 file changes where you already know what to do
45
+ - **Complex reasoning**: Architecture decisions, debugging novel problems, nuanced tradeoffs
46
+ - **Conversation flow**: Follow-up questions, clarifications, explaining code
47
+ - **Creative problem-solving**: When the task doesn't fit any existing pattern
48
+ - **Judgment calls**: Security reviews, design decisions, "should we even do this?"
49
+
50
+ ### The balance:
51
+ The toolkit handles **process** (repeatable workflows, domain-specific checks, multi-step
52
+ sequences). You handle **judgment** (reasoning, creativity, novel problems, architecture).
53
+
54
+ A senior engineer doesn't do everything themselves — they delegate routine work and focus
55
+ their expertise where it matters most. That's you. The toolkit is your team.
56
+
57
+ **Don't over-delegate**: If it's faster to just Read a file and answer, do it.
58
+ **Don't under-delegate**: If it's a 5-step workflow the toolkit has a skill for, use it.
59
+
60
+ ### Project Knowledge System
61
+
62
+ If this project has been calibrated (`/calibrate`), deep context is available:
63
+
64
+ - **`.claude/project-profile.md`** — Architecture patterns, coding conventions, domain model,
65
+ testing style. Read this before writing any code to match the project's patterns.
66
+ - **`.claude/knowledge/`** — The toolkit's long-term memory for this project:
67
+ - `shared/conventions.md` — Coding rules learned from corrections. **Read before writing code.**
68
+ - `shared/domain.md` — Business rules beyond what's in the code. **Read before domain decisions.**
69
+ - `shared/vocabulary.md` — What the team calls things. **Use these terms.**
70
+ - `shared/patterns.md` — Architecture patterns. **Follow these when adding new code.**
71
+ - `agents/{your-name}.md` — Your past learning. **Read on session start.**
72
+ - **Write back** when you learn something new — corrections, discoveries, decisions.
73
+ - See `knowledge/README.md` for the full protocol.
74
+ - **`.claude/knowledge/external/sources.md`** — Where team knowledge lives outside code
75
+ (Notion, Linear, Figma, etc.). Check before making decisions that might already be documented.
76
+
77
+ ## Session Start Behavior (MANDATORY)
78
+
79
+ On your FIRST response in every new session, ALWAYS start with a brief status line
80
+ using context from the SessionStart hook. Include:
81
+ - Current branch + uncommitted file count
82
+ - Docker/infra status (if problems detected)
83
+ - Open PRs or assigned issues (if any)
84
+ - Any red flags (pending migrations, expired tokens)
85
+
86
+ Format: 1-3 compact lines before addressing the user's request. Example:
87
+ ```
88
+ 📋 project — main | 5 uncommitted | Docker: postgres ✓ redis ✓ | 2 open PRs
89
+ ```
90
+ Then proceed with the user's actual request.
91
+
92
+ **CRITICAL — Greetings and vague first messages**: If the user's first message is a
93
+ greeting ("hey", "hi", "hello", "yo", "sup") or vague ("help", "what's up",
94
+ "what should I work on") or ANY message under 5 words with no specific task —
95
+ **ALWAYS use the `/onboard` skill**. Never respond to greetings yourself. The
96
+ bootstrap hook status line is a quick snapshot — `/onboard` gives the real briefing
97
+ with open PRs, issues, priorities, and actionable next steps.
98
+
99
+ ## Routing Trace (MANDATORY)
100
+
101
+ On EVERY response, show a compact routing trace so the user understands the decision
102
+ path. Place it at the end of your response in a dimmed block:
103
+
104
+ ```
105
+ 🔀 Routing: [what triage decided] → [agent/skill/tool used] ([cost tier])
106
+ Why: [1-line reason for this routing choice]
107
+ ```
108
+
109
+ Examples:
110
+ ```
111
+ 🔀 Routing: backend bug fix → python-backend agent (Sonnet, 10x)
112
+ Why: touches backend/app/services/, needs CLAUDE.md context, SPEED=4
113
+ ```
114
+ ```
115
+ 🔀 Routing: file lookup → Grep (built-in, 0x)
116
+ Why: single-file search, no project context needed, SPEED=0
117
+ ```
118
+
119
+ Rules:
120
+ - Always show the SPEED score breakdown if score >= 2
121
+ - Show which hook provided the context (triage-router, bootstrap, etc.)
122
+ - If you chose NOT to use the triage router's suggestion, explain why
123
+ - Skip the trace only for simple follow-up messages in an ongoing conversation
@@ -0,0 +1,111 @@
1
+ # CLAUDE.md — {{PROJECT_NAME}}
2
+
3
+ <!-- Generated by claude-agents install.sh --init -->
4
+ <!-- TODO: Replace {{placeholders}} with your project details -->
5
+
6
+ ## Project Overview
7
+
8
+ {{PROJECT_NAME}} is a {{DESCRIPTION}}.
9
+
10
+ ## Tech Stack
11
+
12
+ - **Frontend**: <!-- TODO: e.g., Next.js 14, React 18, TypeScript, Tailwind -->
13
+ - **Backend**: <!-- TODO: e.g., FastAPI, SQLAlchemy, PostgreSQL -->
14
+ - **Auth**: <!-- TODO: e.g., Stytch, Auth0, Clerk -->
15
+ - **Deploy**: <!-- TODO: e.g., Railway, Vercel, AWS -->
16
+
17
+ ## Project Structure
18
+
19
+ ```
20
+ {{PROJECT_NAME}}/
21
+ ├── frontend/ <!-- TODO: Frontend directory -->
22
+ ├── backend/ <!-- TODO: Backend directory -->
23
+ └── ...
24
+ ```
25
+
26
+ ## Key Architecture
27
+
28
+ <!-- TODO: Describe your auth flow, API patterns, database schema, etc. -->
29
+
30
+ ## Local Dev Services
31
+
32
+ <!-- TODO: Auto-populated by /scan or fill manually -->
33
+
34
+ | Service | Port | Directory | Start Command |
35
+ |----------|------|-----------|---------------|
36
+ | Frontend | <!-- TODO --> | frontend/ | <!-- TODO: e.g., npm run dev --> |
37
+ | Backend | <!-- TODO --> | backend/ | <!-- TODO: e.g., uvicorn app.main:app --reload --> |
38
+
39
+ ## Test Commands
40
+
41
+ <!-- TODO: Auto-populated by /scan or fill manually -->
42
+
43
+ | What | Command | Directory |
44
+ |------|---------|-----------|
45
+ | Backend tests | <!-- TODO: e.g., pytest --> | backend/ |
46
+ | Backend lint | <!-- TODO: e.g., ruff check . --> | backend/ |
47
+ | Frontend tests | <!-- TODO: e.g., npm test --> | frontend/ |
48
+ | Frontend lint | <!-- TODO: e.g., npm run lint --> | frontend/ |
49
+ | Type check | <!-- TODO: e.g., npx tsc --noEmit --> | frontend/ |
50
+ | E2E tests | <!-- TODO: e.g., npx playwright test --> | frontend/ |
51
+
52
+ ## Infrastructure
53
+
54
+ <!-- TODO: Auto-populated by /scan or fill manually -->
55
+
56
+ | Platform | Service | Domain |
57
+ |----------|---------|--------|
58
+ | <!-- TODO: e.g., Railway --> | <!-- TODO --> | <!-- TODO --> |
59
+
60
+ Health endpoints: <!-- TODO: e.g., /health, /api/health -->
61
+
62
+ ## Environments
63
+
64
+ <!-- TODO: Auto-populated by /scan environments or /calibrate -->
65
+
66
+ | Name | Type | URL | Health | Deploy | Branch |
67
+ |------|------|-----|--------|--------|--------|
68
+ | local | development | <!-- TODO --> | <!-- TODO: e.g., /health --> | manual | — |
69
+ | <!-- TODO --> | <!-- TODO: staging/production/preview/canary --> | <!-- TODO --> | <!-- TODO --> | <!-- TODO --> | <!-- TODO --> |
70
+
71
+ Access notes: <!-- TODO: e.g., Railway MCP for staging/prod. Env vars: .env.local, .env.staging -->
72
+
73
+ ## Domain
74
+
75
+ <!-- TODO: Auto-populated by /scan or fill manually -->
76
+ <!-- Describe what this app does, its core entities, and business rules. -->
77
+ <!-- Used by qa-domain agent for domain-aware testing. -->
78
+
79
+ ## Running Locally
80
+
81
+ ```bash
82
+ # TODO: Add your local development commands
83
+ # Frontend
84
+ cd frontend && npm run dev
85
+
86
+ # Backend
87
+ cd backend && source .venv/bin/activate && uvicorn app.main:app --reload
88
+ ```
89
+
90
+ ## Critical Rules
91
+
92
+ <!-- TODO: Add project-specific rules, e.g.: -->
93
+ - Never push to main directly — always create a PR
94
+ - Secrets in .env.local only — never committed
95
+
96
+ ## Agent Customization
97
+
98
+ The following agents/skills are managed by `claude-agents` (symlinked):
99
+ - Run `~/.claude-agents/install.sh --status` to see what's linked
100
+ - To override any portable file, replace the symlink with a regular file
101
+ - Your override won't be touched by future syncs
102
+
103
+ ### Project-Specific Agents
104
+
105
+ Add project-specific agents as regular files in `.claude/agents/`:
106
+ - See `~/.claude-agents/examples/agents/` for templates (frontend, backend, ops, sre, qa)
107
+
108
+ ### Project-Specific Skills
109
+
110
+ Add project-specific skills as regular directories in `.claude/skills/`:
111
+ - See `~/.claude-agents/examples/skills/` for templates (ci-fix, qa, restart)
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "prism",
3
3
  "description": "Deep QA — multi-agent testing, baseline tracking, incident analysis",
4
- "version": "1.0.4",
4
+ "version": "1.0.6",
5
5
  "author": {
6
6
  "name": "Arth AI"
7
7
  }
@@ -0,0 +1 @@
1
+ 1.0.6
@@ -40,6 +40,60 @@ affected_files:
40
40
 
41
41
  4. **Confirm to user**: "Incident logged. Next `/qa` run will generate a regression test targeting this issue."
42
42
 
43
+ ## Auto-Logging from Escalation (Circuit Breaker Resolution)
44
+
45
+ When an agent resolves a stuck situation (circuit breaker was tripped, then the issue was fixed),
46
+ the resolution should be logged automatically. This enables future agents to find the fix
47
+ without repeating the same debugging journey.
48
+
49
+ **Trigger:** Any workflow that resolves an error after the escalation guard tripped (3+ consecutive failures).
50
+
51
+ **Auto-log format** — create `.claude/qa-knowledge/incidents/{date}-escalation-{slug}.md`:
52
+
53
+ ```markdown
54
+ ---
55
+ date: {today YYYY-MM-DD}
56
+ severity: medium
57
+ status: covered
58
+ type: escalation-resolution
59
+ error_signature: {from .claude/.escalation-state.json}
60
+ affected_files:
61
+ - {files that were modified to fix the issue}
62
+ ---
63
+ # Escalation: {brief description of what was stuck}
64
+
65
+ ## Error
66
+ {exact error message that triggered the circuit breaker}
67
+
68
+ ## What Was Tried (failed)
69
+ 1. {attempt 1 from escalation state} → {result}
70
+ 2. {attempt 2} → {result}
71
+ 3. {attempt 3} → {result}
72
+
73
+ ## Root Cause
74
+ {what was actually wrong}
75
+
76
+ ## Fix Applied
77
+ {what change resolved the issue}
78
+
79
+ ## How to Prevent
80
+ {if applicable — what convention or check would catch this earlier}
81
+
82
+ ## Search Keywords
83
+ {error message fragments, file names, command patterns — for future KB searches}
84
+ ```
85
+
86
+ **Also update** `.claude/qa-knowledge/bug-patterns.md` if this represents a new pattern:
87
+ ```
88
+ ## {Pattern name}
89
+ - **Signature:** {error message or command pattern}
90
+ - **Root cause:** {common reason}
91
+ - **Fix:** {standard resolution}
92
+ - **First seen:** {date}
93
+ ```
94
+
95
+ This closes the learning loop: stuck → escalate → fix → log → future agents find it instantly.
96
+
43
97
  ## If No Description Provided
44
98
 
45
99
  Ask: "Describe the issue you want to log (e.g., 'admin page crashes when user has no sessions')"
@@ -1,5 +1,17 @@
1
1
  {
2
2
  "hooks": {
3
+ "SessionStart": [
4
+ {
5
+ "matcher": "",
6
+ "hooks": [
7
+ {
8
+ "type": "command",
9
+ "command": "${CLAUDE_PLUGIN_ROOT}/hooks/project-setup.sh",
10
+ "timeout": 10
11
+ }
12
+ ]
13
+ }
14
+ ],
3
15
  "PostToolUse": [
4
16
  {
5
17
  "matcher": "Bash",
@@ -0,0 +1,109 @@
1
+ #!/bin/bash
2
+ # hooks/project-setup.sh — SessionStart hook: first-run project setup for marketplace installs.
3
+ #
4
+ # Runs on every SessionStart. Checks for marker file .claude/.toolkit-setup-done.
5
+ # If missing (or version is stale): creates CLAUDE.md from template, injects managed block,
6
+ # updates .gitignore with toolkit markers.
7
+ #
8
+ # Templates are read from ${CLAUDE_PLUGIN_ROOT}/templates/ (bundled with the plugin).
9
+
10
+ set -euo pipefail
11
+
12
+ PROJECT_DIR="${CLAUDE_PROJECT_DIR:-$(pwd)}"
13
+ PLUGIN_ROOT="${CLAUDE_PLUGIN_ROOT:-}"
14
+ MARKER_FILE="$PROJECT_DIR/.claude/.toolkit-setup-done"
15
+
16
+ # Exit silently if CLAUDE_PLUGIN_ROOT is not set (not running from a plugin context)
17
+ if [ -z "$PLUGIN_ROOT" ]; then
18
+ exit 0
19
+ fi
20
+
21
+ TEMPLATES_DIR="$PLUGIN_ROOT/templates"
22
+ TEMPLATE_CLAUDE="$TEMPLATES_DIR/CLAUDE.md.template"
23
+ TEMPLATE_BLOCK="$TEMPLATES_DIR/CLAUDE.md.managed-block"
24
+
25
+ # Exit silently if templates are not bundled
26
+ if [ ! -f "$TEMPLATE_CLAUDE" ] || [ ! -f "$TEMPLATE_BLOCK" ]; then
27
+ exit 0
28
+ fi
29
+
30
+ # Read toolkit version from VERSION file (bundled alongside plugin)
31
+ TOOLKIT_VERSION="0.0.0"
32
+ if [ -f "$PLUGIN_ROOT/VERSION" ]; then
33
+ TOOLKIT_VERSION=$(cat "$PLUGIN_ROOT/VERSION" 2>/dev/null | tr -d '[:space:]' || echo "0.0.0")
34
+ fi
35
+
36
+ MANAGED_START="<!-- >>> claude-agents toolkit (DO NOT EDIT THIS BLOCK) >>> -->"
37
+ MANAGED_END="<!-- <<< claude-agents toolkit <<< -->"
38
+ GITIGNORE_START="# >>> claude-agents managed (DO NOT EDIT THIS BLOCK) >>>"
39
+
40
+ # Check marker file — skip if current version is already set up
41
+ if [ -f "$MARKER_FILE" ]; then
42
+ STORED_VERSION=$(cat "$MARKER_FILE" 2>/dev/null | tr -d '[:space:]' || echo "")
43
+ if [ "$STORED_VERSION" = "$TOOLKIT_VERSION" ]; then
44
+ exit 0
45
+ fi
46
+ fi
47
+
48
+ CLAUDE_MD="$PROJECT_DIR/CLAUDE.md"
49
+ GITIGNORE="$PROJECT_DIR/.gitignore"
50
+
51
+ # 1. Create CLAUDE.md from template if it doesn't exist (never overwrite existing)
52
+ if [ ! -f "$CLAUDE_MD" ]; then
53
+ PROJECT_NAME=$(basename "$PROJECT_DIR")
54
+ sed "s/{{PROJECT_NAME}}/$PROJECT_NAME/g" "$TEMPLATE_CLAUDE" > "$CLAUDE_MD"
55
+ fi
56
+
57
+ # 2. Inject managed block into CLAUDE.md if missing, or update if version is stale
58
+ if [ -f "$CLAUDE_MD" ]; then
59
+ BLOCK_CONTENT=$(cat "$TEMPLATE_BLOCK")
60
+ NEW_BLOCK=$(printf '%s\n<!-- version: %s -->\n%s\n%s' \
61
+ "$MANAGED_START" "$TOOLKIT_VERSION" "$BLOCK_CONTENT" "$MANAGED_END")
62
+
63
+ if ! grep -qF "$MANAGED_START" "$CLAUDE_MD"; then
64
+ # Block missing — append it
65
+ printf '\n\n%s\n' "$NEW_BLOCK" >> "$CLAUDE_MD"
66
+ else
67
+ # Block exists — update if version changed
68
+ EXISTING_VERSION=$(grep -o '<!-- version: [^>]* -->' "$CLAUDE_MD" 2>/dev/null | head -1 | sed 's/<!-- version: //;s/ -->//' | tr -d '[:space:]' || echo "")
69
+ if [ "$EXISTING_VERSION" != "$TOOLKIT_VERSION" ]; then
70
+ # Replace block contents between markers
71
+ tmp=$(mktemp)
72
+ in_block=false
73
+ wrote_block=false
74
+ while IFS= read -r line; do
75
+ if echo "$line" | grep -qF "$MANAGED_START"; then
76
+ in_block=true
77
+ printf '%s\n' "$NEW_BLOCK" >> "$tmp"
78
+ wrote_block=true
79
+ continue
80
+ fi
81
+ if echo "$line" | grep -qF "$MANAGED_END"; then
82
+ in_block=false
83
+ continue
84
+ fi
85
+ if ! $in_block; then
86
+ echo "$line" >> "$tmp"
87
+ fi
88
+ done < "$CLAUDE_MD"
89
+ mv "$tmp" "$CLAUDE_MD"
90
+ fi
91
+ fi
92
+ fi
93
+
94
+ # 3. Update .gitignore with toolkit marker block if missing
95
+ if [ ! -f "$GITIGNORE" ] || ! grep -qF "$GITIGNORE_START" "$GITIGNORE" 2>/dev/null; then
96
+ GITIGNORE_BLOCK=$(printf '%s\n.claude/.toolkit-last-seen-sha\n.claude/.toolkit-setup-done\n.claude/.claude-agents.conf\n%s' \
97
+ "$GITIGNORE_START" "# <<< claude-agents managed <<<")
98
+ if [ ! -f "$GITIGNORE" ]; then
99
+ printf '%s\n' "$GITIGNORE_BLOCK" > "$GITIGNORE"
100
+ else
101
+ printf '\n\n%s\n' "$GITIGNORE_BLOCK" >> "$GITIGNORE"
102
+ fi
103
+ fi
104
+
105
+ # 4. Write marker file with current version
106
+ mkdir -p "$PROJECT_DIR/.claude"
107
+ printf '%s\n' "$TOOLKIT_VERSION" > "$MARKER_FILE"
108
+
109
+ exit 0