@event4u/agent-config 5.10.1 → 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 (2226) hide show
  1. package/.claude-plugin/marketplace.json +233 -229
  2. package/AGENTS.md +6 -6
  3. package/CHANGELOG.md +453 -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 -179
  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 -172
  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/cli_wrapper.py +0 -64
  1277. package/scripts/_lib/install_regenerator.py +0 -129
  1278. package/scripts/_lib/installed_lock.py +0 -256
  1279. package/scripts/_lib/scope_guard.sh +0 -162
  1280. package/scripts/_lib/value_ladder.py +0 -696
  1281. package/scripts/_lib/value_report.py +0 -455
  1282. package/scripts/_phase4_bucket.py +0 -210
  1283. package/scripts/_pilot_measure.py +0 -53
  1284. package/scripts/adoption_report.py +0 -195
  1285. package/scripts/adoption_snapshot.py +0 -219
  1286. package/scripts/adoption_status.py +0 -166
  1287. package/scripts/agent-config +0 -57
  1288. package/scripts/ai-video/adapters/gemini-veo.sh +0 -62
  1289. package/scripts/ai-video/adapters/higgsfield.sh +0 -245
  1290. package/scripts/ai-video/adapters/kling.sh +0 -59
  1291. package/scripts/ai-video/adapters/openai-images.sh +0 -143
  1292. package/scripts/ai-video/adapters/sora.sh +0 -60
  1293. package/scripts/ai-video/lib/adapter-common.sh +0 -116
  1294. package/scripts/ai-video/lib/adapter-contract.md +0 -163
  1295. package/scripts/ai-video/lib/fixtures/gemini-veo/result.json +0 -1
  1296. package/scripts/ai-video/lib/fixtures/higgsfield/result.json +0 -1
  1297. package/scripts/ai-video/lib/fixtures/kling/result.json +0 -1
  1298. package/scripts/ai-video/lib/fixtures/openai-images/result.json +0 -1
  1299. package/scripts/ai-video/lib/fixtures/sora/result.json +0 -1
  1300. package/scripts/ai-video/lib/load-config.sh +0 -140
  1301. package/scripts/ai-video/lib/validate-deps.sh +0 -132
  1302. package/scripts/ai-video/stitch.sh +0 -154
  1303. package/scripts/ai-video/test-pipeline.sh +0 -169
  1304. package/scripts/ai_council/advisors.py +0 -148
  1305. package/scripts/ai_council/clients.py +0 -1385
  1306. package/scripts/ai_council/compile_corpus.py +0 -179
  1307. package/scripts/ai_council/events_log.py +0 -141
  1308. package/scripts/ai_council/one_off_archive/2026-05/_one_off_2a4_acceptance.py +0 -208
  1309. package/scripts/ai_council/one_off_archive/2026-05/_one_off_budget_v2_audit.py +0 -206
  1310. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_estimate.py +0 -67
  1311. package/scripts/ai_council/one_off_archive/2026-05/_one_off_context_layer_v1_review.py +0 -292
  1312. package/scripts/ai_council/one_off_archive/2026-05/_one_off_followups_review.py +0 -259
  1313. package/scripts/ai_council/one_off_archive/2026-05/_one_off_nondestructive_inline_audit.py +0 -209
  1314. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase4_dispatch_latency.py +0 -108
  1315. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase6_trigger_jaccard.py +0 -92
  1316. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_budget_rebalance.py +0 -257
  1317. package/scripts/ai_council/one_off_archive/2026-05/_one_off_phase_2a_post_revert.py +0 -197
  1318. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rebalancing_audit.py +0 -149
  1319. package/scripts/ai_council/one_off_archive/2026-05/_one_off_roundtrip.py +0 -111
  1320. package/scripts/ai_council/one_off_archive/2026-05/_one_off_rule_hardening_v1.py +0 -251
  1321. package/scripts/ai_council/one_off_archive/2026-05/_one_off_silent_taskfiles.py +0 -98
  1322. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_open_questions.py +0 -232
  1323. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_optimization.py +0 -144
  1324. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_gaps.py +0 -252
  1325. package/scripts/ai_council/one_off_archive/2026-05/_one_off_structural_v3_review.py +0 -240
  1326. package/scripts/ai_council/one_off_archive/2026-05/_one_off_tier_retrofit.py +0 -180
  1327. package/scripts/ai_council/pricing.py +0 -215
  1328. package/scripts/ai_council/session.py +0 -366
  1329. package/scripts/annotate_discovery.py +0 -149
  1330. package/scripts/apply_modules_config.py +0 -290
  1331. package/scripts/audit_adr_coverage.py +0 -175
  1332. package/scripts/audit_auto_rules.py +0 -175
  1333. package/scripts/audit_cloud_compatibility.py +0 -362
  1334. package/scripts/audit_command_surface.py +0 -374
  1335. package/scripts/audit_initial_context.py +0 -234
  1336. package/scripts/audit_likelihood.py +0 -148
  1337. package/scripts/audit_mcp_tools.py +0 -146
  1338. package/scripts/audit_overlap.py +0 -145
  1339. package/scripts/audit_user_type_axis.py +0 -140
  1340. package/scripts/backfill_model_tier.py +0 -182
  1341. package/scripts/bench_ab_cache_dispatch.py +0 -68
  1342. package/scripts/bench_ab_clone.py +0 -170
  1343. package/scripts/bench_ab_diff.py +0 -220
  1344. package/scripts/bench_ab_integrity.py +0 -143
  1345. package/scripts/bench_ab_run.py +0 -235
  1346. package/scripts/bench_ab_task_runner.py +0 -369
  1347. package/scripts/bench_ab_tracka_run.py +0 -202
  1348. package/scripts/bench_baseline_ready.py +0 -108
  1349. package/scripts/bench_condense_memory.py +0 -168
  1350. package/scripts/bench_drift_check.py +0 -151
  1351. package/scripts/bench_per_tool.py +0 -216
  1352. package/scripts/bench_rtk_savings.py +0 -320
  1353. package/scripts/bench_run.py +0 -272
  1354. package/scripts/bench_runner.py +0 -158
  1355. package/scripts/build_cloud_bundle.py +0 -458
  1356. package/scripts/build_discovery_manifest.py +0 -679
  1357. package/scripts/build_linear_digest.py +0 -260
  1358. package/scripts/build_mcp_registry_manifest.py +0 -181
  1359. package/scripts/build_rule_trigger_matrix.py +0 -350
  1360. package/scripts/capture_showcase_session.py +0 -361
  1361. package/scripts/check_always_budget.py +0 -532
  1362. package/scripts/check_artefact_checksums.py +0 -111
  1363. package/scripts/check_augment_description_cap.py +0 -79
  1364. package/scripts/check_augmentignore.py +0 -72
  1365. package/scripts/check_beta_review_markers.py +0 -127
  1366. package/scripts/check_cluster_patterns.py +0 -175
  1367. package/scripts/check_command_count_messaging.py +0 -158
  1368. package/scripts/check_condensation.py +0 -375
  1369. package/scripts/check_condensed_paths.py +0 -221
  1370. package/scripts/check_context_paths.py +0 -202
  1371. package/scripts/check_council_references.py +0 -228
  1372. package/scripts/check_discovery_determinism.py +0 -70
  1373. package/scripts/check_gate_paths.py +0 -117
  1374. package/scripts/check_module_management_neutral.py +0 -149
  1375. package/scripts/check_no_roadmap_refs.py +0 -155
  1376. package/scripts/check_one_off_location.py +0 -81
  1377. package/scripts/check_overlay_cascade_subdirs.py +0 -129
  1378. package/scripts/check_portability.py +0 -574
  1379. package/scripts/check_public_catalog_links.py +0 -125
  1380. package/scripts/check_public_links.py +0 -185
  1381. package/scripts/check_references.py +0 -541
  1382. package/scripts/check_release_includes_discovery.py +0 -61
  1383. package/scripts/check_release_pr_shape.py +0 -119
  1384. package/scripts/check_release_published.py +0 -145
  1385. package/scripts/check_reply_consistency.py +0 -169
  1386. package/scripts/check_roadmap_trackable.py +0 -114
  1387. package/scripts/check_role_doc_links.py +0 -110
  1388. package/scripts/check_safety_floor_untouched.py +0 -125
  1389. package/scripts/check_skill_requires.py +0 -143
  1390. package/scripts/check_template_pin_drift.py +0 -129
  1391. package/scripts/check_test_coverage_diff.py +0 -180
  1392. package/scripts/check_token_optimizer_freshness.py +0 -146
  1393. package/scripts/check_update_banner.py +0 -86
  1394. package/scripts/ci_time_ratio.py +0 -168
  1395. package/scripts/compile_router.py +0 -232
  1396. package/scripts/condense.py +0 -1649
  1397. package/scripts/condense_memory.py +0 -178
  1398. package/scripts/config/profiles.py +0 -188
  1399. package/scripts/config/session_profiles.py +0 -492
  1400. package/scripts/cost_by_conversation.py +0 -78
  1401. package/scripts/cost_summary.py +0 -97
  1402. package/scripts/council_cli.py +0 -2544
  1403. package/scripts/cross_repo_retrieve.py +0 -172
  1404. package/scripts/discovery_stats.py +0 -70
  1405. package/scripts/extract_audit_patterns.py +0 -202
  1406. package/scripts/first_run_gate_hook.py +0 -178
  1407. package/scripts/gen_discovery_baseline.py +0 -127
  1408. package/scripts/generate_catalog.py +0 -116
  1409. package/scripts/generate_index.py +0 -302
  1410. package/scripts/generate_ownership_matrix.py +0 -378
  1411. package/scripts/generate_pack_manifests.py +0 -183
  1412. package/scripts/hook_manifest.yaml +0 -243
  1413. package/scripts/hooks/dispatch_hook.py +0 -461
  1414. package/scripts/hooks/replay_hook.py +0 -144
  1415. package/scripts/hooks_doctor.py +0 -223
  1416. package/scripts/hooks_status.py +0 -157
  1417. package/scripts/install +0 -424
  1418. package/scripts/install-hooks.sh +0 -185
  1419. package/scripts/install.py +0 -5027
  1420. package/scripts/install.sh +0 -1140
  1421. package/scripts/inventory_abstraction_budget.py +0 -621
  1422. package/scripts/inventory_frontmatter.py +0 -164
  1423. package/scripts/inventory_meta_layers.py +0 -288
  1424. package/scripts/iron_law_sha.py +0 -107
  1425. package/scripts/linked_projects_list.py +0 -91
  1426. package/scripts/lint_agents_layout.py +0 -191
  1427. package/scripts/lint_agents_md.py +0 -208
  1428. package/scripts/lint_archived_skills.py +0 -159
  1429. package/scripts/lint_artefact_frontmatter.py +0 -180
  1430. package/scripts/lint_bench_ab.py +0 -172
  1431. package/scripts/lint_bench_corpus.py +0 -255
  1432. package/scripts/lint_command_tiers.py +0 -128
  1433. package/scripts/lint_commit_subjects.py +0 -139
  1434. package/scripts/lint_context_spine_usage.py +0 -137
  1435. package/scripts/lint_discovery_manifest.py +0 -136
  1436. package/scripts/lint_discovery_vocabulary.py +0 -156
  1437. package/scripts/lint_examples.py +0 -102
  1438. package/scripts/lint_explain_trace.py +0 -80
  1439. package/scripts/lint_featured_skills.py +0 -139
  1440. package/scripts/lint_framework_leakage.py +0 -375
  1441. package/scripts/lint_framework_leakage_allowlist.json +0 -575
  1442. package/scripts/lint_frontmatter_boilerplate.py +0 -77
  1443. package/scripts/lint_ghostwriter_source.py +0 -240
  1444. package/scripts/lint_handoffs.py +0 -217
  1445. package/scripts/lint_hook_concern_budget.py +0 -207
  1446. package/scripts/lint_hook_manifest.py +0 -217
  1447. package/scripts/lint_load_context.py +0 -196
  1448. package/scripts/lint_marketplace.py +0 -180
  1449. package/scripts/lint_marketplace_install_completeness.py +0 -188
  1450. package/scripts/lint_mcp_registry_manifest.py +0 -69
  1451. package/scripts/lint_media_policy_linkage.py +0 -140
  1452. package/scripts/lint_model_tier_coverage.py +0 -73
  1453. package/scripts/lint_namespace.py +0 -135
  1454. package/scripts/lint_no_new_atomic_commands.py +0 -180
  1455. package/scripts/lint_one_off_age.py +0 -184
  1456. package/scripts/lint_orchestration_dsl.py +0 -217
  1457. package/scripts/lint_pack_boundaries.py +0 -147
  1458. package/scripts/lint_pack_first_win.py +0 -103
  1459. package/scripts/lint_persona_governance.py +0 -164
  1460. package/scripts/lint_positioning.py +0 -143
  1461. package/scripts/lint_regression.py +0 -232
  1462. package/scripts/lint_roadmap_ci_steps.py +0 -186
  1463. package/scripts/lint_roadmap_complexity.py +0 -220
  1464. package/scripts/lint_role_experiences.py +0 -237
  1465. package/scripts/lint_rule_interactions.py +0 -170
  1466. package/scripts/lint_rule_tiers.py +0 -90
  1467. package/scripts/lint_showcase_sessions.py +0 -148
  1468. package/scripts/lint_skill_tools.py +0 -168
  1469. package/scripts/lint_topics_yaml.py +0 -89
  1470. package/scripts/lint_trust_coherence.py +0 -212
  1471. package/scripts/lint_value_dashboard.py +0 -218
  1472. package/scripts/mcp_parity_smoke.py +0 -164
  1473. package/scripts/mcp_registry_submit.sh +0 -187
  1474. package/scripts/mcp_server/__init__.py +0 -19
  1475. package/scripts/mcp_server/consumer_tool_catalog.json +0 -275
  1476. package/scripts/mcp_server/prompts.py +0 -441
  1477. package/scripts/mcp_server/resources.py +0 -201
  1478. package/scripts/mcp_server/tools.py +0 -838
  1479. package/scripts/measure_augment_budget.py +0 -214
  1480. package/scripts/measure_density.py +0 -232
  1481. package/scripts/measure_frugality_savings.py +0 -164
  1482. package/scripts/measure_markitdown_lift.py +0 -127
  1483. package/scripts/measure_patterns.py +0 -376
  1484. package/scripts/measure_projection_bytes.py +0 -159
  1485. package/scripts/measure_rule_budget.py +0 -347
  1486. package/scripts/measure_skill_reduction.py +0 -102
  1487. package/scripts/migrate_command_suggestions.py +0 -151
  1488. package/scripts/migrate_frontmatter_defaults.py +0 -245
  1489. package/scripts/mine_session.py +0 -279
  1490. package/scripts/move_artefact.py +0 -143
  1491. package/scripts/new_skill.py +0 -148
  1492. package/scripts/pack_mcp_content.py +0 -288
  1493. package/scripts/plan_physical_move.py +0 -353
  1494. package/scripts/print_required_checks.py +0 -196
  1495. package/scripts/probe_projection_fidelity.py +0 -202
  1496. package/scripts/profile_staleness_hook.py +0 -69
  1497. package/scripts/profile_use.py +0 -125
  1498. package/scripts/project_thin_rules.py +0 -168
  1499. package/scripts/prototype_lint_contradictions.py +0 -150
  1500. package/scripts/recruit_preflight.sh +0 -152
  1501. package/scripts/refine_ticket_detect.py +0 -646
  1502. package/scripts/release.py +0 -1049
  1503. package/scripts/render_benchmark_md.py +0 -312
  1504. package/scripts/render_value_md.py +0 -347
  1505. package/scripts/repro/repro_marketplace_install_gap.sh +0 -161
  1506. package/scripts/roadmap_progress_hook.py +0 -274
  1507. package/scripts/router_telemetry.py +0 -470
  1508. package/scripts/run_skill_evals.py +0 -185
  1509. package/scripts/runtime_registry.py +0 -166
  1510. package/scripts/schemas/command.schema.json +0 -178
  1511. package/scripts/schemas/rule.schema.json +0 -145
  1512. package/scripts/score_skill_selection.py +0 -198
  1513. package/scripts/skill_collision_clusters.py +0 -162
  1514. package/scripts/skill_discovery.py +0 -254
  1515. package/scripts/skill_linter.py +0 -3686
  1516. package/scripts/skill_overlap.py +0 -204
  1517. package/scripts/skill_preview.py +0 -179
  1518. package/scripts/skill_tools/audit_persona_coverage.py +0 -147
  1519. package/scripts/skill_tools/audit_user_type_coverage.py +0 -148
  1520. package/scripts/skill_tools/run_block_d_eval.py +0 -129
  1521. package/scripts/skill_tools/score_skill_relevance.py +0 -169
  1522. package/scripts/skill_tools/suggest_skill_for_task.py +0 -113
  1523. package/scripts/skill_trigger_eval.py +0 -682
  1524. package/scripts/skill_usage_collect.py +0 -191
  1525. package/scripts/skill_usage_report.py +0 -162
  1526. package/scripts/smoke/kernel.sh +0 -107
  1527. package/scripts/smoke/router.sh +0 -148
  1528. package/scripts/smoke/schema.sh +0 -71
  1529. package/scripts/smoke/skills.sh +0 -112
  1530. package/scripts/smoke_path_resolution.py +0 -93
  1531. package/scripts/smoke_quickstart.py +0 -144
  1532. package/scripts/snapshot_agent_outputs.py +0 -144
  1533. package/scripts/spotcheck_thin_root.py +0 -134
  1534. package/scripts/sync_agent_settings.py +0 -180
  1535. package/scripts/sync_github_metadata.py +0 -147
  1536. package/scripts/sync_gitignore.py +0 -291
  1537. package/scripts/telegraph_stats.py +0 -119
  1538. package/scripts/trigger_coverage.py +0 -129
  1539. package/scripts/update_counts.py +0 -195
  1540. package/scripts/update_prices.py +0 -125
  1541. package/scripts/validate_agent_settings.py +0 -124
  1542. package/scripts/validate_decision_engine.py +0 -136
  1543. package/scripts/validate_discovery_manifest.py +0 -94
  1544. package/scripts/validate_frontmatter.py +0 -571
  1545. package/scripts/verify_physical_move.py +0 -185
  1546. package/scripts/wrapper_freshness_hook.py +0 -86
  1547. /package/{.agent-src → dist/agent-src}/contexts/augment-infrastructure.md +0 -0
  1548. /package/{.agent-src → dist/agent-src}/contexts/authority/destructive-mechanics.md +0 -0
  1549. /package/{.agent-src → dist/agent-src}/contexts/authority/kernel-rule-edits.md +0 -0
  1550. /package/{.agent-src → dist/agent-src}/contexts/authority/scope-mechanics.md +0 -0
  1551. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/guidelines-mechanics.md +0 -0
  1552. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/skill-quality-mechanics.md +0 -0
  1553. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/slash-command-routing-policy-mechanics.md +0 -0
  1554. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/think-before-action-mechanics.md +0 -0
  1555. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/token-efficiency-mechanics.md +0 -0
  1556. /package/{.agent-src → dist/agent-src}/contexts/communication/rules-auto/user-interaction-mechanics.md +0 -0
  1557. /package/{.agent-src → dist/agent-src}/contexts/contracts/agents-md-anatomy.md +0 -0
  1558. /package/{.agent-src → dist/agent-src}/contexts/contracts/command-suggestion-flow.md +0 -0
  1559. /package/{.agent-src → dist/agent-src}/contexts/contracts/frugality-charter.md +0 -0
  1560. /package/{.agent-src → dist/agent-src}/contexts/contracts/research-schema.md +0 -0
  1561. /package/{.agent-src → dist/agent-src}/contexts/documentation-hierarchy.md +0 -0
  1562. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-detection.md +0 -0
  1563. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-examples.md +0 -0
  1564. /package/{.agent-src → dist/agent-src}/contexts/execution/autonomy-mechanics.md +0 -0
  1565. /package/{.agent-src → dist/agent-src}/contexts/execution/cheap-question-mechanics.md +0 -0
  1566. /package/{.agent-src → dist/agent-src}/contexts/execution/interrupt-examples.md +0 -0
  1567. /package/{.agent-src → dist/agent-src}/contexts/execution/roadmap-process-loop.md +0 -0
  1568. /package/{.agent-src → dist/agent-src}/contexts/execution/verification-mechanics.md +0 -0
  1569. /package/{.agent-src → dist/agent-src}/contexts/judges/no-consolidate-rationale.md +0 -0
  1570. /package/{.agent-src → dist/agent-src}/contexts/judges/persona-voice-rubric.md +0 -0
  1571. /package/{.agent-src → dist/agent-src}/contexts/model-recommendations.md +0 -0
  1572. /package/{.agent-src → dist/agent-src}/contexts/override-system.md +0 -0
  1573. /package/{.agent-src → dist/agent-src}/contexts/skills-and-commands.md +0 -0
  1574. /package/{.agent-src → dist/agent-src}/contexts/subagent-configuration.md +0 -0
  1575. /package/{.agent-src → dist/agent-src}/ghostwriter/README.md +0 -0
  1576. /package/{.agent-src → dist/agent-src}/ghostwriter/fictional-fixture-v1.md +0 -0
  1577. /package/{.agent-src → dist/agent-src}/packs/README.md +0 -0
  1578. /package/{.agent-src → dist/agent-src}/packs/agency-delivery.yml +0 -0
  1579. /package/{.agent-src → dist/agent-src}/packs/content-engine.yml +0 -0
  1580. /package/{.agent-src → dist/agent-src}/packs/founder-mvp.yml +0 -0
  1581. /package/{.agent-src → dist/agent-src}/personas/_template-specialist/persona.md +0 -0
  1582. /package/{.agent-src → dist/agent-src}/personas/advisors/contrarian.md +0 -0
  1583. /package/{.agent-src → dist/agent-src}/personas/advisors/executor.md +0 -0
  1584. /package/{.agent-src → dist/agent-src}/personas/advisors/expansionist.md +0 -0
  1585. /package/{.agent-src → dist/agent-src}/personas/advisors/first-principles.md +0 -0
  1586. /package/{.agent-src → dist/agent-src}/personas/advisors/outsider.md +0 -0
  1587. /package/{.agent-src → dist/agent-src}/personas/ai-agent.md +0 -0
  1588. /package/{.agent-src → dist/agent-src}/personas/ai-video-technical-director.md +0 -0
  1589. /package/{.agent-src → dist/agent-src}/personas/backend-architect.md +0 -0
  1590. /package/{.agent-src → dist/agent-src}/personas/cmo.md +0 -0
  1591. /package/{.agent-src → dist/agent-src}/personas/critical-challenger.md +0 -0
  1592. /package/{.agent-src → dist/agent-src}/personas/customer-success-lead.md +0 -0
  1593. /package/{.agent-src → dist/agent-src}/personas/developer.md +0 -0
  1594. /package/{.agent-src → dist/agent-src}/personas/discovery-lead.md +0 -0
  1595. /package/{.agent-src → dist/agent-src}/personas/eloquent-tamer.md +0 -0
  1596. /package/{.agent-src → dist/agent-src}/personas/engineering-manager.md +0 -0
  1597. /package/{.agent-src → dist/agent-src}/personas/finance-partner.md +0 -0
  1598. /package/{.agent-src → dist/agent-src}/personas/frontend-engineer.md +0 -0
  1599. /package/{.agent-src → dist/agent-src}/personas/growth-pm.md +0 -0
  1600. /package/{.agent-src → dist/agent-src}/personas/hollywood-director.md +0 -0
  1601. /package/{.agent-src → dist/agent-src}/personas/people-strategist.md +0 -0
  1602. /package/{.agent-src → dist/agent-src}/personas/product-owner.md +0 -0
  1603. /package/{.agent-src → dist/agent-src}/personas/qa.md +0 -0
  1604. /package/{.agent-src → dist/agent-src}/personas/revops-maintainer.md +0 -0
  1605. /package/{.agent-src → dist/agent-src}/personas/revops.md +0 -0
  1606. /package/{.agent-src → dist/agent-src}/personas/security-engineer.md +0 -0
  1607. /package/{.agent-src → dist/agent-src}/personas/senior-engineer.md +0 -0
  1608. /package/{.agent-src → dist/agent-src}/personas/stakeholder.md +0 -0
  1609. /package/{.agent-src → dist/agent-src}/personas/strategist.md +0 -0
  1610. /package/{.agent-src → dist/agent-src}/personas/tech-writer.md +0 -0
  1611. /package/{.agent-src → dist/agent-src}/presets/README.md +0 -0
  1612. /package/{.agent-src → dist/agent-src}/presets/balanced.yml +0 -0
  1613. /package/{.agent-src → dist/agent-src}/presets/fast.yml +0 -0
  1614. /package/{.agent-src → dist/agent-src}/presets/strict.yml +0 -0
  1615. /package/{.agent-src → dist/agent-src}/profiles/README.md +0 -0
  1616. /package/{.agent-src → dist/agent-src}/rules/agent-authority.md +0 -0
  1617. /package/{.agent-src → dist/agent-src}/rules/analysis-skill-routing.md +0 -0
  1618. /package/{.agent-src → dist/agent-src}/rules/architecture.md +0 -0
  1619. /package/{.agent-src → dist/agent-src}/rules/artifact-drafting-protocol.md +0 -0
  1620. /package/{.agent-src → dist/agent-src}/rules/artifact-engagement-recording.md +0 -0
  1621. /package/{.agent-src → dist/agent-src}/rules/autonomous-execution.md +0 -0
  1622. /package/{.agent-src → dist/agent-src}/rules/cli-output-handling.md +0 -0
  1623. /package/{.agent-src → dist/agent-src}/rules/command-suggestion-policy.md +0 -0
  1624. /package/{.agent-src → dist/agent-src}/rules/commit-conventions.md +0 -0
  1625. /package/{.agent-src → dist/agent-src}/rules/context-hygiene.md +0 -0
  1626. /package/{.agent-src → dist/agent-src}/rules/copilot-routing.md +0 -0
  1627. /package/{.agent-src → dist/agent-src}/rules/devcontainer-routing.md +0 -0
  1628. /package/{.agent-src → dist/agent-src}/rules/docker-commands.md +0 -0
  1629. /package/{.agent-src → dist/agent-src}/rules/domain-safety-disclaimer.md +0 -0
  1630. /package/{.agent-src → dist/agent-src}/rules/domain-safety-pii.md +0 -0
  1631. /package/{.agent-src → dist/agent-src}/rules/domain-safety-retention.md +0 -0
  1632. /package/{.agent-src → dist/agent-src}/rules/downstream-changes.md +0 -0
  1633. /package/{.agent-src → dist/agent-src}/rules/engineering-safety-floor.md +0 -0
  1634. /package/{.agent-src → dist/agent-src}/rules/external-reference-deep-dive.md +0 -0
  1635. /package/{.agent-src → dist/agent-src}/rules/fast-path-marker-visibility.md +0 -0
  1636. /package/{.agent-src → dist/agent-src}/rules/finance-safety-floor.md +0 -0
  1637. /package/{.agent-src → dist/agent-src}/rules/framework-neutrality-in-generic-skills.md +0 -0
  1638. /package/{.agent-src → dist/agent-src}/rules/git-history-discipline.md +0 -0
  1639. /package/{.agent-src → dist/agent-src}/rules/guidelines.md +0 -0
  1640. /package/{.agent-src → dist/agent-src}/rules/improve-before-implement.md +0 -0
  1641. /package/{.agent-src → dist/agent-src}/rules/invite-challenge.md +0 -0
  1642. /package/{.agent-src → dist/agent-src}/rules/laravel-routing.md +0 -0
  1643. /package/{.agent-src → dist/agent-src}/rules/laravel-translations.md +0 -0
  1644. /package/{.agent-src → dist/agent-src}/rules/low-impact-corpus-privacy-floor.md +0 -0
  1645. /package/{.agent-src → dist/agent-src}/rules/markdown-safe-codeblocks.md +0 -0
  1646. /package/{.agent-src → dist/agent-src}/rules/media-sync-ground-truth.md +0 -0
  1647. /package/{.agent-src → dist/agent-src}/rules/minimal-safe-diff.md +0 -0
  1648. /package/{.agent-src → dist/agent-src}/rules/no-decorative-emojis-in-git-surfaces.md +0 -0
  1649. /package/{.agent-src → dist/agent-src}/rules/onboarding-gate.md +0 -0
  1650. /package/{.agent-src → dist/agent-src}/rules/package-ci-checks.md +0 -0
  1651. /package/{.agent-src → dist/agent-src}/rules/php-coding.md +0 -0
  1652. /package/{.agent-src → dist/agent-src}/rules/reviewer-awareness.md +0 -0
  1653. /package/{.agent-src → dist/agent-src}/rules/roadmap-ci-steps-policy.md +0 -0
  1654. /package/{.agent-src → dist/agent-src}/rules/role-mode-adherence.md +0 -0
  1655. /package/{.agent-src → dist/agent-src}/rules/rule-type-governance.md +0 -0
  1656. /package/{.agent-src → dist/agent-src}/rules/runtime-safety.md +0 -0
  1657. /package/{.agent-src → dist/agent-src}/rules/security-sensitive-stop.md +0 -0
  1658. /package/{.agent-src → dist/agent-src}/rules/size-enforcement.md +0 -0
  1659. /package/{.agent-src → dist/agent-src}/rules/skill-improvement-trigger.md +0 -0
  1660. /package/{.agent-src → dist/agent-src}/rules/skill-quality.md +0 -0
  1661. /package/{.agent-src → dist/agent-src}/rules/slash-command-routing-policy.md +0 -0
  1662. /package/{.agent-src → dist/agent-src}/rules/strategy-safety-floor.md +0 -0
  1663. /package/{.agent-src → dist/agent-src}/rules/symfony-routing.md +0 -0
  1664. /package/{.agent-src → dist/agent-src}/rules/telegraph-speak.md +0 -0
  1665. /package/{.agent-src → dist/agent-src}/rules/think-before-action.md +0 -0
  1666. /package/{.agent-src → dist/agent-src}/rules/token-efficiency.md +0 -0
  1667. /package/{.agent-src → dist/agent-src}/rules/token-optimizer-maintenance.md +0 -0
  1668. /package/{.agent-src → dist/agent-src}/rules/tool-safety.md +0 -0
  1669. /package/{.agent-src → dist/agent-src}/rules/ui-audit-gate.md +0 -0
  1670. /package/{.agent-src → dist/agent-src}/rules/upstream-proposal.md +0 -0
  1671. /package/{.agent-src → dist/agent-src}/rules/user-interaction.md +0 -0
  1672. /package/{.agent-src → dist/agent-src}/scripts/scan-seeder-violations.php +0 -0
  1673. /package/{.agent-src → dist/agent-src}/skills/activation-design/SKILL.md +0 -0
  1674. /package/{.agent-src → dist/agent-src}/skills/adr-create/SKILL.md +0 -0
  1675. /package/{.agent-src → dist/agent-src}/skills/adversarial-review/SKILL.md +0 -0
  1676. /package/{.agent-src → dist/agent-src}/skills/agent-docs-writing/SKILL.md +0 -0
  1677. /package/{.agent-src → dist/agent-src}/skills/ai-council/SKILL.md +0 -0
  1678. /package/{.agent-src → dist/agent-src}/skills/analysis-autonomous-mode/SKILL.md +0 -0
  1679. /package/{.agent-src → dist/agent-src}/skills/analysis-skill-router/SKILL.md +0 -0
  1680. /package/{.agent-src → dist/agent-src}/skills/api-testing/SKILL.md +0 -0
  1681. /package/{.agent-src → dist/agent-src}/skills/architecture-review-lens/SKILL.md +0 -0
  1682. /package/{.agent-src → dist/agent-src}/skills/artisan-commands/SKILL.md +0 -0
  1683. /package/{.agent-src → dist/agent-src}/skills/async-python-patterns/SKILL.md +0 -0
  1684. /package/{.agent-src → dist/agent-src}/skills/aws-infrastructure/SKILL.md +0 -0
  1685. /package/{.agent-src → dist/agent-src}/skills/blast-radius-analyzer/SKILL.md +0 -0
  1686. /package/{.agent-src → dist/agent-src}/skills/bug-analyzer/SKILL.md +0 -0
  1687. /package/{.agent-src → dist/agent-src}/skills/build-buy-partner/SKILL.md +0 -0
  1688. /package/{.agent-src → dist/agent-src}/skills/canvas-design/SKILL.md +0 -0
  1689. /package/{.agent-src → dist/agent-src}/skills/canvas-design/evals/triggers.json +0 -0
  1690. /package/{.agent-src → dist/agent-src}/skills/churn-prevention/SKILL.md +0 -0
  1691. /package/{.agent-src → dist/agent-src}/skills/code-refactoring/SKILL.md +0 -0
  1692. /package/{.agent-src → dist/agent-src}/skills/command-routing/SKILL.md +0 -0
  1693. /package/{.agent-src → dist/agent-src}/skills/comp-banding/SKILL.md +0 -0
  1694. /package/{.agent-src → dist/agent-src}/skills/competitive-moat-analysis/SKILL.md +0 -0
  1695. /package/{.agent-src → dist/agent-src}/skills/competitive-positioning/SKILL.md +0 -0
  1696. /package/{.agent-src → dist/agent-src}/skills/composer-packages/SKILL.md +0 -0
  1697. /package/{.agent-src → dist/agent-src}/skills/content-funnel-design/SKILL.md +0 -0
  1698. /package/{.agent-src → dist/agent-src}/skills/context-authoring/SKILL.md +0 -0
  1699. /package/{.agent-src → dist/agent-src}/skills/contracts-cognition/SKILL.md +0 -0
  1700. /package/{.agent-src → dist/agent-src}/skills/conventional-commits-writing/SKILL.md +0 -0
  1701. /package/{.agent-src → dist/agent-src}/skills/copilot-agents-optimization/SKILL.md +0 -0
  1702. /package/{.agent-src → dist/agent-src}/skills/copilot-config/SKILL.md +0 -0
  1703. /package/{.agent-src → dist/agent-src}/skills/customer-research/SKILL.md +0 -0
  1704. /package/{.agent-src → dist/agent-src}/skills/data-flow-mapper/SKILL.md +0 -0
  1705. /package/{.agent-src → dist/agent-src}/skills/data-handling-judgment/SKILL.md +0 -0
  1706. /package/{.agent-src → dist/agent-src}/skills/dcf-modeling/SKILL.md +0 -0
  1707. /package/{.agent-src → dist/agent-src}/skills/deal-qualification-meddic/SKILL.md +0 -0
  1708. /package/{.agent-src → dist/agent-src}/skills/decision-record/SKILL.md +0 -0
  1709. /package/{.agent-src → dist/agent-src}/skills/defense-in-depth/SKILL.md +0 -0
  1710. /package/{.agent-src → dist/agent-src}/skills/dependency-upgrade/SKILL.md +0 -0
  1711. /package/{.agent-src → dist/agent-src}/skills/description-assist/SKILL.md +0 -0
  1712. /package/{.agent-src → dist/agent-src}/skills/devcontainer/SKILL.md +0 -0
  1713. /package/{.agent-src → dist/agent-src}/skills/developer-like-execution/SKILL.md +0 -0
  1714. /package/{.agent-src → dist/agent-src}/skills/discovery-interview/SKILL.md +0 -0
  1715. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/SKILL.md +0 -0
  1716. /package/{.agent-src → dist/agent-src}/skills/doc-coauthoring/evals/triggers.json +0 -0
  1717. /package/{.agent-src → dist/agent-src}/skills/docker/SKILL.md +0 -0
  1718. /package/{.agent-src → dist/agent-src}/skills/editorial-calendar/SKILL.md +0 -0
  1719. /package/{.agent-src → dist/agent-src}/skills/eloquent/SKILL.md +0 -0
  1720. /package/{.agent-src → dist/agent-src}/skills/eloquent/evals/triggers.json +0 -0
  1721. /package/{.agent-src → dist/agent-src}/skills/error-handling-patterns/SKILL.md +0 -0
  1722. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/SKILL.md +0 -0
  1723. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/output-schema.yml +0 -0
  1724. /package/{.agent-src → dist/agent-src}/skills/estimate-ticket/evals/triggers.json +0 -0
  1725. /package/{.agent-src → dist/agent-src}/skills/expansion-playbook/SKILL.md +0 -0
  1726. /package/{.agent-src → dist/agent-src}/skills/file-editor/SKILL.md +0 -0
  1727. /package/{.agent-src → dist/agent-src}/skills/finishing-a-development-branch/SKILL.md +0 -0
  1728. /package/{.agent-src → dist/agent-src}/skills/forecast-accuracy/SKILL.md +0 -0
  1729. /package/{.agent-src → dist/agent-src}/skills/forecasting/SKILL.md +0 -0
  1730. /package/{.agent-src → dist/agent-src}/skills/form-handler/SKILL.md +0 -0
  1731. /package/{.agent-src → dist/agent-src}/skills/fundraising-narrative/SKILL.md +0 -0
  1732. /package/{.agent-src → dist/agent-src}/skills/funnel-analysis/SKILL.md +0 -0
  1733. /package/{.agent-src → dist/agent-src}/skills/git-workflow/SKILL.md +0 -0
  1734. /package/{.agent-src → dist/agent-src}/skills/github-ci/SKILL.md +0 -0
  1735. /package/{.agent-src → dist/agent-src}/skills/grafana/SKILL.md +0 -0
  1736. /package/{.agent-src → dist/agent-src}/skills/gtm-launch/SKILL.md +0 -0
  1737. /package/{.agent-src → dist/agent-src}/skills/guideline-writing/SKILL.md +0 -0
  1738. /package/{.agent-src → dist/agent-src}/skills/hiring-loop-design/SKILL.md +0 -0
  1739. /package/{.agent-src → dist/agent-src}/skills/image-analyser/SKILL.md +0 -0
  1740. /package/{.agent-src → dist/agent-src}/skills/image-analyser/canon-spec.md +0 -0
  1741. /package/{.agent-src → dist/agent-src}/skills/image-analyser/evals/triggers.json +0 -0
  1742. /package/{.agent-src → dist/agent-src}/skills/image-creator/SKILL.md +0 -0
  1743. /package/{.agent-src → dist/agent-src}/skills/image-creator/evals/triggers.json +0 -0
  1744. /package/{.agent-src → dist/agent-src}/skills/incident-commander/SKILL.md +0 -0
  1745. /package/{.agent-src → dist/agent-src}/skills/jobs-events/SKILL.md +0 -0
  1746. /package/{.agent-src → dist/agent-src}/skills/judge-bug-hunter/SKILL.md +0 -0
  1747. /package/{.agent-src → dist/agent-src}/skills/judge-code-quality/SKILL.md +0 -0
  1748. /package/{.agent-src → dist/agent-src}/skills/judge-security-auditor/SKILL.md +0 -0
  1749. /package/{.agent-src → dist/agent-src}/skills/judge-test-coverage/SKILL.md +0 -0
  1750. /package/{.agent-src → dist/agent-src}/skills/laravel/SKILL.md +0 -0
  1751. /package/{.agent-src → dist/agent-src}/skills/laravel-api-endpoint/SKILL.md +0 -0
  1752. /package/{.agent-src → dist/agent-src}/skills/laravel-dto/SKILL.md +0 -0
  1753. /package/{.agent-src → dist/agent-src}/skills/laravel-horizon/SKILL.md +0 -0
  1754. /package/{.agent-src → dist/agent-src}/skills/laravel-mail/SKILL.md +0 -0
  1755. /package/{.agent-src → dist/agent-src}/skills/laravel-middleware/SKILL.md +0 -0
  1756. /package/{.agent-src → dist/agent-src}/skills/laravel-migration/SKILL.md +0 -0
  1757. /package/{.agent-src → dist/agent-src}/skills/laravel-notifications/SKILL.md +0 -0
  1758. /package/{.agent-src → dist/agent-src}/skills/laravel-pennant/SKILL.md +0 -0
  1759. /package/{.agent-src → dist/agent-src}/skills/laravel-pulse/SKILL.md +0 -0
  1760. /package/{.agent-src → dist/agent-src}/skills/laravel-reverb/SKILL.md +0 -0
  1761. /package/{.agent-src → dist/agent-src}/skills/laravel-scheduling/SKILL.md +0 -0
  1762. /package/{.agent-src → dist/agent-src}/skills/laravel-validation/SKILL.md +0 -0
  1763. /package/{.agent-src → dist/agent-src}/skills/laravel-websocket/SKILL.md +0 -0
  1764. /package/{.agent-src → dist/agent-src}/skills/launch-readiness/SKILL.md +0 -0
  1765. /package/{.agent-src → dist/agent-src}/skills/learning-to-rule-or-skill/SKILL.md +0 -0
  1766. /package/{.agent-src → dist/agent-src}/skills/livewire-architect/SKILL.md +0 -0
  1767. /package/{.agent-src → dist/agent-src}/skills/logging-monitoring/SKILL.md +0 -0
  1768. /package/{.agent-src → dist/agent-src}/skills/market-entry-analysis/SKILL.md +0 -0
  1769. /package/{.agent-src → dist/agent-src}/skills/markitdown/SKILL.md +0 -0
  1770. /package/{.agent-src → dist/agent-src}/skills/mcp/SKILL.md +0 -0
  1771. /package/{.agent-src → dist/agent-src}/skills/mcp-builder/SKILL.md +0 -0
  1772. /package/{.agent-src → dist/agent-src}/skills/memory-consolidation/SKILL.md +0 -0
  1773. /package/{.agent-src → dist/agent-src}/skills/messaging-architecture/SKILL.md +0 -0
  1774. /package/{.agent-src → dist/agent-src}/skills/migration-architect/SKILL.md +0 -0
  1775. /package/{.agent-src → dist/agent-src}/skills/mobile-e2e-strategy/SKILL.md +0 -0
  1776. /package/{.agent-src → dist/agent-src}/skills/module-detect-on-the-fly/SKILL.md +0 -0
  1777. /package/{.agent-src → dist/agent-src}/skills/module-management/SKILL.md +0 -0
  1778. /package/{.agent-src → dist/agent-src}/skills/multi-tenancy/SKILL.md +0 -0
  1779. /package/{.agent-src → dist/agent-src}/skills/nextjs-patterns/SKILL.md +0 -0
  1780. /package/{.agent-src → dist/agent-src}/skills/okr-tree-modeling/SKILL.md +0 -0
  1781. /package/{.agent-src → dist/agent-src}/skills/onboarding-design/SKILL.md +0 -0
  1782. /package/{.agent-src → dist/agent-src}/skills/onboarding-program/SKILL.md +0 -0
  1783. /package/{.agent-src → dist/agent-src}/skills/one-on-one-cadence/SKILL.md +0 -0
  1784. /package/{.agent-src → dist/agent-src}/skills/openapi/SKILL.md +0 -0
  1785. /package/{.agent-src → dist/agent-src}/skills/org-design/SKILL.md +0 -0
  1786. /package/{.agent-src → dist/agent-src}/skills/override-management/SKILL.md +0 -0
  1787. /package/{.agent-src → dist/agent-src}/skills/perf-feedback-craft/SKILL.md +0 -0
  1788. /package/{.agent-src → dist/agent-src}/skills/performance/SKILL.md +0 -0
  1789. /package/{.agent-src → dist/agent-src}/skills/performance-analysis/SKILL.md +0 -0
  1790. /package/{.agent-src → dist/agent-src}/skills/pest-testing/SKILL.md +0 -0
  1791. /package/{.agent-src → dist/agent-src}/skills/php-coder/SKILL.md +0 -0
  1792. /package/{.agent-src → dist/agent-src}/skills/php-coder/evals/triggers.json +0 -0
  1793. /package/{.agent-src → dist/agent-src}/skills/php-debugging/SKILL.md +0 -0
  1794. /package/{.agent-src → dist/agent-src}/skills/php-service/SKILL.md +0 -0
  1795. /package/{.agent-src → dist/agent-src}/skills/pipeline-strategy/SKILL.md +0 -0
  1796. /package/{.agent-src → dist/agent-src}/skills/pixar-storyteller/SKILL.md +0 -0
  1797. /package/{.agent-src → dist/agent-src}/skills/playwright-architect/SKILL.md +0 -0
  1798. /package/{.agent-src → dist/agent-src}/skills/playwright-testing/SKILL.md +0 -0
  1799. /package/{.agent-src → dist/agent-src}/skills/po-discovery/SKILL.md +0 -0
  1800. /package/{.agent-src → dist/agent-src}/skills/positioning-strategy/SKILL.md +0 -0
  1801. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/SKILL.md +0 -0
  1802. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/evals/triggers.json +0 -0
  1803. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/ev-fixtures.md +0 -0
  1804. /package/{.agent-src → dist/agent-src}/skills/prediction-pool-optimizer/reference/odds-and-bonus.md +0 -0
  1805. /package/{.agent-src → dist/agent-src}/skills/privacy-review/SKILL.md +0 -0
  1806. /package/{.agent-src → dist/agent-src}/skills/project-analysis-core/SKILL.md +0 -0
  1807. /package/{.agent-src → dist/agent-src}/skills/project-analysis-hypothesis-driven/SKILL.md +0 -0
  1808. /package/{.agent-src → dist/agent-src}/skills/project-analysis-laravel/SKILL.md +0 -0
  1809. /package/{.agent-src → dist/agent-src}/skills/project-analysis-nextjs/SKILL.md +0 -0
  1810. /package/{.agent-src → dist/agent-src}/skills/project-analysis-node-express/SKILL.md +0 -0
  1811. /package/{.agent-src → dist/agent-src}/skills/project-analysis-react/SKILL.md +0 -0
  1812. /package/{.agent-src → dist/agent-src}/skills/project-analysis-symfony/SKILL.md +0 -0
  1813. /package/{.agent-src → dist/agent-src}/skills/project-analysis-zend-laminas/SKILL.md +0 -0
  1814. /package/{.agent-src → dist/agent-src}/skills/project-analyzer/SKILL.md +0 -0
  1815. /package/{.agent-src → dist/agent-src}/skills/project-docs/SKILL.md +0 -0
  1816. /package/{.agent-src → dist/agent-src}/skills/prompt-engineering-patterns/SKILL.md +0 -0
  1817. /package/{.agent-src → dist/agent-src}/skills/prompt-optimizer/SKILL.md +0 -0
  1818. /package/{.agent-src → dist/agent-src}/skills/quality-tools/SKILL.md +0 -0
  1819. /package/{.agent-src → dist/agent-src}/skills/react-native-setup/SKILL.md +0 -0
  1820. /package/{.agent-src → dist/agent-src}/skills/receiving-code-review/SKILL.md +0 -0
  1821. /package/{.agent-src → dist/agent-src}/skills/refine-prompt/SKILL.md +0 -0
  1822. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/SKILL.md +0 -0
  1823. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/detection-map.yml +0 -0
  1824. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/output-schema.yml +0 -0
  1825. /package/{.agent-src → dist/agent-src}/skills/refine-ticket/evals/triggers.json +0 -0
  1826. /package/{.agent-src → dist/agent-src}/skills/release-comms/SKILL.md +0 -0
  1827. /package/{.agent-src → dist/agent-src}/skills/repomix-packer/SKILL.md +0 -0
  1828. /package/{.agent-src → dist/agent-src}/skills/requesting-code-review/SKILL.md +0 -0
  1829. /package/{.agent-src → dist/agent-src}/skills/retention-loops/SKILL.md +0 -0
  1830. /package/{.agent-src → dist/agent-src}/skills/review-routing/SKILL.md +0 -0
  1831. /package/{.agent-src → dist/agent-src}/skills/rice-prioritization/SKILL.md +0 -0
  1832. /package/{.agent-src → dist/agent-src}/skills/risk-officer/SKILL.md +0 -0
  1833. /package/{.agent-src → dist/agent-src}/skills/roadmap-writing/SKILL.md +0 -0
  1834. /package/{.agent-src → dist/agent-src}/skills/rtk-output-filtering/SKILL.md +0 -0
  1835. /package/{.agent-src → dist/agent-src}/skills/runway-cognition/SKILL.md +0 -0
  1836. /package/{.agent-src → dist/agent-src}/skills/scenario-modeling/SKILL.md +0 -0
  1837. /package/{.agent-src → dist/agent-src}/skills/secrets-management/SKILL.md +0 -0
  1838. /package/{.agent-src → dist/agent-src}/skills/security/SKILL.md +0 -0
  1839. /package/{.agent-src → dist/agent-src}/skills/security-audit/SKILL.md +0 -0
  1840. /package/{.agent-src → dist/agent-src}/skills/sequential-thinking/SKILL.md +0 -0
  1841. /package/{.agent-src → dist/agent-src}/skills/skill-improvement-pipeline/SKILL.md +0 -0
  1842. /package/{.agent-src → dist/agent-src}/skills/skill-management/SKILL.md +0 -0
  1843. /package/{.agent-src → dist/agent-src}/skills/skill-reviewer/SKILL.md +0 -0
  1844. /package/{.agent-src → dist/agent-src}/skills/skill-writing/SKILL.md +0 -0
  1845. /package/{.agent-src → dist/agent-src}/skills/skill-writing/evals/triggers.json +0 -0
  1846. /package/{.agent-src → dist/agent-src}/skills/stakeholder-tradeoff/SKILL.md +0 -0
  1847. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/SKILL.md +0 -0
  1848. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/README.md +0 -0
  1849. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge-two-stage.md +0 -0
  1850. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-and-judge.md +0 -0
  1851. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-competitively.md +0 -0
  1852. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-parallel.md +0 -0
  1853. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-steps.md +0 -0
  1854. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/do-in-worktrees.md +0 -0
  1855. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/prompts/judge-with-debate.md +0 -0
  1856. /package/{.agent-src → dist/agent-src}/skills/subagent-orchestration/schemas/subagent-status.json +0 -0
  1857. /package/{.agent-src → dist/agent-src}/skills/symfony-workflow/SKILL.md +0 -0
  1858. /package/{.agent-src → dist/agent-src}/skills/systematic-debugging/SKILL.md +0 -0
  1859. /package/{.agent-src → dist/agent-src}/skills/tech-debt-tracker/SKILL.md +0 -0
  1860. /package/{.agent-src → dist/agent-src}/skills/terraform/SKILL.md +0 -0
  1861. /package/{.agent-src → dist/agent-src}/skills/terragrunt/SKILL.md +0 -0
  1862. /package/{.agent-src → dist/agent-src}/skills/test-driven-development/SKILL.md +0 -0
  1863. /package/{.agent-src → dist/agent-src}/skills/test-performance/SKILL.md +0 -0
  1864. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/SKILL.md +0 -0
  1865. /package/{.agent-src → dist/agent-src}/skills/testing-anti-patterns/process-anti-patterns.md +0 -0
  1866. /package/{.agent-src → dist/agent-src}/skills/throughput-vs-morale-tradeoff/SKILL.md +0 -0
  1867. /package/{.agent-src → dist/agent-src}/skills/token-optimizer/SKILL.md +0 -0
  1868. /package/{.agent-src → dist/agent-src}/skills/traefik/SKILL.md +0 -0
  1869. /package/{.agent-src → dist/agent-src}/skills/ui-component-architect/SKILL.md +0 -0
  1870. /package/{.agent-src → dist/agent-src}/skills/unit-economics-modeling/SKILL.md +0 -0
  1871. /package/{.agent-src → dist/agent-src}/skills/universal-project-analysis/SKILL.md +0 -0
  1872. /package/{.agent-src → dist/agent-src}/skills/using-git-worktrees/SKILL.md +0 -0
  1873. /package/{.agent-src → dist/agent-src}/skills/validate-feature-fit/SKILL.md +0 -0
  1874. /package/{.agent-src → dist/agent-src}/skills/verify-completion-evidence/SKILL.md +0 -0
  1875. /package/{.agent-src → dist/agent-src}/skills/video-director/SKILL.md +0 -0
  1876. /package/{.agent-src → dist/agent-src}/skills/vision-articulation/SKILL.md +0 -0
  1877. /package/{.agent-src → dist/agent-src}/skills/voc-extract/SKILL.md +0 -0
  1878. /package/{.agent-src → dist/agent-src}/skills/voice-and-tone-design/SKILL.md +0 -0
  1879. /package/{.agent-src → dist/agent-src}/templates/agent-settings.md +0 -0
  1880. /package/{.agent-src → dist/agent-src}/templates/agents/.gitattributes.fragment +0 -0
  1881. /package/{.agent-src → dist/agent-src}/templates/agents/memory/architecture-decisions.example.yml +0 -0
  1882. /package/{.agent-src → dist/agent-src}/templates/agents/memory/domain-invariants.example.yml +0 -0
  1883. /package/{.agent-src → dist/agent-src}/templates/agents/memory/historical-patterns.example.yml +0 -0
  1884. /package/{.agent-src → dist/agent-src}/templates/agents/memory/incident-learnings.example.yml +0 -0
  1885. /package/{.agent-src → dist/agent-src}/templates/agents/memory/ownership.example.yml +0 -0
  1886. /package/{.agent-src → dist/agent-src}/templates/agents/memory/product-rules.example.yml +0 -0
  1887. /package/{.agent-src → dist/agent-src}/templates/contexts/auth-model.md +0 -0
  1888. /package/{.agent-src → dist/agent-src}/templates/contexts/data-sensitivity.md +0 -0
  1889. /package/{.agent-src → dist/agent-src}/templates/contexts/deployment-order.md +0 -0
  1890. /package/{.agent-src → dist/agent-src}/templates/contexts/observability.md +0 -0
  1891. /package/{.agent-src → dist/agent-src}/templates/contexts/tenant-boundaries.md +0 -0
  1892. /package/{.agent-src → dist/agent-src}/templates/contexts.md +0 -0
  1893. /package/{.agent-src → dist/agent-src}/templates/features.md +0 -0
  1894. /package/{.agent-src → dist/agent-src}/templates/github-workflows/memory-hygiene.yml +0 -0
  1895. /package/{.agent-src → dist/agent-src}/templates/github-workflows/pr-risk-review.yml +0 -0
  1896. /package/{.agent-src → dist/agent-src}/templates/github-workflows/roadmap-progress-check.yml +0 -0
  1897. /package/{.agent-src → dist/agent-src}/templates/overrides/command.md +0 -0
  1898. /package/{.agent-src → dist/agent-src}/templates/overrides/guideline.md +0 -0
  1899. /package/{.agent-src → dist/agent-src}/templates/overrides/rule.md +0 -0
  1900. /package/{.agent-src → dist/agent-src}/templates/overrides/skill.md +0 -0
  1901. /package/{.agent-src → dist/agent-src}/templates/overrides/template.md +0 -0
  1902. /package/{.agent-src → dist/agent-src}/templates/roadmaps.md +0 -0
  1903. /package/{.agent-src → dist/agent-src}/templates/scripts/README.md +0 -0
  1904. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory.py +0 -0
  1905. /package/{.agent-src → dist/agent-src}/templates/scripts/check_memory_proposal.py +0 -0
  1906. /package/{.agent-src → dist/agent-src}/templates/scripts/historical-bug-patterns.example.yml +0 -0
  1907. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__init__.py +0 -0
  1908. /package/{.agent-src → dist/agent-src}/templates/scripts/implement_ticket/__main__.py +0 -0
  1909. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_hash.py +0 -0
  1910. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_lookup.py +0 -0
  1911. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_report.py +0 -0
  1912. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_signal.py +0 -0
  1913. /package/{.agent-src → dist/agent-src}/templates/scripts/memory_status.py +0 -0
  1914. /package/{.agent-src → dist/agent-src}/templates/scripts/ownership-map.example.yml +0 -0
  1915. /package/{.agent-src → dist/agent-src}/templates/scripts/pr-risk-config.example.yml +0 -0
  1916. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_review_routing.py +0 -0
  1917. /package/{.agent-src → dist/agent-src}/templates/scripts/pr_risk_review.py +0 -0
  1918. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/__init__.py +0 -0
  1919. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/aggregator.py +0 -0
  1920. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/boundary.py +0 -0
  1921. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/engagement.py +0 -0
  1922. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/report_renderer.py +0 -0
  1923. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry/settings.py +0 -0
  1924. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_record.py +0 -0
  1925. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_report.py +0 -0
  1926. /package/{.agent-src → dist/agent-src}/templates/scripts/telemetry_status.py +0 -0
  1927. /package/{.agent-src → dist/agent-src}/templates/scripts/tier_usage_report.py +0 -0
  1928. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__init__.py +0 -0
  1929. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/__main__.py +0 -0
  1930. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/__init__.py +0 -0
  1931. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/agent_settings.py +0 -0
  1932. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/_lib/user_global_paths.py +0 -0
  1933. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli.py +0 -0
  1934. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/cli_args.py +0 -0
  1935. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/delivery_state.py +0 -0
  1936. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/__init__.py +0 -0
  1937. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/__init__.py +0 -0
  1938. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/analyze.py +0 -0
  1939. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/implement.py +0 -0
  1940. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/memory.py +0 -0
  1941. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/plan.py +0 -0
  1942. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/refine.py +0 -0
  1943. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/report.py +0 -0
  1944. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/test.py +0 -0
  1945. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/backend/verify.py +0 -0
  1946. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/__init__.py +0 -0
  1947. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/contract.py +0 -0
  1948. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/stitch.py +0 -0
  1949. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/mixed/ui.py +0 -0
  1950. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/__init__.py +0 -0
  1951. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/_passthrough.py +0 -0
  1952. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/apply.py +0 -0
  1953. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/audit.py +0 -0
  1954. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui/design.py +0 -0
  1955. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/__init__.py +0 -0
  1956. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/_skipped.py +0 -0
  1957. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/apply.py +0 -0
  1958. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/refine.py +0 -0
  1959. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/report.py +0 -0
  1960. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/directives/ui_trivial/test.py +0 -0
  1961. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/dispatcher.py +0 -0
  1962. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/emitters.py +0 -0
  1963. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/errors.py +0 -0
  1964. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hook_bootstrap.py +0 -0
  1965. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/__init__.py +0 -0
  1966. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/__init__.py +0 -0
  1967. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/_chat_history_base.py +0 -0
  1968. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_append.py +0 -0
  1969. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/chat_history_halt_append.py +0 -0
  1970. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_gate.py +0 -0
  1971. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/decision_trace.py +0 -0
  1972. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/directive_set_guard.py +0 -0
  1973. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/halt_surface_audit.py +0 -0
  1974. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/memory_visibility.py +0 -0
  1975. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/state_shape_validation.py +0 -0
  1976. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/builtin/trace.py +0 -0
  1977. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/context.py +0 -0
  1978. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/events.py +0 -0
  1979. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/exceptions.py +0 -0
  1980. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/registry.py +0 -0
  1981. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/runner.py +0 -0
  1982. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/hooks/settings.py +0 -0
  1983. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/input_builders.py +0 -0
  1984. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/__init__.py +0 -0
  1985. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/intent/classify.py +0 -0
  1986. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/__init__.py +0 -0
  1987. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/migration/v0_to_v1.py +0 -0
  1988. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/persona_policy.py +0 -0
  1989. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/__init__.py +0 -0
  1990. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/diff.py +0 -0
  1991. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/file.py +0 -0
  1992. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/resolvers/prompt.py +0 -0
  1993. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/__init__.py +0 -0
  1994. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/confidence.py +0 -0
  1995. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_engine.py +0 -0
  1996. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/decision_trace.py +0 -0
  1997. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/scoring/memory_visibility.py +0 -0
  1998. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/__init__.py +0 -0
  1999. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/stack/detect.py +0 -0
  2000. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state.py +0 -0
  2001. /package/{.agent-src → dist/agent-src}/templates/scripts/work_engine/state_io.py +0 -0
  2002. /package/{.agent-src → dist/agent-src}/templates/skill-archive-note.md +0 -0
  2003. /package/{.agent-src → dist/agent-src}/templates/skill.md +0 -0
  2004. /package/{.agent-src → dist/agent-src}/user-types/_template/user-type.md +0 -0
  2005. /package/{.agent-src → dist/agent-src}/user-types/galabau-field-crew.md +0 -0
  2006. /package/{.agent-src → dist/agent-src}/user-types/metalworking-shop.md +0 -0
  2007. /package/{.agent-src → dist/agent-src}/user-types/truck-driver.md +0 -0
  2008. /package/{config → src/config}/discovery/session-profiles.yml +0 -0
  2009. /package/{config → src/config}/discovery/unassigned-artefacts.yml +0 -0
  2010. /package/{config → src/config}/gitignore-block.txt +0 -0
  2011. /package/{config → src/config}/profiles/balanced.ini +0 -0
  2012. /package/{config → src/config}/profiles/full.ini +0 -0
  2013. /package/{config → src/config}/profiles/minimal.ini +0 -0
  2014. /package/{scripts → src/scripts}/_archive/_backfill_skill_domains.py +0 -0
  2015. /package/{scripts → src/scripts}/_archive/_phase2_shim_helper.py +0 -0
  2016. /package/{scripts → src/scripts}/_archive/_pilot_council_question.py +0 -0
  2017. /package/{scripts → src/scripts}/_cli/__init__.py +0 -0
  2018. /package/{scripts → src/scripts}/_cli/cmd_explain.py +0 -0
  2019. /package/{scripts → src/scripts}/_cli/cmd_prune.py +0 -0
  2020. /package/{scripts → src/scripts}/_cli/cmd_settings_check.py +0 -0
  2021. /package/{scripts → src/scripts}/_cli/cmd_sync.py +0 -0
  2022. /package/{scripts → src/scripts}/_cli/cmd_uninstall.py +0 -0
  2023. /package/{scripts → src/scripts}/_cli/cmd_validate.py +0 -0
  2024. /package/{scripts → src/scripts}/_cli/explain_last/__init__.py +0 -0
  2025. /package/{scripts → src/scripts}/_cli/explain_last/assumptions.py +0 -0
  2026. /package/{scripts → src/scripts}/_cli/explain_last/council.py +0 -0
  2027. /package/{scripts → src/scripts}/_cli/explain_last/halt.py +0 -0
  2028. /package/{scripts → src/scripts}/_cli/explain_last/inputs.py +0 -0
  2029. /package/{scripts → src/scripts}/_cli/explain_last/memory.py +0 -0
  2030. /package/{scripts → src/scripts}/_cli/explain_last/provider.py +0 -0
  2031. /package/{scripts → src/scripts}/_cli/explain_last/render.py +0 -0
  2032. /package/{scripts → src/scripts}/_cli/explain_last/route.py +0 -0
  2033. /package/{scripts → src/scripts}/_cli/explain_last/scrubber.py +0 -0
  2034. /package/{scripts → src/scripts}/_cli/explain_last/sections/__init__.py +0 -0
  2035. /package/{scripts → src/scripts}/_cli/explain_last/sections/assumptions.py +0 -0
  2036. /package/{scripts → src/scripts}/_cli/explain_last/sections/council.py +0 -0
  2037. /package/{scripts → src/scripts}/_cli/explain_last/sections/halt.py +0 -0
  2038. /package/{scripts → src/scripts}/_cli/explain_last/sections/header.py +0 -0
  2039. /package/{scripts → src/scripts}/_cli/explain_last/sections/inputs.py +0 -0
  2040. /package/{scripts → src/scripts}/_cli/explain_last/sections/memory.py +0 -0
  2041. /package/{scripts → src/scripts}/_cli/explain_last/sections/pack.py +0 -0
  2042. /package/{scripts → src/scripts}/_cli/explain_last/sections/provider.py +0 -0
  2043. /package/{scripts → src/scripts}/_cli/explain_last/sections/route.py +0 -0
  2044. /package/{scripts → src/scripts}/_cli/explain_last/state_loader.py +0 -0
  2045. /package/{scripts → src/scripts}/_emit_domain_table.py +0 -0
  2046. /package/{scripts → src/scripts}/_lib/__init__.py +0 -0
  2047. /package/{scripts → src/scripts}/_lib/agent_settings.py +0 -0
  2048. /package/{scripts → src/scripts}/_lib/agents_overlay.py +0 -0
  2049. /package/{scripts → src/scripts}/_lib/bench_ab_scoring.py +0 -0
  2050. /package/{scripts → src/scripts}/_lib/bench_cost.py +0 -0
  2051. /package/{scripts → src/scripts}/_lib/bench_quality.py +0 -0
  2052. /package/{scripts → src/scripts}/_lib/bench_report.py +0 -0
  2053. /package/{scripts → src/scripts}/_lib/bench_telegraph.py +0 -0
  2054. /package/{scripts → src/scripts}/_lib/bench_telegraph_report.py +0 -0
  2055. /package/{scripts → src/scripts}/_lib/fs_atomic.py +0 -0
  2056. /package/{scripts → src/scripts}/_lib/installed_tools.py +0 -0
  2057. /package/{scripts → src/scripts}/_lib/json_pointers.py +0 -0
  2058. /package/{scripts → src/scripts}/_lib/linked_projects.py +0 -0
  2059. /package/{scripts → src/scripts}/_lib/module_detection.py +0 -0
  2060. /package/{scripts → src/scripts}/_lib/pin_resolver.py +0 -0
  2061. /package/{scripts → src/scripts}/_lib/script_output.py +0 -0
  2062. /package/{scripts → src/scripts}/_lib/token_count.py +0 -0
  2063. /package/{scripts → src/scripts}/_lib/update_check.py +0 -0
  2064. /package/{scripts → src/scripts}/_lib/user_global_paths.py +0 -0
  2065. /package/{scripts → src/scripts}/_tmp_scan_framework_leakage.py +0 -0
  2066. /package/{scripts → src/scripts}/adr/regenerate_index.py +0 -0
  2067. /package/{scripts/ai-video/lib/fixtures/kling → src/scripts/ai-video/lib/fixtures/comfyui}/scene-0001.mp4 +0 -0
  2068. /package/{scripts → src/scripts}/ai-video/lib/fixtures/gemini-veo/scene-0001.mp4 +0 -0
  2069. /package/{scripts → src/scripts}/ai-video/lib/fixtures/higgsfield/scene-0001.mp4 +0 -0
  2070. /package/{scripts → src/scripts}/ai-video/lib/fixtures/openai-images/scene-0001.png +0 -0
  2071. /package/{scripts → src/scripts}/ai-video/lib/fixtures/sora/scene-0001.mp4 +0 -0
  2072. /package/{scripts → src/scripts}/ai-video/lib/operator-pick.sh +0 -0
  2073. /package/{scripts → src/scripts}/ai-video/lib/parse-blueprint.sh +0 -0
  2074. /package/{scripts → src/scripts}/ai-video/lib/probe-audio.sh +0 -0
  2075. /package/{scripts → src/scripts}/ai-video/lib/redact.sh +0 -0
  2076. /package/{scripts → src/scripts}/ai_council/__init__.py +0 -0
  2077. /package/{scripts → src/scripts}/ai_council/_default_prices.py +0 -0
  2078. /package/{scripts → src/scripts}/ai_council/airgap.py +0 -0
  2079. /package/{scripts → src/scripts}/ai_council/budget_guard.py +0 -0
  2080. /package/{scripts → src/scripts}/ai_council/bundler.py +0 -0
  2081. /package/{scripts → src/scripts}/ai_council/cli_hints.py +0 -0
  2082. /package/{scripts → src/scripts}/ai_council/confidence_gate.py +0 -0
  2083. /package/{scripts → src/scripts}/ai_council/config.py +0 -0
  2084. /package/{scripts → src/scripts}/ai_council/consensus.py +0 -0
  2085. /package/{scripts → src/scripts}/ai_council/learn_low_impact_preview.py +0 -0
  2086. /package/{scripts → src/scripts}/ai_council/low_impact.py +0 -0
  2087. /package/{scripts → src/scripts}/ai_council/low_impact_corpus.py +0 -0
  2088. /package/{scripts → src/scripts}/ai_council/low_impact_intake.py +0 -0
  2089. /package/{scripts → src/scripts}/ai_council/modes.py +0 -0
  2090. /package/{scripts → src/scripts}/ai_council/necessity.py +0 -0
  2091. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/README.md +0 -0
  2092. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_add_quiet.py +0 -0
  2093. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_inject_quiet_flag.py +0 -0
  2094. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_v2.sh +0 -0
  2095. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_measure_verbosity.sh +0 -0
  2096. /package/{scripts → src/scripts}/ai_council/one_off_archive/2026-05/_one_off_per_task.sh +0 -0
  2097. /package/{scripts → src/scripts}/ai_council/orchestrator.py +0 -0
  2098. /package/{scripts → src/scripts}/ai_council/probation_gate.py +0 -0
  2099. /package/{scripts → src/scripts}/ai_council/project_context.py +0 -0
  2100. /package/{scripts → src/scripts}/ai_council/prompts.py +0 -0
  2101. /package/{scripts → src/scripts}/ai_council/redact_low_impact_entry.py +0 -0
  2102. /package/{scripts → src/scripts}/ai_council/replay.py +0 -0
  2103. /package/{scripts → src/scripts}/ai_council/shadow_dispatch.py +0 -0
  2104. /package/{scripts → src/scripts}/ai_council/solo_dispatch.py +0 -0
  2105. /package/{scripts → src/scripts}/audit_skill_descriptions.py +0 -0
  2106. /package/{scripts → src/scripts}/bootstrap.sh +0 -0
  2107. /package/{scripts → src/scripts}/chat_history.py +0 -0
  2108. /package/{scripts → src/scripts}/check_bite_sized_granularity.py +0 -0
  2109. /package/{scripts → src/scripts}/check_council_layout.py +0 -0
  2110. /package/{scripts → src/scripts}/check_iron_law_prominence.py +0 -0
  2111. /package/{scripts → src/scripts}/check_kernel_rule_bundle.py +0 -0
  2112. /package/{scripts → src/scripts}/check_md_language.py +0 -0
  2113. /package/{scripts → src/scripts}/check_memory.py +0 -0
  2114. /package/{scripts → src/scripts}/check_memory_proposal.py +0 -0
  2115. /package/{scripts → src/scripts}/check_no_local_settings_committed.py +0 -0
  2116. /package/{scripts → src/scripts}/check_proposal.py +0 -0
  2117. /package/{scripts → src/scripts}/check_release_trunk_sync.py +0 -0
  2118. /package/{scripts → src/scripts}/ci_status.py +0 -0
  2119. /package/{scripts → src/scripts}/ci_summary.py +0 -0
  2120. /package/{scripts → src/scripts}/cleanup_other_scope.sh +0 -0
  2121. /package/{scripts → src/scripts}/command_suggester/__init__.py +0 -0
  2122. /package/{scripts → src/scripts}/command_suggester/cooldown.py +0 -0
  2123. /package/{scripts → src/scripts}/command_suggester/loader.py +0 -0
  2124. /package/{scripts → src/scripts}/command_suggester/match.py +0 -0
  2125. /package/{scripts → src/scripts}/command_suggester/rank.py +0 -0
  2126. /package/{scripts → src/scripts}/command_suggester/render.py +0 -0
  2127. /package/{scripts → src/scripts}/command_suggester/sanitize.py +0 -0
  2128. /package/{scripts → src/scripts}/command_suggester/settings.py +0 -0
  2129. /package/{scripts → src/scripts}/command_suggester/types.py +0 -0
  2130. /package/{scripts → src/scripts}/condense.sh +0 -0
  2131. /package/{scripts → src/scripts}/config/__init__.py +0 -0
  2132. /package/{scripts → src/scripts}/config/presets.py +0 -0
  2133. /package/{scripts → src/scripts}/context_hygiene_hook.py +0 -0
  2134. /package/{scripts → src/scripts}/cost/budget.mjs +0 -0
  2135. /package/{scripts → src/scripts}/cost/preflight.mjs +0 -0
  2136. /package/{scripts → src/scripts}/cost/track.mjs +0 -0
  2137. /package/{scripts → src/scripts}/council_prune.py +0 -0
  2138. /package/{scripts → src/scripts}/count_token_optimizer_usage.sh +0 -0
  2139. /package/{scripts → src/scripts}/expected_perms.json +0 -0
  2140. /package/{scripts → src/scripts}/first-run.sh +0 -0
  2141. /package/{scripts → src/scripts}/ghostwriter_fixture_allowlist.txt +0 -0
  2142. /package/{scripts → src/scripts}/hermetic-install.sh +0 -0
  2143. /package/{scripts → src/scripts}/hooks/__init__.py +0 -0
  2144. /package/{scripts → src/scripts}/hooks/augment-chat-history.sh +0 -0
  2145. /package/{scripts → src/scripts}/hooks/augment-context-hygiene.sh +0 -0
  2146. /package/{scripts → src/scripts}/hooks/augment-dispatcher.sh +0 -0
  2147. /package/{scripts → src/scripts}/hooks/augment-onboarding-gate.sh +0 -0
  2148. /package/{scripts → src/scripts}/hooks/augment-roadmap-progress.sh +0 -0
  2149. /package/{scripts → src/scripts}/hooks/cline-dispatcher.sh +0 -0
  2150. /package/{scripts → src/scripts}/hooks/cowork-dispatcher.sh +0 -0
  2151. /package/{scripts → src/scripts}/hooks/cursor-dispatcher.sh +0 -0
  2152. /package/{scripts → src/scripts}/hooks/dispatch_issues.py +0 -0
  2153. /package/{scripts → src/scripts}/hooks/envelope.py +0 -0
  2154. /package/{scripts → src/scripts}/hooks/gemini-dispatcher.sh +0 -0
  2155. /package/{scripts → src/scripts}/hooks/state_io.py +0 -0
  2156. /package/{scripts → src/scripts}/hooks/windsurf-dispatcher.sh +0 -0
  2157. /package/{scripts → src/scripts}/install_anthropic_key.sh +0 -0
  2158. /package/{scripts → src/scripts}/install_openai_key.sh +0 -0
  2159. /package/{scripts → src/scripts}/lint_global_paths.py +0 -0
  2160. /package/{scripts → src/scripts}/lint_readme_jargon.py +0 -0
  2161. /package/{scripts → src/scripts}/lint_readme_size.py +0 -0
  2162. /package/{scripts → src/scripts}/mcp_render.py +0 -0
  2163. /package/{scripts → src/scripts}/mcp_server/__main__.py +0 -0
  2164. /package/{scripts → src/scripts}/mcp_server/catalog.py +0 -0
  2165. /package/{scripts → src/scripts}/mcp_server/metadata.py +0 -0
  2166. /package/{scripts → src/scripts}/mcp_server/requirements.txt +0 -0
  2167. /package/{scripts → src/scripts}/mcp_server/server.py +0 -0
  2168. /package/{scripts → src/scripts}/mcp_server/telemetry.py +0 -0
  2169. /package/{scripts → src/scripts}/mcp_setup.sh +0 -0
  2170. /package/{scripts → src/scripts}/mcp_telemetry_health.py +0 -0
  2171. /package/{scripts → src/scripts}/mcp_telemetry_query.py +0 -0
  2172. /package/{scripts → src/scripts}/mcp_telemetry_store.py +0 -0
  2173. /package/{scripts → src/scripts}/memory_hash.py +0 -0
  2174. /package/{scripts → src/scripts}/memory_lookup.py +0 -0
  2175. /package/{scripts → src/scripts}/memory_report.py +0 -0
  2176. /package/{scripts → src/scripts}/memory_signal.py +0 -0
  2177. /package/{scripts → src/scripts}/memory_status.py +0 -0
  2178. /package/{scripts → src/scripts}/minimal_safe_diff_hook.py +0 -0
  2179. /package/{scripts → src/scripts}/onboarding_gate_hook.py +0 -0
  2180. /package/{scripts → src/scripts}/prediction-pool/adapters/_schema.md +0 -0
  2181. /package/{scripts → src/scripts}/prediction-pool/adapters/kicktipp.yml +0 -0
  2182. /package/{scripts → src/scripts}/prediction-pool/poisson_sim.py +0 -0
  2183. /package/{scripts → src/scripts}/prediction-pool/pool_winsim.py +0 -0
  2184. /package/{scripts → src/scripts}/prediction-pool/score_ev.py +0 -0
  2185. /package/{scripts → src/scripts}/prepack-check.mjs +0 -0
  2186. /package/{scripts → src/scripts}/probe_skill_registration.py +0 -0
  2187. /package/{scripts → src/scripts}/propose_modules_config.py +0 -0
  2188. /package/{scripts → src/scripts}/readme_linter.py +0 -0
  2189. /package/{scripts → src/scripts}/redact_hook_capture.py +0 -0
  2190. /package/{scripts → src/scripts}/requirements-evals.txt +0 -0
  2191. /package/{scripts → src/scripts}/runtime_dispatcher.py +0 -0
  2192. /package/{scripts → src/scripts}/runtime_handler.py +0 -0
  2193. /package/{scripts → src/scripts}/schemas/agent-settings.schema.json +0 -0
  2194. /package/{scripts → src/scripts}/schemas/persona.schema.json +0 -0
  2195. /package/{scripts → src/scripts}/schemas/skill.schema.json +0 -0
  2196. /package/{scripts → src/scripts}/schemas/user-type-axis.schema.json +0 -0
  2197. /package/{scripts → src/scripts}/schemas/user-type.schema.json +0 -0
  2198. /package/{scripts → src/scripts}/setup_eval_venv.sh +0 -0
  2199. /package/{scripts → src/scripts}/skill_tools/__init__.py +0 -0
  2200. /package/{scripts → src/scripts}/sync_yaml_rt.py +0 -0
  2201. /package/{scripts → src/scripts}/tool_registry.py +0 -0
  2202. /package/{scripts → src/scripts}/tools/__init__.py +0 -0
  2203. /package/{scripts → src/scripts}/tools/adapter_errors.py +0 -0
  2204. /package/{scripts → src/scripts}/tools/base_adapter.py +0 -0
  2205. /package/{scripts → src/scripts}/tools/github_adapter.py +0 -0
  2206. /package/{scripts → src/scripts}/tools/jira_adapter.py +0 -0
  2207. /package/{scripts → src/scripts}/update-github-metadata.sh +0 -0
  2208. /package/{scripts → src/scripts}/validate_safe_paths.py +0 -0
  2209. /package/{scripts → src/scripts}/validate_telegraph_carveouts.py +0 -0
  2210. /package/{scripts → src/scripts}/verify_before_complete_hook.py +0 -0
  2211. /package/{templates → src/templates}/agent-config-wrapper.sh +0 -0
  2212. /package/{templates → src/templates}/agent-user.md +0 -0
  2213. /package/{templates → src/templates}/agent-user.yml +0 -0
  2214. /package/{templates → src/templates}/claude_desktop_config.json.template +0 -0
  2215. /package/{templates → src/templates}/consumer-settings/ONBOARDING.md +0 -0
  2216. /package/{templates → src/templates}/consumer-settings/README.md +0 -0
  2217. /package/{templates → src/templates}/consumer-settings/augment-cli-hooks.json +0 -0
  2218. /package/{templates → src/templates}/consumer-settings/augment-settings.json +0 -0
  2219. /package/{templates → src/templates}/consumer-settings/claude-settings.json +0 -0
  2220. /package/{templates → src/templates}/consumer-settings/copilot-settings.json +0 -0
  2221. /package/{templates → src/templates}/cursor-rule.mdc.j2 +0 -0
  2222. /package/{templates → src/templates}/marketing-copy.yml +0 -0
  2223. /package/{templates → src/templates}/minimal/.agent-settings.yml +0 -0
  2224. /package/{templates → src/templates}/minimal/agents-overrides-readme.md +0 -0
  2225. /package/{templates → src/templates}/minimal/overrides-gitkeep +0 -0
  2226. /package/{templates → src/templates}/windsurf-rule.md.j2 +0 -0
@@ -1,1385 +0,0 @@
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-", "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-", "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)