@event4u/agent-config 5.10.0 → 6.0.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.
Files changed (2224) hide show
  1. package/.claude-plugin/marketplace.json +233 -229
  2. package/AGENTS.md +6 -6
  3. package/CHANGELOG.md +466 -0
  4. package/CONTRIBUTING.md +27 -15
  5. package/MIGRATION.md +102 -0
  6. package/README.md +48 -19
  7. package/dist/agent-src/README.md +64 -0
  8. package/dist/agent-src/commands/agent-handoff.md +124 -0
  9. package/dist/agent-src/commands/agent-status.md +140 -0
  10. package/dist/agent-src/commands/agents/audit.md +158 -0
  11. package/dist/agent-src/commands/agents/init.md +192 -0
  12. package/dist/agent-src/commands/agents/optimize.md +187 -0
  13. package/dist/agent-src/commands/agents/user/accept.md +123 -0
  14. package/dist/agent-src/commands/agents/user/init.md +163 -0
  15. package/dist/agent-src/commands/agents/user/review.md +113 -0
  16. package/dist/agent-src/commands/agents/user/show.md +115 -0
  17. package/dist/agent-src/commands/agents/user/update.md +103 -0
  18. package/dist/agent-src/commands/agents/user.md +71 -0
  19. package/dist/agent-src/commands/agents.md +66 -0
  20. package/dist/agent-src/commands/analytics/prune.md +71 -0
  21. package/dist/agent-src/commands/analytics/show.md +100 -0
  22. package/dist/agent-src/commands/analytics.md +77 -0
  23. package/dist/agent-src/commands/analyze-reference-repo.md +204 -0
  24. package/dist/agent-src/commands/bug-fix.md +193 -0
  25. package/dist/agent-src/commands/bug-investigate.md +186 -0
  26. package/dist/agent-src/commands/challenge-me/vision.md +354 -0
  27. package/dist/agent-src/commands/challenge-me/with-docs.md +339 -0
  28. package/dist/agent-src/commands/challenge-me.md +68 -0
  29. package/dist/agent-src/commands/chat-history/import.md +172 -0
  30. package/dist/agent-src/commands/chat-history/learn.md +184 -0
  31. package/dist/agent-src/commands/chat-history/show.md +113 -0
  32. package/dist/agent-src/commands/chat-history.md +60 -0
  33. package/dist/agent-src/commands/check-current-md.md +143 -0
  34. package/dist/agent-src/commands/commit/in-chunks.md +147 -0
  35. package/dist/agent-src/commands/commit.md +195 -0
  36. package/dist/agent-src/commands/condense.md +239 -0
  37. package/dist/agent-src/commands/context/create.md +181 -0
  38. package/dist/agent-src/commands/context/refactor.md +183 -0
  39. package/dist/agent-src/commands/context.md +52 -0
  40. package/dist/agent-src/commands/cost-report.md +131 -0
  41. package/dist/agent-src/commands/council/analysis.md +147 -0
  42. package/dist/agent-src/commands/council/debate.md +134 -0
  43. package/dist/agent-src/commands/council/default.md +289 -0
  44. package/dist/agent-src/commands/council/design.md +107 -0
  45. package/dist/agent-src/commands/council/optimize.md +123 -0
  46. package/dist/agent-src/commands/council/pr.md +130 -0
  47. package/dist/agent-src/commands/council.md +111 -0
  48. package/dist/agent-src/commands/e2e-heal.md +110 -0
  49. package/dist/agent-src/commands/e2e-plan.md +97 -0
  50. package/dist/agent-src/commands/estimate-ticket.md +92 -0
  51. package/dist/agent-src/commands/evals/agent-handoff.json +34 -0
  52. package/dist/agent-src/commands/evals/agent-status.json +34 -0
  53. package/dist/agent-src/commands/evals/agents.json +34 -0
  54. package/dist/agent-src/commands/evals/commit.json +34 -0
  55. package/dist/agent-src/commands/evals/condense.json +34 -0
  56. package/dist/agent-src/commands/evals/council.json +34 -0
  57. package/dist/agent-src/commands/evals/create-pr.json +34 -0
  58. package/dist/agent-src/commands/evals/estimate-ticket.json +34 -0
  59. package/dist/agent-src/commands/evals/feature.json +34 -0
  60. package/dist/agent-src/commands/evals/fix.json +34 -0
  61. package/dist/agent-src/commands/evals/implement-ticket.json +34 -0
  62. package/dist/agent-src/commands/evals/jira-ticket.json +34 -0
  63. package/dist/agent-src/commands/evals/judge.json +34 -0
  64. package/dist/agent-src/commands/evals/memory.json +34 -0
  65. package/dist/agent-src/commands/evals/mode.json +34 -0
  66. package/dist/agent-src/commands/evals/optimize.json +34 -0
  67. package/dist/agent-src/commands/evals/refine-ticket.json +34 -0
  68. package/dist/agent-src/commands/evals/review-changes.json +34 -0
  69. package/dist/agent-src/commands/evals/roadmap.json +34 -0
  70. package/dist/agent-src/commands/evals/work.json +34 -0
  71. package/dist/agent-src/commands/feature/dev.md +124 -0
  72. package/dist/agent-src/commands/feature/explore.md +191 -0
  73. package/dist/agent-src/commands/feature/plan.md +333 -0
  74. package/dist/agent-src/commands/feature/refactor.md +194 -0
  75. package/dist/agent-src/commands/feature/roadmap.md +222 -0
  76. package/dist/agent-src/commands/feature.md +63 -0
  77. package/dist/agent-src/commands/fix/ci.md +59 -0
  78. package/dist/agent-src/commands/fix/portability.md +108 -0
  79. package/dist/agent-src/commands/fix/pr-bot-comments.md +157 -0
  80. package/dist/agent-src/commands/fix/pr-comments.md +69 -0
  81. package/dist/agent-src/commands/fix/pr-developer-comments.md +163 -0
  82. package/dist/agent-src/commands/fix/refs.md +105 -0
  83. package/dist/agent-src/commands/fix/seeder.md +158 -0
  84. package/dist/agent-src/commands/fix.md +88 -0
  85. package/dist/agent-src/commands/ghostwriter/delete.md +124 -0
  86. package/dist/agent-src/commands/ghostwriter/fetch.md +190 -0
  87. package/dist/agent-src/commands/ghostwriter/list.md +108 -0
  88. package/dist/agent-src/commands/ghostwriter/show.md +119 -0
  89. package/dist/agent-src/commands/ghostwriter/write.md +165 -0
  90. package/dist/agent-src/commands/ghostwriter.md +101 -0
  91. package/dist/agent-src/commands/grill-me.md +45 -0
  92. package/dist/agent-src/commands/image/analyse.md +52 -0
  93. package/dist/agent-src/commands/image/create.md +54 -0
  94. package/dist/agent-src/commands/image/verify.md +49 -0
  95. package/dist/agent-src/commands/image.md +70 -0
  96. package/dist/agent-src/commands/implement-ticket.md +169 -0
  97. package/dist/agent-src/commands/jira-ticket.md +84 -0
  98. package/dist/agent-src/commands/judge/on-diff.md +124 -0
  99. package/dist/agent-src/commands/judge/solo.md +96 -0
  100. package/dist/agent-src/commands/judge/steps.md +94 -0
  101. package/dist/agent-src/commands/judge.md +86 -0
  102. package/dist/agent-src/commands/knowledge/cross-repo.md +72 -0
  103. package/dist/agent-src/commands/knowledge/forget.md +97 -0
  104. package/dist/agent-src/commands/knowledge/ingest.md +115 -0
  105. package/dist/agent-src/commands/knowledge/list.md +95 -0
  106. package/dist/agent-src/commands/knowledge.md +70 -0
  107. package/dist/agent-src/commands/memory/add.md +147 -0
  108. package/dist/agent-src/commands/memory/learn-low-impact.md +148 -0
  109. package/dist/agent-src/commands/memory/load.md +176 -0
  110. package/dist/agent-src/commands/memory/mine-session.md +157 -0
  111. package/dist/agent-src/commands/memory/promote.md +195 -0
  112. package/dist/agent-src/commands/memory/propose.md +122 -0
  113. package/dist/agent-src/commands/memory.md +61 -0
  114. package/dist/agent-src/commands/mode.md +133 -0
  115. package/dist/agent-src/commands/module/create.md +144 -0
  116. package/dist/agent-src/commands/module/explore.md +198 -0
  117. package/dist/agent-src/commands/module.md +52 -0
  118. package/dist/agent-src/commands/optimize/agents-dir.md +119 -0
  119. package/dist/agent-src/commands/optimize/augmentignore.md +312 -0
  120. package/dist/agent-src/commands/optimize/rtk.md +161 -0
  121. package/dist/agent-src/commands/optimize/skills.md +132 -0
  122. package/dist/agent-src/commands/optimize-prompt.md +67 -0
  123. package/dist/agent-src/commands/optimize.md +61 -0
  124. package/dist/agent-src/commands/orchestrate.md +129 -0
  125. package/dist/agent-src/commands/override/create.md +108 -0
  126. package/dist/agent-src/commands/override/manage.md +107 -0
  127. package/dist/agent-src/commands/override.md +72 -0
  128. package/dist/agent-src/commands/package-reset.md +163 -0
  129. package/dist/agent-src/commands/package-test.md +239 -0
  130. package/dist/agent-src/commands/post-as/ghostwriter.md +72 -0
  131. package/dist/agent-src/commands/post-as/me.md +130 -0
  132. package/dist/agent-src/commands/post-as.md +63 -0
  133. package/dist/agent-src/commands/pr/create/description-only.md +161 -0
  134. package/dist/agent-src/commands/pr/create.md +254 -0
  135. package/dist/agent-src/commands/prediction-pool.md +235 -0
  136. package/dist/agent-src/commands/prepare-for-review.md +107 -0
  137. package/dist/agent-src/commands/profile/activate.md +82 -0
  138. package/dist/agent-src/commands/profile/deactivate.md +69 -0
  139. package/dist/agent-src/commands/profile/show.md +80 -0
  140. package/dist/agent-src/commands/profile.md +69 -0
  141. package/dist/agent-src/commands/project-analyze.md +321 -0
  142. package/dist/agent-src/commands/project-health.md +106 -0
  143. package/dist/agent-src/commands/quality-fix.md +145 -0
  144. package/dist/agent-src/commands/refine-ticket.md +98 -0
  145. package/dist/agent-src/commands/research/deep.md +155 -0
  146. package/dist/agent-src/commands/research/report.md +140 -0
  147. package/dist/agent-src/commands/research.md +179 -0
  148. package/dist/agent-src/commands/review-changes.md +213 -0
  149. package/dist/agent-src/commands/review-routing.md +125 -0
  150. package/dist/agent-src/commands/roadmap/ai-council.md +189 -0
  151. package/dist/agent-src/commands/roadmap/create.md +214 -0
  152. package/dist/agent-src/commands/roadmap/process-full.md +109 -0
  153. package/dist/agent-src/commands/roadmap/process-phase.md +75 -0
  154. package/dist/agent-src/commands/roadmap/process-step.md +63 -0
  155. package/dist/agent-src/commands/roadmap.md +83 -0
  156. package/dist/agent-src/commands/rule-compliance-audit.md +156 -0
  157. package/dist/agent-src/commands/set-cost-profile.md +118 -0
  158. package/dist/agent-src/commands/skill/preview.md +68 -0
  159. package/dist/agent-src/commands/skill.md +49 -0
  160. package/dist/agent-src/commands/skills/discover.md +77 -0
  161. package/dist/agent-src/commands/skills.md +57 -0
  162. package/dist/agent-src/commands/sync-agent-settings.md +141 -0
  163. package/dist/agent-src/commands/sync-gitignore/fix.md +149 -0
  164. package/dist/agent-src/commands/sync-gitignore.md +140 -0
  165. package/dist/agent-src/commands/tests/create.md +91 -0
  166. package/dist/agent-src/commands/tests/execute.md +85 -0
  167. package/dist/agent-src/commands/tests.md +76 -0
  168. package/dist/agent-src/commands/threat-model.md +126 -0
  169. package/dist/agent-src/commands/update-form-request-messages.md +200 -0
  170. package/dist/agent-src/commands/upstream-contribute.md +182 -0
  171. package/dist/agent-src/commands/video/from-script.md +158 -0
  172. package/dist/agent-src/commands/video/from-song.md +490 -0
  173. package/dist/agent-src/commands/video/scene.md +130 -0
  174. package/dist/agent-src/commands/video/stitch.md +88 -0
  175. package/dist/agent-src/commands/video/storyboard.md +100 -0
  176. package/dist/agent-src/commands/video.md +74 -0
  177. package/dist/agent-src/commands/work.md +175 -0
  178. package/dist/agent-src/contexts/authority/commit-mechanics.md +93 -0
  179. package/dist/agent-src/contexts/communication/rules-auto/source-of-truth-mechanics.md +99 -0
  180. package/dist/agent-src/contexts/contracts/artifact-engagement-flow.md +259 -0
  181. package/dist/agent-src/contexts/contracts/consumer-agents-md-guide.md +127 -0
  182. package/dist/agent-src/contexts/contracts/emergency-triage-block.md +53 -0
  183. package/dist/agent-src/contexts/execution/non-interactive-contract.md +132 -0
  184. package/dist/agent-src/contexts/execution/toolchain-resolver.md +113 -0
  185. package/dist/agent-src/personas/README.md +114 -0
  186. package/dist/agent-src/profiles/agency.yml +36 -0
  187. package/dist/agent-src/profiles/content_creator.yml +34 -0
  188. package/dist/agent-src/profiles/developer.yml +31 -0
  189. package/dist/agent-src/profiles/finance.yml +30 -0
  190. package/dist/agent-src/profiles/founder.yml +33 -0
  191. package/dist/agent-src/profiles/ops.yml +33 -0
  192. package/dist/agent-src/rules/ask-when-uncertain.md +70 -0
  193. package/dist/agent-src/rules/augment-edit-discipline.md +31 -0
  194. package/dist/agent-src/rules/commit-policy.md +59 -0
  195. package/dist/agent-src/rules/direct-answers.md +64 -0
  196. package/dist/agent-src/rules/domain-adoption-policy.md +160 -0
  197. package/dist/agent-src/rules/language-and-tone.md +64 -0
  198. package/dist/agent-src/rules/linked-projects-onboarding-gate.md +38 -0
  199. package/dist/agent-src/rules/media-governance-routing.md +85 -0
  200. package/dist/agent-src/rules/missing-tool-handling.md +22 -0
  201. package/dist/agent-src/rules/model-recommendation.md +25 -0
  202. package/dist/agent-src/rules/no-attribution-footers.md +57 -0
  203. package/dist/agent-src/rules/no-cheap-questions.md +75 -0
  204. package/dist/agent-src/rules/no-pr-progress-comments.md +109 -0
  205. package/dist/agent-src/rules/no-roadmap-references.md +141 -0
  206. package/dist/agent-src/rules/non-destructive-by-default.md +58 -0
  207. package/dist/agent-src/rules/persona-governance.md +93 -0
  208. package/dist/agent-src/rules/preservation-guard.md +97 -0
  209. package/dist/agent-src/rules/provider-lifecycle-discipline.md +78 -0
  210. package/dist/agent-src/rules/roadmap-progress-sync.md +114 -0
  211. package/dist/agent-src/rules/scope-control.md +68 -0
  212. package/dist/agent-src/rules/source-of-truth.md +80 -0
  213. package/dist/agent-src/rules/user-interrupt-priority.md +49 -0
  214. package/dist/agent-src/rules/verify-before-complete.md +78 -0
  215. package/dist/agent-src/scripts/update_roadmap_progress.py +537 -0
  216. package/dist/agent-src/skills/accessibility-auditor/SKILL.md +147 -0
  217. package/dist/agent-src/skills/accessibility-auditor/data/aria-patterns.csv +13 -0
  218. package/dist/agent-src/skills/accessibility-auditor/data/manifest.json +34 -0
  219. package/dist/agent-src/skills/agents-md-thin-root/SKILL.md +143 -0
  220. package/dist/agent-src/skills/api-design/SKILL.md +120 -0
  221. package/dist/agent-src/skills/api-design/data/api-patterns.csv +13 -0
  222. package/dist/agent-src/skills/api-design/data/manifest.json +34 -0
  223. package/dist/agent-src/skills/api-endpoint/SKILL.md +100 -0
  224. package/dist/agent-src/skills/authz-review/SKILL.md +188 -0
  225. package/dist/agent-src/skills/blade-ui/SKILL.md +135 -0
  226. package/dist/agent-src/skills/character-consistency/SKILL.md +192 -0
  227. package/dist/agent-src/skills/check-refs/SKILL.md +96 -0
  228. package/dist/agent-src/skills/code-review/SKILL.md +224 -0
  229. package/dist/agent-src/skills/command-writing/SKILL.md +301 -0
  230. package/dist/agent-src/skills/condense-memory/SKILL.md +123 -0
  231. package/dist/agent-src/skills/context-document/SKILL.md +160 -0
  232. package/dist/agent-src/skills/corpus-grounding/SKILL.md +205 -0
  233. package/dist/agent-src/skills/corpus-grounding/evals/triggers.json +16 -0
  234. package/dist/agent-src/skills/corpus-grounding/scripts/bm25_search.py +212 -0
  235. package/dist/agent-src/skills/corpus-grounding/scripts/decision_engine.py +438 -0
  236. package/dist/agent-src/skills/corpus-grounding/scripts/ground.py +166 -0
  237. package/dist/agent-src/skills/corpus-grounding/scripts/schema_validator.py +160 -0
  238. package/dist/agent-src/skills/dashboard-design/SKILL.md +129 -0
  239. package/dist/agent-src/skills/database/SKILL.md +111 -0
  240. package/dist/agent-src/skills/database/data/manifest.json +35 -0
  241. package/dist/agent-src/skills/database/data/query-tuning.csv +13 -0
  242. package/dist/agent-src/skills/deep-reading-analyst/SKILL.md +188 -0
  243. package/dist/agent-src/skills/design-intelligence/ATTRIBUTION.md +54 -0
  244. package/dist/agent-src/skills/design-intelligence/LICENSE.apache-2.0.txt +202 -0
  245. package/dist/agent-src/skills/design-intelligence/SKILL.md +177 -0
  246. package/dist/agent-src/skills/design-intelligence/data/app-interface.csv +31 -0
  247. package/dist/agent-src/skills/design-intelligence/data/charts.csv +26 -0
  248. package/dist/agent-src/skills/design-intelligence/data/colors.csv +162 -0
  249. package/dist/agent-src/skills/design-intelligence/data/design-languages/academia.txt +120 -0
  250. package/dist/agent-src/skills/design-intelligence/data/design-languages/bauhaus.txt +140 -0
  251. package/dist/agent-src/skills/design-intelligence/data/design-languages/bold-typography.txt +107 -0
  252. package/dist/agent-src/skills/design-intelligence/data/design-languages/claymorphism.txt +76 -0
  253. package/dist/agent-src/skills/design-intelligence/data/design-languages/cyberpunk.txt +157 -0
  254. package/dist/agent-src/skills/design-intelligence/data/design-languages/enterprise.txt +89 -0
  255. package/dist/agent-src/skills/design-intelligence/data/design-languages/flat-design.txt +66 -0
  256. package/dist/agent-src/skills/design-intelligence/data/design-languages/kinetic.txt +98 -0
  257. package/dist/agent-src/skills/design-intelligence/data/design-languages/material-design.txt +133 -0
  258. package/dist/agent-src/skills/design-intelligence/data/design-languages/modern-dark.txt +123 -0
  259. package/dist/agent-src/skills/design-intelligence/data/design-languages/monochrome.txt +216 -0
  260. package/dist/agent-src/skills/design-intelligence/data/design-languages/neo-brutalism.txt +65 -0
  261. package/dist/agent-src/skills/design-intelligence/data/design-languages/neumorphism.txt +75 -0
  262. package/dist/agent-src/skills/design-intelligence/data/design-languages/saas.txt +109 -0
  263. package/dist/agent-src/skills/design-intelligence/data/design-languages/sketch.txt +83 -0
  264. package/dist/agent-src/skills/design-intelligence/data/design-languages/terminal.txt +80 -0
  265. package/dist/agent-src/skills/design-intelligence/data/icons.csv +106 -0
  266. package/dist/agent-src/skills/design-intelligence/data/landing.csv +35 -0
  267. package/dist/agent-src/skills/design-intelligence/data/manifest.json +500 -0
  268. package/dist/agent-src/skills/design-intelligence/data/products.csv +162 -0
  269. package/dist/agent-src/skills/design-intelligence/data/react-performance.csv +45 -0
  270. package/dist/agent-src/skills/design-intelligence/data/stacks/angular.csv +51 -0
  271. package/dist/agent-src/skills/design-intelligence/data/stacks/astro.csv +54 -0
  272. package/dist/agent-src/skills/design-intelligence/data/stacks/flutter.csv +53 -0
  273. package/dist/agent-src/skills/design-intelligence/data/stacks/html-tailwind.csv +56 -0
  274. package/dist/agent-src/skills/design-intelligence/data/stacks/jetpack-compose.csv +53 -0
  275. package/dist/agent-src/skills/design-intelligence/data/stacks/laravel.csv +51 -0
  276. package/dist/agent-src/skills/design-intelligence/data/stacks/nextjs.csv +53 -0
  277. package/dist/agent-src/skills/design-intelligence/data/stacks/nuxt-ui.csv +51 -0
  278. package/dist/agent-src/skills/design-intelligence/data/stacks/nuxtjs.csv +59 -0
  279. package/dist/agent-src/skills/design-intelligence/data/stacks/react-native.csv +52 -0
  280. package/dist/agent-src/skills/design-intelligence/data/stacks/react.csv +54 -0
  281. package/dist/agent-src/skills/design-intelligence/data/stacks/shadcn.csv +61 -0
  282. package/dist/agent-src/skills/design-intelligence/data/stacks/svelte.csv +54 -0
  283. package/dist/agent-src/skills/design-intelligence/data/stacks/swiftui.csv +51 -0
  284. package/dist/agent-src/skills/design-intelligence/data/stacks/threejs.csv +54 -0
  285. package/dist/agent-src/skills/design-intelligence/data/stacks/vue.csv +50 -0
  286. package/dist/agent-src/skills/design-intelligence/data/styles.csv +85 -0
  287. package/dist/agent-src/skills/design-intelligence/data/typography.csv +74 -0
  288. package/dist/agent-src/skills/design-intelligence/data/ui-reasoning.csv +162 -0
  289. package/dist/agent-src/skills/design-intelligence/data/ux-guidelines.csv +100 -0
  290. package/dist/agent-src/skills/design-intelligence/evals/triggers.json +16 -0
  291. package/dist/agent-src/skills/design-intelligence/references/design-languages.md +45 -0
  292. package/dist/agent-src/skills/design-intelligence/references/design-rules-checklist.md +268 -0
  293. package/dist/agent-src/skills/design-review/SKILL.md +233 -0
  294. package/dist/agent-src/skills/design-tokens/SKILL.md +135 -0
  295. package/dist/agent-src/skills/design-tokens/evals/triggers.json +16 -0
  296. package/dist/agent-src/skills/design-tokens/scripts/tokens.py +296 -0
  297. package/dist/agent-src/skills/design-tokens/templates/design-tokens-starter.json +143 -0
  298. package/dist/agent-src/skills/existing-ui-audit/SKILL.md +217 -0
  299. package/dist/agent-src/skills/fe-design/SKILL.md +265 -0
  300. package/dist/agent-src/skills/feature-planning/SKILL.md +271 -0
  301. package/dist/agent-src/skills/flux/SKILL.md +126 -0
  302. package/dist/agent-src/skills/jira-integration/SKILL.md +187 -0
  303. package/dist/agent-src/skills/lint-skills/SKILL.md +95 -0
  304. package/dist/agent-src/skills/livewire/SKILL.md +139 -0
  305. package/dist/agent-src/skills/md-language-check/SKILL.md +130 -0
  306. package/dist/agent-src/skills/merge-conflicts/SKILL.md +195 -0
  307. package/dist/agent-src/skills/motion-choreographer/SKILL.md +197 -0
  308. package/dist/agent-src/skills/persona-writing/SKILL.md +158 -0
  309. package/dist/agent-src/skills/prompt-validator/SKILL.md +167 -0
  310. package/dist/agent-src/skills/prompt-validator/evals/triggers.json +16 -0
  311. package/dist/agent-src/skills/react-shadcn-ui/SKILL.md +235 -0
  312. package/dist/agent-src/skills/react-shadcn-ui/scripts/shadcn_add.py +299 -0
  313. package/dist/agent-src/skills/readme-reviewer/SKILL.md +242 -0
  314. package/dist/agent-src/skills/readme-writing/SKILL.md +240 -0
  315. package/dist/agent-src/skills/readme-writing-package/SKILL.md +350 -0
  316. package/dist/agent-src/skills/roadmap-management/SKILL.md +461 -0
  317. package/dist/agent-src/skills/rule-refactor/SKILL.md +149 -0
  318. package/dist/agent-src/skills/rule-writing/SKILL.md +277 -0
  319. package/dist/agent-src/skills/scene-expander/SKILL.md +158 -0
  320. package/dist/agent-src/skills/scene-expander/scene-blueprint.schema.yaml +114 -0
  321. package/dist/agent-src/skills/script-writing/SKILL.md +231 -0
  322. package/dist/agent-src/skills/sentry-integration/SKILL.md +175 -0
  323. package/dist/agent-src/skills/song-to-script/SKILL.md +303 -0
  324. package/dist/agent-src/skills/sql-writing/SKILL.md +85 -0
  325. package/dist/agent-src/skills/tailwind-engineer/SKILL.md +154 -0
  326. package/dist/agent-src/skills/tailwind-engineer/scripts/tailwind_config_gen.py +463 -0
  327. package/dist/agent-src/skills/technical-specification/SKILL.md +251 -0
  328. package/dist/agent-src/skills/threat-modeling/SKILL.md +207 -0
  329. package/dist/agent-src/skills/threat-modeling/data/manifest.json +83 -0
  330. package/dist/agent-src/skills/threat-modeling/data/reasoning.csv +10 -0
  331. package/dist/agent-src/skills/threat-modeling/data/surfaces.csv +10 -0
  332. package/dist/agent-src/skills/threat-modeling/data/threats.csv +16 -0
  333. package/dist/agent-src/skills/upstream-contribute/SKILL.md +261 -0
  334. package/dist/agent-src/templates/AGENTS.md +34 -0
  335. package/dist/agent-src/templates/agents/agent-project-settings.example.yml +286 -0
  336. package/dist/agent-src/templates/agents/proposal.example.md +155 -0
  337. package/dist/agent-src/templates/command.md +105 -0
  338. package/dist/agent-src/templates/copilot-instructions.md +167 -0
  339. package/dist/agent-src/templates/github-workflows/proposal-drift.yml +118 -0
  340. package/dist/agent-src/templates/hooks/pre-commit-frontmatter +66 -0
  341. package/dist/agent-src/templates/hooks/pre-commit-roadmap-progress +99 -0
  342. package/dist/agent-src/templates/persona.md +99 -0
  343. package/dist/agent-src/templates/rule.md +135 -0
  344. package/dist/agent-src/templates/scripts/work_engine/directives/ui/polish.py +513 -0
  345. package/dist/agent-src/templates/scripts/work_engine/directives/ui/review.py +471 -0
  346. package/dist/agent-src/templates/scripts/work_engine/orchestration.py +193 -0
  347. package/dist/agent-src/templates/scripts/work_engine/stack/runner.py +481 -0
  348. package/dist/agent-src/user-types/README.md +124 -0
  349. package/dist/cli/agent-config.js +51 -3
  350. package/dist/cli/agent-config.js.map +1 -1
  351. package/dist/cli/commands/commands.js +152 -0
  352. package/dist/cli/commands/commands.js.map +1 -0
  353. package/dist/cli/commands/mcpServer.js +54 -0
  354. package/dist/cli/commands/mcpServer.js.map +1 -0
  355. package/dist/cli/commands/packs.js +1 -1
  356. package/dist/cli/commands/packs.js.map +1 -1
  357. package/dist/cli/commands/profiles.js +77 -0
  358. package/dist/cli/commands/profiles.js.map +1 -0
  359. package/dist/cli/commands/profiles.test.js +88 -0
  360. package/dist/cli/commands/profiles.test.js.map +1 -0
  361. package/dist/cli/commands/workspaces.js +1 -1
  362. package/dist/cli/commands/workspaces.js.map +1 -1
  363. package/dist/cli/discovery/loadManifest.js.map +1 -1
  364. package/dist/cli/mcp/content.js +127 -0
  365. package/dist/cli/mcp/content.js.map +1 -0
  366. package/dist/cli/mcp/content.test.js +54 -0
  367. package/dist/cli/mcp/content.test.js.map +1 -0
  368. package/dist/cli/mcp/dispatch.js +167 -0
  369. package/dist/cli/mcp/dispatch.js.map +1 -0
  370. package/dist/cli/mcp/dispatch.test.js +108 -0
  371. package/dist/cli/mcp/dispatch.test.js.map +1 -0
  372. package/dist/cli/mcp/stdio.js +69 -0
  373. package/dist/cli/mcp/stdio.js.map +1 -0
  374. package/dist/cli/paths.js +8 -2
  375. package/dist/cli/paths.js.map +1 -1
  376. package/dist/cli/registry.js +2 -0
  377. package/dist/cli/registry.js.map +1 -1
  378. package/dist/discovery/deprecation-report.md +1 -1
  379. package/dist/discovery/discovery-manifest.json +2885 -2056
  380. package/dist/discovery/discovery-manifest.json.sha256 +1 -1
  381. package/dist/discovery/discovery-manifest.summary.md +8 -6
  382. package/dist/discovery/orphan-report.md +1 -1
  383. package/dist/discovery/packs.json +689 -466
  384. package/dist/discovery/trust-report.md +5 -5
  385. package/dist/discovery/workspaces.json +495 -477
  386. package/dist/install/detect.js +2 -2
  387. package/dist/install/detect.js.map +1 -1
  388. package/dist/install/wizard-plan.js +18 -18
  389. package/dist/install/wizard-plan.js.map +1 -1
  390. package/dist/mcp/registry-manifest.json +4 -4
  391. package/dist/router.json +1 -1
  392. package/dist/server/io/substituteTemplate.js +5 -5
  393. package/dist/server/io/substituteTemplate.js.map +1 -1
  394. package/dist/server/routes/settings.js +2 -2
  395. package/dist/server/routes/settings.js.map +1 -1
  396. package/dist/server/routes/userMd.js +1 -1
  397. package/dist/server/routes/userMd.js.map +1 -1
  398. package/dist/server/routes/wizard.js +27 -13
  399. package/dist/server/routes/wizard.js.map +1 -1
  400. package/dist/server/routes/workspace.js +556 -117
  401. package/dist/server/routes/workspace.js.map +1 -1
  402. package/dist/server/schemas/settings.js +7 -2
  403. package/dist/server/schemas/settings.js.map +1 -1
  404. package/dist/shared/userMd/formAdapter.js +2 -2
  405. package/dist/ui/assets/index-CoQo90sz.js +40 -0
  406. package/dist/ui/assets/index-CoQo90sz.js.map +1 -0
  407. package/dist/ui/index.html +1 -1
  408. package/docs/DISTRIBUTION_CHECKLIST.md +2 -2
  409. package/docs/adrs/cost/0001-hard-stop-hook.md +5 -5
  410. package/docs/adrs/memory/0001-consumer-side-snapshot.md +4 -4
  411. package/docs/adrs/router/0001-three-tier-routing.md +3 -3
  412. package/docs/adrs/schema/0001-json-schema-frontmatter.md +6 -6
  413. package/docs/adrs/smoke/0001-per-tier-smoke-scripts.md +6 -6
  414. package/docs/architecture/augment-projection.md +10 -10
  415. package/docs/architecture/claude-bundle.md +5 -5
  416. package/docs/architecture/current-onboard-baseline.md +4 -4
  417. package/docs/architecture/current-safety-behavior.md +16 -16
  418. package/docs/architecture/multi-tool-projection.md +8 -8
  419. package/docs/architecture/source-projection.md +11 -11
  420. package/docs/architecture.md +11 -11
  421. package/docs/archive/CHANGELOG-pre-2.17.0.md +1 -1
  422. package/docs/archive/CHANGELOG-pre-2.2.0.md +7 -7
  423. package/docs/archive/CHANGELOG-pre-2.20.0.md +1 -1
  424. package/docs/archive/CHANGELOG-pre-2.25.0.md +1 -1
  425. package/docs/archive/CHANGELOG-pre-2.7.0.md +1 -1
  426. package/docs/archive/CHANGELOG-pre-3.0.0.md +1 -1
  427. package/docs/archive/CHANGELOG-pre-3.1.0.md +1 -1
  428. package/docs/archive/CHANGELOG-pre-3.2.0.md +1 -1
  429. package/docs/archive/CHANGELOG-pre-4.5.0.md +1 -1
  430. package/docs/archive/CHANGELOG-pre-5.4.0.md +1 -1
  431. package/docs/archive/CHANGELOG-pre-5.9.0.md +1 -1
  432. package/docs/artefact-census.md +71 -0
  433. package/docs/case-studies/frontend-design-vs-ui-ux-pro-max.md +86 -0
  434. package/docs/catalog.md +463 -454
  435. package/docs/command-flows.md +232 -0
  436. package/docs/contracts/CHANGELOG-conventions.md +2 -2
  437. package/docs/contracts/STABILITY.md +1 -1
  438. package/docs/contracts/adoption-signal-floor.md +2 -2
  439. package/docs/contracts/adr-architectural-consensus-mechanism.md +1 -1
  440. package/docs/contracts/adr-chat-history-split.md +1 -1
  441. package/docs/contracts/adr-gtm-context-spine.md +2 -2
  442. package/docs/contracts/adr-install-user-type-axis.md +3 -3
  443. package/docs/contracts/adr-layout.md +3 -3
  444. package/docs/contracts/adr-mcp-runtime.md +8 -8
  445. package/docs/contracts/adr-prompt-driven-execution.md +1 -1
  446. package/docs/contracts/adr-settings-sync-engine.md +3 -3
  447. package/docs/contracts/adr-user-types-axis.md +2 -2
  448. package/docs/contracts/adr-wing4-context-spine.md +2 -2
  449. package/docs/contracts/agent-user-schema.md +6 -6
  450. package/docs/contracts/agents-md-tech-stack.md +2 -2
  451. package/docs/contracts/ai-council-config.md +4 -4
  452. package/docs/contracts/at-rest-encryption.md +48 -7
  453. package/docs/contracts/audit-log-v1.md +3 -3
  454. package/docs/contracts/benchmark-ab-contract.md +6 -1
  455. package/docs/contracts/benchmark-corpus-spec.md +2 -2
  456. package/docs/contracts/benchmark-report-schema.md +4 -4
  457. package/docs/contracts/branch-protection-policy.md +5 -0
  458. package/docs/contracts/capability-packs.md +217 -0
  459. package/docs/contracts/ci-cost-budget.md +6 -1
  460. package/docs/contracts/ci-green-floor.md +1 -1
  461. package/docs/contracts/command-category-governance.md +79 -0
  462. package/docs/contracts/command-clusters.md +42 -4
  463. package/docs/contracts/config-presets.md +1 -1
  464. package/docs/contracts/cost-dashboard.md +1 -1
  465. package/docs/contracts/cost-profile-defaults.md +2 -2
  466. package/docs/contracts/cost-summary-schema.md +4 -4
  467. package/docs/contracts/creative-pack-boundary.md +58 -0
  468. package/docs/contracts/daily-workspace.md +8 -3
  469. package/docs/contracts/discovery-manifest.md +5 -5
  470. package/docs/contracts/discovery-manifest.schema.json +14 -3
  471. package/docs/contracts/evidence-based-pruning.md +101 -0
  472. package/docs/contracts/explain-modes.md +37 -0
  473. package/docs/contracts/file-ownership-matrix.json +1804 -4620
  474. package/docs/contracts/frontmatter-contract.md +6 -6
  475. package/docs/contracts/ghostwriter-schema.md +1 -1
  476. package/docs/contracts/gui-wizard.md +1 -1
  477. package/docs/contracts/harness-expectations.md +5 -0
  478. package/docs/contracts/hook-architecture-v1.md +1 -1
  479. package/docs/contracts/host-agent-protocol.md +19 -1
  480. package/docs/contracts/install-scopes.md +7 -2
  481. package/docs/contracts/installed-tools-lockfile.md +2 -2
  482. package/docs/contracts/linear-ai-rules-inclusion.md +2 -2
  483. package/docs/contracts/linear-ai-three-layers.md +1 -1
  484. package/docs/contracts/linter-structural-model.md +2 -2
  485. package/docs/contracts/load-context-budget-model.md +1 -1
  486. package/docs/contracts/load-context-schema.md +1 -1
  487. package/docs/contracts/local-analytics.md +9 -1
  488. package/docs/contracts/low-impact-corpus-format.md +1 -1
  489. package/docs/contracts/mcp-cloud-scope.md +6 -6
  490. package/docs/contracts/mcp-phase-1-scope.md +5 -5
  491. package/docs/contracts/measurement-baseline.md +5 -5
  492. package/docs/contracts/migrate-command.md +44 -8
  493. package/docs/contracts/multi-tool-projection-fidelity.md +3 -3
  494. package/docs/contracts/namespace.md +1 -1
  495. package/docs/contracts/orchestration-dsl-v1.md +2 -2
  496. package/docs/contracts/package-self-orientation.md +17 -17
  497. package/docs/contracts/pilot/language-and-tone.md +1 -1
  498. package/docs/contracts/plain-language-surface.md +2 -2
  499. package/docs/contracts/profile-system.md +26 -1
  500. package/docs/contracts/provider-lifecycle.md +3 -3
  501. package/docs/contracts/release-pr-gating.md +5 -0
  502. package/docs/contracts/release-trunk-sync.md +3 -3
  503. package/docs/contracts/review-lens-schema.md +59 -0
  504. package/docs/contracts/role-experience.md +10 -6
  505. package/docs/contracts/router-blending.md +2 -2
  506. package/docs/contracts/rule-classification.md +1 -1
  507. package/docs/contracts/rule-router.md +3 -3
  508. package/docs/contracts/safety-model.md +2 -2
  509. package/docs/contracts/session-profile-overlay.md +40 -3
  510. package/docs/contracts/settings-api.md +3 -3
  511. package/docs/contracts/settings-sync-yaml-subset.md +4 -4
  512. package/docs/contracts/skill-bundled-assets.md +62 -0
  513. package/docs/contracts/skill-discovery.md +1 -1
  514. package/docs/contracts/skill-distribution-channels.md +6 -1
  515. package/docs/contracts/skill-dry-run.md +2 -2
  516. package/docs/contracts/skill-family-map.yml +915 -0
  517. package/docs/contracts/smoke-contracts.md +4 -4
  518. package/docs/contracts/telegraph-telemetry.md +2 -2
  519. package/docs/contracts/trust-and-safety.md +3 -3
  520. package/docs/contracts/universal-skills.md +16 -16
  521. package/docs/contracts/value-dashboard-spec.md +21 -21
  522. package/docs/contracts/value-report-schema.md +8 -8
  523. package/docs/customization.md +8 -8
  524. package/docs/decisions/ADR-006-skill-tools-python-pilot.md +2 -2
  525. package/docs/decisions/ADR-007-agent-discovery-scopes.md +1 -1
  526. package/docs/decisions/ADR-008-installed-tools-manifest.md +1 -1
  527. package/docs/decisions/ADR-009-event4u-namespace.md +3 -3
  528. package/docs/decisions/ADR-013-discovery-frontmatter-contract.md +27 -8
  529. package/docs/decisions/ADR-015-discovery-manifest-contract.md +5 -5
  530. package/docs/decisions/ADR-017-monorepo-physical-layout.md +5 -5
  531. package/docs/decisions/ADR-018-trust-and-safety-layer.md +2 -2
  532. package/docs/decisions/ADR-019-router-json-dist-location.md +2 -2
  533. package/docs/decisions/ADR-020-global-only-consumer-scope.md +27 -2
  534. package/docs/decisions/ADR-022-daily-workspace-decomposition.md +2 -2
  535. package/docs/decisions/ADR-024-workspace-v0-feature-floor.md +1 -1
  536. package/docs/decisions/ADR-028-root-layout.md +1 -1
  537. package/docs/decisions/ADR-030-claude-code-command-projection.md +2 -2
  538. package/docs/decisions/ADR-038-canonical-settings-path.md +20 -0
  539. package/docs/decisions/ADR-041-controlled-command-verbs.md +133 -0
  540. package/docs/decisions/ADR-042-runtime-resolver-decision-gate.md +113 -0
  541. package/docs/decisions/ADR-043-monorepo-collapse-to-src-domains.md +128 -0
  542. package/docs/decisions/ADR-044-command-naming-scheme-hyphenated.md +250 -0
  543. package/docs/decisions/ADR-045-src-source-layout-and-profiles-as-views.md +111 -0
  544. package/docs/decisions/ADR-046-thin-command-principle.md +93 -0
  545. package/docs/decisions/ADR-047-framework-neutral-stack-adaptive-commands.md +94 -0
  546. package/docs/decisions/ADR-048-command-justification-rule.md +106 -0
  547. package/docs/decisions/ADR-049-configuration-trust-boundary.md +114 -0
  548. package/docs/decisions/ADR-050-workspace-vs-package-root-boundary.md +121 -0
  549. package/docs/decisions/ADR-051-uncondensed-source-container-relocation.md +114 -0
  550. package/docs/decisions/ADR-052-packages-removal-and-pack-home-migration.md +86 -0
  551. package/docs/decisions/ADR-053-agents-namespace-dual-role-resolution.md +132 -0
  552. package/docs/decisions/ADR-054-rule-adherence-decay-triggered-restate.md +143 -0
  553. package/docs/decisions/ADR-055-flow-layer-data-model.md +235 -0
  554. package/docs/decisions/ADR-056-unvalidated-video-adapters-disposition.md +124 -0
  555. package/docs/decisions/ADR-057-consolidation-evidence-gate-outcomes.md +135 -0
  556. package/docs/decisions/ADR-058-condensed-output-relocation-to-dist.md +94 -0
  557. package/docs/decisions/ADR-059-render-resume-filesystem-as-state.md +161 -0
  558. package/docs/decisions/ADR-060-comfyui-sandbox-model.md +154 -0
  559. package/docs/decisions/ADR-061-corpus-grounding-layer.md +170 -0
  560. package/docs/decisions/ADR-062-encrypt-at-rest-store-architecture.md +121 -0
  561. package/docs/decisions/ADR-063-append-jsonl-encryption-deferred.md +83 -0
  562. package/docs/decisions/ADR-064-append-jsonl-per-record-encryption.md +113 -0
  563. package/docs/decisions/ADR-065-tier3-inbox-handoff-v0.md +86 -0
  564. package/docs/decisions/ADR-066-skill-body-prerendering.md +93 -0
  565. package/docs/decisions/ADR-067-glama-registry-listing.md +259 -0
  566. package/docs/decisions/ADR-068-host-tier-detection.md +90 -0
  567. package/docs/decisions/ADR-069-prompt-renderer.md +97 -0
  568. package/docs/decisions/ADR-070-tier1-drive-loop.md +94 -0
  569. package/docs/decisions/ADR-071-launch-drive-integration.md +95 -0
  570. package/docs/decisions/ADR-072-codex-gemini-drive-configs.md +90 -0
  571. package/docs/decisions/ADR-073-drive-health-kill-switch.md +81 -0
  572. package/docs/decisions/ADR-074-drive-kill-switch-auto-recovery.md +84 -0
  573. package/docs/decisions/ADR-075-workspace-gui-drive.md +83 -0
  574. package/docs/decisions/ADR-076-workspace-multi-turn.md +92 -0
  575. package/docs/decisions/ADR-077-workspace-followup-gui.md +70 -0
  576. package/docs/decisions/ADR-078-drive-health-panel.md +70 -0
  577. package/docs/decisions/ADR-079-workspace-host-picker.md +81 -0
  578. package/docs/decisions/ADR-080-host-session-expired-410.md +92 -0
  579. package/docs/decisions/ADR-081-drive-health-reset-and-410-affordance.md +71 -0
  580. package/docs/decisions/ADR-082-410-one-click-relaunch.md +58 -0
  581. package/docs/decisions/ADR-083-session-thread-and-arbitrary-continuation.md +85 -0
  582. package/docs/decisions/ADR-084-drive-health-refresh-on-drive.md +52 -0
  583. package/docs/decisions/ADR-085-mcp-stdio-end-user-distribution-shape.md +158 -0
  584. package/docs/decisions/ADR-086-read-only-cross-agent-mcp-discovery-helper.md +171 -0
  585. package/docs/decisions/ADR-087-installer-e2e-test-strategy.md +111 -0
  586. package/docs/decisions/ADR-088-no-external-runtime-federation.md +145 -0
  587. package/docs/decisions/ADR-089-lean-local-plugin-install.md +111 -0
  588. package/docs/decisions/INDEX.md +49 -0
  589. package/docs/deploy/small-team-recipe.md +1 -1
  590. package/docs/deploy/team-deployment-posture.md +1 -1
  591. package/docs/development.md +6 -6
  592. package/docs/distribution/public-install-smoke.md +1 -1
  593. package/docs/distribution/registries.md +5 -5
  594. package/docs/distribution/registry-submissions.md +2 -2
  595. package/docs/end-to-end-walkthroughs.md +10 -10
  596. package/docs/experiences/agency.md +49 -0
  597. package/docs/experiences/content_creator.md +47 -0
  598. package/docs/experiences/developer.md +49 -0
  599. package/docs/experiences/finance.md +48 -0
  600. package/docs/experiences/founder.md +47 -0
  601. package/docs/experiences/ops.md +47 -0
  602. package/docs/featured-commands.md +12 -12
  603. package/docs/featured-skills.md +32 -32
  604. package/docs/flows.md +67 -0
  605. package/docs/getting-started-by-role.md +41 -41
  606. package/docs/getting-started-laravel.md +26 -26
  607. package/docs/getting-started-local-stdio.md +77 -0
  608. package/docs/getting-started.md +2 -2
  609. package/docs/governance.md +96 -0
  610. package/docs/guidelines/agent-infra/asking-and-brevity-examples.md +6 -6
  611. package/docs/guidelines/agent-infra/comparison-matrix.md +179 -0
  612. package/docs/guidelines/agent-infra/corpus-grounding-authoring.md +91 -0
  613. package/docs/guidelines/agent-infra/direct-answers-demos.md +23 -26
  614. package/docs/guidelines/agent-infra/language-and-tone-examples.md +29 -2
  615. package/docs/guidelines/agent-infra/layered-settings.md +3 -3
  616. package/docs/guidelines/agent-infra/linked-projects-onboarding-gate.md +80 -0
  617. package/docs/guidelines/agent-infra/missing-tool-handling.md +66 -0
  618. package/docs/guidelines/agent-infra/model-recommendation.md +72 -0
  619. package/docs/guidelines/agent-infra/roadmap-progress-mechanics.md +1 -1
  620. package/docs/guidelines/agent-infra/self-improvement-pipeline.md +1 -1
  621. package/docs/guidelines/agent-infra/verify-before-complete-demos.md +1 -1
  622. package/docs/guidelines/augment-portability-patterns.md +1 -1
  623. package/docs/guides/local-analytics.md +1 -1
  624. package/docs/guides/local-knowledge.md +3 -3
  625. package/docs/hook-payload-capture.md +5 -5
  626. package/docs/installation.md +3 -3
  627. package/docs/mcp-registries.md +94 -0
  628. package/docs/mcp-server.md +4 -4
  629. package/docs/mcp.md +3 -0
  630. package/docs/parity/ruflo.md +7 -7
  631. package/docs/personas.md +3 -3
  632. package/docs/profiles.md +15 -11
  633. package/docs/quality.md +3 -3
  634. package/docs/setup/mcp-client-config.md +134 -9
  635. package/docs/setup/mcp-server-docker.md +9 -7
  636. package/docs/setup/per-ide/claude-code.md +3 -3
  637. package/docs/setup/per-ide/claude-desktop.md +1 -1
  638. package/docs/setup/per-ide/cursor.md +2 -2
  639. package/docs/setup/per-ide/windsurf.md +1 -1
  640. package/docs/showcase.md +12 -12
  641. package/docs/skill-duplication-findings.md +91 -0
  642. package/docs/skills-catalog.md +228 -224
  643. package/docs/skills-taxonomy.md +90 -0
  644. package/docs/ui-track-mental-model.md +2 -2
  645. package/docs/value.md +50 -50
  646. package/docs/walkthroughs/assets/workspace-role-grid.png +0 -0
  647. package/docs/walkthroughs/assets/workspace-session-started.png +0 -0
  648. package/docs/walkthroughs/assets/workspace-task-picker.png +0 -0
  649. package/docs/walkthroughs/daily-workspace.md +127 -0
  650. package/llms.txt +18 -14
  651. package/package.json +10 -9
  652. package/src/config/agent-settings.template.yml +612 -0
  653. package/src/config/discovery/command-verbs.yml +56 -0
  654. package/src/config/discovery/packs.yml +255 -0
  655. package/src/config/discovery/workspaces.yml +72 -0
  656. package/src/scripts/__pycache__/validate_frontmatter.cpython-312.pyc +0 -0
  657. package/src/scripts/_archive/README.md +59 -0
  658. package/src/scripts/_archive/_bootstrap_tier_frontmatter.py +151 -0
  659. package/src/scripts/_archive/_p43_bodies.py +235 -0
  660. package/src/scripts/_archive/_p43_condense.py +118 -0
  661. package/src/scripts/_archive/_p4_migrate.py +199 -0
  662. package/src/scripts/_cli/cmd_doctor.py +1583 -0
  663. package/src/scripts/_cli/cmd_export.py +157 -0
  664. package/src/scripts/_cli/cmd_migrate.py +524 -0
  665. package/src/scripts/_cli/cmd_refresh.py +179 -0
  666. package/src/scripts/_cli/cmd_settings_migrate.py +147 -0
  667. package/src/scripts/_cli/cmd_update.py +279 -0
  668. package/src/scripts/_cli/cmd_upgrade.py +172 -0
  669. package/src/scripts/_cli/cmd_versions.py +160 -0
  670. package/src/scripts/_dispatch.bash +1129 -0
  671. package/src/scripts/_lib/__pycache__/__init__.cpython-312.pyc +0 -0
  672. package/src/scripts/_lib/__pycache__/agent_src.cpython-312.pyc +0 -0
  673. package/src/scripts/_lib/agent_src.py +491 -0
  674. package/src/scripts/_lib/bench_ab_cache.py +162 -0
  675. package/src/scripts/_lib/changelog_eras.py +330 -0
  676. package/src/scripts/_lib/claude_desktop_bundler.py +238 -0
  677. package/src/scripts/_lib/cli_wrapper.py +64 -0
  678. package/src/scripts/_lib/global_deploy_inventory.py +282 -0
  679. package/src/scripts/_lib/install_regenerator.py +134 -0
  680. package/src/scripts/_lib/installed_lock.py +256 -0
  681. package/src/scripts/_lib/model_tier.py +52 -0
  682. package/src/scripts/_lib/scope_guard.sh +163 -0
  683. package/src/scripts/_lib/value_ladder.py +696 -0
  684. package/src/scripts/_lib/value_report.py +455 -0
  685. package/src/scripts/_phase4_bucket.py +210 -0
  686. package/src/scripts/_pilot_measure.py +53 -0
  687. package/src/scripts/adoption_report.py +195 -0
  688. package/src/scripts/adoption_snapshot.py +219 -0
  689. package/src/scripts/adoption_status.py +166 -0
  690. package/src/scripts/agent-config +57 -0
  691. package/src/scripts/ai-video/adapters/comfyui.sh +392 -0
  692. package/src/scripts/ai-video/adapters/fal.sh +311 -0
  693. package/src/scripts/ai-video/adapters/gemini-veo.sh +246 -0
  694. package/src/scripts/ai-video/adapters/higgsfield.sh +310 -0
  695. package/src/scripts/ai-video/adapters/kling.sh +248 -0
  696. package/src/scripts/ai-video/adapters/musetalk.sh +120 -0
  697. package/src/scripts/ai-video/adapters/openai-images.sh +147 -0
  698. package/src/scripts/ai-video/adapters/replicate.sh +289 -0
  699. package/src/scripts/ai-video/adapters/sora.sh +207 -0
  700. package/src/scripts/ai-video/adapters/syncso.sh +200 -0
  701. package/src/scripts/ai-video/audio-adapters/allin1.sh +115 -0
  702. package/src/scripts/ai-video/audio-adapters/whisperx.sh +128 -0
  703. package/src/scripts/ai-video/lib/adapter-common.sh +231 -0
  704. package/src/scripts/ai-video/lib/adapter-contract.md +329 -0
  705. package/src/scripts/ai-video/lib/audio-adapter-contract.md +210 -0
  706. package/src/scripts/ai-video/lib/comfyui-nodes.allowlist.json +21 -0
  707. package/src/scripts/ai-video/lib/comfyui-templates/ltx-2.json +79 -0
  708. package/src/scripts/ai-video/lib/comfyui-templates/wan22-ti2v-5b.json +78 -0
  709. package/src/scripts/ai-video/lib/embed-provenance.sh +194 -0
  710. package/src/scripts/ai-video/lib/fixtures/allin1/analysis.json +13 -0
  711. package/src/scripts/ai-video/lib/fixtures/comfyui/result.json +1 -0
  712. package/src/scripts/ai-video/lib/fixtures/fal/result.json +1 -0
  713. package/src/scripts/ai-video/lib/fixtures/fal/scene-0001.mp4 +1 -0
  714. package/src/scripts/ai-video/lib/fixtures/gemini-veo/result.json +1 -0
  715. package/src/scripts/ai-video/lib/fixtures/higgsfield/result.json +1 -0
  716. package/src/scripts/ai-video/lib/fixtures/kling/result.json +1 -0
  717. package/src/scripts/ai-video/lib/fixtures/kling/scene-0001.mp4 +1 -0
  718. package/src/scripts/ai-video/lib/fixtures/musetalk/lipsync-0001.mp4 +1 -0
  719. package/src/scripts/ai-video/lib/fixtures/musetalk/result.json +1 -0
  720. package/src/scripts/ai-video/lib/fixtures/openai-images/result.json +1 -0
  721. package/src/scripts/ai-video/lib/fixtures/replicate/result.json +1 -0
  722. package/src/scripts/ai-video/lib/fixtures/replicate/scene-0001.mp4 +1 -0
  723. package/src/scripts/ai-video/lib/fixtures/sora/result.json +1 -0
  724. package/src/scripts/ai-video/lib/fixtures/syncso/lipsync-0001.mp4 +1 -0
  725. package/src/scripts/ai-video/lib/fixtures/syncso/result.json +1 -0
  726. package/src/scripts/ai-video/lib/fixtures/whisperx/transcript.json +26 -0
  727. package/src/scripts/ai-video/lib/ingest-song.sh +89 -0
  728. package/src/scripts/ai-video/lib/load-config.sh +180 -0
  729. package/src/scripts/ai-video/lib/model-capabilities/README.md +82 -0
  730. package/src/scripts/ai-video/lib/model-capabilities/comfyui.json +31 -0
  731. package/src/scripts/ai-video/lib/model-capabilities/fal.json +77 -0
  732. package/src/scripts/ai-video/lib/model-capabilities/musetalk.json +24 -0
  733. package/src/scripts/ai-video/lib/model-capabilities/replicate.json +82 -0
  734. package/src/scripts/ai-video/lib/model-capabilities/syncso.json +23 -0
  735. package/src/scripts/ai-video/lib/resume-scan.sh +212 -0
  736. package/src/scripts/ai-video/lib/telemetry.sh +115 -0
  737. package/src/scripts/ai-video/lib/validate-deps.sh +132 -0
  738. package/src/scripts/ai-video/lib/validate-vocal-map.sh +121 -0
  739. package/src/scripts/ai-video/smoke-trace.sh +179 -0
  740. package/src/scripts/ai-video/stitch.sh +161 -0
  741. package/src/scripts/ai-video/test-pipeline.sh +169 -0
  742. package/src/scripts/ai_council/advisors.py +148 -0
  743. package/src/scripts/ai_council/clients.py +1385 -0
  744. package/src/scripts/ai_council/compile_corpus.py +179 -0
  745. package/src/scripts/ai_council/events_log.py +141 -0
  746. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_2a4_acceptance.py +208 -0
  747. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_budget_v2_audit.py +206 -0
  748. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_estimate.py +67 -0
  749. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_review.py +292 -0
  750. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_followups_review.py +259 -0
  751. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_nondestructive_inline_audit.py +209 -0
  752. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase4_dispatch_latency.py +108 -0
  753. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase6_trigger_jaccard.py +92 -0
  754. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_budget_rebalance.py +257 -0
  755. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_post_revert.py +197 -0
  756. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_rebalancing_audit.py +149 -0
  757. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_roundtrip.py +111 -0
  758. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_rule_hardening_v1.py +251 -0
  759. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_silent_taskfiles.py +98 -0
  760. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_open_questions.py +232 -0
  761. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_optimization.py +144 -0
  762. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_gaps.py +252 -0
  763. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_review.py +240 -0
  764. package/src/scripts/ai_council/one_off_archive/2026-05/_one_off_tier_retrofit.py +180 -0
  765. package/src/scripts/ai_council/pricing.py +215 -0
  766. package/src/scripts/ai_council/session.py +366 -0
  767. package/src/scripts/annotate_discovery.py +149 -0
  768. package/src/scripts/apply_modules_config.py +290 -0
  769. package/src/scripts/audit_adr_coverage.py +175 -0
  770. package/src/scripts/audit_auto_rules.py +175 -0
  771. package/src/scripts/audit_cloud_compatibility.py +362 -0
  772. package/src/scripts/audit_command_surface.py +669 -0
  773. package/src/scripts/audit_initial_context.py +237 -0
  774. package/src/scripts/audit_likelihood.py +148 -0
  775. package/src/scripts/audit_mcp_tools.py +146 -0
  776. package/src/scripts/audit_overlap.py +145 -0
  777. package/src/scripts/audit_skill_overlap.py +207 -0
  778. package/src/scripts/audit_user_type_axis.py +140 -0
  779. package/src/scripts/backfill_model_tier.py +184 -0
  780. package/src/scripts/bench_ab_cache_dispatch.py +68 -0
  781. package/src/scripts/bench_ab_clone.py +170 -0
  782. package/src/scripts/bench_ab_diff.py +220 -0
  783. package/src/scripts/bench_ab_integrity.py +143 -0
  784. package/src/scripts/bench_ab_run.py +235 -0
  785. package/src/scripts/bench_ab_task_runner.py +369 -0
  786. package/src/scripts/bench_ab_tracka_run.py +202 -0
  787. package/src/scripts/bench_baseline_ready.py +108 -0
  788. package/src/scripts/bench_condense_memory.py +168 -0
  789. package/src/scripts/bench_drift_check.py +151 -0
  790. package/src/scripts/bench_per_tool.py +216 -0
  791. package/src/scripts/bench_rtk_savings.py +320 -0
  792. package/src/scripts/bench_run.py +272 -0
  793. package/src/scripts/bench_runner.py +158 -0
  794. package/src/scripts/build_cloud_bundle.py +458 -0
  795. package/src/scripts/build_discovery_manifest.py +747 -0
  796. package/src/scripts/build_linear_digest.py +260 -0
  797. package/src/scripts/build_mcp_registry_manifest.py +181 -0
  798. package/src/scripts/build_rule_trigger_matrix.py +350 -0
  799. package/src/scripts/capture_showcase_session.py +361 -0
  800. package/src/scripts/check_always_budget.py +532 -0
  801. package/src/scripts/check_artefact_checksums.py +111 -0
  802. package/src/scripts/check_augment_description_cap.py +79 -0
  803. package/src/scripts/check_augmentignore.py +72 -0
  804. package/src/scripts/check_beta_review_markers.py +127 -0
  805. package/src/scripts/check_cluster_patterns.py +206 -0
  806. package/src/scripts/check_command_count_messaging.py +152 -0
  807. package/src/scripts/check_condensation.py +375 -0
  808. package/src/scripts/check_condensed_paths.py +231 -0
  809. package/src/scripts/check_context_paths.py +202 -0
  810. package/src/scripts/check_council_references.py +228 -0
  811. package/src/scripts/check_discovery_determinism.py +70 -0
  812. package/src/scripts/check_gate_paths.py +128 -0
  813. package/src/scripts/check_module_management_neutral.py +147 -0
  814. package/src/scripts/check_no_new_legacy_path.py +100 -0
  815. package/src/scripts/check_no_roadmap_refs.py +155 -0
  816. package/src/scripts/check_one_off_location.py +81 -0
  817. package/src/scripts/check_overlay_cascade_subdirs.py +129 -0
  818. package/src/scripts/check_portability.py +574 -0
  819. package/src/scripts/check_public_catalog_links.py +125 -0
  820. package/src/scripts/check_public_links.py +185 -0
  821. package/src/scripts/check_references.py +557 -0
  822. package/src/scripts/check_release_includes_discovery.py +61 -0
  823. package/src/scripts/check_release_pr_shape.py +123 -0
  824. package/src/scripts/check_release_published.py +145 -0
  825. package/src/scripts/check_reply_consistency.py +169 -0
  826. package/src/scripts/check_roadmap_trackable.py +114 -0
  827. package/src/scripts/check_role_doc_links.py +110 -0
  828. package/src/scripts/check_safety_floor_untouched.py +125 -0
  829. package/src/scripts/check_skill_requires.py +147 -0
  830. package/src/scripts/check_template_pin_drift.py +129 -0
  831. package/src/scripts/check_test_coverage_diff.py +180 -0
  832. package/src/scripts/check_token_optimizer_freshness.py +146 -0
  833. package/src/scripts/check_update_banner.py +86 -0
  834. package/src/scripts/ci_time_ratio.py +168 -0
  835. package/src/scripts/compile_router.py +232 -0
  836. package/src/scripts/condense.py +1919 -0
  837. package/src/scripts/condense_memory.py +178 -0
  838. package/src/scripts/config/packs.py +157 -0
  839. package/src/scripts/config/profile_explain.py +89 -0
  840. package/src/scripts/config/profiles.py +191 -0
  841. package/src/scripts/config/session_profiles.py +542 -0
  842. package/src/scripts/cost_by_conversation.py +78 -0
  843. package/src/scripts/cost_summary.py +97 -0
  844. package/src/scripts/council_cli.py +2557 -0
  845. package/src/scripts/cross_repo_retrieve.py +172 -0
  846. package/src/scripts/discovery_stats.py +70 -0
  847. package/src/scripts/extract_audit_patterns.py +202 -0
  848. package/src/scripts/first_run_gate_hook.py +179 -0
  849. package/src/scripts/gen_discovery_baseline.py +127 -0
  850. package/src/scripts/generate_catalog.py +116 -0
  851. package/src/scripts/generate_command_flows.py +191 -0
  852. package/src/scripts/generate_index.py +303 -0
  853. package/src/scripts/generate_ownership_matrix.py +378 -0
  854. package/src/scripts/generate_pack_manifests.py +340 -0
  855. package/src/scripts/hook_manifest.yaml +243 -0
  856. package/src/scripts/hooks/dispatch_hook.py +461 -0
  857. package/src/scripts/hooks/replay_hook.py +144 -0
  858. package/src/scripts/hooks_doctor.py +223 -0
  859. package/src/scripts/hooks_status.py +157 -0
  860. package/src/scripts/install +425 -0
  861. package/src/scripts/install-hooks.sh +204 -0
  862. package/src/scripts/install.py +5183 -0
  863. package/src/scripts/install.sh +1156 -0
  864. package/src/scripts/inventory_abstraction_budget.py +622 -0
  865. package/src/scripts/inventory_frontmatter.py +164 -0
  866. package/src/scripts/inventory_meta_layers.py +288 -0
  867. package/src/scripts/iron_law_sha.py +107 -0
  868. package/src/scripts/linked_projects_list.py +91 -0
  869. package/src/scripts/lint_agent_skill_names.py +150 -0
  870. package/src/scripts/lint_agents_layout.py +197 -0
  871. package/src/scripts/lint_agents_md.py +210 -0
  872. package/src/scripts/lint_archived_skills.py +159 -0
  873. package/src/scripts/lint_artefact_frontmatter.py +188 -0
  874. package/src/scripts/lint_bench_ab.py +172 -0
  875. package/src/scripts/lint_bench_corpus.py +255 -0
  876. package/src/scripts/lint_command_flow_coverage.py +132 -0
  877. package/src/scripts/lint_command_routing.py +160 -0
  878. package/src/scripts/lint_command_tiers.py +175 -0
  879. package/src/scripts/lint_command_verbs.py +206 -0
  880. package/src/scripts/lint_commit_subjects.py +139 -0
  881. package/src/scripts/lint_context_spine_usage.py +137 -0
  882. package/src/scripts/lint_discovery_manifest.py +176 -0
  883. package/src/scripts/lint_discovery_vocabulary.py +220 -0
  884. package/src/scripts/lint_examples.py +102 -0
  885. package/src/scripts/lint_explain_trace.py +80 -0
  886. package/src/scripts/lint_featured_skills.py +144 -0
  887. package/src/scripts/lint_flows.py +215 -0
  888. package/src/scripts/lint_framework_leakage.py +375 -0
  889. package/src/scripts/lint_framework_leakage_allowlist.json +575 -0
  890. package/src/scripts/lint_frontmatter_boilerplate.py +77 -0
  891. package/src/scripts/lint_ghostwriter_source.py +242 -0
  892. package/src/scripts/lint_handoffs.py +217 -0
  893. package/src/scripts/lint_hook_concern_budget.py +207 -0
  894. package/src/scripts/lint_hook_manifest.py +217 -0
  895. package/src/scripts/lint_load_context.py +196 -0
  896. package/src/scripts/lint_marketplace.py +180 -0
  897. package/src/scripts/lint_marketplace_install_completeness.py +198 -0
  898. package/src/scripts/lint_mcp_registry_manifest.py +69 -0
  899. package/src/scripts/lint_media_policy_linkage.py +140 -0
  900. package/src/scripts/lint_model_tier_coverage.py +73 -0
  901. package/src/scripts/lint_namespace.py +135 -0
  902. package/src/scripts/lint_namespace_collisions.py +103 -0
  903. package/src/scripts/lint_new_skill_gate.py +144 -0
  904. package/src/scripts/lint_no_new_atomic_commands.py +180 -0
  905. package/src/scripts/lint_one_off_age.py +184 -0
  906. package/src/scripts/lint_orchestration_dsl.py +217 -0
  907. package/src/scripts/lint_orchestrator_auto_detect.py +111 -0
  908. package/src/scripts/lint_pack_boundaries.py +147 -0
  909. package/src/scripts/lint_pack_dependencies.py +137 -0
  910. package/src/scripts/lint_pack_first_win.py +121 -0
  911. package/src/scripts/lint_persona_governance.py +164 -0
  912. package/src/scripts/lint_positioning.py +143 -0
  913. package/src/scripts/lint_profile_overlay_set_only.py +179 -0
  914. package/src/scripts/lint_regression.py +251 -0
  915. package/src/scripts/lint_roadmap_ci_steps.py +186 -0
  916. package/src/scripts/lint_roadmap_complexity.py +220 -0
  917. package/src/scripts/lint_role_experiences.py +255 -0
  918. package/src/scripts/lint_rule_interactions.py +170 -0
  919. package/src/scripts/lint_rule_tiers.py +90 -0
  920. package/src/scripts/lint_showcase_sessions.py +148 -0
  921. package/src/scripts/lint_skill_tools.py +168 -0
  922. package/src/scripts/lint_topics_yaml.py +89 -0
  923. package/src/scripts/lint_trust_coherence.py +212 -0
  924. package/src/scripts/lint_value_dashboard.py +218 -0
  925. package/src/scripts/mcp_parity_smoke.py +316 -0
  926. package/src/scripts/mcp_registry_submit.sh +187 -0
  927. package/src/scripts/mcp_server/__init__.py +19 -0
  928. package/src/scripts/mcp_server/consumer_tool_catalog.json +276 -0
  929. package/src/scripts/mcp_server/prompts.py +442 -0
  930. package/src/scripts/mcp_server/resources.py +201 -0
  931. package/src/scripts/mcp_server/tools.py +950 -0
  932. package/src/scripts/measure_augment_budget.py +214 -0
  933. package/src/scripts/measure_density.py +232 -0
  934. package/src/scripts/measure_frugality_savings.py +164 -0
  935. package/src/scripts/measure_markitdown_lift.py +127 -0
  936. package/src/scripts/measure_patterns.py +376 -0
  937. package/src/scripts/measure_projection_bytes.py +159 -0
  938. package/src/scripts/measure_rule_budget.py +347 -0
  939. package/src/scripts/measure_skill_reduction.py +102 -0
  940. package/src/scripts/migrate_command_suggestions.py +151 -0
  941. package/src/scripts/migrate_frontmatter_defaults.py +245 -0
  942. package/src/scripts/mine_session.py +279 -0
  943. package/src/scripts/move_artefact.py +143 -0
  944. package/src/scripts/new_skill.py +148 -0
  945. package/src/scripts/pack_dependency_allowlist.json +70 -0
  946. package/src/scripts/pack_mcp_content.py +293 -0
  947. package/src/scripts/plan_physical_move.py +353 -0
  948. package/src/scripts/print_required_checks.py +196 -0
  949. package/src/scripts/probe_projection_fidelity.py +202 -0
  950. package/src/scripts/profile_staleness_hook.py +69 -0
  951. package/src/scripts/profile_use.py +164 -0
  952. package/src/scripts/project_thin_rules.py +168 -0
  953. package/src/scripts/prototype_lint_contradictions.py +150 -0
  954. package/src/scripts/prove_pack_extractable.py +187 -0
  955. package/src/scripts/recruit_preflight.sh +152 -0
  956. package/src/scripts/refine_ticket_detect.py +646 -0
  957. package/src/scripts/release.py +1091 -0
  958. package/src/scripts/render_benchmark_md.py +312 -0
  959. package/src/scripts/render_value_md.py +347 -0
  960. package/src/scripts/repro/repro_marketplace_install_gap.sh +161 -0
  961. package/src/scripts/roadmap_progress_hook.py +274 -0
  962. package/src/scripts/router_telemetry.py +470 -0
  963. package/src/scripts/run_skill_evals.py +185 -0
  964. package/src/scripts/runtime_registry.py +166 -0
  965. package/src/scripts/schemas/command.schema.json +219 -0
  966. package/src/scripts/schemas/flow.schema.json +59 -0
  967. package/src/scripts/schemas/pack.schema.json +95 -0
  968. package/src/scripts/schemas/rule.schema.json +145 -0
  969. package/src/scripts/score_skill_selection.py +198 -0
  970. package/src/scripts/skill_collision_clusters.py +162 -0
  971. package/src/scripts/skill_discovery.py +254 -0
  972. package/src/scripts/skill_linter.py +3694 -0
  973. package/src/scripts/skill_overlap.py +204 -0
  974. package/src/scripts/skill_preview.py +179 -0
  975. package/src/scripts/skill_tools/audit_persona_coverage.py +147 -0
  976. package/src/scripts/skill_tools/audit_user_type_coverage.py +148 -0
  977. package/src/scripts/skill_tools/run_block_d_eval.py +129 -0
  978. package/src/scripts/skill_tools/score_skill_relevance.py +169 -0
  979. package/src/scripts/skill_tools/suggest_skill_for_task.py +113 -0
  980. package/src/scripts/skill_trigger_eval.py +682 -0
  981. package/src/scripts/skill_usage_collect.py +191 -0
  982. package/src/scripts/skill_usage_report.py +162 -0
  983. package/src/scripts/smoke/kernel.sh +107 -0
  984. package/src/scripts/smoke/router.sh +148 -0
  985. package/src/scripts/smoke/schema.sh +78 -0
  986. package/src/scripts/smoke/skills.sh +112 -0
  987. package/src/scripts/smoke_path_resolution.py +93 -0
  988. package/src/scripts/smoke_quickstart.py +144 -0
  989. package/src/scripts/snapshot_agent_outputs.py +144 -0
  990. package/src/scripts/spotcheck_thin_root.py +134 -0
  991. package/src/scripts/sync_agent_settings.py +180 -0
  992. package/src/scripts/sync_github_metadata.py +147 -0
  993. package/src/scripts/sync_gitignore.py +291 -0
  994. package/src/scripts/telegraph_stats.py +119 -0
  995. package/src/scripts/trigger_coverage.py +129 -0
  996. package/src/scripts/update_counts.py +199 -0
  997. package/src/scripts/update_prices.py +125 -0
  998. package/src/scripts/validate_agent_settings.py +124 -0
  999. package/src/scripts/validate_decision_engine.py +136 -0
  1000. package/src/scripts/validate_discovery_manifest.py +94 -0
  1001. package/src/scripts/validate_frontmatter.py +647 -0
  1002. package/src/scripts/validate_pack_yaml.py +179 -0
  1003. package/src/scripts/verify_physical_move.py +185 -0
  1004. package/src/scripts/wrapper_freshness_hook.py +86 -0
  1005. package/.agent-src/README.md +0 -64
  1006. package/.agent-src/commands/agent-handoff.md +0 -120
  1007. package/.agent-src/commands/agent-status.md +0 -136
  1008. package/.agent-src/commands/agents/audit.md +0 -157
  1009. package/.agent-src/commands/agents/init.md +0 -191
  1010. package/.agent-src/commands/agents/optimize.md +0 -186
  1011. package/.agent-src/commands/agents/user/accept.md +0 -121
  1012. package/.agent-src/commands/agents/user/init.md +0 -161
  1013. package/.agent-src/commands/agents/user/review.md +0 -111
  1014. package/.agent-src/commands/agents/user/show.md +0 -113
  1015. package/.agent-src/commands/agents/user/update.md +0 -102
  1016. package/.agent-src/commands/agents/user.md +0 -70
  1017. package/.agent-src/commands/agents.md +0 -61
  1018. package/.agent-src/commands/analytics/prune.md +0 -70
  1019. package/.agent-src/commands/analytics/show.md +0 -99
  1020. package/.agent-src/commands/analytics.md +0 -56
  1021. package/.agent-src/commands/analyze-reference-repo.md +0 -203
  1022. package/.agent-src/commands/bug-fix.md +0 -192
  1023. package/.agent-src/commands/bug-investigate.md +0 -185
  1024. package/.agent-src/commands/challenge-me/vision.md +0 -353
  1025. package/.agent-src/commands/challenge-me/with-docs.md +0 -338
  1026. package/.agent-src/commands/challenge-me.md +0 -67
  1027. package/.agent-src/commands/chat-history/import.md +0 -171
  1028. package/.agent-src/commands/chat-history/learn.md +0 -183
  1029. package/.agent-src/commands/chat-history/show.md +0 -111
  1030. package/.agent-src/commands/chat-history.md +0 -58
  1031. package/.agent-src/commands/check-current-md.md +0 -142
  1032. package/.agent-src/commands/commit/in-chunks.md +0 -145
  1033. package/.agent-src/commands/commit.md +0 -190
  1034. package/.agent-src/commands/condense.md +0 -235
  1035. package/.agent-src/commands/context/create.md +0 -180
  1036. package/.agent-src/commands/context/refactor.md +0 -182
  1037. package/.agent-src/commands/context.md +0 -50
  1038. package/.agent-src/commands/cost-report.md +0 -130
  1039. package/.agent-src/commands/council/analysis.md +0 -146
  1040. package/.agent-src/commands/council/debate.md +0 -133
  1041. package/.agent-src/commands/council/default.md +0 -288
  1042. package/.agent-src/commands/council/design.md +0 -106
  1043. package/.agent-src/commands/council/optimize.md +0 -122
  1044. package/.agent-src/commands/council/pr.md +0 -129
  1045. package/.agent-src/commands/council.md +0 -106
  1046. package/.agent-src/commands/create-pr/description-only.md +0 -159
  1047. package/.agent-src/commands/create-pr.md +0 -249
  1048. package/.agent-src/commands/e2e-heal.md +0 -109
  1049. package/.agent-src/commands/e2e-plan.md +0 -96
  1050. package/.agent-src/commands/estimate-ticket.md +0 -88
  1051. package/.agent-src/commands/feature/dev.md +0 -123
  1052. package/.agent-src/commands/feature/explore.md +0 -190
  1053. package/.agent-src/commands/feature/plan.md +0 -332
  1054. package/.agent-src/commands/feature/refactor.md +0 -193
  1055. package/.agent-src/commands/feature/roadmap.md +0 -221
  1056. package/.agent-src/commands/feature.md +0 -58
  1057. package/.agent-src/commands/fix/ci.md +0 -58
  1058. package/.agent-src/commands/fix/portability.md +0 -106
  1059. package/.agent-src/commands/fix/pr-bot-comments.md +0 -156
  1060. package/.agent-src/commands/fix/pr-comments.md +0 -68
  1061. package/.agent-src/commands/fix/pr-developer-comments.md +0 -162
  1062. package/.agent-src/commands/fix/refs.md +0 -103
  1063. package/.agent-src/commands/fix/seeder.md +0 -157
  1064. package/.agent-src/commands/fix.md +0 -60
  1065. package/.agent-src/commands/ghostwriter/delete.md +0 -122
  1066. package/.agent-src/commands/ghostwriter/fetch.md +0 -189
  1067. package/.agent-src/commands/ghostwriter/list.md +0 -106
  1068. package/.agent-src/commands/ghostwriter/show.md +0 -117
  1069. package/.agent-src/commands/ghostwriter/write.md +0 -164
  1070. package/.agent-src/commands/ghostwriter.md +0 -100
  1071. package/.agent-src/commands/grill-me.md +0 -44
  1072. package/.agent-src/commands/image/analyse.md +0 -51
  1073. package/.agent-src/commands/image/create.md +0 -53
  1074. package/.agent-src/commands/image/verify.md +0 -48
  1075. package/.agent-src/commands/image.md +0 -69
  1076. package/.agent-src/commands/implement-ticket.md +0 -165
  1077. package/.agent-src/commands/jira-ticket.md +0 -80
  1078. package/.agent-src/commands/judge/on-diff.md +0 -123
  1079. package/.agent-src/commands/judge/solo.md +0 -95
  1080. package/.agent-src/commands/judge/steps.md +0 -93
  1081. package/.agent-src/commands/judge.md +0 -60
  1082. package/.agent-src/commands/knowledge/cross-repo.md +0 -71
  1083. package/.agent-src/commands/knowledge/forget.md +0 -96
  1084. package/.agent-src/commands/knowledge/ingest.md +0 -114
  1085. package/.agent-src/commands/knowledge/list.md +0 -94
  1086. package/.agent-src/commands/knowledge.md +0 -69
  1087. package/.agent-src/commands/memory/add.md +0 -146
  1088. package/.agent-src/commands/memory/learn-low-impact.md +0 -147
  1089. package/.agent-src/commands/memory/load.md +0 -175
  1090. package/.agent-src/commands/memory/mine-session.md +0 -156
  1091. package/.agent-src/commands/memory/promote.md +0 -194
  1092. package/.agent-src/commands/memory/propose.md +0 -121
  1093. package/.agent-src/commands/memory.md +0 -56
  1094. package/.agent-src/commands/mode.md +0 -129
  1095. package/.agent-src/commands/module/create.md +0 -143
  1096. package/.agent-src/commands/module/explore.md +0 -197
  1097. package/.agent-src/commands/module.md +0 -50
  1098. package/.agent-src/commands/optimize/agents-dir.md +0 -118
  1099. package/.agent-src/commands/optimize/augmentignore.md +0 -311
  1100. package/.agent-src/commands/optimize/rtk.md +0 -160
  1101. package/.agent-src/commands/optimize/skills.md +0 -131
  1102. package/.agent-src/commands/optimize-prompt.md +0 -66
  1103. package/.agent-src/commands/optimize.md +0 -56
  1104. package/.agent-src/commands/orchestrate.md +0 -128
  1105. package/.agent-src/commands/override/create.md +0 -107
  1106. package/.agent-src/commands/override/manage.md +0 -106
  1107. package/.agent-src/commands/override.md +0 -50
  1108. package/.agent-src/commands/package-reset.md +0 -162
  1109. package/.agent-src/commands/package-test.md +0 -238
  1110. package/.agent-src/commands/post-as/ghostwriter.md +0 -70
  1111. package/.agent-src/commands/post-as/me.md +0 -128
  1112. package/.agent-src/commands/post-as.md +0 -62
  1113. package/.agent-src/commands/prediction-pool.md +0 -234
  1114. package/.agent-src/commands/prepare-for-review.md +0 -106
  1115. package/.agent-src/commands/profile/activate.md +0 -81
  1116. package/.agent-src/commands/profile/deactivate.md +0 -68
  1117. package/.agent-src/commands/profile/show.md +0 -70
  1118. package/.agent-src/commands/profile.md +0 -68
  1119. package/.agent-src/commands/project-analyze.md +0 -320
  1120. package/.agent-src/commands/project-health.md +0 -105
  1121. package/.agent-src/commands/quality-fix.md +0 -137
  1122. package/.agent-src/commands/refine-ticket.md +0 -94
  1123. package/.agent-src/commands/research/deep.md +0 -154
  1124. package/.agent-src/commands/research/report.md +0 -139
  1125. package/.agent-src/commands/research.md +0 -177
  1126. package/.agent-src/commands/review-changes.md +0 -205
  1127. package/.agent-src/commands/review-routing.md +0 -117
  1128. package/.agent-src/commands/roadmap/ai-council.md +0 -188
  1129. package/.agent-src/commands/roadmap/create.md +0 -213
  1130. package/.agent-src/commands/roadmap/process-full.md +0 -108
  1131. package/.agent-src/commands/roadmap/process-phase.md +0 -74
  1132. package/.agent-src/commands/roadmap/process-step.md +0 -62
  1133. package/.agent-src/commands/roadmap.md +0 -78
  1134. package/.agent-src/commands/rule-compliance-audit.md +0 -148
  1135. package/.agent-src/commands/set-cost-profile.md +0 -117
  1136. package/.agent-src/commands/skill/preview.md +0 -67
  1137. package/.agent-src/commands/skill.md +0 -48
  1138. package/.agent-src/commands/skills/discover.md +0 -76
  1139. package/.agent-src/commands/skills.md +0 -56
  1140. package/.agent-src/commands/sync-agent-settings.md +0 -139
  1141. package/.agent-src/commands/sync-gitignore/fix.md +0 -147
  1142. package/.agent-src/commands/sync-gitignore.md +0 -138
  1143. package/.agent-src/commands/tests/create.md +0 -83
  1144. package/.agent-src/commands/tests/execute.md +0 -67
  1145. package/.agent-src/commands/tests.md +0 -50
  1146. package/.agent-src/commands/threat-model.md +0 -125
  1147. package/.agent-src/commands/update-form-request-messages.md +0 -199
  1148. package/.agent-src/commands/upstream-contribute.md +0 -181
  1149. package/.agent-src/commands/video/from-script.md +0 -127
  1150. package/.agent-src/commands/video/from-song.md +0 -351
  1151. package/.agent-src/commands/video/scene.md +0 -96
  1152. package/.agent-src/commands/video/stitch.md +0 -87
  1153. package/.agent-src/commands/video/storyboard.md +0 -99
  1154. package/.agent-src/commands/video.md +0 -73
  1155. package/.agent-src/commands/work.md +0 -166
  1156. package/.agent-src/contexts/authority/commit-mechanics.md +0 -93
  1157. package/.agent-src/contexts/communication/rules-auto/augment-source-of-truth-mechanics.md +0 -98
  1158. package/.agent-src/contexts/contracts/artifact-engagement-flow.md +0 -259
  1159. package/.agent-src/contexts/contracts/consumer-agents-md-guide.md +0 -127
  1160. package/.agent-src/contexts/contracts/emergency-triage-block.md +0 -53
  1161. package/.agent-src/personas/README.md +0 -114
  1162. package/.agent-src/profiles/agency.yml +0 -27
  1163. package/.agent-src/profiles/content_creator.yml +0 -30
  1164. package/.agent-src/profiles/developer.yml +0 -26
  1165. package/.agent-src/profiles/finance.yml +0 -24
  1166. package/.agent-src/profiles/founder.yml +0 -25
  1167. package/.agent-src/profiles/ops.yml +0 -25
  1168. package/.agent-src/rules/ask-when-uncertain.md +0 -70
  1169. package/.agent-src/rules/augment-edit-discipline.md +0 -31
  1170. package/.agent-src/rules/augment-source-of-truth.md +0 -75
  1171. package/.agent-src/rules/commit-policy.md +0 -59
  1172. package/.agent-src/rules/direct-answers.md +0 -64
  1173. package/.agent-src/rules/domain-adoption-policy.md +0 -160
  1174. package/.agent-src/rules/language-and-tone.md +0 -64
  1175. package/.agent-src/rules/linked-projects-onboarding-gate.md +0 -79
  1176. package/.agent-src/rules/media-governance-routing.md +0 -85
  1177. package/.agent-src/rules/missing-tool-handling.md +0 -76
  1178. package/.agent-src/rules/model-recommendation.md +0 -85
  1179. package/.agent-src/rules/no-attribution-footers.md +0 -57
  1180. package/.agent-src/rules/no-cheap-questions.md +0 -75
  1181. package/.agent-src/rules/no-pr-progress-comments.md +0 -109
  1182. package/.agent-src/rules/no-roadmap-references.md +0 -141
  1183. package/.agent-src/rules/non-destructive-by-default.md +0 -58
  1184. package/.agent-src/rules/persona-governance.md +0 -93
  1185. package/.agent-src/rules/preservation-guard.md +0 -97
  1186. package/.agent-src/rules/provider-lifecycle-discipline.md +0 -78
  1187. package/.agent-src/rules/roadmap-progress-sync.md +0 -99
  1188. package/.agent-src/rules/scope-control.md +0 -68
  1189. package/.agent-src/rules/user-interrupt-priority.md +0 -49
  1190. package/.agent-src/rules/verify-before-complete.md +0 -78
  1191. package/.agent-src/scripts/update_roadmap_progress.py +0 -416
  1192. package/.agent-src/skills/accessibility-auditor/SKILL.md +0 -136
  1193. package/.agent-src/skills/agents-md-thin-root/SKILL.md +0 -143
  1194. package/.agent-src/skills/api-design/SKILL.md +0 -112
  1195. package/.agent-src/skills/api-endpoint/SKILL.md +0 -94
  1196. package/.agent-src/skills/authz-review/SKILL.md +0 -180
  1197. package/.agent-src/skills/blade-ui/SKILL.md +0 -129
  1198. package/.agent-src/skills/character-consistency/SKILL.md +0 -141
  1199. package/.agent-src/skills/check-refs/SKILL.md +0 -96
  1200. package/.agent-src/skills/code-review/SKILL.md +0 -224
  1201. package/.agent-src/skills/command-writing/SKILL.md +0 -282
  1202. package/.agent-src/skills/condense-memory/SKILL.md +0 -123
  1203. package/.agent-src/skills/context-document/SKILL.md +0 -160
  1204. package/.agent-src/skills/dashboard-design/SKILL.md +0 -123
  1205. package/.agent-src/skills/database/SKILL.md +0 -103
  1206. package/.agent-src/skills/deep-reading-analyst/SKILL.md +0 -198
  1207. package/.agent-src/skills/design-review/SKILL.md +0 -233
  1208. package/.agent-src/skills/existing-ui-audit/SKILL.md +0 -209
  1209. package/.agent-src/skills/fe-design/SKILL.md +0 -255
  1210. package/.agent-src/skills/feature-planning/SKILL.md +0 -271
  1211. package/.agent-src/skills/flux/SKILL.md +0 -121
  1212. package/.agent-src/skills/jira-integration/SKILL.md +0 -187
  1213. package/.agent-src/skills/lint-skills/SKILL.md +0 -95
  1214. package/.agent-src/skills/livewire/SKILL.md +0 -134
  1215. package/.agent-src/skills/md-language-check/SKILL.md +0 -130
  1216. package/.agent-src/skills/merge-conflicts/SKILL.md +0 -195
  1217. package/.agent-src/skills/motion-choreographer/SKILL.md +0 -171
  1218. package/.agent-src/skills/persona-writing/SKILL.md +0 -158
  1219. package/.agent-src/skills/react-shadcn-ui/SKILL.md +0 -213
  1220. package/.agent-src/skills/readme-reviewer/SKILL.md +0 -242
  1221. package/.agent-src/skills/readme-writing/SKILL.md +0 -240
  1222. package/.agent-src/skills/readme-writing-package/SKILL.md +0 -350
  1223. package/.agent-src/skills/roadmap-management/SKILL.md +0 -461
  1224. package/.agent-src/skills/rule-refactor/SKILL.md +0 -149
  1225. package/.agent-src/skills/rule-writing/SKILL.md +0 -277
  1226. package/.agent-src/skills/scene-expander/SKILL.md +0 -147
  1227. package/.agent-src/skills/scene-expander/scene-blueprint.schema.yaml +0 -108
  1228. package/.agent-src/skills/script-writing/SKILL.md +0 -231
  1229. package/.agent-src/skills/sentry-integration/SKILL.md +0 -175
  1230. package/.agent-src/skills/song-to-script/SKILL.md +0 -216
  1231. package/.agent-src/skills/sql-writing/SKILL.md +0 -79
  1232. package/.agent-src/skills/tailwind-engineer/SKILL.md +0 -148
  1233. package/.agent-src/skills/technical-specification/SKILL.md +0 -251
  1234. package/.agent-src/skills/threat-modeling/SKILL.md +0 -197
  1235. package/.agent-src/skills/upstream-contribute/SKILL.md +0 -261
  1236. package/.agent-src/templates/AGENTS.md +0 -34
  1237. package/.agent-src/templates/agents/agent-project-settings.example.yml +0 -286
  1238. package/.agent-src/templates/agents/proposal.example.md +0 -155
  1239. package/.agent-src/templates/command.md +0 -105
  1240. package/.agent-src/templates/copilot-instructions.md +0 -167
  1241. package/.agent-src/templates/github-workflows/proposal-drift.yml +0 -118
  1242. package/.agent-src/templates/hooks/pre-commit-frontmatter +0 -66
  1243. package/.agent-src/templates/hooks/pre-commit-roadmap-progress +0 -99
  1244. package/.agent-src/templates/persona.md +0 -99
  1245. package/.agent-src/templates/rule.md +0 -135
  1246. package/.agent-src/templates/scripts/work_engine/directives/ui/polish.py +0 -510
  1247. package/.agent-src/templates/scripts/work_engine/directives/ui/review.py +0 -468
  1248. package/.agent-src/templates/scripts/work_engine/orchestration.py +0 -182
  1249. package/.agent-src/user-types/README.md +0 -124
  1250. package/config/agent-settings.template.yml +0 -578
  1251. package/config/discovery/packs.yml +0 -181
  1252. package/config/discovery/workspaces.yml +0 -72
  1253. package/dist/ui/assets/index-DcAWIwwY.js +0 -40
  1254. package/dist/ui/assets/index-DcAWIwwY.js.map +0 -1
  1255. package/scripts/__pycache__/validate_frontmatter.cpython-312.pyc +0 -0
  1256. package/scripts/_archive/README.md +0 -59
  1257. package/scripts/_archive/_bootstrap_tier_frontmatter.py +0 -151
  1258. package/scripts/_archive/_p43_bodies.py +0 -235
  1259. package/scripts/_archive/_p43_condense.py +0 -118
  1260. package/scripts/_archive/_p4_migrate.py +0 -199
  1261. package/scripts/_cli/cmd_doctor.py +0 -1583
  1262. package/scripts/_cli/cmd_export.py +0 -157
  1263. package/scripts/_cli/cmd_migrate.py +0 -437
  1264. package/scripts/_cli/cmd_refresh.py +0 -173
  1265. package/scripts/_cli/cmd_settings_migrate.py +0 -147
  1266. package/scripts/_cli/cmd_update.py +0 -279
  1267. package/scripts/_cli/cmd_upgrade.py +0 -142
  1268. package/scripts/_cli/cmd_versions.py +0 -160
  1269. package/scripts/_dispatch.bash +0 -1126
  1270. package/scripts/_lib/__pycache__/__init__.cpython-312.pyc +0 -0
  1271. package/scripts/_lib/__pycache__/agent_src.cpython-312.pyc +0 -0
  1272. package/scripts/_lib/agent_src.py +0 -187
  1273. package/scripts/_lib/bench_ab_cache.py +0 -162
  1274. package/scripts/_lib/changelog_eras.py +0 -330
  1275. package/scripts/_lib/claude_desktop_bundler.py +0 -238
  1276. package/scripts/_lib/install_regenerator.py +0 -129
  1277. package/scripts/_lib/installed_lock.py +0 -256
  1278. package/scripts/_lib/scope_guard.sh +0 -162
  1279. package/scripts/_lib/value_ladder.py +0 -696
  1280. package/scripts/_lib/value_report.py +0 -455
  1281. package/scripts/_phase4_bucket.py +0 -210
  1282. package/scripts/_pilot_measure.py +0 -53
  1283. package/scripts/adoption_report.py +0 -195
  1284. package/scripts/adoption_snapshot.py +0 -219
  1285. package/scripts/adoption_status.py +0 -166
  1286. package/scripts/agent-config +0 -57
  1287. package/scripts/ai-video/adapters/gemini-veo.sh +0 -62
  1288. package/scripts/ai-video/adapters/higgsfield.sh +0 -245
  1289. package/scripts/ai-video/adapters/kling.sh +0 -59
  1290. package/scripts/ai-video/adapters/openai-images.sh +0 -143
  1291. package/scripts/ai-video/adapters/sora.sh +0 -60
  1292. package/scripts/ai-video/lib/adapter-common.sh +0 -116
  1293. package/scripts/ai-video/lib/adapter-contract.md +0 -163
  1294. package/scripts/ai-video/lib/fixtures/gemini-veo/result.json +0 -1
  1295. package/scripts/ai-video/lib/fixtures/higgsfield/result.json +0 -1
  1296. package/scripts/ai-video/lib/fixtures/kling/result.json +0 -1
  1297. package/scripts/ai-video/lib/fixtures/openai-images/result.json +0 -1
  1298. package/scripts/ai-video/lib/fixtures/sora/result.json +0 -1
  1299. package/scripts/ai-video/lib/load-config.sh +0 -140
  1300. package/scripts/ai-video/lib/validate-deps.sh +0 -132
  1301. package/scripts/ai-video/stitch.sh +0 -154
  1302. package/scripts/ai-video/test-pipeline.sh +0 -169
  1303. package/scripts/ai_council/advisors.py +0 -148
  1304. package/scripts/ai_council/clients.py +0 -1385
  1305. package/scripts/ai_council/compile_corpus.py +0 -179
  1306. package/scripts/ai_council/events_log.py +0 -141
  1307. package/scripts/ai_council/one_off_archive/2026-05/_one_off_2a4_acceptance.py +0 -208
  1308. package/scripts/ai_council/one_off_archive/2026-05/_one_off_budget_v2_audit.py +0 -206
  1309. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_estimate.py +0 -67
  1310. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_review.py +0 -292
  1311. package/scripts/ai_council/one_off_archive/2026-05/_one_off_followups_review.py +0 -259
  1312. package/scripts/ai_council/one_off_archive/2026-05/_one_off_nondestructive_inline_audit.py +0 -209
  1313. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase4_dispatch_latency.py +0 -108
  1314. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase6_trigger_jaccard.py +0 -92
  1315. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_budget_rebalance.py +0 -257
  1316. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_post_revert.py +0 -197
  1317. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rebalancing_audit.py +0 -149
  1318. package/scripts/ai_council/one_off_archive/2026-05/_one_off_roundtrip.py +0 -111
  1319. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rule_hardening_v1.py +0 -251
  1320. package/scripts/ai_council/one_off_archive/2026-05/_one_off_silent_taskfiles.py +0 -98
  1321. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_open_questions.py +0 -232
  1322. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_optimization.py +0 -144
  1323. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_gaps.py +0 -252
  1324. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_review.py +0 -240
  1325. package/scripts/ai_council/one_off_archive/2026-05/_one_off_tier_retrofit.py +0 -180
  1326. package/scripts/ai_council/pricing.py +0 -215
  1327. package/scripts/ai_council/session.py +0 -366
  1328. package/scripts/annotate_discovery.py +0 -149
  1329. package/scripts/apply_modules_config.py +0 -290
  1330. package/scripts/audit_adr_coverage.py +0 -175
  1331. package/scripts/audit_auto_rules.py +0 -175
  1332. package/scripts/audit_cloud_compatibility.py +0 -362
  1333. package/scripts/audit_command_surface.py +0 -374
  1334. package/scripts/audit_initial_context.py +0 -234
  1335. package/scripts/audit_likelihood.py +0 -148
  1336. package/scripts/audit_mcp_tools.py +0 -146
  1337. package/scripts/audit_overlap.py +0 -145
  1338. package/scripts/audit_user_type_axis.py +0 -140
  1339. package/scripts/backfill_model_tier.py +0 -182
  1340. package/scripts/bench_ab_cache_dispatch.py +0 -68
  1341. package/scripts/bench_ab_clone.py +0 -170
  1342. package/scripts/bench_ab_diff.py +0 -220
  1343. package/scripts/bench_ab_integrity.py +0 -143
  1344. package/scripts/bench_ab_run.py +0 -235
  1345. package/scripts/bench_ab_task_runner.py +0 -369
  1346. package/scripts/bench_ab_tracka_run.py +0 -202
  1347. package/scripts/bench_baseline_ready.py +0 -108
  1348. package/scripts/bench_condense_memory.py +0 -168
  1349. package/scripts/bench_drift_check.py +0 -151
  1350. package/scripts/bench_per_tool.py +0 -216
  1351. package/scripts/bench_rtk_savings.py +0 -320
  1352. package/scripts/bench_run.py +0 -272
  1353. package/scripts/bench_runner.py +0 -158
  1354. package/scripts/build_cloud_bundle.py +0 -458
  1355. package/scripts/build_discovery_manifest.py +0 -679
  1356. package/scripts/build_linear_digest.py +0 -260
  1357. package/scripts/build_mcp_registry_manifest.py +0 -181
  1358. package/scripts/build_rule_trigger_matrix.py +0 -350
  1359. package/scripts/capture_showcase_session.py +0 -361
  1360. package/scripts/check_always_budget.py +0 -532
  1361. package/scripts/check_artefact_checksums.py +0 -111
  1362. package/scripts/check_augment_description_cap.py +0 -79
  1363. package/scripts/check_augmentignore.py +0 -72
  1364. package/scripts/check_beta_review_markers.py +0 -127
  1365. package/scripts/check_cluster_patterns.py +0 -175
  1366. package/scripts/check_command_count_messaging.py +0 -158
  1367. package/scripts/check_condensation.py +0 -375
  1368. package/scripts/check_condensed_paths.py +0 -221
  1369. package/scripts/check_context_paths.py +0 -202
  1370. package/scripts/check_council_references.py +0 -228
  1371. package/scripts/check_discovery_determinism.py +0 -70
  1372. package/scripts/check_gate_paths.py +0 -117
  1373. package/scripts/check_module_management_neutral.py +0 -149
  1374. package/scripts/check_no_roadmap_refs.py +0 -155
  1375. package/scripts/check_one_off_location.py +0 -81
  1376. package/scripts/check_overlay_cascade_subdirs.py +0 -129
  1377. package/scripts/check_portability.py +0 -574
  1378. package/scripts/check_public_catalog_links.py +0 -125
  1379. package/scripts/check_public_links.py +0 -185
  1380. package/scripts/check_references.py +0 -541
  1381. package/scripts/check_release_includes_discovery.py +0 -61
  1382. package/scripts/check_release_pr_shape.py +0 -119
  1383. package/scripts/check_release_published.py +0 -145
  1384. package/scripts/check_reply_consistency.py +0 -169
  1385. package/scripts/check_roadmap_trackable.py +0 -114
  1386. package/scripts/check_role_doc_links.py +0 -110
  1387. package/scripts/check_safety_floor_untouched.py +0 -125
  1388. package/scripts/check_skill_requires.py +0 -143
  1389. package/scripts/check_template_pin_drift.py +0 -129
  1390. package/scripts/check_test_coverage_diff.py +0 -180
  1391. package/scripts/check_token_optimizer_freshness.py +0 -146
  1392. package/scripts/check_update_banner.py +0 -86
  1393. package/scripts/ci_time_ratio.py +0 -168
  1394. package/scripts/compile_router.py +0 -232
  1395. package/scripts/condense.py +0 -1649
  1396. package/scripts/condense_memory.py +0 -178
  1397. package/scripts/config/profiles.py +0 -188
  1398. package/scripts/config/session_profiles.py +0 -492
  1399. package/scripts/cost_by_conversation.py +0 -78
  1400. package/scripts/cost_summary.py +0 -97
  1401. package/scripts/council_cli.py +0 -2544
  1402. package/scripts/cross_repo_retrieve.py +0 -172
  1403. package/scripts/discovery_stats.py +0 -70
  1404. package/scripts/extract_audit_patterns.py +0 -202
  1405. package/scripts/first_run_gate_hook.py +0 -178
  1406. package/scripts/gen_discovery_baseline.py +0 -127
  1407. package/scripts/generate_catalog.py +0 -116
  1408. package/scripts/generate_index.py +0 -302
  1409. package/scripts/generate_ownership_matrix.py +0 -378
  1410. package/scripts/generate_pack_manifests.py +0 -183
  1411. package/scripts/hook_manifest.yaml +0 -234
  1412. package/scripts/hooks/dispatch_hook.py +0 -461
  1413. package/scripts/hooks/replay_hook.py +0 -144
  1414. package/scripts/hooks_doctor.py +0 -223
  1415. package/scripts/hooks_status.py +0 -157
  1416. package/scripts/install +0 -424
  1417. package/scripts/install-hooks.sh +0 -185
  1418. package/scripts/install.py +0 -5027
  1419. package/scripts/install.sh +0 -1140
  1420. package/scripts/inventory_abstraction_budget.py +0 -621
  1421. package/scripts/inventory_frontmatter.py +0 -164
  1422. package/scripts/inventory_meta_layers.py +0 -288
  1423. package/scripts/iron_law_sha.py +0 -107
  1424. package/scripts/linked_projects_list.py +0 -91
  1425. package/scripts/lint_agents_layout.py +0 -191
  1426. package/scripts/lint_agents_md.py +0 -208
  1427. package/scripts/lint_archived_skills.py +0 -159
  1428. package/scripts/lint_artefact_frontmatter.py +0 -180
  1429. package/scripts/lint_bench_ab.py +0 -172
  1430. package/scripts/lint_bench_corpus.py +0 -255
  1431. package/scripts/lint_command_tiers.py +0 -128
  1432. package/scripts/lint_commit_subjects.py +0 -139
  1433. package/scripts/lint_context_spine_usage.py +0 -137
  1434. package/scripts/lint_discovery_manifest.py +0 -136
  1435. package/scripts/lint_discovery_vocabulary.py +0 -156
  1436. package/scripts/lint_examples.py +0 -102
  1437. package/scripts/lint_explain_trace.py +0 -80
  1438. package/scripts/lint_featured_skills.py +0 -139
  1439. package/scripts/lint_framework_leakage.py +0 -375
  1440. package/scripts/lint_framework_leakage_allowlist.json +0 -575
  1441. package/scripts/lint_frontmatter_boilerplate.py +0 -77
  1442. package/scripts/lint_ghostwriter_source.py +0 -240
  1443. package/scripts/lint_handoffs.py +0 -217
  1444. package/scripts/lint_hook_concern_budget.py +0 -207
  1445. package/scripts/lint_hook_manifest.py +0 -217
  1446. package/scripts/lint_load_context.py +0 -196
  1447. package/scripts/lint_marketplace.py +0 -180
  1448. package/scripts/lint_marketplace_install_completeness.py +0 -188
  1449. package/scripts/lint_mcp_registry_manifest.py +0 -69
  1450. package/scripts/lint_media_policy_linkage.py +0 -140
  1451. package/scripts/lint_model_tier_coverage.py +0 -73
  1452. package/scripts/lint_namespace.py +0 -135
  1453. package/scripts/lint_no_new_atomic_commands.py +0 -180
  1454. package/scripts/lint_one_off_age.py +0 -184
  1455. package/scripts/lint_orchestration_dsl.py +0 -217
  1456. package/scripts/lint_pack_boundaries.py +0 -147
  1457. package/scripts/lint_pack_first_win.py +0 -103
  1458. package/scripts/lint_persona_governance.py +0 -164
  1459. package/scripts/lint_positioning.py +0 -143
  1460. package/scripts/lint_regression.py +0 -232
  1461. package/scripts/lint_roadmap_ci_steps.py +0 -186
  1462. package/scripts/lint_roadmap_complexity.py +0 -220
  1463. package/scripts/lint_role_experiences.py +0 -237
  1464. package/scripts/lint_rule_interactions.py +0 -170
  1465. package/scripts/lint_rule_tiers.py +0 -90
  1466. package/scripts/lint_showcase_sessions.py +0 -148
  1467. package/scripts/lint_skill_tools.py +0 -168
  1468. package/scripts/lint_topics_yaml.py +0 -89
  1469. package/scripts/lint_trust_coherence.py +0 -212
  1470. package/scripts/lint_value_dashboard.py +0 -218
  1471. package/scripts/mcp_parity_smoke.py +0 -164
  1472. package/scripts/mcp_registry_submit.sh +0 -187
  1473. package/scripts/mcp_server/__init__.py +0 -19
  1474. package/scripts/mcp_server/consumer_tool_catalog.json +0 -275
  1475. package/scripts/mcp_server/prompts.py +0 -441
  1476. package/scripts/mcp_server/resources.py +0 -201
  1477. package/scripts/mcp_server/tools.py +0 -838
  1478. package/scripts/measure_augment_budget.py +0 -214
  1479. package/scripts/measure_density.py +0 -232
  1480. package/scripts/measure_frugality_savings.py +0 -164
  1481. package/scripts/measure_markitdown_lift.py +0 -127
  1482. package/scripts/measure_patterns.py +0 -376
  1483. package/scripts/measure_projection_bytes.py +0 -159
  1484. package/scripts/measure_rule_budget.py +0 -347
  1485. package/scripts/measure_skill_reduction.py +0 -102
  1486. package/scripts/migrate_command_suggestions.py +0 -151
  1487. package/scripts/migrate_frontmatter_defaults.py +0 -245
  1488. package/scripts/mine_session.py +0 -279
  1489. package/scripts/move_artefact.py +0 -143
  1490. package/scripts/new_skill.py +0 -148
  1491. package/scripts/pack_mcp_content.py +0 -288
  1492. package/scripts/plan_physical_move.py +0 -353
  1493. package/scripts/print_required_checks.py +0 -196
  1494. package/scripts/probe_projection_fidelity.py +0 -202
  1495. package/scripts/profile_staleness_hook.py +0 -69
  1496. package/scripts/profile_use.py +0 -125
  1497. package/scripts/project_thin_rules.py +0 -168
  1498. package/scripts/prototype_lint_contradictions.py +0 -150
  1499. package/scripts/recruit_preflight.sh +0 -152
  1500. package/scripts/refine_ticket_detect.py +0 -646
  1501. package/scripts/release.py +0 -1049
  1502. package/scripts/render_benchmark_md.py +0 -312
  1503. package/scripts/render_value_md.py +0 -347
  1504. package/scripts/repro/repro_marketplace_install_gap.sh +0 -161
  1505. package/scripts/roadmap_progress_hook.py +0 -274
  1506. package/scripts/router_telemetry.py +0 -470
  1507. package/scripts/run_skill_evals.py +0 -185
  1508. package/scripts/runtime_registry.py +0 -166
  1509. package/scripts/schemas/command.schema.json +0 -178
  1510. package/scripts/schemas/rule.schema.json +0 -145
  1511. package/scripts/score_skill_selection.py +0 -198
  1512. package/scripts/skill_collision_clusters.py +0 -162
  1513. package/scripts/skill_discovery.py +0 -254
  1514. package/scripts/skill_linter.py +0 -3686
  1515. package/scripts/skill_overlap.py +0 -204
  1516. package/scripts/skill_preview.py +0 -179
  1517. package/scripts/skill_tools/audit_persona_coverage.py +0 -147
  1518. package/scripts/skill_tools/audit_user_type_coverage.py +0 -148
  1519. package/scripts/skill_tools/run_block_d_eval.py +0 -129
  1520. package/scripts/skill_tools/score_skill_relevance.py +0 -169
  1521. package/scripts/skill_tools/suggest_skill_for_task.py +0 -113
  1522. package/scripts/skill_trigger_eval.py +0 -682
  1523. package/scripts/skill_usage_collect.py +0 -191
  1524. package/scripts/skill_usage_report.py +0 -162
  1525. package/scripts/smoke/kernel.sh +0 -107
  1526. package/scripts/smoke/router.sh +0 -148
  1527. package/scripts/smoke/schema.sh +0 -71
  1528. package/scripts/smoke/skills.sh +0 -112
  1529. package/scripts/smoke_path_resolution.py +0 -93
  1530. package/scripts/smoke_quickstart.py +0 -144
  1531. package/scripts/snapshot_agent_outputs.py +0 -144
  1532. package/scripts/spotcheck_thin_root.py +0 -134
  1533. package/scripts/sync_agent_settings.py +0 -180
  1534. package/scripts/sync_github_metadata.py +0 -147
  1535. package/scripts/sync_gitignore.py +0 -291
  1536. package/scripts/telegraph_stats.py +0 -119
  1537. package/scripts/trigger_coverage.py +0 -129
  1538. package/scripts/update_counts.py +0 -195
  1539. package/scripts/update_prices.py +0 -125
  1540. package/scripts/validate_agent_settings.py +0 -124
  1541. package/scripts/validate_decision_engine.py +0 -136
  1542. package/scripts/validate_discovery_manifest.py +0 -94
  1543. package/scripts/validate_frontmatter.py +0 -571
  1544. package/scripts/verify_physical_move.py +0 -185
  1545. /package/{.agent-src → dist/agent-src}/contexts/augment-infrastructure.md +0 -0
  1546. /package/{.agent-src → dist/agent-src}/contexts/authority/destructive-mechanics.md +0 -0
  1547. /package/{.agent-src → dist/agent-src}/contexts/authority/kernel-rule-edits.md +0 -0
  1548. /package/{.agent-src → dist/agent-src}/contexts/authority/scope-mechanics.md +0 -0
  1549. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/guidelines-mechanics.md +0 -0
  1550. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/skill-quality-mechanics.md +0 -0
  1551. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/slash-command-routing-policy-mechanics.md +0 -0
  1552. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/think-before-action-mechanics.md +0 -0
  1553. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/token-efficiency-mechanics.md +0 -0
  1554. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/user-interaction-mechanics.md +0 -0
  1555. /package/{.agent-src → dist/agent-src}/contexts/contracts/agents-md-anatomy.md +0 -0
  1556. /package/{.agent-src → dist/agent-src}/contexts/contracts/command-suggestion-flow.md +0 -0
  1557. /package/{.agent-src → dist/agent-src}/contexts/contracts/frugality-charter.md +0 -0
  1558. /package/{.agent-src → dist/agent-src}/contexts/contracts/research-schema.md +0 -0
  1559. /package/{.agent-src → dist/agent-src}/contexts/documentation-hierarchy.md +0 -0
  1560. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-detection.md +0 -0
  1561. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-examples.md +0 -0
  1562. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-mechanics.md +0 -0
  1563. /package/{.agent-src → dist/agent-src}/contexts/execution/cheap-question-mechanics.md +0 -0
  1564. /package/{.agent-src → dist/agent-src}/contexts/execution/interrupt-examples.md +0 -0
  1565. /package/{.agent-src → dist/agent-src}/contexts/execution/roadmap-process-loop.md +0 -0
  1566. /package/{.agent-src → dist/agent-src}/contexts/execution/verification-mechanics.md +0 -0
  1567. /package/{.agent-src → dist/agent-src}/contexts/judges/no-consolidate-rationale.md +0 -0
  1568. /package/{.agent-src → dist/agent-src}/contexts/judges/persona-voice-rubric.md +0 -0
  1569. /package/{.agent-src → dist/agent-src}/contexts/model-recommendations.md +0 -0
  1570. /package/{.agent-src → dist/agent-src}/contexts/override-system.md +0 -0
  1571. /package/{.agent-src → dist/agent-src}/contexts/skills-and-commands.md +0 -0
  1572. /package/{.agent-src → dist/agent-src}/contexts/subagent-configuration.md +0 -0
  1573. /package/{.agent-src → dist/agent-src}/ghostwriter/README.md +0 -0
  1574. /package/{.agent-src → dist/agent-src}/ghostwriter/fictional-fixture-v1.md +0 -0
  1575. /package/{.agent-src → dist/agent-src}/packs/README.md +0 -0
  1576. /package/{.agent-src → dist/agent-src}/packs/agency-delivery.yml +0 -0
  1577. /package/{.agent-src → dist/agent-src}/packs/content-engine.yml +0 -0
  1578. /package/{.agent-src → dist/agent-src}/packs/founder-mvp.yml +0 -0
  1579. /package/{.agent-src → dist/agent-src}/personas/_template-specialist/persona.md +0 -0
  1580. /package/{.agent-src → dist/agent-src}/personas/advisors/contrarian.md +0 -0
  1581. /package/{.agent-src → dist/agent-src}/personas/advisors/executor.md +0 -0
  1582. /package/{.agent-src → dist/agent-src}/personas/advisors/expansionist.md +0 -0
  1583. /package/{.agent-src → dist/agent-src}/personas/advisors/first-principles.md +0 -0
  1584. /package/{.agent-src → dist/agent-src}/personas/advisors/outsider.md +0 -0
  1585. /package/{.agent-src → dist/agent-src}/personas/ai-agent.md +0 -0
  1586. /package/{.agent-src → dist/agent-src}/personas/ai-video-technical-director.md +0 -0
  1587. /package/{.agent-src → dist/agent-src}/personas/backend-architect.md +0 -0
  1588. /package/{.agent-src → dist/agent-src}/personas/cmo.md +0 -0
  1589. /package/{.agent-src → dist/agent-src}/personas/critical-challenger.md +0 -0
  1590. /package/{.agent-src → dist/agent-src}/personas/customer-success-lead.md +0 -0
  1591. /package/{.agent-src → dist/agent-src}/personas/developer.md +0 -0
  1592. /package/{.agent-src → dist/agent-src}/personas/discovery-lead.md +0 -0
  1593. /package/{.agent-src → dist/agent-src}/personas/eloquent-tamer.md +0 -0
  1594. /package/{.agent-src → dist/agent-src}/personas/engineering-manager.md +0 -0
  1595. /package/{.agent-src → dist/agent-src}/personas/finance-partner.md +0 -0
  1596. /package/{.agent-src → dist/agent-src}/personas/frontend-engineer.md +0 -0
  1597. /package/{.agent-src → dist/agent-src}/personas/growth-pm.md +0 -0
  1598. /package/{.agent-src → dist/agent-src}/personas/hollywood-director.md +0 -0
  1599. /package/{.agent-src → dist/agent-src}/personas/people-strategist.md +0 -0
  1600. /package/{.agent-src → dist/agent-src}/personas/product-owner.md +0 -0
  1601. /package/{.agent-src → dist/agent-src}/personas/qa.md +0 -0
  1602. /package/{.agent-src → dist/agent-src}/personas/revops-maintainer.md +0 -0
  1603. /package/{.agent-src → dist/agent-src}/personas/revops.md +0 -0
  1604. /package/{.agent-src → dist/agent-src}/personas/security-engineer.md +0 -0
  1605. /package/{.agent-src → dist/agent-src}/personas/senior-engineer.md +0 -0
  1606. /package/{.agent-src → dist/agent-src}/personas/stakeholder.md +0 -0
  1607. /package/{.agent-src → dist/agent-src}/personas/strategist.md +0 -0
  1608. /package/{.agent-src → dist/agent-src}/personas/tech-writer.md +0 -0
  1609. /package/{.agent-src → dist/agent-src}/presets/README.md +0 -0
  1610. /package/{.agent-src → dist/agent-src}/presets/balanced.yml +0 -0
  1611. /package/{.agent-src → dist/agent-src}/presets/fast.yml +0 -0
  1612. /package/{.agent-src → dist/agent-src}/presets/strict.yml +0 -0
  1613. /package/{.agent-src → dist/agent-src}/profiles/README.md +0 -0
  1614. /package/{.agent-src → dist/agent-src}/rules/agent-authority.md +0 -0
  1615. /package/{.agent-src → dist/agent-src}/rules/analysis-skill-routing.md +0 -0
  1616. /package/{.agent-src → dist/agent-src}/rules/architecture.md +0 -0
  1617. /package/{.agent-src → dist/agent-src}/rules/artifact-drafting-protocol.md +0 -0
  1618. /package/{.agent-src → dist/agent-src}/rules/artifact-engagement-recording.md +0 -0
  1619. /package/{.agent-src → dist/agent-src}/rules/autonomous-execution.md +0 -0
  1620. /package/{.agent-src → dist/agent-src}/rules/cli-output-handling.md +0 -0
  1621. /package/{.agent-src → dist/agent-src}/rules/command-suggestion-policy.md +0 -0
  1622. /package/{.agent-src → dist/agent-src}/rules/commit-conventions.md +0 -0
  1623. /package/{.agent-src → dist/agent-src}/rules/context-hygiene.md +0 -0
  1624. /package/{.agent-src → dist/agent-src}/rules/copilot-routing.md +0 -0
  1625. /package/{.agent-src → dist/agent-src}/rules/devcontainer-routing.md +0 -0
  1626. /package/{.agent-src → dist/agent-src}/rules/docker-commands.md +0 -0
  1627. /package/{.agent-src → dist/agent-src}/rules/domain-safety-disclaimer.md +0 -0
  1628. /package/{.agent-src → dist/agent-src}/rules/domain-safety-pii.md +0 -0
  1629. /package/{.agent-src → dist/agent-src}/rules/domain-safety-retention.md +0 -0
  1630. /package/{.agent-src → dist/agent-src}/rules/downstream-changes.md +0 -0
  1631. /package/{.agent-src → dist/agent-src}/rules/engineering-safety-floor.md +0 -0
  1632. /package/{.agent-src → dist/agent-src}/rules/external-reference-deep-dive.md +0 -0
  1633. /package/{.agent-src → dist/agent-src}/rules/fast-path-marker-visibility.md +0 -0
  1634. /package/{.agent-src → dist/agent-src}/rules/finance-safety-floor.md +0 -0
  1635. /package/{.agent-src → dist/agent-src}/rules/framework-neutrality-in-generic-skills.md +0 -0
  1636. /package/{.agent-src → dist/agent-src}/rules/git-history-discipline.md +0 -0
  1637. /package/{.agent-src → dist/agent-src}/rules/guidelines.md +0 -0
  1638. /package/{.agent-src → dist/agent-src}/rules/improve-before-implement.md +0 -0
  1639. /package/{.agent-src → dist/agent-src}/rules/invite-challenge.md +0 -0
  1640. /package/{.agent-src → dist/agent-src}/rules/laravel-routing.md +0 -0
  1641. /package/{.agent-src → dist/agent-src}/rules/laravel-translations.md +0 -0
  1642. /package/{.agent-src → dist/agent-src}/rules/low-impact-corpus-privacy-floor.md +0 -0
  1643. /package/{.agent-src → dist/agent-src}/rules/markdown-safe-codeblocks.md +0 -0
  1644. /package/{.agent-src → dist/agent-src}/rules/media-sync-ground-truth.md +0 -0
  1645. /package/{.agent-src → dist/agent-src}/rules/minimal-safe-diff.md +0 -0
  1646. /package/{.agent-src → dist/agent-src}/rules/no-decorative-emojis-in-git-surfaces.md +0 -0
  1647. /package/{.agent-src → dist/agent-src}/rules/onboarding-gate.md +0 -0
  1648. /package/{.agent-src → dist/agent-src}/rules/package-ci-checks.md +0 -0
  1649. /package/{.agent-src → dist/agent-src}/rules/php-coding.md +0 -0
  1650. /package/{.agent-src → dist/agent-src}/rules/reviewer-awareness.md +0 -0
  1651. /package/{.agent-src → dist/agent-src}/rules/roadmap-ci-steps-policy.md +0 -0
  1652. /package/{.agent-src → dist/agent-src}/rules/role-mode-adherence.md +0 -0
  1653. /package/{.agent-src → dist/agent-src}/rules/rule-type-governance.md +0 -0
  1654. /package/{.agent-src → dist/agent-src}/rules/runtime-safety.md +0 -0
  1655. /package/{.agent-src → dist/agent-src}/rules/security-sensitive-stop.md +0 -0
  1656. /package/{.agent-src → dist/agent-src}/rules/size-enforcement.md +0 -0
  1657. /package/{.agent-src → dist/agent-src}/rules/skill-improvement-trigger.md +0 -0
  1658. /package/{.agent-src → dist/agent-src}/rules/skill-quality.md +0 -0
  1659. /package/{.agent-src → dist/agent-src}/rules/slash-command-routing-policy.md +0 -0
  1660. /package/{.agent-src → dist/agent-src}/rules/strategy-safety-floor.md +0 -0
  1661. /package/{.agent-src → dist/agent-src}/rules/symfony-routing.md +0 -0
  1662. /package/{.agent-src → dist/agent-src}/rules/telegraph-speak.md +0 -0
  1663. /package/{.agent-src → dist/agent-src}/rules/think-before-action.md +0 -0
  1664. /package/{.agent-src → dist/agent-src}/rules/token-efficiency.md +0 -0
  1665. /package/{.agent-src → dist/agent-src}/rules/token-optimizer-maintenance.md +0 -0
  1666. /package/{.agent-src → dist/agent-src}/rules/tool-safety.md +0 -0
  1667. /package/{.agent-src → dist/agent-src}/rules/ui-audit-gate.md +0 -0
  1668. /package/{.agent-src → dist/agent-src}/rules/upstream-proposal.md +0 -0
  1669. /package/{.agent-src → dist/agent-src}/rules/user-interaction.md +0 -0
  1670. /package/{.agent-src → dist/agent-src}/scripts/scan-seeder-violations.php +0 -0
  1671. /package/{.agent-src → dist/agent-src}/skills/activation-design/SKILL.md +0 -0
  1672. /package/{.agent-src → dist/agent-src}/skills/adr-create/SKILL.md +0 -0
  1673. /package/{.agent-src → dist/agent-src}/skills/adversarial-review/SKILL.md +0 -0
  1674. /package/{.agent-src → dist/agent-src}/skills/agent-docs-writing/SKILL.md +0 -0
  1675. /package/{.agent-src → dist/agent-src}/skills/ai-council/SKILL.md +0 -0
  1676. /package/{.agent-src → dist/agent-src}/skills/analysis-autonomous-mode/SKILL.md +0 -0
  1677. /package/{.agent-src → dist/agent-src}/skills/analysis-skill-router/SKILL.md +0 -0
  1678. /package/{.agent-src → dist/agent-src}/skills/api-testing/SKILL.md +0 -0
  1679. /package/{.agent-src → dist/agent-src}/skills/architecture-review-lens/SKILL.md +0 -0
  1680. /package/{.agent-src → dist/agent-src}/skills/artisan-commands/SKILL.md +0 -0
  1681. /package/{.agent-src → dist/agent-src}/skills/async-python-patterns/SKILL.md +0 -0
  1682. /package/{.agent-src → dist/agent-src}/skills/aws-infrastructure/SKILL.md +0 -0
  1683. /package/{.agent-src → dist/agent-src}/skills/blast-radius-analyzer/SKILL.md +0 -0
  1684. /package/{.agent-src → dist/agent-src}/skills/bug-analyzer/SKILL.md +0 -0
  1685. /package/{.agent-src → dist/agent-src}/skills/build-buy-partner/SKILL.md +0 -0
  1686. /package/{.agent-src → dist/agent-src}/skills/canvas-design/SKILL.md +0 -0
  1687. /package/{.agent-src → dist/agent-src}/skills/canvas-design/evals/triggers.json +0 -0
  1688. /package/{.agent-src → dist/agent-src}/skills/churn-prevention/SKILL.md +0 -0
  1689. /package/{.agent-src → dist/agent-src}/skills/code-refactoring/SKILL.md +0 -0
  1690. /package/{.agent-src → dist/agent-src}/skills/command-routing/SKILL.md +0 -0
  1691. /package/{.agent-src → dist/agent-src}/skills/comp-banding/SKILL.md +0 -0
  1692. /package/{.agent-src → dist/agent-src}/skills/competitive-moat-analysis/SKILL.md +0 -0
  1693. /package/{.agent-src → dist/agent-src}/skills/competitive-positioning/SKILL.md +0 -0
  1694. /package/{.agent-src → dist/agent-src}/skills/composer-packages/SKILL.md +0 -0
  1695. /package/{.agent-src → dist/agent-src}/skills/content-funnel-design/SKILL.md +0 -0
  1696. /package/{.agent-src → dist/agent-src}/skills/context-authoring/SKILL.md +0 -0
  1697. /package/{.agent-src → dist/agent-src}/skills/contracts-cognition/SKILL.md +0 -0
  1698. /package/{.agent-src → dist/agent-src}/skills/conventional-commits-writing/SKILL.md +0 -0
  1699. /package/{.agent-src → dist/agent-src}/skills/copilot-agents-optimization/SKILL.md +0 -0
  1700. /package/{.agent-src → dist/agent-src}/skills/copilot-config/SKILL.md +0 -0
  1701. /package/{.agent-src → dist/agent-src}/skills/customer-research/SKILL.md +0 -0
  1702. /package/{.agent-src → dist/agent-src}/skills/data-flow-mapper/SKILL.md +0 -0
  1703. /package/{.agent-src → dist/agent-src}/skills/data-handling-judgment/SKILL.md +0 -0
  1704. /package/{.agent-src → dist/agent-src}/skills/dcf-modeling/SKILL.md +0 -0
  1705. /package/{.agent-src → dist/agent-src}/skills/deal-qualification-meddic/SKILL.md +0 -0
  1706. /package/{.agent-src → dist/agent-src}/skills/decision-record/SKILL.md +0 -0
  1707. /package/{.agent-src → dist/agent-src}/skills/defense-in-depth/SKILL.md +0 -0
  1708. /package/{.agent-src → dist/agent-src}/skills/dependency-upgrade/SKILL.md +0 -0
  1709. /package/{.agent-src → dist/agent-src}/skills/description-assist/SKILL.md +0 -0
  1710. /package/{.agent-src → dist/agent-src}/skills/devcontainer/SKILL.md +0 -0
  1711. /package/{.agent-src → dist/agent-src}/skills/developer-like-execution/SKILL.md +0 -0
  1712. /package/{.agent-src → dist/agent-src}/skills/discovery-interview/SKILL.md +0 -0
  1713. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/SKILL.md +0 -0
  1714. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/evals/triggers.json +0 -0
  1715. /package/{.agent-src → dist/agent-src}/skills/docker/SKILL.md +0 -0
  1716. /package/{.agent-src → dist/agent-src}/skills/editorial-calendar/SKILL.md +0 -0
  1717. /package/{.agent-src → dist/agent-src}/skills/eloquent/SKILL.md +0 -0
  1718. /package/{.agent-src → dist/agent-src}/skills/eloquent/evals/triggers.json +0 -0
  1719. /package/{.agent-src → dist/agent-src}/skills/error-handling-patterns/SKILL.md +0 -0
  1720. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/SKILL.md +0 -0
  1721. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/output-schema.yml +0 -0
  1722. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/triggers.json +0 -0
  1723. /package/{.agent-src → dist/agent-src}/skills/expansion-playbook/SKILL.md +0 -0
  1724. /package/{.agent-src → dist/agent-src}/skills/file-editor/SKILL.md +0 -0
  1725. /package/{.agent-src → dist/agent-src}/skills/finishing-a-development-branch/SKILL.md +0 -0
  1726. /package/{.agent-src → dist/agent-src}/skills/forecast-accuracy/SKILL.md +0 -0
  1727. /package/{.agent-src → dist/agent-src}/skills/forecasting/SKILL.md +0 -0
  1728. /package/{.agent-src → dist/agent-src}/skills/form-handler/SKILL.md +0 -0
  1729. /package/{.agent-src → dist/agent-src}/skills/fundraising-narrative/SKILL.md +0 -0
  1730. /package/{.agent-src → dist/agent-src}/skills/funnel-analysis/SKILL.md +0 -0
  1731. /package/{.agent-src → dist/agent-src}/skills/git-workflow/SKILL.md +0 -0
  1732. /package/{.agent-src → dist/agent-src}/skills/github-ci/SKILL.md +0 -0
  1733. /package/{.agent-src → dist/agent-src}/skills/grafana/SKILL.md +0 -0
  1734. /package/{.agent-src → dist/agent-src}/skills/gtm-launch/SKILL.md +0 -0
  1735. /package/{.agent-src → dist/agent-src}/skills/guideline-writing/SKILL.md +0 -0
  1736. /package/{.agent-src → dist/agent-src}/skills/hiring-loop-design/SKILL.md +0 -0
  1737. /package/{.agent-src → dist/agent-src}/skills/image-analyser/SKILL.md +0 -0
  1738. /package/{.agent-src → dist/agent-src}/skills/image-analyser/canon-spec.md +0 -0
  1739. /package/{.agent-src → dist/agent-src}/skills/image-analyser/evals/triggers.json +0 -0
  1740. /package/{.agent-src → dist/agent-src}/skills/image-creator/SKILL.md +0 -0
  1741. /package/{.agent-src → dist/agent-src}/skills/image-creator/evals/triggers.json +0 -0
  1742. /package/{.agent-src → dist/agent-src}/skills/incident-commander/SKILL.md +0 -0
  1743. /package/{.agent-src → dist/agent-src}/skills/jobs-events/SKILL.md +0 -0
  1744. /package/{.agent-src → dist/agent-src}/skills/judge-bug-hunter/SKILL.md +0 -0
  1745. /package/{.agent-src → dist/agent-src}/skills/judge-code-quality/SKILL.md +0 -0
  1746. /package/{.agent-src → dist/agent-src}/skills/judge-security-auditor/SKILL.md +0 -0
  1747. /package/{.agent-src → dist/agent-src}/skills/judge-test-coverage/SKILL.md +0 -0
  1748. /package/{.agent-src → dist/agent-src}/skills/laravel/SKILL.md +0 -0
  1749. /package/{.agent-src → dist/agent-src}/skills/laravel-api-endpoint/SKILL.md +0 -0
  1750. /package/{.agent-src → dist/agent-src}/skills/laravel-dto/SKILL.md +0 -0
  1751. /package/{.agent-src → dist/agent-src}/skills/laravel-horizon/SKILL.md +0 -0
  1752. /package/{.agent-src → dist/agent-src}/skills/laravel-mail/SKILL.md +0 -0
  1753. /package/{.agent-src → dist/agent-src}/skills/laravel-middleware/SKILL.md +0 -0
  1754. /package/{.agent-src → dist/agent-src}/skills/laravel-migration/SKILL.md +0 -0
  1755. /package/{.agent-src → dist/agent-src}/skills/laravel-notifications/SKILL.md +0 -0
  1756. /package/{.agent-src → dist/agent-src}/skills/laravel-pennant/SKILL.md +0 -0
  1757. /package/{.agent-src → dist/agent-src}/skills/laravel-pulse/SKILL.md +0 -0
  1758. /package/{.agent-src → dist/agent-src}/skills/laravel-reverb/SKILL.md +0 -0
  1759. /package/{.agent-src → dist/agent-src}/skills/laravel-scheduling/SKILL.md +0 -0
  1760. /package/{.agent-src → dist/agent-src}/skills/laravel-validation/SKILL.md +0 -0
  1761. /package/{.agent-src → dist/agent-src}/skills/laravel-websocket/SKILL.md +0 -0
  1762. /package/{.agent-src → dist/agent-src}/skills/launch-readiness/SKILL.md +0 -0
  1763. /package/{.agent-src → dist/agent-src}/skills/learning-to-rule-or-skill/SKILL.md +0 -0
  1764. /package/{.agent-src → dist/agent-src}/skills/livewire-architect/SKILL.md +0 -0
  1765. /package/{.agent-src → dist/agent-src}/skills/logging-monitoring/SKILL.md +0 -0
  1766. /package/{.agent-src → dist/agent-src}/skills/market-entry-analysis/SKILL.md +0 -0
  1767. /package/{.agent-src → dist/agent-src}/skills/markitdown/SKILL.md +0 -0
  1768. /package/{.agent-src → dist/agent-src}/skills/mcp/SKILL.md +0 -0
  1769. /package/{.agent-src → dist/agent-src}/skills/mcp-builder/SKILL.md +0 -0
  1770. /package/{.agent-src → dist/agent-src}/skills/memory-consolidation/SKILL.md +0 -0
  1771. /package/{.agent-src → dist/agent-src}/skills/messaging-architecture/SKILL.md +0 -0
  1772. /package/{.agent-src → dist/agent-src}/skills/migration-architect/SKILL.md +0 -0
  1773. /package/{.agent-src → dist/agent-src}/skills/mobile-e2e-strategy/SKILL.md +0 -0
  1774. /package/{.agent-src → dist/agent-src}/skills/module-detect-on-the-fly/SKILL.md +0 -0
  1775. /package/{.agent-src → dist/agent-src}/skills/module-management/SKILL.md +0 -0
  1776. /package/{.agent-src → dist/agent-src}/skills/multi-tenancy/SKILL.md +0 -0
  1777. /package/{.agent-src → dist/agent-src}/skills/nextjs-patterns/SKILL.md +0 -0
  1778. /package/{.agent-src → dist/agent-src}/skills/okr-tree-modeling/SKILL.md +0 -0
  1779. /package/{.agent-src → dist/agent-src}/skills/onboarding-design/SKILL.md +0 -0
  1780. /package/{.agent-src → dist/agent-src}/skills/onboarding-program/SKILL.md +0 -0
  1781. /package/{.agent-src → dist/agent-src}/skills/one-on-one-cadence/SKILL.md +0 -0
  1782. /package/{.agent-src → dist/agent-src}/skills/openapi/SKILL.md +0 -0
  1783. /package/{.agent-src → dist/agent-src}/skills/org-design/SKILL.md +0 -0
  1784. /package/{.agent-src → dist/agent-src}/skills/override-management/SKILL.md +0 -0
  1785. /package/{.agent-src → dist/agent-src}/skills/perf-feedback-craft/SKILL.md +0 -0
  1786. /package/{.agent-src → dist/agent-src}/skills/performance/SKILL.md +0 -0
  1787. /package/{.agent-src → dist/agent-src}/skills/performance-analysis/SKILL.md +0 -0
  1788. /package/{.agent-src → dist/agent-src}/skills/pest-testing/SKILL.md +0 -0
  1789. /package/{.agent-src → dist/agent-src}/skills/php-coder/SKILL.md +0 -0
  1790. /package/{.agent-src → dist/agent-src}/skills/php-coder/evals/triggers.json +0 -0
  1791. /package/{.agent-src → dist/agent-src}/skills/php-debugging/SKILL.md +0 -0
  1792. /package/{.agent-src → dist/agent-src}/skills/php-service/SKILL.md +0 -0
  1793. /package/{.agent-src → dist/agent-src}/skills/pipeline-strategy/SKILL.md +0 -0
  1794. /package/{.agent-src → dist/agent-src}/skills/pixar-storyteller/SKILL.md +0 -0
  1795. /package/{.agent-src → dist/agent-src}/skills/playwright-architect/SKILL.md +0 -0
  1796. /package/{.agent-src → dist/agent-src}/skills/playwright-testing/SKILL.md +0 -0
  1797. /package/{.agent-src → dist/agent-src}/skills/po-discovery/SKILL.md +0 -0
  1798. /package/{.agent-src → dist/agent-src}/skills/positioning-strategy/SKILL.md +0 -0
  1799. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/SKILL.md +0 -0
  1800. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/evals/triggers.json +0 -0
  1801. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/ev-fixtures.md +0 -0
  1802. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/odds-and-bonus.md +0 -0
  1803. /package/{.agent-src → dist/agent-src}/skills/privacy-review/SKILL.md +0 -0
  1804. /package/{.agent-src → dist/agent-src}/skills/project-analysis-core/SKILL.md +0 -0
  1805. /package/{.agent-src → dist/agent-src}/skills/project-analysis-hypothesis-driven/SKILL.md +0 -0
  1806. /package/{.agent-src → dist/agent-src}/skills/project-analysis-laravel/SKILL.md +0 -0
  1807. /package/{.agent-src → dist/agent-src}/skills/project-analysis-nextjs/SKILL.md +0 -0
  1808. /package/{.agent-src → dist/agent-src}/skills/project-analysis-node-express/SKILL.md +0 -0
  1809. /package/{.agent-src → dist/agent-src}/skills/project-analysis-react/SKILL.md +0 -0
  1810. /package/{.agent-src → dist/agent-src}/skills/project-analysis-symfony/SKILL.md +0 -0
  1811. /package/{.agent-src → dist/agent-src}/skills/project-analysis-zend-laminas/SKILL.md +0 -0
  1812. /package/{.agent-src → dist/agent-src}/skills/project-analyzer/SKILL.md +0 -0
  1813. /package/{.agent-src → dist/agent-src}/skills/project-docs/SKILL.md +0 -0
  1814. /package/{.agent-src → dist/agent-src}/skills/prompt-engineering-patterns/SKILL.md +0 -0
  1815. /package/{.agent-src → dist/agent-src}/skills/prompt-optimizer/SKILL.md +0 -0
  1816. /package/{.agent-src → dist/agent-src}/skills/quality-tools/SKILL.md +0 -0
  1817. /package/{.agent-src → dist/agent-src}/skills/react-native-setup/SKILL.md +0 -0
  1818. /package/{.agent-src → dist/agent-src}/skills/receiving-code-review/SKILL.md +0 -0
  1819. /package/{.agent-src → dist/agent-src}/skills/refine-prompt/SKILL.md +0 -0
  1820. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/SKILL.md +0 -0
  1821. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/detection-map.yml +0 -0
  1822. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/output-schema.yml +0 -0
  1823. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/triggers.json +0 -0
  1824. /package/{.agent-src → dist/agent-src}/skills/release-comms/SKILL.md +0 -0
  1825. /package/{.agent-src → dist/agent-src}/skills/repomix-packer/SKILL.md +0 -0
  1826. /package/{.agent-src → dist/agent-src}/skills/requesting-code-review/SKILL.md +0 -0
  1827. /package/{.agent-src → dist/agent-src}/skills/retention-loops/SKILL.md +0 -0
  1828. /package/{.agent-src → dist/agent-src}/skills/review-routing/SKILL.md +0 -0
  1829. /package/{.agent-src → dist/agent-src}/skills/rice-prioritization/SKILL.md +0 -0
  1830. /package/{.agent-src → dist/agent-src}/skills/risk-officer/SKILL.md +0 -0
  1831. /package/{.agent-src → dist/agent-src}/skills/roadmap-writing/SKILL.md +0 -0
  1832. /package/{.agent-src → dist/agent-src}/skills/rtk-output-filtering/SKILL.md +0 -0
  1833. /package/{.agent-src → dist/agent-src}/skills/runway-cognition/SKILL.md +0 -0
  1834. /package/{.agent-src → dist/agent-src}/skills/scenario-modeling/SKILL.md +0 -0
  1835. /package/{.agent-src → dist/agent-src}/skills/secrets-management/SKILL.md +0 -0
  1836. /package/{.agent-src → dist/agent-src}/skills/security/SKILL.md +0 -0
  1837. /package/{.agent-src → dist/agent-src}/skills/security-audit/SKILL.md +0 -0
  1838. /package/{.agent-src → dist/agent-src}/skills/sequential-thinking/SKILL.md +0 -0
  1839. /package/{.agent-src → dist/agent-src}/skills/skill-improvement-pipeline/SKILL.md +0 -0
  1840. /package/{.agent-src → dist/agent-src}/skills/skill-management/SKILL.md +0 -0
  1841. /package/{.agent-src → dist/agent-src}/skills/skill-reviewer/SKILL.md +0 -0
  1842. /package/{.agent-src → dist/agent-src}/skills/skill-writing/SKILL.md +0 -0
  1843. /package/{.agent-src → dist/agent-src}/skills/skill-writing/evals/triggers.json +0 -0
  1844. /package/{.agent-src → dist/agent-src}/skills/stakeholder-tradeoff/SKILL.md +0 -0
  1845. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/SKILL.md +0 -0
  1846. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/README.md +0 -0
  1847. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge-two-stage.md +0 -0
  1848. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge.md +0 -0
  1849. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-competitively.md +0 -0
  1850. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-parallel.md +0 -0
  1851. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-steps.md +0 -0
  1852. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-worktrees.md +0 -0
  1853. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/judge-with-debate.md +0 -0
  1854. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/schemas/subagent-status.json +0 -0
  1855. /package/{.agent-src → dist/agent-src}/skills/symfony-workflow/SKILL.md +0 -0
  1856. /package/{.agent-src → dist/agent-src}/skills/systematic-debugging/SKILL.md +0 -0
  1857. /package/{.agent-src → dist/agent-src}/skills/tech-debt-tracker/SKILL.md +0 -0
  1858. /package/{.agent-src → dist/agent-src}/skills/terraform/SKILL.md +0 -0
  1859. /package/{.agent-src → dist/agent-src}/skills/terragrunt/SKILL.md +0 -0
  1860. /package/{.agent-src → dist/agent-src}/skills/test-driven-development/SKILL.md +0 -0
  1861. /package/{.agent-src → dist/agent-src}/skills/test-performance/SKILL.md +0 -0
  1862. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/SKILL.md +0 -0
  1863. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/process-anti-patterns.md +0 -0
  1864. /package/{.agent-src → dist/agent-src}/skills/throughput-vs-morale-tradeoff/SKILL.md +0 -0
  1865. /package/{.agent-src → dist/agent-src}/skills/token-optimizer/SKILL.md +0 -0
  1866. /package/{.agent-src → dist/agent-src}/skills/traefik/SKILL.md +0 -0
  1867. /package/{.agent-src → dist/agent-src}/skills/ui-component-architect/SKILL.md +0 -0
  1868. /package/{.agent-src → dist/agent-src}/skills/unit-economics-modeling/SKILL.md +0 -0
  1869. /package/{.agent-src → dist/agent-src}/skills/universal-project-analysis/SKILL.md +0 -0
  1870. /package/{.agent-src → dist/agent-src}/skills/using-git-worktrees/SKILL.md +0 -0
  1871. /package/{.agent-src → dist/agent-src}/skills/validate-feature-fit/SKILL.md +0 -0
  1872. /package/{.agent-src → dist/agent-src}/skills/verify-completion-evidence/SKILL.md +0 -0
  1873. /package/{.agent-src → dist/agent-src}/skills/video-director/SKILL.md +0 -0
  1874. /package/{.agent-src → dist/agent-src}/skills/vision-articulation/SKILL.md +0 -0
  1875. /package/{.agent-src → dist/agent-src}/skills/voc-extract/SKILL.md +0 -0
  1876. /package/{.agent-src → dist/agent-src}/skills/voice-and-tone-design/SKILL.md +0 -0
  1877. /package/{.agent-src → dist/agent-src}/templates/agent-settings.md +0 -0
  1878. /package/{.agent-src → dist/agent-src}/templates/agents/.gitattributes.fragment +0 -0
  1879. /package/{.agent-src → dist/agent-src}/templates/agents/memory/architecture-decisions.example.yml +0 -0
  1880. /package/{.agent-src → dist/agent-src}/templates/agents/memory/domain-invariants.example.yml +0 -0
  1881. /package/{.agent-src → dist/agent-src}/templates/agents/memory/historical-patterns.example.yml +0 -0
  1882. /package/{.agent-src → dist/agent-src}/templates/agents/memory/incident-learnings.example.yml +0 -0
  1883. /package/{.agent-src → dist/agent-src}/templates/agents/memory/ownership.example.yml +0 -0
  1884. /package/{.agent-src → dist/agent-src}/templates/agents/memory/product-rules.example.yml +0 -0
  1885. /package/{.agent-src → dist/agent-src}/templates/contexts/auth-model.md +0 -0
  1886. /package/{.agent-src → dist/agent-src}/templates/contexts/data-sensitivity.md +0 -0
  1887. /package/{.agent-src → dist/agent-src}/templates/contexts/deployment-order.md +0 -0
  1888. /package/{.agent-src → dist/agent-src}/templates/contexts/observability.md +0 -0
  1889. /package/{.agent-src → dist/agent-src}/templates/contexts/tenant-boundaries.md +0 -0
  1890. /package/{.agent-src → dist/agent-src}/templates/contexts.md +0 -0
  1891. /package/{.agent-src → dist/agent-src}/templates/features.md +0 -0
  1892. /package/{.agent-src → dist/agent-src}/templates/github-workflows/memory-hygiene.yml +0 -0
  1893. /package/{.agent-src → dist/agent-src}/templates/github-workflows/pr-risk-review.yml +0 -0
  1894. /package/{.agent-src → dist/agent-src}/templates/github-workflows/roadmap-progress-check.yml +0 -0
  1895. /package/{.agent-src → dist/agent-src}/templates/overrides/command.md +0 -0
  1896. /package/{.agent-src → dist/agent-src}/templates/overrides/guideline.md +0 -0
  1897. /package/{.agent-src → dist/agent-src}/templates/overrides/rule.md +0 -0
  1898. /package/{.agent-src → dist/agent-src}/templates/overrides/skill.md +0 -0
  1899. /package/{.agent-src → dist/agent-src}/templates/overrides/template.md +0 -0
  1900. /package/{.agent-src → dist/agent-src}/templates/roadmaps.md +0 -0
  1901. /package/{.agent-src → dist/agent-src}/templates/scripts/README.md +0 -0
  1902. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory.py +0 -0
  1903. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory_proposal.py +0 -0
  1904. /package/{.agent-src → dist/agent-src}/templates/scripts/historical-bug-patterns.example.yml +0 -0
  1905. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__init__.py +0 -0
  1906. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__main__.py +0 -0
  1907. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_hash.py +0 -0
  1908. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_lookup.py +0 -0
  1909. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_report.py +0 -0
  1910. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_signal.py +0 -0
  1911. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_status.py +0 -0
  1912. /package/{.agent-src → dist/agent-src}/templates/scripts/ownership-map.example.yml +0 -0
  1913. /package/{.agent-src → dist/agent-src}/templates/scripts/pr-risk-config.example.yml +0 -0
  1914. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_review_routing.py +0 -0
  1915. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_risk_review.py +0 -0
  1916. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/__init__.py +0 -0
  1917. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/aggregator.py +0 -0
  1918. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/boundary.py +0 -0
  1919. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/engagement.py +0 -0
  1920. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/report_renderer.py +0 -0
  1921. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/settings.py +0 -0
  1922. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_record.py +0 -0
  1923. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_report.py +0 -0
  1924. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_status.py +0 -0
  1925. /package/{.agent-src → dist/agent-src}/templates/scripts/tier_usage_report.py +0 -0
  1926. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__init__.py +0 -0
  1927. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__main__.py +0 -0
  1928. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/__init__.py +0 -0
  1929. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/agent_settings.py +0 -0
  1930. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/user_global_paths.py +0 -0
  1931. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli.py +0 -0
  1932. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli_args.py +0 -0
  1933. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/delivery_state.py +0 -0
  1934. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/__init__.py +0 -0
  1935. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/__init__.py +0 -0
  1936. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/analyze.py +0 -0
  1937. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/implement.py +0 -0
  1938. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/memory.py +0 -0
  1939. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/plan.py +0 -0
  1940. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/refine.py +0 -0
  1941. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/report.py +0 -0
  1942. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/test.py +0 -0
  1943. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/verify.py +0 -0
  1944. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/__init__.py +0 -0
  1945. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/contract.py +0 -0
  1946. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/stitch.py +0 -0
  1947. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/ui.py +0 -0
  1948. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/__init__.py +0 -0
  1949. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/_passthrough.py +0 -0
  1950. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/apply.py +0 -0
  1951. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/audit.py +0 -0
  1952. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/design.py +0 -0
  1953. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/__init__.py +0 -0
  1954. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/_skipped.py +0 -0
  1955. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/apply.py +0 -0
  1956. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/refine.py +0 -0
  1957. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/report.py +0 -0
  1958. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/test.py +0 -0
  1959. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/dispatcher.py +0 -0
  1960. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/emitters.py +0 -0
  1961. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/errors.py +0 -0
  1962. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hook_bootstrap.py +0 -0
  1963. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/__init__.py +0 -0
  1964. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/__init__.py +0 -0
  1965. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/_chat_history_base.py +0 -0
  1966. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_append.py +0 -0
  1967. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_halt_append.py +0 -0
  1968. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_gate.py +0 -0
  1969. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_trace.py +0 -0
  1970. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/directive_set_guard.py +0 -0
  1971. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/halt_surface_audit.py +0 -0
  1972. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/memory_visibility.py +0 -0
  1973. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/state_shape_validation.py +0 -0
  1974. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/trace.py +0 -0
  1975. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/context.py +0 -0
  1976. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/events.py +0 -0
  1977. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/exceptions.py +0 -0
  1978. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/registry.py +0 -0
  1979. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/runner.py +0 -0
  1980. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/settings.py +0 -0
  1981. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/input_builders.py +0 -0
  1982. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/__init__.py +0 -0
  1983. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/classify.py +0 -0
  1984. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/__init__.py +0 -0
  1985. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/v0_to_v1.py +0 -0
  1986. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/persona_policy.py +0 -0
  1987. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/__init__.py +0 -0
  1988. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/diff.py +0 -0
  1989. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/file.py +0 -0
  1990. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/prompt.py +0 -0
  1991. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/__init__.py +0 -0
  1992. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/confidence.py +0 -0
  1993. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_engine.py +0 -0
  1994. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_trace.py +0 -0
  1995. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/memory_visibility.py +0 -0
  1996. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/__init__.py +0 -0
  1997. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/detect.py +0 -0
  1998. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state.py +0 -0
  1999. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state_io.py +0 -0
  2000. /package/{.agent-src → dist/agent-src}/templates/skill-archive-note.md +0 -0
  2001. /package/{.agent-src → dist/agent-src}/templates/skill.md +0 -0
  2002. /package/{.agent-src → dist/agent-src}/user-types/_template/user-type.md +0 -0
  2003. /package/{.agent-src → dist/agent-src}/user-types/galabau-field-crew.md +0 -0
  2004. /package/{.agent-src → dist/agent-src}/user-types/metalworking-shop.md +0 -0
  2005. /package/{.agent-src → dist/agent-src}/user-types/truck-driver.md +0 -0
  2006. /package/{config → src/config}/discovery/session-profiles.yml +0 -0
  2007. /package/{config → src/config}/discovery/unassigned-artefacts.yml +0 -0
  2008. /package/{config → src/config}/gitignore-block.txt +0 -0
  2009. /package/{config → src/config}/profiles/balanced.ini +0 -0
  2010. /package/{config → src/config}/profiles/full.ini +0 -0
  2011. /package/{config → src/config}/profiles/minimal.ini +0 -0
  2012. /package/{scripts → src/scripts}/_archive/_backfill_skill_domains.py +0 -0
  2013. /package/{scripts → src/scripts}/_archive/_phase2_shim_helper.py +0 -0
  2014. /package/{scripts → src/scripts}/_archive/_pilot_council_question.py +0 -0
  2015. /package/{scripts → src/scripts}/_cli/__init__.py +0 -0
  2016. /package/{scripts → src/scripts}/_cli/cmd_explain.py +0 -0
  2017. /package/{scripts → src/scripts}/_cli/cmd_prune.py +0 -0
  2018. /package/{scripts → src/scripts}/_cli/cmd_settings_check.py +0 -0
  2019. /package/{scripts → src/scripts}/_cli/cmd_sync.py +0 -0
  2020. /package/{scripts → src/scripts}/_cli/cmd_uninstall.py +0 -0
  2021. /package/{scripts → src/scripts}/_cli/cmd_validate.py +0 -0
  2022. /package/{scripts → src/scripts}/_cli/explain_last/__init__.py +0 -0
  2023. /package/{scripts → src/scripts}/_cli/explain_last/assumptions.py +0 -0
  2024. /package/{scripts → src/scripts}/_cli/explain_last/council.py +0 -0
  2025. /package/{scripts → src/scripts}/_cli/explain_last/halt.py +0 -0
  2026. /package/{scripts → src/scripts}/_cli/explain_last/inputs.py +0 -0
  2027. /package/{scripts → src/scripts}/_cli/explain_last/memory.py +0 -0
  2028. /package/{scripts → src/scripts}/_cli/explain_last/provider.py +0 -0
  2029. /package/{scripts → src/scripts}/_cli/explain_last/render.py +0 -0
  2030. /package/{scripts → src/scripts}/_cli/explain_last/route.py +0 -0
  2031. /package/{scripts → src/scripts}/_cli/explain_last/scrubber.py +0 -0
  2032. /package/{scripts → src/scripts}/_cli/explain_last/sections/__init__.py +0 -0
  2033. /package/{scripts → src/scripts}/_cli/explain_last/sections/assumptions.py +0 -0
  2034. /package/{scripts → src/scripts}/_cli/explain_last/sections/council.py +0 -0
  2035. /package/{scripts → src/scripts}/_cli/explain_last/sections/halt.py +0 -0
  2036. /package/{scripts → src/scripts}/_cli/explain_last/sections/header.py +0 -0
  2037. /package/{scripts → src/scripts}/_cli/explain_last/sections/inputs.py +0 -0
  2038. /package/{scripts → src/scripts}/_cli/explain_last/sections/memory.py +0 -0
  2039. /package/{scripts → src/scripts}/_cli/explain_last/sections/pack.py +0 -0
  2040. /package/{scripts → src/scripts}/_cli/explain_last/sections/provider.py +0 -0
  2041. /package/{scripts → src/scripts}/_cli/explain_last/sections/route.py +0 -0
  2042. /package/{scripts → src/scripts}/_cli/explain_last/state_loader.py +0 -0
  2043. /package/{scripts → src/scripts}/_emit_domain_table.py +0 -0
  2044. /package/{scripts → src/scripts}/_lib/__init__.py +0 -0
  2045. /package/{scripts → src/scripts}/_lib/agent_settings.py +0 -0
  2046. /package/{scripts → src/scripts}/_lib/agents_overlay.py +0 -0
  2047. /package/{scripts → src/scripts}/_lib/bench_ab_scoring.py +0 -0
  2048. /package/{scripts → src/scripts}/_lib/bench_cost.py +0 -0
  2049. /package/{scripts → src/scripts}/_lib/bench_quality.py +0 -0
  2050. /package/{scripts → src/scripts}/_lib/bench_report.py +0 -0
  2051. /package/{scripts → src/scripts}/_lib/bench_telegraph.py +0 -0
  2052. /package/{scripts → src/scripts}/_lib/bench_telegraph_report.py +0 -0
  2053. /package/{scripts → src/scripts}/_lib/fs_atomic.py +0 -0
  2054. /package/{scripts → src/scripts}/_lib/installed_tools.py +0 -0
  2055. /package/{scripts → src/scripts}/_lib/json_pointers.py +0 -0
  2056. /package/{scripts → src/scripts}/_lib/linked_projects.py +0 -0
  2057. /package/{scripts → src/scripts}/_lib/module_detection.py +0 -0
  2058. /package/{scripts → src/scripts}/_lib/pin_resolver.py +0 -0
  2059. /package/{scripts → src/scripts}/_lib/script_output.py +0 -0
  2060. /package/{scripts → src/scripts}/_lib/token_count.py +0 -0
  2061. /package/{scripts → src/scripts}/_lib/update_check.py +0 -0
  2062. /package/{scripts → src/scripts}/_lib/user_global_paths.py +0 -0
  2063. /package/{scripts → src/scripts}/_tmp_scan_framework_leakage.py +0 -0
  2064. /package/{scripts → src/scripts}/adr/regenerate_index.py +0 -0
  2065. /package/{scripts/ai-video/lib/fixtures/kling → src/scripts/ai-video/lib/fixtures/comfyui}/scene-0001.mp4 +0 -0
  2066. /package/{scripts → src/scripts}/ai-video/lib/fixtures/gemini-veo/scene-0001.mp4 +0 -0
  2067. /package/{scripts → src/scripts}/ai-video/lib/fixtures/higgsfield/scene-0001.mp4 +0 -0
  2068. /package/{scripts → src/scripts}/ai-video/lib/fixtures/openai-images/scene-0001.png +0 -0
  2069. /package/{scripts → src/scripts}/ai-video/lib/fixtures/sora/scene-0001.mp4 +0 -0
  2070. /package/{scripts → src/scripts}/ai-video/lib/operator-pick.sh +0 -0
  2071. /package/{scripts → src/scripts}/ai-video/lib/parse-blueprint.sh +0 -0
  2072. /package/{scripts → src/scripts}/ai-video/lib/probe-audio.sh +0 -0
  2073. /package/{scripts → src/scripts}/ai-video/lib/redact.sh +0 -0
  2074. /package/{scripts → src/scripts}/ai_council/__init__.py +0 -0
  2075. /package/{scripts → src/scripts}/ai_council/_default_prices.py +0 -0
  2076. /package/{scripts → src/scripts}/ai_council/airgap.py +0 -0
  2077. /package/{scripts → src/scripts}/ai_council/budget_guard.py +0 -0
  2078. /package/{scripts → src/scripts}/ai_council/bundler.py +0 -0
  2079. /package/{scripts → src/scripts}/ai_council/cli_hints.py +0 -0
  2080. /package/{scripts → src/scripts}/ai_council/confidence_gate.py +0 -0
  2081. /package/{scripts → src/scripts}/ai_council/config.py +0 -0
  2082. /package/{scripts → src/scripts}/ai_council/consensus.py +0 -0
  2083. /package/{scripts → src/scripts}/ai_council/learn_low_impact_preview.py +0 -0
  2084. /package/{scripts → src/scripts}/ai_council/low_impact.py +0 -0
  2085. /package/{scripts → src/scripts}/ai_council/low_impact_corpus.py +0 -0
  2086. /package/{scripts → src/scripts}/ai_council/low_impact_intake.py +0 -0
  2087. /package/{scripts → src/scripts}/ai_council/modes.py +0 -0
  2088. /package/{scripts → src/scripts}/ai_council/necessity.py +0 -0
  2089. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/README.md +0 -0
  2090. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_add_quiet.py +0 -0
  2091. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_inject_quiet_flag.py +0 -0
  2092. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_v2.sh +0 -0
  2093. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_verbosity.sh +0 -0
  2094. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_per_task.sh +0 -0
  2095. /package/{scripts → src/scripts}/ai_council/orchestrator.py +0 -0
  2096. /package/{scripts → src/scripts}/ai_council/probation_gate.py +0 -0
  2097. /package/{scripts → src/scripts}/ai_council/project_context.py +0 -0
  2098. /package/{scripts → src/scripts}/ai_council/prompts.py +0 -0
  2099. /package/{scripts → src/scripts}/ai_council/redact_low_impact_entry.py +0 -0
  2100. /package/{scripts → src/scripts}/ai_council/replay.py +0 -0
  2101. /package/{scripts → src/scripts}/ai_council/shadow_dispatch.py +0 -0
  2102. /package/{scripts → src/scripts}/ai_council/solo_dispatch.py +0 -0
  2103. /package/{scripts → src/scripts}/audit_skill_descriptions.py +0 -0
  2104. /package/{scripts → src/scripts}/bootstrap.sh +0 -0
  2105. /package/{scripts → src/scripts}/chat_history.py +0 -0
  2106. /package/{scripts → src/scripts}/check_bite_sized_granularity.py +0 -0
  2107. /package/{scripts → src/scripts}/check_council_layout.py +0 -0
  2108. /package/{scripts → src/scripts}/check_iron_law_prominence.py +0 -0
  2109. /package/{scripts → src/scripts}/check_kernel_rule_bundle.py +0 -0
  2110. /package/{scripts → src/scripts}/check_md_language.py +0 -0
  2111. /package/{scripts → src/scripts}/check_memory.py +0 -0
  2112. /package/{scripts → src/scripts}/check_memory_proposal.py +0 -0
  2113. /package/{scripts → src/scripts}/check_no_local_settings_committed.py +0 -0
  2114. /package/{scripts → src/scripts}/check_proposal.py +0 -0
  2115. /package/{scripts → src/scripts}/check_release_trunk_sync.py +0 -0
  2116. /package/{scripts → src/scripts}/ci_status.py +0 -0
  2117. /package/{scripts → src/scripts}/ci_summary.py +0 -0
  2118. /package/{scripts → src/scripts}/cleanup_other_scope.sh +0 -0
  2119. /package/{scripts → src/scripts}/command_suggester/__init__.py +0 -0
  2120. /package/{scripts → src/scripts}/command_suggester/cooldown.py +0 -0
  2121. /package/{scripts → src/scripts}/command_suggester/loader.py +0 -0
  2122. /package/{scripts → src/scripts}/command_suggester/match.py +0 -0
  2123. /package/{scripts → src/scripts}/command_suggester/rank.py +0 -0
  2124. /package/{scripts → src/scripts}/command_suggester/render.py +0 -0
  2125. /package/{scripts → src/scripts}/command_suggester/sanitize.py +0 -0
  2126. /package/{scripts → src/scripts}/command_suggester/settings.py +0 -0
  2127. /package/{scripts → src/scripts}/command_suggester/types.py +0 -0
  2128. /package/{scripts → src/scripts}/condense.sh +0 -0
  2129. /package/{scripts → src/scripts}/config/__init__.py +0 -0
  2130. /package/{scripts → src/scripts}/config/presets.py +0 -0
  2131. /package/{scripts → src/scripts}/context_hygiene_hook.py +0 -0
  2132. /package/{scripts → src/scripts}/cost/budget.mjs +0 -0
  2133. /package/{scripts → src/scripts}/cost/preflight.mjs +0 -0
  2134. /package/{scripts → src/scripts}/cost/track.mjs +0 -0
  2135. /package/{scripts → src/scripts}/council_prune.py +0 -0
  2136. /package/{scripts → src/scripts}/count_token_optimizer_usage.sh +0 -0
  2137. /package/{scripts → src/scripts}/expected_perms.json +0 -0
  2138. /package/{scripts → src/scripts}/first-run.sh +0 -0
  2139. /package/{scripts → src/scripts}/ghostwriter_fixture_allowlist.txt +0 -0
  2140. /package/{scripts → src/scripts}/hermetic-install.sh +0 -0
  2141. /package/{scripts → src/scripts}/hooks/__init__.py +0 -0
  2142. /package/{scripts → src/scripts}/hooks/augment-chat-history.sh +0 -0
  2143. /package/{scripts → src/scripts}/hooks/augment-context-hygiene.sh +0 -0
  2144. /package/{scripts → src/scripts}/hooks/augment-dispatcher.sh +0 -0
  2145. /package/{scripts → src/scripts}/hooks/augment-onboarding-gate.sh +0 -0
  2146. /package/{scripts → src/scripts}/hooks/augment-roadmap-progress.sh +0 -0
  2147. /package/{scripts → src/scripts}/hooks/cline-dispatcher.sh +0 -0
  2148. /package/{scripts → src/scripts}/hooks/cowork-dispatcher.sh +0 -0
  2149. /package/{scripts → src/scripts}/hooks/cursor-dispatcher.sh +0 -0
  2150. /package/{scripts → src/scripts}/hooks/dispatch_issues.py +0 -0
  2151. /package/{scripts → src/scripts}/hooks/envelope.py +0 -0
  2152. /package/{scripts → src/scripts}/hooks/gemini-dispatcher.sh +0 -0
  2153. /package/{scripts → src/scripts}/hooks/state_io.py +0 -0
  2154. /package/{scripts → src/scripts}/hooks/windsurf-dispatcher.sh +0 -0
  2155. /package/{scripts → src/scripts}/install_anthropic_key.sh +0 -0
  2156. /package/{scripts → src/scripts}/install_openai_key.sh +0 -0
  2157. /package/{scripts → src/scripts}/lint_global_paths.py +0 -0
  2158. /package/{scripts → src/scripts}/lint_readme_jargon.py +0 -0
  2159. /package/{scripts → src/scripts}/lint_readme_size.py +0 -0
  2160. /package/{scripts → src/scripts}/mcp_render.py +0 -0
  2161. /package/{scripts → src/scripts}/mcp_server/__main__.py +0 -0
  2162. /package/{scripts → src/scripts}/mcp_server/catalog.py +0 -0
  2163. /package/{scripts → src/scripts}/mcp_server/metadata.py +0 -0
  2164. /package/{scripts → src/scripts}/mcp_server/requirements.txt +0 -0
  2165. /package/{scripts → src/scripts}/mcp_server/server.py +0 -0
  2166. /package/{scripts → src/scripts}/mcp_server/telemetry.py +0 -0
  2167. /package/{scripts → src/scripts}/mcp_setup.sh +0 -0
  2168. /package/{scripts → src/scripts}/mcp_telemetry_health.py +0 -0
  2169. /package/{scripts → src/scripts}/mcp_telemetry_query.py +0 -0
  2170. /package/{scripts → src/scripts}/mcp_telemetry_store.py +0 -0
  2171. /package/{scripts → src/scripts}/memory_hash.py +0 -0
  2172. /package/{scripts → src/scripts}/memory_lookup.py +0 -0
  2173. /package/{scripts → src/scripts}/memory_report.py +0 -0
  2174. /package/{scripts → src/scripts}/memory_signal.py +0 -0
  2175. /package/{scripts → src/scripts}/memory_status.py +0 -0
  2176. /package/{scripts → src/scripts}/minimal_safe_diff_hook.py +0 -0
  2177. /package/{scripts → src/scripts}/onboarding_gate_hook.py +0 -0
  2178. /package/{scripts → src/scripts}/prediction-pool/adapters/_schema.md +0 -0
  2179. /package/{scripts → src/scripts}/prediction-pool/adapters/kicktipp.yml +0 -0
  2180. /package/{scripts → src/scripts}/prediction-pool/poisson_sim.py +0 -0
  2181. /package/{scripts → src/scripts}/prediction-pool/pool_winsim.py +0 -0
  2182. /package/{scripts → src/scripts}/prediction-pool/score_ev.py +0 -0
  2183. /package/{scripts → src/scripts}/prepack-check.mjs +0 -0
  2184. /package/{scripts → src/scripts}/probe_skill_registration.py +0 -0
  2185. /package/{scripts → src/scripts}/propose_modules_config.py +0 -0
  2186. /package/{scripts → src/scripts}/readme_linter.py +0 -0
  2187. /package/{scripts → src/scripts}/redact_hook_capture.py +0 -0
  2188. /package/{scripts → src/scripts}/requirements-evals.txt +0 -0
  2189. /package/{scripts → src/scripts}/runtime_dispatcher.py +0 -0
  2190. /package/{scripts → src/scripts}/runtime_handler.py +0 -0
  2191. /package/{scripts → src/scripts}/schemas/agent-settings.schema.json +0 -0
  2192. /package/{scripts → src/scripts}/schemas/persona.schema.json +0 -0
  2193. /package/{scripts → src/scripts}/schemas/skill.schema.json +0 -0
  2194. /package/{scripts → src/scripts}/schemas/user-type-axis.schema.json +0 -0
  2195. /package/{scripts → src/scripts}/schemas/user-type.schema.json +0 -0
  2196. /package/{scripts → src/scripts}/setup_eval_venv.sh +0 -0
  2197. /package/{scripts → src/scripts}/skill_tools/__init__.py +0 -0
  2198. /package/{scripts → src/scripts}/sync_yaml_rt.py +0 -0
  2199. /package/{scripts → src/scripts}/tool_registry.py +0 -0
  2200. /package/{scripts → src/scripts}/tools/__init__.py +0 -0
  2201. /package/{scripts → src/scripts}/tools/adapter_errors.py +0 -0
  2202. /package/{scripts → src/scripts}/tools/base_adapter.py +0 -0
  2203. /package/{scripts → src/scripts}/tools/github_adapter.py +0 -0
  2204. /package/{scripts → src/scripts}/tools/jira_adapter.py +0 -0
  2205. /package/{scripts → src/scripts}/update-github-metadata.sh +0 -0
  2206. /package/{scripts → src/scripts}/validate_safe_paths.py +0 -0
  2207. /package/{scripts → src/scripts}/validate_telegraph_carveouts.py +0 -0
  2208. /package/{scripts → src/scripts}/verify_before_complete_hook.py +0 -0
  2209. /package/{templates → src/templates}/agent-config-wrapper.sh +0 -0
  2210. /package/{templates → src/templates}/agent-user.md +0 -0
  2211. /package/{templates → src/templates}/agent-user.yml +0 -0
  2212. /package/{templates → src/templates}/claude_desktop_config.json.template +0 -0
  2213. /package/{templates → src/templates}/consumer-settings/ONBOARDING.md +0 -0
  2214. /package/{templates → src/templates}/consumer-settings/README.md +0 -0
  2215. /package/{templates → src/templates}/consumer-settings/augment-cli-hooks.json +0 -0
  2216. /package/{templates → src/templates}/consumer-settings/augment-settings.json +0 -0
  2217. /package/{templates → src/templates}/consumer-settings/claude-settings.json +0 -0
  2218. /package/{templates → src/templates}/consumer-settings/copilot-settings.json +0 -0
  2219. /package/{templates → src/templates}/cursor-rule.mdc.j2 +0 -0
  2220. /package/{templates → src/templates}/marketing-copy.yml +0 -0
  2221. /package/{templates → src/templates}/minimal/.agent-settings.yml +0 -0
  2222. /package/{templates → src/templates}/minimal/agents-overrides-readme.md +0 -0
  2223. /package/{templates → src/templates}/minimal/overrides-gitkeep +0 -0
  2224. /package/{templates → src/templates}/windsurf-rule.md.j2 +0 -0
@@ -0,0 +1,1385 @@
1
+ """External-AI clients for the council.
2
+
3
+ Mirrors the contract from `scripts/skill_trigger_eval.py`:
4
+ - Tokens come exclusively from ``~/.event4u/agent-config/<provider>.key``
5
+ (legacy ``~/.config/agent-config/<provider>.key`` is read as a
6
+ fallback so pre-2.4 installs keep working until the user moves the
7
+ files into the new namespace).
8
+ - File mode must be exactly 0o600. Drift is a hard abort.
9
+ - No environment-variable fallback. No keychain fallback.
10
+ - Real SDKs (`anthropic`, `openai`) are *soft* dependencies — the
11
+ module imports cleanly without them; only `ask()` requires them.
12
+
13
+ Tests inject mock clients via the `client=` constructor argument and
14
+ never hit the real API.
15
+
16
+ Mode contract:
17
+ - `billable=True` clients (AnthropicClient, OpenAIClient, GeminiClient,
18
+ XAIClient, PerplexityClient) participate in the cost gate — projected
19
+ USD spend is checked before each call.
20
+ - `billable=False` clients (ManualClient, vendor-official CliClient
21
+ subclasses — AnthropicCliClient, OpenAICliClient, GeminiCliClient)
22
+ skip the USD cost gate entirely. Spend = $0 to us; provider-side
23
+ limits are the user's concern.
24
+ - `billable=True` CLI subclasses (XAICliClient, PerplexityCliClient)
25
+ wrap community-maintained CLIs that consume the same API key as
26
+ their `api` counterparts — they participate in the USD cost gate.
27
+ `mode: cli` here is an ergonomic shortcut, not a billing change.
28
+
29
+ CLI subclasses additionally consult the optional
30
+ `cli_call_budget.max_calls_per_day.<provider>` quota with state
31
+ persisted at `~/.event4u/agent-config/cli-calls.json` (daily UTC reset).
32
+ """
33
+
34
+ from __future__ import annotations
35
+
36
+ import json
37
+ import shutil
38
+ import stat
39
+ import subprocess
40
+ import sys
41
+ import time
42
+ from abc import ABC, abstractmethod
43
+ from dataclasses import dataclass, field
44
+ from datetime import datetime, timezone
45
+ from pathlib import Path
46
+ from typing import TextIO
47
+
48
+ from scripts._lib import user_global_paths
49
+
50
+ ANTHROPIC_KEY_FILENAME = "anthropic.key"
51
+ OPENAI_KEY_FILENAME = "openai.key"
52
+
53
+ #: Canonical write target under the new namespace. Reads route via
54
+ #: :func:`_resolve_key_path` so a key still sitting in the legacy
55
+ #: ``~/.config/agent-config/`` tree keeps working.
56
+ ANTHROPIC_KEY_PATH = user_global_paths.write_target(ANTHROPIC_KEY_FILENAME)
57
+ OPENAI_KEY_PATH = user_global_paths.write_target(OPENAI_KEY_FILENAME)
58
+
59
+
60
+ def _resolve_key_path(filename: str) -> Path:
61
+ """Return the active key path, preferring the new namespace."""
62
+ found = user_global_paths.resolve_with_fallback(filename)
63
+ if found is not None:
64
+ return found
65
+ return user_global_paths.write_target(filename)
66
+
67
+ DEFAULT_ANTHROPIC_MODEL = "claude-sonnet-4-5"
68
+ DEFAULT_OPENAI_MODEL = "gpt-4o"
69
+ DEFAULT_GEMINI_MODEL = "gemini-2.5-pro"
70
+ DEFAULT_XAI_MODEL = "grok-4"
71
+ DEFAULT_PERPLEXITY_MODEL = "sonar-pro"
72
+
73
+ #: OpenAI-API-compatible endpoints. xAI and Perplexity both expose the
74
+ #: ``/v1/chat/completions`` shape, so their clients reuse the ``openai``
75
+ #: SDK with a custom ``base_url``. Gemini has its own SDK (``google-genai``).
76
+ XAI_BASE_URL = "https://api.x.ai/v1"
77
+ PERPLEXITY_BASE_URL = "https://api.perplexity.ai"
78
+
79
+ #: Per-call output budget when no caller-supplied value reaches `ask()`.
80
+ #: The CLI resolves the live default from `ai_council.max_output_tokens`
81
+ #: in `.agent-settings.yml`; this constant is only the abstract-base /
82
+ #: direct-API fallback when nothing else is wired up.
83
+ DEFAULT_MAX_TOKENS = 2048
84
+
85
+ #: Expansion target when the user sets `max_output_tokens: 0` ("unlimited")
86
+ #: in settings. Anthropic requires `max_tokens` to be a positive integer,
87
+ #: so 0 is widened to this safe ceiling before the SDK call. Big enough
88
+ #: for current frontier models (Sonnet/GPT-4o headroom ≥ 16k); raise
89
+ #: explicitly in settings if a larger budget is genuinely needed.
90
+ UNLIMITED_TOKENS_FALLBACK = 16384
91
+
92
+ # OpenAI reasoning models (o1, o3, o4 families) reject `max_tokens` and the
93
+ # `system` role; they require `max_completion_tokens` and accept only `user`
94
+ # (and `developer`) messages.
95
+ _REASONING_PREFIXES = ("o1", "o3", "o4")
96
+
97
+
98
+ def _is_reasoning_model(model: str) -> bool:
99
+ name = model.lower()
100
+ return any(name == p or name.startswith(p + "-") for p in _REASONING_PREFIXES)
101
+
102
+
103
+ class KeyGateError(RuntimeError):
104
+ """Raised when a provider key file violates the 0600 contract."""
105
+
106
+
107
+ @dataclass
108
+ class CouncilResponse:
109
+ """Normalised output from a single council member."""
110
+
111
+ provider: str
112
+ model: str
113
+ text: str
114
+ input_tokens: int = 0
115
+ output_tokens: int = 0
116
+ latency_ms: int = 0
117
+ error: str | None = None
118
+ metadata: dict[str, object] = field(default_factory=dict)
119
+
120
+
121
+ def _load_key(path: Path, prefix: str, install_script: str) -> str:
122
+ """Shared 0600-gated key loader. Refuses anything outside the contract."""
123
+ if not path.exists():
124
+ raise KeyGateError(
125
+ f"Key not found at {path}.\n"
126
+ f" Install it with: bash {install_script}"
127
+ )
128
+ st = path.stat()
129
+ mode = stat.S_IMODE(st.st_mode)
130
+ if mode != 0o600:
131
+ raise KeyGateError(
132
+ f"Unsafe permissions on {path}: got {oct(mode)}, expected 0o600.\n"
133
+ f" Fix: chmod 600 {path}"
134
+ )
135
+ key = path.read_text(encoding="utf-8").strip()
136
+ if not key:
137
+ raise KeyGateError(f"{path} is empty.")
138
+ if not key.startswith(prefix):
139
+ raise KeyGateError(
140
+ f"{path} does not look like a {prefix!r}-prefixed key."
141
+ )
142
+ return key
143
+
144
+
145
+ def load_anthropic_key(path: Path | None = None) -> str:
146
+ resolved = path if path is not None else _resolve_key_path(ANTHROPIC_KEY_FILENAME)
147
+ return _load_key(resolved, "sk-ant-", "src/scripts/install_anthropic_key.sh")
148
+
149
+
150
+ def load_openai_key(path: Path | None = None) -> str:
151
+ resolved = path if path is not None else _resolve_key_path(OPENAI_KEY_FILENAME)
152
+ return _load_key(resolved, "sk-", "src/scripts/install_openai_key.sh")
153
+
154
+
155
+ class ExternalAIClient(ABC):
156
+ """Abstract base for council members."""
157
+
158
+ name: str = ""
159
+ model: str = ""
160
+ billable: bool = True # API-mode subclasses spend money; manual doesn't.
161
+ transport: str = "api" # "api" | "cli" | "manual" — surfaced in session manifest.
162
+ subscription_label: str = "" # vendor-CLI label (e.g. "claude") for non-billable transports.
163
+
164
+ @abstractmethod
165
+ def ask(
166
+ self,
167
+ system_prompt: str,
168
+ user_prompt: str,
169
+ max_tokens: int = DEFAULT_MAX_TOKENS,
170
+ ) -> CouncilResponse:
171
+ """Send one independent query. Must never raise on network/API
172
+ failure — return a `CouncilResponse` with `error` set instead.
173
+ Other members should not be blocked by one failure."""
174
+
175
+
176
+ class AnthropicClient(ExternalAIClient):
177
+ name = "anthropic"
178
+ billable = True
179
+
180
+ def __init__(
181
+ self,
182
+ model: str = DEFAULT_ANTHROPIC_MODEL,
183
+ client: object = None,
184
+ api_key: str | None = None,
185
+ ):
186
+ self.model = model
187
+ if client is not None:
188
+ self._client = client
189
+ return
190
+ if api_key is None:
191
+ raise RuntimeError(
192
+ "AnthropicClient requires explicit api_key or injected client. "
193
+ "Use load_anthropic_key() — no env-var fallback."
194
+ )
195
+ try:
196
+ import anthropic # type: ignore[import-not-found]
197
+ except ImportError as exc: # pragma: no cover - exercised only with real SDK
198
+ raise RuntimeError(
199
+ "anthropic package not installed. `pip install anthropic`."
200
+ ) from exc
201
+ self._client = anthropic.Anthropic(api_key=api_key)
202
+
203
+ def ask(self, system_prompt: str, user_prompt: str, max_tokens: int = DEFAULT_MAX_TOKENS) -> CouncilResponse:
204
+ t0 = time.monotonic()
205
+ try:
206
+ response = self._client.messages.create(
207
+ model=self.model,
208
+ max_tokens=max_tokens,
209
+ system=system_prompt,
210
+ messages=[{"role": "user", "content": user_prompt}],
211
+ )
212
+ except Exception as exc: # noqa: BLE001 - normalise all SDK errors
213
+ return CouncilResponse(
214
+ provider=self.name, model=self.model, text="",
215
+ latency_ms=int((time.monotonic() - t0) * 1000),
216
+ error=f"{type(exc).__name__}: {exc}",
217
+ )
218
+ latency_ms = int((time.monotonic() - t0) * 1000)
219
+ text = ""
220
+ content = getattr(response, "content", None)
221
+ if content:
222
+ text = getattr(content[0], "text", "") or ""
223
+ usage = getattr(response, "usage", None)
224
+ return CouncilResponse(
225
+ provider=self.name, model=self.model, text=text,
226
+ input_tokens=getattr(usage, "input_tokens", 0) if usage else 0,
227
+ output_tokens=getattr(usage, "output_tokens", 0) if usage else 0,
228
+ latency_ms=latency_ms,
229
+ )
230
+
231
+
232
+ class OpenAIClient(ExternalAIClient):
233
+ name = "openai"
234
+ billable = True
235
+
236
+ def __init__(
237
+ self,
238
+ model: str = DEFAULT_OPENAI_MODEL,
239
+ client: object = None,
240
+ api_key: str | None = None,
241
+ ):
242
+ self.model = model
243
+ if client is not None:
244
+ self._client = client
245
+ return
246
+ if api_key is None:
247
+ raise RuntimeError(
248
+ "OpenAIClient requires explicit api_key or injected client. "
249
+ "Use load_openai_key() — no env-var fallback."
250
+ )
251
+ try:
252
+ import openai # type: ignore[import-not-found]
253
+ except ImportError as exc: # pragma: no cover - exercised only with real SDK
254
+ raise RuntimeError(
255
+ "openai package not installed. `pip install openai`."
256
+ ) from exc
257
+ self._client = openai.OpenAI(api_key=api_key)
258
+
259
+ def ask(self, system_prompt: str, user_prompt: str, max_tokens: int = DEFAULT_MAX_TOKENS) -> CouncilResponse:
260
+ t0 = time.monotonic()
261
+ kwargs: dict[str, object] = {"model": self.model}
262
+ if _is_reasoning_model(self.model):
263
+ # o1/o3/o4 reasoning models reject `max_tokens` and `system` role.
264
+ kwargs["max_completion_tokens"] = max_tokens
265
+ kwargs["messages"] = [
266
+ {"role": "user", "content": f"{system_prompt}\n\n---\n\n{user_prompt}"},
267
+ ]
268
+ else:
269
+ kwargs["max_tokens"] = max_tokens
270
+ kwargs["messages"] = [
271
+ {"role": "system", "content": system_prompt},
272
+ {"role": "user", "content": user_prompt},
273
+ ]
274
+ try:
275
+ response = self._client.chat.completions.create(**kwargs)
276
+ except Exception as exc: # noqa: BLE001 - normalise all SDK errors
277
+ return CouncilResponse(
278
+ provider=self.name, model=self.model, text="",
279
+ latency_ms=int((time.monotonic() - t0) * 1000),
280
+ error=f"{type(exc).__name__}: {exc}",
281
+ )
282
+ latency_ms = int((time.monotonic() - t0) * 1000)
283
+ text = ""
284
+ choices = getattr(response, "choices", None)
285
+ if choices:
286
+ msg = getattr(choices[0], "message", None)
287
+ text = getattr(msg, "content", "") if msg else ""
288
+ usage = getattr(response, "usage", None)
289
+ return CouncilResponse(
290
+ provider=self.name, model=self.model, text=text or "",
291
+ input_tokens=getattr(usage, "prompt_tokens", 0) if usage else 0,
292
+ output_tokens=getattr(usage, "completion_tokens", 0) if usage else 0,
293
+ latency_ms=latency_ms,
294
+ )
295
+
296
+
297
+ # ── Gemini / xAI / Perplexity (Phase 0 — Step 6) ─────────────────────
298
+
299
+
300
+ class GeminiClient(ExternalAIClient):
301
+ """Google Gemini via the ``google-genai`` SDK.
302
+
303
+ Lazy-imports ``google.genai`` on first ``ask()`` so disabled
304
+ members do not require the SDK to be installed. Tests inject a
305
+ mock client shaped like ``genai.Client(api_key=...)`` —
306
+ ``self._client.models.generate_content(...)`` returns an object
307
+ with ``.text`` and ``.usage_metadata.{prompt_token_count,
308
+ candidates_token_count}``.
309
+ """
310
+
311
+ name = "gemini"
312
+ billable = True
313
+
314
+ def __init__(
315
+ self,
316
+ model: str = DEFAULT_GEMINI_MODEL,
317
+ client: object = None,
318
+ api_key: str | None = None,
319
+ ):
320
+ self.model = model
321
+ if client is not None:
322
+ self._client = client
323
+ return
324
+ if api_key is None:
325
+ raise RuntimeError(
326
+ "GeminiClient requires explicit api_key or injected client. "
327
+ "Use `api_key_ref: env:GEMINI_API_KEY` in agents/settings/.ai-council.yml."
328
+ )
329
+ try:
330
+ from google import genai # type: ignore[import-not-found]
331
+ except ImportError as exc: # pragma: no cover - exercised only with real SDK
332
+ raise RuntimeError(
333
+ "google-genai package not installed. `pip install google-genai`."
334
+ ) from exc
335
+ self._client = genai.Client(api_key=api_key)
336
+
337
+ def ask(self, system_prompt: str, user_prompt: str, max_tokens: int = DEFAULT_MAX_TOKENS) -> CouncilResponse:
338
+ t0 = time.monotonic()
339
+ contents = f"{system_prompt}\n\n---\n\n{user_prompt}"
340
+ try:
341
+ response = self._client.models.generate_content(
342
+ model=self.model,
343
+ contents=contents,
344
+ config={"max_output_tokens": max_tokens},
345
+ )
346
+ except Exception as exc: # noqa: BLE001 - normalise all SDK errors
347
+ return CouncilResponse(
348
+ provider=self.name, model=self.model, text="",
349
+ latency_ms=int((time.monotonic() - t0) * 1000),
350
+ error=f"{type(exc).__name__}: {exc}",
351
+ )
352
+ latency_ms = int((time.monotonic() - t0) * 1000)
353
+ text = getattr(response, "text", "") or ""
354
+ usage = getattr(response, "usage_metadata", None)
355
+ return CouncilResponse(
356
+ provider=self.name, model=self.model, text=text,
357
+ input_tokens=getattr(usage, "prompt_token_count", 0) if usage else 0,
358
+ output_tokens=getattr(usage, "candidates_token_count", 0) if usage else 0,
359
+ latency_ms=latency_ms,
360
+ )
361
+
362
+
363
+ class _OpenAICompatibleClient(ExternalAIClient):
364
+ """Shared shape for OpenAI-API-compatible providers (xAI, Perplexity).
365
+
366
+ Both vendors implement ``/v1/chat/completions`` and accept the
367
+ ``openai`` Python SDK with a custom ``base_url``. The reasoning-
368
+ model branch from :class:`OpenAIClient` is intentionally omitted —
369
+ neither xAI nor Perplexity ships a reasoning model that requires
370
+ ``max_completion_tokens`` as of 2026-05-14.
371
+ """
372
+
373
+ billable = True
374
+ base_url: str = ""
375
+
376
+ def __init__(
377
+ self,
378
+ model: str,
379
+ client: object = None,
380
+ api_key: str | None = None,
381
+ ):
382
+ self.model = model
383
+ if client is not None:
384
+ self._client = client
385
+ return
386
+ if api_key is None:
387
+ raise RuntimeError(
388
+ f"{type(self).__name__} requires explicit api_key or injected client."
389
+ )
390
+ try:
391
+ import openai # type: ignore[import-not-found]
392
+ except ImportError as exc: # pragma: no cover - exercised only with real SDK
393
+ raise RuntimeError(
394
+ "openai package not installed. `pip install openai`."
395
+ ) from exc
396
+ self._client = openai.OpenAI(api_key=api_key, base_url=self.base_url)
397
+
398
+ def ask(self, system_prompt: str, user_prompt: str, max_tokens: int = DEFAULT_MAX_TOKENS) -> CouncilResponse:
399
+ t0 = time.monotonic()
400
+ try:
401
+ response = self._client.chat.completions.create(
402
+ model=self.model,
403
+ max_tokens=max_tokens,
404
+ messages=[
405
+ {"role": "system", "content": system_prompt},
406
+ {"role": "user", "content": user_prompt},
407
+ ],
408
+ )
409
+ except Exception as exc: # noqa: BLE001 - normalise all SDK errors
410
+ return CouncilResponse(
411
+ provider=self.name, model=self.model, text="",
412
+ latency_ms=int((time.monotonic() - t0) * 1000),
413
+ error=f"{type(exc).__name__}: {exc}",
414
+ )
415
+ latency_ms = int((time.monotonic() - t0) * 1000)
416
+ text = ""
417
+ choices = getattr(response, "choices", None)
418
+ if choices:
419
+ msg = getattr(choices[0], "message", None)
420
+ text = getattr(msg, "content", "") if msg else ""
421
+ usage = getattr(response, "usage", None)
422
+ return CouncilResponse(
423
+ provider=self.name, model=self.model, text=text or "",
424
+ input_tokens=getattr(usage, "prompt_tokens", 0) if usage else 0,
425
+ output_tokens=getattr(usage, "completion_tokens", 0) if usage else 0,
426
+ latency_ms=latency_ms,
427
+ )
428
+
429
+
430
+ class XAIClient(_OpenAICompatibleClient):
431
+ """xAI Grok via the OpenAI-compatible endpoint at api.x.ai/v1."""
432
+
433
+ name = "xai"
434
+ base_url = XAI_BASE_URL
435
+
436
+ def __init__(
437
+ self,
438
+ model: str = DEFAULT_XAI_MODEL,
439
+ client: object = None,
440
+ api_key: str | None = None,
441
+ ):
442
+ super().__init__(model=model, client=client, api_key=api_key)
443
+
444
+
445
+ class PerplexityClient(_OpenAICompatibleClient):
446
+ """Perplexity via the OpenAI-compatible endpoint at api.perplexity.ai."""
447
+
448
+ name = "perplexity"
449
+ base_url = PERPLEXITY_BASE_URL
450
+
451
+ def __init__(
452
+ self,
453
+ model: str = DEFAULT_PERPLEXITY_MODEL,
454
+ client: object = None,
455
+ api_key: str | None = None,
456
+ ):
457
+ super().__init__(model=model, client=client, api_key=api_key)
458
+
459
+
460
+ # ── CLI transport (step-1 Phase 1+) ──────────────────────────────────
461
+
462
+
463
+ CLI_CALLS_FILENAME = "cli-calls.json"
464
+
465
+ #: Default subprocess timeout for a single CLI call. Long enough for the
466
+ #: largest frontier models to think; short enough to surface a hung
467
+ #: subprocess without freezing the council run.
468
+ DEFAULT_CLI_TIMEOUT_SECONDS = 120.0
469
+
470
+
471
+ class CliClientError(RuntimeError):
472
+ """Raised when a CLI member cannot be constructed (binary missing, etc.)."""
473
+
474
+
475
+ def _cli_calls_state_path() -> Path:
476
+ """Return the canonical write target for the daily-quota counter."""
477
+ return user_global_paths.write_target(CLI_CALLS_FILENAME)
478
+
479
+
480
+ def _today_utc_iso() -> str:
481
+ return datetime.now(timezone.utc).date().isoformat()
482
+
483
+
484
+ def load_cli_call_counts(path: Path | None = None) -> dict[str, int]:
485
+ """Return today's per-provider call counts. Empty dict on UTC rollover."""
486
+ p = path if path is not None else _cli_calls_state_path()
487
+ if not p.exists():
488
+ return {}
489
+ try:
490
+ data = json.loads(p.read_text(encoding="utf-8"))
491
+ except (json.JSONDecodeError, OSError):
492
+ return {}
493
+ if not isinstance(data, dict) or data.get("date") != _today_utc_iso():
494
+ return {}
495
+ counts = data.get("counts", {})
496
+ if not isinstance(counts, dict):
497
+ return {}
498
+ return {str(k): int(v) for k, v in counts.items() if isinstance(v, (int, str))}
499
+
500
+
501
+ def record_cli_call(provider: str, path: Path | None = None) -> int:
502
+ """Increment today's call count for `provider`. Returns new total."""
503
+ p = path if path is not None else _cli_calls_state_path()
504
+ counts = load_cli_call_counts(p)
505
+ counts[provider] = counts.get(provider, 0) + 1
506
+ p.parent.mkdir(parents=True, exist_ok=True)
507
+ p.write_text(
508
+ json.dumps({"date": _today_utc_iso(), "counts": counts}, indent=2),
509
+ encoding="utf-8",
510
+ )
511
+ return counts[provider]
512
+
513
+
514
+ def reset_cli_call_counts(
515
+ provider: str | None = None,
516
+ path: Path | None = None,
517
+ ) -> dict[str, int]:
518
+ """Reset the per-provider call counter (step-8 P1, `council quota --reset`).
519
+
520
+ ``provider=None`` clears all providers (today's record). Otherwise
521
+ only the named provider's count is removed; other providers and
522
+ the UTC date marker are preserved. Returns the post-reset counts.
523
+ """
524
+ p = path if path is not None else _cli_calls_state_path()
525
+ counts = load_cli_call_counts(p)
526
+ if provider is None:
527
+ counts = {}
528
+ else:
529
+ counts.pop(provider, None)
530
+ p.parent.mkdir(parents=True, exist_ok=True)
531
+ p.write_text(
532
+ json.dumps({"date": _today_utc_iso(), "counts": counts}, indent=2),
533
+ encoding="utf-8",
534
+ )
535
+ return counts
536
+
537
+
538
+ def quota_summary_line(
539
+ clients: "list[CliClient]",
540
+ *,
541
+ cli_calls_path: Path | None = None,
542
+ ) -> tuple[str, list[str]]:
543
+ """Build the pre-run quota summary line (step-8 P1, D1 + D4).
544
+
545
+ Returns ``(summary, warn_providers)`` where ``summary`` is the
546
+ formatted one-liner (empty string when no CLI member has a
547
+ configured cap) and ``warn_providers`` is the subset whose
548
+ ``used / max_calls_per_day`` ratio crossed ``warn_at``. Uncapped
549
+ providers (``max_calls_per_day is None``) are omitted from the
550
+ summary entirely — they cannot exceed a threshold that does not
551
+ exist.
552
+
553
+ Tested in ``tests/test_cli_quota_warn.py``.
554
+ """
555
+ capped = [c for c in clients if getattr(c, "max_calls_per_day", None)]
556
+ if not capped:
557
+ return "", []
558
+ # Read state once for the whole summary — call counts only mutate
559
+ # inside ``CliClient.ask`` (sequential per-member dispatch), so the
560
+ # pre-run snapshot is always consistent with what's about to fire.
561
+ counts = load_cli_call_counts(cli_calls_path)
562
+ parts: list[str] = []
563
+ warn: list[str] = []
564
+ for c in capped:
565
+ name = getattr(c, "name", "?")
566
+ used = int(counts.get(name, 0))
567
+ limit = int(c.max_calls_per_day)
568
+ parts.append(f"{name} {used}/{limit}")
569
+ ratio = used / limit if limit > 0 else 0.0
570
+ warn_at = float(getattr(c, "warn_at", 0.8))
571
+ if ratio >= warn_at:
572
+ warn.append(name)
573
+ prefix = "⚠️ " if warn else ""
574
+ return f"{prefix}council:quota · " + " · ".join(parts), warn
575
+
576
+
577
+ class CliClient(ExternalAIClient):
578
+ """Shell-out council member — subscription-authed transport.
579
+
580
+ Spawns a locally-installed provider CLI via ``subprocess.run``. Auth
581
+ is delegated to the binary itself (Claude CLI, Codex CLI, Gemini
582
+ CLI, etc. use the user's logged-in subscription session). Spend is
583
+ $0 from this loader's perspective — ``billable=False`` keeps the
584
+ USD cost gate from firing.
585
+
586
+ Provider subscription quotas (Claude Pro 5h windows, ChatGPT Plus
587
+ message caps, Gemini free-tier limits) are guarded by the optional
588
+ ``cli_call_budget.max_calls_per_day.<provider>`` config. Counter
589
+ state lives at ``~/.event4u/agent-config/cli-calls.json`` and
590
+ resets on UTC date rollover.
591
+
592
+ Subclass contract:
593
+
594
+ - ``name``: provider key (`anthropic`, `openai`, `gemini`, …).
595
+ - ``default_binary``: executable name resolved via ``shutil.which``
596
+ when the member-level ``binary:`` field is not set.
597
+ - ``_build_command(system_prompt, user_prompt, max_tokens)``:
598
+ return the argv list to execute.
599
+ - ``_parse_output(stdout, stderr)``: return a partial
600
+ ``CouncilResponse`` (``provider``, ``model``, ``text``,
601
+ ``input_tokens``, ``output_tokens``, ``metadata``). The base
602
+ ``ask()`` fills in ``latency_ms``.
603
+
604
+ Construction validates the binary up front — a missing CLI fails
605
+ fast with ``CliClientError`` so the loader can surface a structured
606
+ "skip member with reason" entry rather than crashing the run.
607
+
608
+ Stderr heuristics map known failure shapes to short error codes:
609
+
610
+ - ``auth_expired`` — authentication / login / unauthorized.
611
+ - ``timeout`` — subprocess timeout or deadline exceeded.
612
+ - ``cli_quota_exhausted`` — rate-limit / quota messaging from the
613
+ provider, OR the local counter has hit ``max_calls_per_day``.
614
+ - ``parse_failed`` — non-zero exit absent + stdout was not parseable.
615
+ - ``exit_<N>`` — fallback for any non-zero exit code without a known
616
+ stderr pattern.
617
+ """
618
+
619
+ billable = False
620
+ transport = "cli"
621
+ default_binary: str = ""
622
+
623
+ _AUTH_FAILURE_PATTERNS = (
624
+ "authentication", "unauthorized", "auth failed", "auth_error",
625
+ "login", "not logged in", "session expired", "invalid credentials",
626
+ )
627
+ _TIMEOUT_PATTERNS = ("timeout", "timed out", "deadline exceeded")
628
+ _QUOTA_PATTERNS = (
629
+ "rate limit", "rate_limit", "rate-limit", "quota exceeded",
630
+ "too many requests", "429", "usage limit",
631
+ )
632
+
633
+ def __init__(
634
+ self,
635
+ *,
636
+ model: str,
637
+ binary: str | None = None,
638
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
639
+ max_calls_per_day: int | None = None,
640
+ warn_at: float = 0.8,
641
+ cli_calls_path: Path | None = None,
642
+ ):
643
+ self.model = model
644
+ self.timeout_seconds = timeout_seconds
645
+ self.max_calls_per_day = max_calls_per_day
646
+ self.warn_at = warn_at
647
+ self._cli_calls_path = cli_calls_path
648
+ if binary is not None:
649
+ self.binary = binary
650
+ else:
651
+ if not self.default_binary:
652
+ raise CliClientError(
653
+ f"{type(self).__name__}: no `default_binary` set on subclass; "
654
+ f"either fix the class or pass `binary=` explicitly."
655
+ )
656
+ resolved = shutil.which(self.default_binary)
657
+ if resolved is None:
658
+ raise CliClientError(
659
+ f"{type(self).__name__}: binary {self.default_binary!r} "
660
+ f"not found on PATH. Install the provider CLI or set "
661
+ f"`members.{self.name}.binary:` in agents/settings/.ai-council.yml."
662
+ )
663
+ self.binary = resolved
664
+
665
+ # ── subclass hooks ────────────────────────────────────────────
666
+
667
+ @abstractmethod
668
+ def _build_command(
669
+ self, system_prompt: str, user_prompt: str, max_tokens: int
670
+ ) -> list[str]:
671
+ """Return the argv list the subprocess should execute.
672
+
673
+ ``self.binary`` is already resolved to an absolute path. Subclasses
674
+ return ``[self.binary, ...flags...]`` and pass the prompt either
675
+ via argv (small) or via stdin (large) — see ``_stdin_payload``.
676
+ """
677
+
678
+ @abstractmethod
679
+ def _parse_output(
680
+ self, stdout: str, stderr: str
681
+ ) -> CouncilResponse:
682
+ """Parse provider-specific stdout into a CouncilResponse.
683
+
684
+ ``latency_ms`` and ``error`` are set by the base ``ask()`` wrapper;
685
+ subclasses populate ``provider``, ``model``, ``text``,
686
+ ``input_tokens``, ``output_tokens``, and any ``metadata``.
687
+ """
688
+
689
+ def _stdin_payload(self, system_prompt: str, user_prompt: str) -> str | None:
690
+ """Return text to send on stdin, or ``None`` to inherit caller's stdin.
691
+
692
+ Default: ``None`` — subclasses that prefer stdin-piped prompts
693
+ override (typical for long prompts that would blow argv limits).
694
+ """
695
+ return None
696
+
697
+ # ── ask() ──────────────────────────────────────────────────────
698
+
699
+ def ask(
700
+ self,
701
+ system_prompt: str,
702
+ user_prompt: str,
703
+ max_tokens: int = DEFAULT_MAX_TOKENS,
704
+ ) -> CouncilResponse:
705
+ t0 = time.monotonic()
706
+
707
+ # 1. quota gate — local counter check before spawning anything.
708
+ if self.max_calls_per_day is not None:
709
+ counts = load_cli_call_counts(self._cli_calls_path)
710
+ used = counts.get(self.name, 0)
711
+ if used >= self.max_calls_per_day:
712
+ # step-8 D3 — record the block on the persistent events
713
+ # log. Lazy import to keep clients.py independent of the
714
+ # CLI layer at module load time.
715
+ try:
716
+ from scripts.ai_council.events_log import append_event
717
+ append_event({
718
+ "lens": "",
719
+ "invocation": "",
720
+ "action": "block_quota",
721
+ "verdict": "",
722
+ "provider_caps": {
723
+ self.name: {
724
+ "mode": "cli", "model": self.model,
725
+ },
726
+ },
727
+ "original_ask": user_prompt,
728
+ "cli_calls_used": used,
729
+ "cli_calls_max": self.max_calls_per_day,
730
+ })
731
+ except Exception: # pragma: no cover — never crash ask()
732
+ pass
733
+ return CouncilResponse(
734
+ provider=self.name, model=self.model, text="",
735
+ latency_ms=int((time.monotonic() - t0) * 1000),
736
+ error="cli_quota_exhausted",
737
+ metadata={
738
+ "cli": True,
739
+ "cli_calls_used": used,
740
+ "cli_calls_max": self.max_calls_per_day,
741
+ },
742
+ )
743
+
744
+ # 2. build command + spawn.
745
+ cmd = self._build_command(system_prompt, user_prompt, max_tokens)
746
+ stdin_payload = self._stdin_payload(system_prompt, user_prompt)
747
+ try:
748
+ proc = subprocess.run(
749
+ cmd,
750
+ input=stdin_payload,
751
+ capture_output=True,
752
+ text=True,
753
+ timeout=self.timeout_seconds,
754
+ check=False,
755
+ )
756
+ except subprocess.TimeoutExpired:
757
+ return CouncilResponse(
758
+ provider=self.name, model=self.model, text="",
759
+ latency_ms=int((time.monotonic() - t0) * 1000),
760
+ error="timeout",
761
+ metadata={"cli": True, "timeout_seconds": self.timeout_seconds},
762
+ )
763
+ except FileNotFoundError:
764
+ return CouncilResponse(
765
+ provider=self.name, model=self.model, text="",
766
+ latency_ms=int((time.monotonic() - t0) * 1000),
767
+ error="binary_missing",
768
+ metadata={"cli": True, "binary": self.binary},
769
+ )
770
+ except OSError as exc:
771
+ return CouncilResponse(
772
+ provider=self.name, model=self.model, text="",
773
+ latency_ms=int((time.monotonic() - t0) * 1000),
774
+ error=f"os_error: {type(exc).__name__}",
775
+ metadata={"cli": True},
776
+ )
777
+
778
+ # 3. record the call — even failures count against the quota so
779
+ # a broken CLI cannot burn the whole budget in a tight loop.
780
+ try:
781
+ record_cli_call(self.name, self._cli_calls_path)
782
+ except OSError: # state-file write failure is non-fatal here.
783
+ pass
784
+
785
+ latency_ms = int((time.monotonic() - t0) * 1000)
786
+
787
+ # 4. non-zero exit → classify and bail.
788
+ if proc.returncode != 0:
789
+ code = self._classify_stderr(proc.stderr or "", proc.returncode)
790
+ return CouncilResponse(
791
+ provider=self.name, model=self.model, text="",
792
+ latency_ms=latency_ms,
793
+ error=code,
794
+ metadata={
795
+ "cli": True,
796
+ "returncode": proc.returncode,
797
+ "stderr_tail": (proc.stderr or "")[-500:],
798
+ },
799
+ )
800
+
801
+ # 5. parse stdout via the subclass hook.
802
+ try:
803
+ response = self._parse_output(proc.stdout or "", proc.stderr or "")
804
+ except Exception as exc: # noqa: BLE001 — defensive: parse must never crash the run.
805
+ return CouncilResponse(
806
+ provider=self.name, model=self.model,
807
+ text=proc.stdout or "",
808
+ latency_ms=latency_ms,
809
+ error=f"parse_failed: {type(exc).__name__}",
810
+ metadata={"cli": True, "stderr_tail": (proc.stderr or "")[-500:]},
811
+ )
812
+ response.latency_ms = latency_ms
813
+ meta = dict(response.metadata)
814
+ meta.setdefault("cli", True)
815
+ response.metadata = meta
816
+ return response
817
+
818
+ @classmethod
819
+ def _classify_stderr(cls, stderr: str, returncode: int) -> str:
820
+ haystack = stderr.lower()
821
+ if any(p in haystack for p in cls._AUTH_FAILURE_PATTERNS):
822
+ return "auth_expired"
823
+ if any(p in haystack for p in cls._TIMEOUT_PATTERNS):
824
+ return "timeout"
825
+ if any(p in haystack for p in cls._QUOTA_PATTERNS):
826
+ return "cli_quota_exhausted"
827
+ return f"exit_{returncode}"
828
+
829
+
830
+ class AnthropicCliClient(CliClient):
831
+ """Claude via the official `claude` CLI (subscription-authed).
832
+
833
+ Invokes ``claude --print --output-format json`` and consumes the
834
+ structured envelope: ``{"result": str, "usage": {"input_tokens":
835
+ int, "output_tokens": int}, "session_id": str, ...}``. The prompt
836
+ is piped on stdin so it never collides with argv length limits.
837
+
838
+ Auth is delegated to the CLI's own session — the user runs
839
+ ``claude /login`` once and the orchestrator inherits the
840
+ subscription. No API key flows through this process.
841
+ """
842
+
843
+ name = "anthropic"
844
+ default_binary = "claude"
845
+ subscription_label = "claude-pro"
846
+
847
+ def __init__(
848
+ self,
849
+ *,
850
+ model: str = "claude-sonnet-4-5",
851
+ binary: str | None = None,
852
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
853
+ max_calls_per_day: int | None = None,
854
+ warn_at: float = 0.8,
855
+ cli_calls_path: Path | None = None,
856
+ ):
857
+ super().__init__(
858
+ model=model,
859
+ binary=binary,
860
+ timeout_seconds=timeout_seconds,
861
+ max_calls_per_day=max_calls_per_day,
862
+ warn_at=warn_at,
863
+ cli_calls_path=cli_calls_path,
864
+ )
865
+
866
+ def _build_command(
867
+ self, system_prompt: str, user_prompt: str, max_tokens: int # noqa: ARG002
868
+ ) -> list[str]:
869
+ return [
870
+ self.binary,
871
+ "--print",
872
+ "--output-format", "json",
873
+ "--model", self.model,
874
+ "--append-system-prompt", system_prompt,
875
+ ]
876
+
877
+ def _stdin_payload(self, system_prompt: str, user_prompt: str) -> str | None: # noqa: ARG002
878
+ return user_prompt
879
+
880
+ def _parse_output(self, stdout: str, stderr: str) -> CouncilResponse: # noqa: ARG002
881
+ envelope = json.loads(stdout)
882
+ if not isinstance(envelope, dict):
883
+ raise ValueError("expected JSON object at the top level of claude CLI output")
884
+ text = str(envelope.get("result", "")).strip()
885
+ usage = envelope.get("usage") or {}
886
+ if not isinstance(usage, dict):
887
+ usage = {}
888
+ meta: dict[str, object] = {}
889
+ session_id = envelope.get("session_id")
890
+ if session_id:
891
+ meta["session_id"] = str(session_id)
892
+ total_cost = envelope.get("total_cost_usd")
893
+ if total_cost is not None:
894
+ meta["reported_cost_usd"] = total_cost
895
+ duration_ms = envelope.get("duration_ms")
896
+ if duration_ms is not None:
897
+ meta["reported_duration_ms"] = duration_ms
898
+ return CouncilResponse(
899
+ provider=self.name, model=self.model, text=text,
900
+ input_tokens=int(usage.get("input_tokens", 0) or 0),
901
+ output_tokens=int(usage.get("output_tokens", 0) or 0),
902
+ metadata=meta,
903
+ )
904
+
905
+
906
+ class OpenAICliClient(CliClient):
907
+ """OpenAI via the official `codex` CLI (subscription-authed).
908
+
909
+ Invokes ``codex exec --json <prompt>`` and consumes the
910
+ newline-delimited JSON event stream. The user prompt rides on
911
+ argv (Codex does not read prompts from stdin in ``exec`` mode);
912
+ the system prompt is passed via ``--system`` when non-empty.
913
+
914
+ Auth is delegated to the CLI's own session — the user runs
915
+ ``codex login`` once and the orchestrator inherits the
916
+ subscription. No API key flows through this process.
917
+
918
+ Output shape: one JSON object per line. The terminal event has
919
+ ``type == "item.completed"`` with the final assistant message in
920
+ ``item.content[0].text``; a separate ``type == "turn.completed"``
921
+ event carries token usage in ``usage.input_tokens`` /
922
+ ``usage.output_tokens``. Robust against the order of events and
923
+ against unknown event types (silently skipped).
924
+ """
925
+
926
+ name = "openai"
927
+ default_binary = "codex"
928
+ subscription_label = "chatgpt-plus"
929
+
930
+ _AUTH_FAILURE_PATTERNS = CliClient._AUTH_FAILURE_PATTERNS + (
931
+ "codex login", "auth_required", "401",
932
+ )
933
+
934
+ def __init__(
935
+ self,
936
+ *,
937
+ model: str = "gpt-5",
938
+ binary: str | None = None,
939
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
940
+ max_calls_per_day: int | None = None,
941
+ warn_at: float = 0.8,
942
+ cli_calls_path: Path | None = None,
943
+ ):
944
+ super().__init__(
945
+ model=model,
946
+ binary=binary,
947
+ timeout_seconds=timeout_seconds,
948
+ max_calls_per_day=max_calls_per_day,
949
+ warn_at=warn_at,
950
+ cli_calls_path=cli_calls_path,
951
+ )
952
+
953
+ def _build_command(
954
+ self, system_prompt: str, user_prompt: str, max_tokens: int # noqa: ARG002
955
+ ) -> list[str]:
956
+ cmd = [self.binary, "exec", "--json", "--model", self.model]
957
+ if system_prompt:
958
+ cmd.extend(["--system", system_prompt])
959
+ cmd.append(user_prompt)
960
+ return cmd
961
+
962
+ def _parse_output(self, stdout: str, stderr: str) -> CouncilResponse: # noqa: ARG002
963
+ text = ""
964
+ input_tokens = 0
965
+ output_tokens = 0
966
+ meta: dict[str, object] = {}
967
+ for line in stdout.splitlines():
968
+ line = line.strip()
969
+ if not line:
970
+ continue
971
+ try:
972
+ event = json.loads(line)
973
+ except json.JSONDecodeError:
974
+ continue
975
+ if not isinstance(event, dict):
976
+ continue
977
+ event_type = event.get("type")
978
+ if event_type == "item.completed":
979
+ item = event.get("item") or {}
980
+ if isinstance(item, dict):
981
+ content = item.get("content") or []
982
+ if isinstance(content, list):
983
+ chunks: list[str] = []
984
+ for entry in content:
985
+ if isinstance(entry, dict) and entry.get("text"):
986
+ chunks.append(str(entry["text"]))
987
+ if chunks:
988
+ text = "\n".join(chunks).strip()
989
+ if item.get("id"):
990
+ meta["item_id"] = str(item["id"])
991
+ elif event_type == "turn.completed":
992
+ usage = event.get("usage") or {}
993
+ if isinstance(usage, dict):
994
+ input_tokens = int(usage.get("input_tokens", 0) or 0)
995
+ output_tokens = int(usage.get("output_tokens", 0) or 0)
996
+ elif event_type == "session.created":
997
+ if event.get("session_id"):
998
+ meta["session_id"] = str(event["session_id"])
999
+ return CouncilResponse(
1000
+ provider=self.name, model=self.model, text=text,
1001
+ input_tokens=input_tokens, output_tokens=output_tokens,
1002
+ metadata=meta,
1003
+ )
1004
+
1005
+
1006
+ class GeminiCliClient(CliClient):
1007
+ """Google Gemini via the official `gemini` CLI (free-tier subscription).
1008
+
1009
+ Invokes ``gemini --prompt <prompt> --output-format json`` and
1010
+ consumes the structured envelope: ``{"response": str, "stats":
1011
+ {"models": {"<model>": {"tokens": {"prompt": int, "candidates":
1012
+ int}}}}, ...}``. Prompt is piped on stdin to dodge argv limits.
1013
+
1014
+ Auth is delegated to the CLI's own session — the user runs
1015
+ ``gemini`` once interactively to set up OAuth, then the
1016
+ orchestrator inherits the consent. Free-tier quotas apply at the
1017
+ Google account level; ``cli_call_budget`` enforces a local mirror.
1018
+ """
1019
+
1020
+ name = "gemini"
1021
+ default_binary = "gemini"
1022
+ subscription_label = "gemini-pro"
1023
+
1024
+ _AUTH_FAILURE_PATTERNS = CliClient._AUTH_FAILURE_PATTERNS + (
1025
+ "interactive consent could not be obtained",
1026
+ "please run `gemini`",
1027
+ "oauth",
1028
+ )
1029
+
1030
+ def __init__(
1031
+ self,
1032
+ *,
1033
+ model: str = "gemini-2.5-pro",
1034
+ binary: str | None = None,
1035
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
1036
+ max_calls_per_day: int | None = None,
1037
+ warn_at: float = 0.8,
1038
+ cli_calls_path: Path | None = None,
1039
+ ):
1040
+ super().__init__(
1041
+ model=model,
1042
+ binary=binary,
1043
+ timeout_seconds=timeout_seconds,
1044
+ max_calls_per_day=max_calls_per_day,
1045
+ warn_at=warn_at,
1046
+ cli_calls_path=cli_calls_path,
1047
+ )
1048
+
1049
+ def _build_command(
1050
+ self, system_prompt: str, user_prompt: str, max_tokens: int # noqa: ARG002
1051
+ ) -> list[str]:
1052
+ cmd = [
1053
+ self.binary,
1054
+ "--output-format", "json",
1055
+ "--model", self.model,
1056
+ ]
1057
+ if system_prompt:
1058
+ cmd.extend(["--system", system_prompt])
1059
+ return cmd
1060
+
1061
+ def _stdin_payload(self, system_prompt: str, user_prompt: str) -> str | None: # noqa: ARG002
1062
+ return user_prompt
1063
+
1064
+ def _parse_output(self, stdout: str, stderr: str) -> CouncilResponse: # noqa: ARG002
1065
+ envelope = json.loads(stdout)
1066
+ if not isinstance(envelope, dict):
1067
+ raise ValueError("expected JSON object at the top level of gemini CLI output")
1068
+ text = str(envelope.get("response", "")).strip()
1069
+ input_tokens = 0
1070
+ output_tokens = 0
1071
+ stats = envelope.get("stats") or {}
1072
+ if isinstance(stats, dict):
1073
+ models = stats.get("models") or {}
1074
+ if isinstance(models, dict):
1075
+ # gemini emits per-model token counts; pick the configured model
1076
+ # if present, else sum across all models in the envelope.
1077
+ model_stats = models.get(self.model)
1078
+ if not isinstance(model_stats, dict):
1079
+ model_stats = next(
1080
+ (v for v in models.values() if isinstance(v, dict)),
1081
+ {},
1082
+ )
1083
+ tokens = (model_stats.get("tokens") or {}) if isinstance(model_stats, dict) else {}
1084
+ if isinstance(tokens, dict):
1085
+ input_tokens = int(tokens.get("prompt", 0) or 0)
1086
+ output_tokens = int(tokens.get("candidates", 0) or 0)
1087
+ meta: dict[str, object] = {}
1088
+ session_id = envelope.get("sessionId") or envelope.get("session_id")
1089
+ if session_id:
1090
+ meta["session_id"] = str(session_id)
1091
+ return CouncilResponse(
1092
+ provider=self.name, model=self.model, text=text,
1093
+ input_tokens=input_tokens, output_tokens=output_tokens,
1094
+ metadata=meta,
1095
+ )
1096
+
1097
+
1098
+ class XAICliClient(CliClient):
1099
+ """xAI Grok via the community `grok` CLI (Superagent project).
1100
+
1101
+ Community-maintained wrapper around the xAI API — **not** an
1102
+ official subscription transport. The CLI consumes ``XAI_API_KEY``
1103
+ from its own environment, so every call is paid per-token exactly
1104
+ as ``XAIClient`` (api transport) would be. ``mode: cli`` here is
1105
+ an ergonomic shortcut for users who already drive Grok from the
1106
+ shell; it does NOT bypass the USD cost gate.
1107
+
1108
+ Invokes ``grok -p <prompt>``. Output is plain text — no JSON
1109
+ envelope. ``_parse_output`` returns the trimmed stdout and
1110
+ estimates token counts heuristically (chars / 4) for the
1111
+ audit-trail; estimates feed the post-call spend tracker, not the
1112
+ pre-call gate (the orchestrator's ``estimate()`` already projects
1113
+ cost from the prompt before this client is invoked).
1114
+ """
1115
+
1116
+ name = "xai"
1117
+ default_binary = "grok"
1118
+ billable = True # community CLI consumes an API key — billable applies
1119
+
1120
+ _AUTH_FAILURE_PATTERNS = CliClient._AUTH_FAILURE_PATTERNS + (
1121
+ "xai_api_key", "401", "unauthorized",
1122
+ )
1123
+
1124
+ def __init__(
1125
+ self,
1126
+ *,
1127
+ model: str = DEFAULT_XAI_MODEL,
1128
+ binary: str | None = None,
1129
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
1130
+ max_calls_per_day: int | None = None,
1131
+ warn_at: float = 0.8,
1132
+ cli_calls_path: Path | None = None,
1133
+ ):
1134
+ super().__init__(
1135
+ model=model,
1136
+ binary=binary,
1137
+ timeout_seconds=timeout_seconds,
1138
+ max_calls_per_day=max_calls_per_day,
1139
+ warn_at=warn_at,
1140
+ cli_calls_path=cli_calls_path,
1141
+ )
1142
+
1143
+ def _build_command(
1144
+ self, system_prompt: str, user_prompt: str, max_tokens: int # noqa: ARG002
1145
+ ) -> list[str]:
1146
+ cmd = [self.binary, "-p", user_prompt]
1147
+ if self.model:
1148
+ cmd.extend(["--model", self.model])
1149
+ return cmd
1150
+
1151
+ def _parse_output(self, stdout: str, stderr: str) -> CouncilResponse: # noqa: ARG002
1152
+ text = stdout.strip()
1153
+ # Plain-text CLIs surface no token usage — estimate from text
1154
+ # length so the audit trail and post-call tracker stay populated.
1155
+ # chars / 4 mirrors `pricing.estimate_input_tokens`.
1156
+ output_tokens = max(1, len(text) // 4) if text else 0
1157
+ return CouncilResponse(
1158
+ provider=self.name, model=self.model, text=text,
1159
+ input_tokens=0, output_tokens=output_tokens,
1160
+ metadata={"cli_output_format": "plain_text", "tokens_estimated": True},
1161
+ )
1162
+
1163
+
1164
+ class PerplexityCliClient(CliClient):
1165
+ """Perplexity via the community `perplexity` CLI (npm package).
1166
+
1167
+ Community-maintained wrapper around the Perplexity API — **not**
1168
+ an official subscription transport. The CLI consumes
1169
+ ``PERPLEXITY_API_KEY`` from its own environment, so every call is
1170
+ paid per-token exactly as ``PerplexityClient`` (api transport)
1171
+ would be. ``mode: cli`` here is an ergonomic shortcut; it does
1172
+ NOT bypass the USD cost gate.
1173
+
1174
+ Invokes ``perplexity -p <prompt>``. Output is plain text — no
1175
+ JSON envelope. Token counts are estimated heuristically for the
1176
+ audit trail; the pre-call cost gate uses the orchestrator's
1177
+ prompt-side estimate.
1178
+ """
1179
+
1180
+ name = "perplexity"
1181
+ default_binary = "perplexity"
1182
+ billable = True # community CLI consumes an API key — billable applies
1183
+
1184
+ _AUTH_FAILURE_PATTERNS = CliClient._AUTH_FAILURE_PATTERNS + (
1185
+ "perplexity_api_key", "401", "unauthorized",
1186
+ )
1187
+
1188
+ def __init__(
1189
+ self,
1190
+ *,
1191
+ model: str = DEFAULT_PERPLEXITY_MODEL,
1192
+ binary: str | None = None,
1193
+ timeout_seconds: float = DEFAULT_CLI_TIMEOUT_SECONDS,
1194
+ max_calls_per_day: int | None = None,
1195
+ warn_at: float = 0.8,
1196
+ cli_calls_path: Path | None = None,
1197
+ ):
1198
+ super().__init__(
1199
+ model=model,
1200
+ binary=binary,
1201
+ timeout_seconds=timeout_seconds,
1202
+ max_calls_per_day=max_calls_per_day,
1203
+ warn_at=warn_at,
1204
+ cli_calls_path=cli_calls_path,
1205
+ )
1206
+
1207
+ def _build_command(
1208
+ self, system_prompt: str, user_prompt: str, max_tokens: int # noqa: ARG002
1209
+ ) -> list[str]:
1210
+ cmd = [self.binary, "-p", user_prompt]
1211
+ if self.model:
1212
+ cmd.extend(["--model", self.model])
1213
+ return cmd
1214
+
1215
+ def _parse_output(self, stdout: str, stderr: str) -> CouncilResponse: # noqa: ARG002
1216
+ text = stdout.strip()
1217
+ output_tokens = max(1, len(text) // 4) if text else 0
1218
+ return CouncilResponse(
1219
+ provider=self.name, model=self.model, text=text,
1220
+ input_tokens=0, output_tokens=output_tokens,
1221
+ metadata={"cli_output_format": "plain_text", "tokens_estimated": True},
1222
+ )
1223
+
1224
+
1225
+ # ── Manual mode (Phase 2b) ───────────────────────────────────────────
1226
+
1227
+
1228
+ MANUAL_END_MARKER = "END" # line containing only this terminates a paste block.
1229
+
1230
+
1231
+ def _read_until_marker(stream: TextIO, marker: str) -> str:
1232
+ """Read lines from `stream` until a line equal to `marker` (after strip).
1233
+
1234
+ Returns the joined body without the marker line. EOF before the
1235
+ marker is treated as end-of-input — the body collected so far is
1236
+ returned; callers decide whether that counts as abort.
1237
+ """
1238
+ body: list[str] = []
1239
+ for raw in stream:
1240
+ line = raw.rstrip("\n")
1241
+ if line.strip() == marker:
1242
+ break
1243
+ body.append(line)
1244
+ return "\n".join(body).strip()
1245
+
1246
+
1247
+ class ManualClient(ExternalAIClient):
1248
+ """Copy-paste council member — user is the transport.
1249
+
1250
+ `ask()` renders the system prompt + artefact as one Markdown block,
1251
+ prints it to `stdout`, and reads pasted replies from `stdin`. After
1252
+ each pasted reply, surfaces a 1/2/3 menu (more · next · abort) per
1253
+ `user-interaction`. Loops until the user picks 2 or 3.
1254
+
1255
+ Spend is $0 — `billable=False` makes the orchestrator skip the cost
1256
+ gate for this member regardless of the price table.
1257
+
1258
+ Tests inject `stdin` / `stdout` `TextIO` streams. Production usage
1259
+ falls back to `sys.stdin` / `sys.stdout`.
1260
+ """
1261
+
1262
+ billable = False
1263
+ transport = "manual"
1264
+
1265
+ def __init__(
1266
+ self,
1267
+ *,
1268
+ name: str = "manual",
1269
+ model: str = "manual",
1270
+ provider_label: str = "your LLM web UI",
1271
+ stdin: TextIO | None = None,
1272
+ stdout: TextIO | None = None,
1273
+ end_marker: str = MANUAL_END_MARKER,
1274
+ ):
1275
+ self.name = name
1276
+ self.model = model
1277
+ self.provider_label = provider_label
1278
+ self._stdin = stdin if stdin is not None else sys.stdin
1279
+ self._stdout = stdout if stdout is not None else sys.stdout
1280
+ self._end_marker = end_marker
1281
+
1282
+ def ask(
1283
+ self,
1284
+ system_prompt: str,
1285
+ user_prompt: str,
1286
+ max_tokens: int = DEFAULT_MAX_TOKENS, # noqa: ARG002 — accepted for ABC parity
1287
+ ) -> CouncilResponse:
1288
+ t0 = time.monotonic()
1289
+ rounds: list[str] = []
1290
+ block = self._render_block(system_prompt, user_prompt, follow_up=None)
1291
+ self._emit(block)
1292
+
1293
+ try:
1294
+ while True:
1295
+ reply = _read_until_marker(self._stdin, self._end_marker)
1296
+ rounds.append(reply)
1297
+ choice = self._ask_menu(reply_chars=len(reply))
1298
+
1299
+ if choice == "2": # done with this member
1300
+ break
1301
+ if choice == "3": # abort the council run
1302
+ return CouncilResponse(
1303
+ provider=self.name, model=self.model, text="",
1304
+ latency_ms=int((time.monotonic() - t0) * 1000),
1305
+ error="manual_aborted",
1306
+ metadata={"rounds": len(rounds), "manual": True},
1307
+ )
1308
+ # choice == "1": collect follow-up, re-emit context block.
1309
+ follow_up = self._read_follow_up()
1310
+ if not follow_up:
1311
+ break # empty follow-up → treat as "done with this member"
1312
+ rounds.append(f"[follow-up sent]\n{follow_up}")
1313
+ block = self._render_block(system_prompt, user_prompt, follow_up=follow_up)
1314
+ self._emit(block)
1315
+ except Exception as exc: # noqa: BLE001 — never break the council on a stdin glitch
1316
+ return CouncilResponse(
1317
+ provider=self.name, model=self.model, text="\n\n".join(rounds),
1318
+ latency_ms=int((time.monotonic() - t0) * 1000),
1319
+ error=f"{type(exc).__name__}: {exc}",
1320
+ metadata={"rounds": len(rounds), "manual": True},
1321
+ )
1322
+
1323
+ text = "\n\n---\n\n".join(rounds).strip()
1324
+ return CouncilResponse(
1325
+ provider=self.name, model=self.model, text=text,
1326
+ latency_ms=int((time.monotonic() - t0) * 1000),
1327
+ metadata={"rounds": len(rounds), "manual": True},
1328
+ )
1329
+
1330
+ # ── helpers ──────────────────────────────────────────────────────
1331
+
1332
+ def _emit(self, text: str) -> None:
1333
+ self._stdout.write(text)
1334
+ self._stdout.write("\n")
1335
+ self._stdout.flush()
1336
+
1337
+ def _render_block(
1338
+ self,
1339
+ system_prompt: str,
1340
+ user_prompt: str,
1341
+ *,
1342
+ follow_up: str | None,
1343
+ ) -> str:
1344
+ bar = "═" * 67
1345
+ head = (
1346
+ f"{bar}\n"
1347
+ f"Manual council member: {self.provider_label}\n"
1348
+ f"Paste this block into the web UI · then paste the reply below.\n"
1349
+ f"{bar}"
1350
+ )
1351
+ if follow_up is not None:
1352
+ body = (
1353
+ f"[Follow-up — paste this into the SAME chat thread]\n\n"
1354
+ f"{follow_up}"
1355
+ )
1356
+ else:
1357
+ body = f"{system_prompt}\n\n---\n\n{user_prompt}"
1358
+ tail = (
1359
+ f"{bar}\n"
1360
+ f"End your pasted reply with a line containing only: {self._end_marker}\n"
1361
+ f"{bar}"
1362
+ )
1363
+ return f"{head}\n\n{body}\n\n{tail}"
1364
+
1365
+ def _ask_menu(self, *, reply_chars: int) -> str:
1366
+ prompt = (
1367
+ f"\nReply received ({reply_chars} chars). Now what?\n"
1368
+ f" 1. More feedback for this member (continue this thread)\n"
1369
+ f" 2. Done with this member, move to the next\n"
1370
+ f" 3. Abort the council run\n\n"
1371
+ f"Choose 1/2/3: "
1372
+ )
1373
+ self._stdout.write(prompt)
1374
+ self._stdout.flush()
1375
+ line = self._stdin.readline().strip()
1376
+ if line in {"1", "2", "3"}:
1377
+ return line
1378
+ # unknown input → treat as "next" so we never block forever in tests / piped runs.
1379
+ return "2"
1380
+
1381
+ def _read_follow_up(self) -> str:
1382
+ self._emit(
1383
+ f"\nType your follow-up question, end with a line containing only: {self._end_marker}"
1384
+ )
1385
+ return _read_until_marker(self._stdin, self._end_marker)