@dewtech/dare-cli 3.11.0 → 3.13.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 (316) hide show
  1. package/README.md +2 -0
  2. package/dist/__tests__/cli-only-invariants.test.d.ts +2 -0
  3. package/dist/__tests__/cli-only-invariants.test.d.ts.map +1 -0
  4. package/dist/__tests__/cli-only-invariants.test.js +100 -0
  5. package/dist/__tests__/cli-only-invariants.test.js.map +1 -0
  6. package/dist/__tests__/cli-only-regression.test.d.ts +2 -0
  7. package/dist/__tests__/cli-only-regression.test.d.ts.map +1 -0
  8. package/dist/__tests__/cli-only-regression.test.js +29 -0
  9. package/dist/__tests__/cli-only-regression.test.js.map +1 -0
  10. package/dist/__tests__/ensure-skills.test.js +5 -0
  11. package/dist/__tests__/ensure-skills.test.js.map +1 -1
  12. package/dist/__tests__/ide-command-parity.test.js +1 -0
  13. package/dist/__tests__/ide-command-parity.test.js.map +1 -1
  14. package/dist/__tests__/project-generator.test.js +17 -0
  15. package/dist/__tests__/project-generator.test.js.map +1 -1
  16. package/dist/__tests__/reverse-facts.test.js +1 -0
  17. package/dist/__tests__/reverse-facts.test.js.map +1 -1
  18. package/dist/__tests__/terminal-parity-regression.test.d.ts +2 -0
  19. package/dist/__tests__/terminal-parity-regression.test.d.ts.map +1 -0
  20. package/dist/__tests__/terminal-parity-regression.test.js +116 -0
  21. package/dist/__tests__/terminal-parity-regression.test.js.map +1 -0
  22. package/dist/__tests__/terminal-parity.test.d.ts +2 -0
  23. package/dist/__tests__/terminal-parity.test.d.ts.map +1 -0
  24. package/dist/__tests__/terminal-parity.test.js +81 -0
  25. package/dist/__tests__/terminal-parity.test.js.map +1 -0
  26. package/dist/agent/__tests__/antigravity-driver.test.d.ts +2 -0
  27. package/dist/agent/__tests__/antigravity-driver.test.d.ts.map +1 -0
  28. package/dist/agent/__tests__/antigravity-driver.test.js +52 -0
  29. package/dist/agent/__tests__/antigravity-driver.test.js.map +1 -0
  30. package/dist/agent/__tests__/codex-driver.test.d.ts +2 -0
  31. package/dist/agent/__tests__/codex-driver.test.d.ts.map +1 -0
  32. package/dist/agent/__tests__/codex-driver.test.js +68 -0
  33. package/dist/agent/__tests__/codex-driver.test.js.map +1 -0
  34. package/dist/agent/__tests__/cursor-driver.test.d.ts +2 -0
  35. package/dist/agent/__tests__/cursor-driver.test.d.ts.map +1 -0
  36. package/dist/agent/__tests__/cursor-driver.test.js +52 -0
  37. package/dist/agent/__tests__/cursor-driver.test.js.map +1 -0
  38. package/dist/agent/driver.d.ts +1 -1
  39. package/dist/agent/driver.d.ts.map +1 -1
  40. package/dist/agent/drivers/antigravity.d.ts +8 -0
  41. package/dist/agent/drivers/antigravity.d.ts.map +1 -0
  42. package/dist/agent/drivers/antigravity.js +99 -0
  43. package/dist/agent/drivers/antigravity.js.map +1 -0
  44. package/dist/agent/drivers/codex.d.ts +12 -0
  45. package/dist/agent/drivers/codex.d.ts.map +1 -0
  46. package/dist/agent/drivers/codex.js +137 -0
  47. package/dist/agent/drivers/codex.js.map +1 -0
  48. package/dist/agent/drivers/cursor.d.ts +8 -0
  49. package/dist/agent/drivers/cursor.d.ts.map +1 -0
  50. package/dist/agent/drivers/cursor.js +99 -0
  51. package/dist/agent/drivers/cursor.js.map +1 -0
  52. package/dist/ai/__tests__/ai-core.test.d.ts +2 -0
  53. package/dist/ai/__tests__/ai-core.test.d.ts.map +1 -0
  54. package/dist/ai/__tests__/ai-core.test.js +41 -0
  55. package/dist/ai/__tests__/ai-core.test.js.map +1 -0
  56. package/dist/ai/__tests__/parity.test.d.ts +2 -0
  57. package/dist/ai/__tests__/parity.test.d.ts.map +1 -0
  58. package/dist/ai/__tests__/parity.test.js +36 -0
  59. package/dist/ai/__tests__/parity.test.js.map +1 -0
  60. package/dist/ai/__tests__/pipeline.test.d.ts +2 -0
  61. package/dist/ai/__tests__/pipeline.test.d.ts.map +1 -0
  62. package/dist/ai/__tests__/pipeline.test.js +147 -0
  63. package/dist/ai/__tests__/pipeline.test.js.map +1 -0
  64. package/dist/ai/__tests__/refine-bridge.test.d.ts +2 -0
  65. package/dist/ai/__tests__/refine-bridge.test.d.ts.map +1 -0
  66. package/dist/ai/__tests__/refine-bridge.test.js +17 -0
  67. package/dist/ai/__tests__/refine-bridge.test.js.map +1 -0
  68. package/dist/ai/__tests__/resolve.test.d.ts +2 -0
  69. package/dist/ai/__tests__/resolve.test.d.ts.map +1 -0
  70. package/dist/ai/__tests__/resolve.test.js +42 -0
  71. package/dist/ai/__tests__/resolve.test.js.map +1 -0
  72. package/dist/ai/capabilities.d.ts +3 -0
  73. package/dist/ai/capabilities.d.ts.map +1 -0
  74. package/dist/ai/capabilities.js +11 -0
  75. package/dist/ai/capabilities.js.map +1 -0
  76. package/dist/ai/command-options.d.ts +10 -0
  77. package/dist/ai/command-options.d.ts.map +1 -0
  78. package/dist/ai/command-options.js +15 -0
  79. package/dist/ai/command-options.js.map +1 -0
  80. package/dist/ai/config.d.ts +27 -0
  81. package/dist/ai/config.d.ts.map +1 -0
  82. package/dist/ai/config.js +89 -0
  83. package/dist/ai/config.js.map +1 -0
  84. package/dist/ai/parity.d.ts +13 -0
  85. package/dist/ai/parity.d.ts.map +1 -0
  86. package/dist/ai/parity.js +87 -0
  87. package/dist/ai/parity.js.map +1 -0
  88. package/dist/ai/parse-json-output.d.ts +5 -0
  89. package/dist/ai/parse-json-output.d.ts.map +1 -0
  90. package/dist/ai/parse-json-output.js +25 -0
  91. package/dist/ai/parse-json-output.js.map +1 -0
  92. package/dist/ai/pipeline.d.ts +20 -0
  93. package/dist/ai/pipeline.d.ts.map +1 -0
  94. package/dist/ai/pipeline.js +303 -0
  95. package/dist/ai/pipeline.js.map +1 -0
  96. package/dist/ai/prompts.d.ts +6 -0
  97. package/dist/ai/prompts.d.ts.map +1 -0
  98. package/dist/ai/prompts.js +49 -0
  99. package/dist/ai/prompts.js.map +1 -0
  100. package/dist/ai/providers.d.ts +63 -0
  101. package/dist/ai/providers.d.ts.map +1 -0
  102. package/dist/ai/providers.js +297 -0
  103. package/dist/ai/providers.js.map +1 -0
  104. package/dist/ai/refine-bridge.d.ts +5 -0
  105. package/dist/ai/refine-bridge.d.ts.map +1 -0
  106. package/dist/ai/refine-bridge.js +14 -0
  107. package/dist/ai/refine-bridge.js.map +1 -0
  108. package/dist/ai/registry.d.ts +12 -0
  109. package/dist/ai/registry.d.ts.map +1 -0
  110. package/dist/ai/registry.js +43 -0
  111. package/dist/ai/registry.js.map +1 -0
  112. package/dist/ai/resolve.d.ts +28 -0
  113. package/dist/ai/resolve.d.ts.map +1 -0
  114. package/dist/ai/resolve.js +83 -0
  115. package/dist/ai/resolve.js.map +1 -0
  116. package/dist/ai/schemas.d.ts +175 -0
  117. package/dist/ai/schemas.d.ts.map +1 -0
  118. package/dist/ai/schemas.js +199 -0
  119. package/dist/ai/schemas.js.map +1 -0
  120. package/dist/ai/types.d.ts +52 -0
  121. package/dist/ai/types.d.ts.map +1 -0
  122. package/dist/ai/types.js +8 -0
  123. package/dist/ai/types.js.map +1 -0
  124. package/dist/bin/dare.js +2 -0
  125. package/dist/bin/dare.js.map +1 -1
  126. package/dist/commands/__tests__/ai-command.test.d.ts +2 -0
  127. package/dist/commands/__tests__/ai-command.test.d.ts.map +1 -0
  128. package/dist/commands/__tests__/ai-command.test.js +68 -0
  129. package/dist/commands/__tests__/ai-command.test.js.map +1 -0
  130. package/dist/commands/__tests__/execute-agent.test.js +82 -0
  131. package/dist/commands/__tests__/execute-agent.test.js.map +1 -1
  132. package/dist/commands/ai.d.ts +3 -0
  133. package/dist/commands/ai.d.ts.map +1 -0
  134. package/dist/commands/ai.js +141 -0
  135. package/dist/commands/ai.js.map +1 -0
  136. package/dist/commands/blueprint.d.ts.map +1 -1
  137. package/dist/commands/blueprint.js +17 -3
  138. package/dist/commands/blueprint.js.map +1 -1
  139. package/dist/commands/design.d.ts.map +1 -1
  140. package/dist/commands/design.js +21 -2
  141. package/dist/commands/design.js.map +1 -1
  142. package/dist/commands/discover.d.ts.map +1 -1
  143. package/dist/commands/discover.js +9 -1
  144. package/dist/commands/discover.js.map +1 -1
  145. package/dist/commands/dna.d.ts.map +1 -1
  146. package/dist/commands/dna.js +23 -3
  147. package/dist/commands/dna.js.map +1 -1
  148. package/dist/commands/execute.d.ts +11 -0
  149. package/dist/commands/execute.d.ts.map +1 -1
  150. package/dist/commands/execute.js +111 -4
  151. package/dist/commands/execute.js.map +1 -1
  152. package/dist/commands/init.d.ts.map +1 -1
  153. package/dist/commands/init.js +1 -0
  154. package/dist/commands/init.js.map +1 -1
  155. package/dist/commands/migrate.d.ts.map +1 -1
  156. package/dist/commands/migrate.js +14 -2
  157. package/dist/commands/migrate.js.map +1 -1
  158. package/dist/commands/patterns.d.ts.map +1 -1
  159. package/dist/commands/patterns.js +14 -2
  160. package/dist/commands/patterns.js.map +1 -1
  161. package/dist/commands/refine.d.ts.map +1 -1
  162. package/dist/commands/refine.js +23 -2
  163. package/dist/commands/refine.js.map +1 -1
  164. package/dist/commands/reverse.d.ts.map +1 -1
  165. package/dist/commands/reverse.js +28 -3
  166. package/dist/commands/reverse.js.map +1 -1
  167. package/dist/commands/review.d.ts.map +1 -1
  168. package/dist/commands/review.js +25 -3
  169. package/dist/commands/review.js.map +1 -1
  170. package/dist/core/types/project.d.ts +1 -1
  171. package/dist/core/types/project.d.ts.map +1 -1
  172. package/dist/dag-runner/run_dag.d.ts +1 -1
  173. package/dist/dag-runner/run_dag.d.ts.map +1 -1
  174. package/dist/exec/safe-spawn.d.ts.map +1 -1
  175. package/dist/exec/safe-spawn.js +6 -1
  176. package/dist/exec/safe-spawn.js.map +1 -1
  177. package/dist/skills/bundled.d.ts +5 -0
  178. package/dist/skills/bundled.d.ts.map +1 -0
  179. package/dist/skills/bundled.js +34 -0
  180. package/dist/skills/bundled.js.map +1 -0
  181. package/dist/skills/commands/add.d.ts +1 -3
  182. package/dist/skills/commands/add.d.ts.map +1 -1
  183. package/dist/skills/commands/add.js +20 -3
  184. package/dist/skills/commands/add.js.map +1 -1
  185. package/dist/skills/tests/bundled.spec.d.ts +2 -0
  186. package/dist/skills/tests/bundled.spec.d.ts.map +1 -0
  187. package/dist/skills/tests/bundled.spec.js +24 -0
  188. package/dist/skills/tests/bundled.spec.js.map +1 -0
  189. package/dist/types/UpdateManifest.types.d.ts +1 -1
  190. package/dist/types/UpdateManifest.types.d.ts.map +1 -1
  191. package/dist/utils/dag-converter.js +1 -1
  192. package/dist/utils/dag-converter.js.map +1 -1
  193. package/dist/utils/project-detector.d.ts +1 -0
  194. package/dist/utils/project-detector.d.ts.map +1 -1
  195. package/dist/utils/project-detector.js +8 -0
  196. package/dist/utils/project-detector.js.map +1 -1
  197. package/dist/utils/project-generator.d.ts +1 -1
  198. package/dist/utils/project-generator.d.ts.map +1 -1
  199. package/dist/utils/project-generator.js +23 -2
  200. package/dist/utils/project-generator.js.map +1 -1
  201. package/dist/utils/templates.d.ts +2 -0
  202. package/dist/utils/templates.d.ts.map +1 -1
  203. package/dist/utils/templates.js +74 -0
  204. package/dist/utils/templates.js.map +1 -1
  205. package/dist/verification/__tests__/safe-spawn.test.js +12 -0
  206. package/dist/verification/__tests__/safe-spawn.test.js.map +1 -1
  207. package/package.json +2 -1
  208. package/skills/dare-ax/generator.ts +325 -0
  209. package/skills/dare-ax/index.ts +19 -0
  210. package/skills/dare-ax/metrics.ts +352 -0
  211. package/skills/dare-ax/package-lock.json +1855 -0
  212. package/skills/dare-ax/package.json +50 -0
  213. package/skills/dare-ax/secret-detector.ts +123 -0
  214. package/skills/dare-ax/skill.yml +19 -0
  215. package/skills/dare-ax/templates/llms.txt.jinja2 +80 -0
  216. package/skills/dare-ax/tests/generator.spec.ts +193 -0
  217. package/skills/dare-ax/tests/metrics.spec.ts +394 -0
  218. package/skills/dare-ax/tests/validator.spec.ts +298 -0
  219. package/skills/dare-ax/tsconfig.json +18 -0
  220. package/skills/dare-ax/types.ts +79 -0
  221. package/skills/dare-ax/validator.ts +238 -0
  222. package/skills/dare-frontend-design/generator.ts +616 -0
  223. package/skills/dare-frontend-design/index.ts +25 -0
  224. package/skills/dare-frontend-design/linter.ts +227 -0
  225. package/skills/dare-frontend-design/metrics.ts +82 -0
  226. package/skills/dare-frontend-design/package-lock.json +1855 -0
  227. package/skills/dare-frontend-design/package.json +43 -0
  228. package/skills/dare-frontend-design/skill.yml +20 -0
  229. package/skills/dare-frontend-design/tests/frontend_design.spec.ts +435 -0
  230. package/skills/dare-frontend-design/tsconfig.json +18 -0
  231. package/skills/dare-frontend-design/types.ts +62 -0
  232. package/skills/dare-layered-design/generator.ts +740 -0
  233. package/skills/dare-layered-design/index.ts +17 -0
  234. package/skills/dare-layered-design/linter.ts +462 -0
  235. package/skills/dare-layered-design/metrics.ts +409 -0
  236. package/skills/dare-layered-design/package-lock.json +1855 -0
  237. package/skills/dare-layered-design/package.json +50 -0
  238. package/skills/dare-layered-design/skill.yml +35 -0
  239. package/skills/dare-layered-design/tests/generator.spec.ts +156 -0
  240. package/skills/dare-layered-design/tests/linter.spec.ts +255 -0
  241. package/skills/dare-layered-design/tests/metrics.spec.ts +286 -0
  242. package/skills/dare-layered-design/tsconfig.json +18 -0
  243. package/skills/dare-layered-design/types.ts +48 -0
  244. package/skills/dare-llm-integration/cache/llm_cache.ts +122 -0
  245. package/skills/dare-llm-integration/index.ts +49 -0
  246. package/skills/dare-llm-integration/metrics.ts +107 -0
  247. package/skills/dare-llm-integration/package-lock.json +1855 -0
  248. package/skills/dare-llm-integration/package.json +49 -0
  249. package/skills/dare-llm-integration/prompts/prompt_loader.ts +258 -0
  250. package/skills/dare-llm-integration/providers/anthropic_provider.ts +159 -0
  251. package/skills/dare-llm-integration/providers/dummy_provider.ts +113 -0
  252. package/skills/dare-llm-integration/providers/llm_provider.ts +6 -0
  253. package/skills/dare-llm-integration/providers/openai_provider.ts +215 -0
  254. package/skills/dare-llm-integration/rate_limit/token_bucket.ts +86 -0
  255. package/skills/dare-llm-integration/skill.yml +23 -0
  256. package/skills/dare-llm-integration/tests/fixtures/greet_v1.jinja2 +1 -0
  257. package/skills/dare-llm-integration/tests/fixtures/summarize_v1.jinja2 +1 -0
  258. package/skills/dare-llm-integration/tests/fixtures/summarize_v2.jinja2 +3 -0
  259. package/skills/dare-llm-integration/tests/llm_integration.spec.ts +657 -0
  260. package/skills/dare-llm-integration/tsconfig.json +23 -0
  261. package/skills/dare-llm-integration/types.ts +91 -0
  262. package/skills/dare-llm-integration/validators/output_validator.ts +200 -0
  263. package/skills/dare-quality-telemetry/collect.ts +134 -0
  264. package/skills/dare-quality-telemetry/collectors/dare_ax_collector.ts +301 -0
  265. package/skills/dare-quality-telemetry/collectors/dare_layered_design_collector.ts +406 -0
  266. package/skills/dare-quality-telemetry/collectors/index.ts +24 -0
  267. package/skills/dare-quality-telemetry/github_actions_template.ts +25 -0
  268. package/skills/dare-quality-telemetry/index.ts +18 -0
  269. package/skills/dare-quality-telemetry/metrics.ts +137 -0
  270. package/skills/dare-quality-telemetry/package-lock.json +1855 -0
  271. package/skills/dare-quality-telemetry/package.json +48 -0
  272. package/skills/dare-quality-telemetry/regression.ts +60 -0
  273. package/skills/dare-quality-telemetry/reporter.ts +132 -0
  274. package/skills/dare-quality-telemetry/skill.yml +18 -0
  275. package/skills/dare-quality-telemetry/tests/quality_telemetry.spec.ts +885 -0
  276. package/skills/dare-quality-telemetry/tsconfig.json +19 -0
  277. package/skills/dare-quality-telemetry/types.ts +41 -0
  278. package/skills/dare-realtime/event_registry.ts +101 -0
  279. package/skills/dare-realtime/index.ts +30 -0
  280. package/skills/dare-realtime/metrics.ts +84 -0
  281. package/skills/dare-realtime/package-lock.json +1855 -0
  282. package/skills/dare-realtime/package.json +43 -0
  283. package/skills/dare-realtime/reconnect_strategy.ts +85 -0
  284. package/skills/dare-realtime/schema_validator.ts +80 -0
  285. package/skills/dare-realtime/skill.yml +21 -0
  286. package/skills/dare-realtime/subscription_manager.ts +106 -0
  287. package/skills/dare-realtime/tests/realtime.spec.ts +482 -0
  288. package/skills/dare-realtime/tsconfig.json +18 -0
  289. package/skills/dare-realtime/types.ts +51 -0
  290. package/templates/ide/antigravity/.agents/skills/dare-ai/SKILL.md +17 -0
  291. package/templates/ide/antigravity/.agents/skills/dare-blueprint/SKILL.md +2 -0
  292. package/templates/ide/antigravity/.agents/skills/dare-design/SKILL.md +2 -0
  293. package/templates/ide/antigravity/.agents/skills/dare-dna/SKILL.md +3 -0
  294. package/templates/ide/antigravity/.agents/skills/dare-migrate/SKILL.md +3 -0
  295. package/templates/ide/antigravity/.agents/skills/dare-patterns/SKILL.md +3 -0
  296. package/templates/ide/antigravity/.agents/skills/dare-refine/SKILL.md +3 -0
  297. package/templates/ide/antigravity/.agents/skills/dare-reverse/SKILL.md +3 -0
  298. package/templates/ide/antigravity/.agents/skills/dare-review/SKILL.md +3 -0
  299. package/templates/ide/claude/.claude/commands/dare-ai.md +17 -0
  300. package/templates/ide/claude/.claude/commands/dare-blueprint.md +2 -0
  301. package/templates/ide/claude/.claude/commands/dare-design.md +2 -0
  302. package/templates/ide/claude/.claude/commands/dare-dna.md +2 -0
  303. package/templates/ide/claude/.claude/commands/dare-migrate.md +2 -0
  304. package/templates/ide/claude/.claude/commands/dare-patterns.md +3 -0
  305. package/templates/ide/claude/.claude/commands/dare-refine.md +3 -0
  306. package/templates/ide/claude/.claude/commands/dare-reverse.md +2 -0
  307. package/templates/ide/claude/.claude/commands/dare-review.md +3 -0
  308. package/templates/ide/cursor/.cursor/commands/dare-ai.md +17 -0
  309. package/templates/ide/cursor/.cursor/commands/dare-blueprint.md +3 -0
  310. package/templates/ide/cursor/.cursor/commands/dare-design.md +3 -0
  311. package/templates/ide/cursor/.cursor/commands/dare-dna.md +2 -0
  312. package/templates/ide/cursor/.cursor/commands/dare-migrate.md +2 -0
  313. package/templates/ide/cursor/.cursor/commands/dare-patterns.md +3 -0
  314. package/templates/ide/cursor/.cursor/commands/dare-refine.md +3 -0
  315. package/templates/ide/cursor/.cursor/commands/dare-reverse.md +2 -0
  316. package/templates/ide/cursor/.cursor/commands/dare-review.md +3 -0
@@ -0,0 +1,36 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { z } from 'zod';
3
+ import { PARITY_CONTRACTS, parityFor, SEMANTIC_COMMANDS } from '../parity.js';
4
+ import { schemaForCommand } from '../schemas.js';
5
+ function zodTopLevelKeys(schema) {
6
+ if (schema instanceof z.ZodObject) {
7
+ return Object.keys(schema.shape);
8
+ }
9
+ return [];
10
+ }
11
+ describe('ai/parity', () => {
12
+ it('every_semantic_command_has_contract', () => {
13
+ expect(SEMANTIC_COMMANDS.length).toBe(8);
14
+ for (const command of SEMANTIC_COMMANDS) {
15
+ expect(parityFor(command).command).toBe(command);
16
+ }
17
+ });
18
+ it('schema_fields_exist_in_schemas', () => {
19
+ for (const contract of PARITY_CONTRACTS) {
20
+ const schemaKeys = new Set(zodTopLevelKeys(schemaForCommand(contract.command)));
21
+ for (const field of contract.schemaFields) {
22
+ expect(schemaKeys.has(field), `${contract.command}.${field}`).toBe(true);
23
+ }
24
+ }
25
+ });
26
+ it('parityFor_returns_contract', () => {
27
+ const reverse = parityFor('reverse');
28
+ expect(reverse.skillSlug).toBe('/dare-reverse');
29
+ expect(reverse.terminal).toContain('--ai');
30
+ expect(reverse.artifacts.length).toBeGreaterThan(0);
31
+ });
32
+ it('contracts_cover_all_parity_commands', () => {
33
+ expect(PARITY_CONTRACTS.map((c) => c.command).sort()).toEqual([...SEMANTIC_COMMANDS].sort());
34
+ });
35
+ });
36
+ //# sourceMappingURL=parity.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parity.test.js","sourceRoot":"","sources":["../../../src/ai/__tests__/parity.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AAC9E,OAAO,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEjD,SAAS,eAAe,CAAC,MAAoB;IAC3C,IAAI,MAAM,YAAY,CAAC,CAAC,SAAS,EAAE,CAAC;QAClC,OAAO,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IACnC,CAAC;IACD,OAAO,EAAE,CAAC;AACZ,CAAC;AAED,QAAQ,CAAC,WAAW,EAAE,GAAG,EAAE;IACzB,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,iBAAiB,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACzC,KAAK,MAAM,OAAO,IAAI,iBAAiB,EAAE,CAAC;YACxC,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACnD,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,gCAAgC,EAAE,GAAG,EAAE;QACxC,KAAK,MAAM,QAAQ,IAAI,gBAAgB,EAAE,CAAC;YACxC,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,eAAe,CAAC,gBAAgB,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;YAChF,KAAK,MAAM,KAAK,IAAI,QAAQ,CAAC,YAAY,EAAE,CAAC;gBAC1C,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,GAAG,QAAQ,CAAC,OAAO,IAAI,KAAK,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAC3E,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,4BAA4B,EAAE,GAAG,EAAE;QACpC,MAAM,OAAO,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;QACrC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;QAChD,MAAM,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;QAC3C,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;IACtD,CAAC,CAAC,CAAC;IAEH,EAAE,CAAC,qCAAqC,EAAE,GAAG,EAAE;QAC7C,MAAM,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,CAC3D,CAAC,GAAG,iBAAiB,CAAC,CAAC,IAAI,EAAE,CAC9B,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=pipeline.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.test.d.ts","sourceRoot":"","sources":["../../../src/ai/__tests__/pipeline.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,147 @@
1
+ import { afterEach, beforeEach, describe, expect, it } from 'vitest';
2
+ import fs from 'fs-extra';
3
+ import os from 'os';
4
+ import path from 'path';
5
+ import { MockAiProvider } from '../providers.js';
6
+ import { setMockProviderFactoryForTests } from '../registry.js';
7
+ import { runCommandEnrichment } from '../pipeline.js';
8
+ let tmpDir;
9
+ beforeEach(async () => {
10
+ tmpDir = await fs.mkdtemp(path.join(os.tmpdir(), 'dare-ai-pipeline-'));
11
+ setMockProviderFactoryForTests(() => new MockAiProvider(() => ({
12
+ ok: true,
13
+ provider: 'mock',
14
+ raw: '{}',
15
+ data: {
16
+ purpose: 'Test system',
17
+ domainGlossary: 'Foo, Bar',
18
+ },
19
+ })));
20
+ });
21
+ afterEach(async () => {
22
+ setMockProviderFactoryForTests(null);
23
+ await fs.remove(tmpDir).catch(() => undefined);
24
+ });
25
+ describe('ai pipeline', () => {
26
+ it('enriches_reverse_and_writes_semantic_file', async () => {
27
+ await fs.ensureDir(path.join(tmpDir, 'DARE', 'REVERSE'));
28
+ await fs.writeFile(path.join(tmpDir, 'DARE', 'IDEIA.md'), '<!-- AGENT: purpose -->\n');
29
+ const result = await runCommandEnrichment({
30
+ command: 'reverse',
31
+ cwd: tmpDir,
32
+ facts: { modules: [] },
33
+ provider: 'mock',
34
+ });
35
+ expect(result.ok).toBe(true);
36
+ expect(await fs.pathExists(path.join(tmpDir, 'DARE', 'REVERSE', 'semantic-enrichment.json'))).toBe(true);
37
+ const ideia = await fs.readFile(path.join(tmpDir, 'DARE', 'IDEIA.md'), 'utf-8');
38
+ expect(ideia).toContain('Test system');
39
+ });
40
+ it('enriches_blueprint_and_writes_blueprint_md', async () => {
41
+ setMockProviderFactoryForTests(() => new MockAiProvider(() => ({
42
+ ok: true,
43
+ provider: 'mock',
44
+ raw: '{}',
45
+ data: {
46
+ architectureSummary: 'Modular monolith with API layer',
47
+ keyDecisions: ['Use PostgreSQL', 'Expose REST first'],
48
+ },
49
+ })));
50
+ await fs.ensureDir(path.join(tmpDir, 'DARE'));
51
+ const result = await runCommandEnrichment({
52
+ command: 'blueprint',
53
+ cwd: tmpDir,
54
+ facts: { design: '# DESIGN' },
55
+ provider: 'mock',
56
+ });
57
+ expect(result.ok).toBe(true);
58
+ const blueprint = await fs.readFile(path.join(tmpDir, 'DARE', 'BLUEPRINT.md'), 'utf-8');
59
+ expect(blueprint).toContain('Modular monolith');
60
+ });
61
+ it('migrate_rewrites_migration_md', async () => {
62
+ setMockProviderFactoryForTests(() => new MockAiProvider(() => ({
63
+ ok: true,
64
+ provider: 'mock',
65
+ raw: '{}',
66
+ data: {
67
+ strategySummary: 'Strangler fig over 3 modules',
68
+ riskAreas: ['Data migration', 'Auth parity'],
69
+ parityNotes: 'Run Gherkin before cutover',
70
+ blockingGaps: ['Legacy billing API undocumented'],
71
+ },
72
+ })));
73
+ await fs.ensureDir(path.join(tmpDir, 'DARE', 'MIGRATION'));
74
+ await fs.writeFile(path.join(tmpDir, 'DARE', 'MIGRATION', 'MIGRATION.md'), [
75
+ '# MIGRATION',
76
+ '',
77
+ '## Estratégia de Migração',
78
+ '<!-- AGENT: big-bang vs. strangler/parallel-run. Critérios, ordem dos módulos, feature flags. -->',
79
+ '',
80
+ '<!-- AGENT: adicione riscos de regressão, dados, performance e mitigações. -->',
81
+ '',
82
+ '## Plano de Cutover & Rollback',
83
+ '<!-- AGENT: passos de corte, validação de paridade (rodar os .feature), critério de go/no-go e rollback. -->',
84
+ '',
85
+ '| Spec | 🔴 | Tratamento |',
86
+ '|---|---|---|',
87
+ '| `legacy` | 1 | <!-- AGENT: tratamento --> |',
88
+ ].join('\n'));
89
+ const result = await runCommandEnrichment({
90
+ command: 'migrate',
91
+ cwd: tmpDir,
92
+ facts: { modules: [] },
93
+ provider: 'mock',
94
+ });
95
+ expect(result.ok).toBe(true);
96
+ const migration = await fs.readFile(path.join(tmpDir, 'DARE', 'MIGRATION', 'MIGRATION.md'), 'utf-8');
97
+ expect(migration).toContain('Strangler fig over 3 modules');
98
+ expect(migration).toContain('Data migration');
99
+ expect(migration).toContain('Run Gherkin before cutover');
100
+ expect(migration).toContain('Legacy billing API undocumented');
101
+ });
102
+ it('review_injects_verdict_without_from_agent', async () => {
103
+ setMockProviderFactoryForTests(() => new MockAiProvider(() => ({
104
+ ok: true,
105
+ provider: 'mock',
106
+ raw: '{}',
107
+ data: {
108
+ passed: false,
109
+ unmetCriteria: ['Missing edge-case tests'],
110
+ notes: 'Add tests for null input',
111
+ },
112
+ })));
113
+ await fs.ensureDir(path.join(tmpDir, 'DARE'));
114
+ const result = await runCommandEnrichment({
115
+ command: 'review',
116
+ cwd: tmpDir,
117
+ facts: { taskId: 'task-001', spec: '# spec' },
118
+ provider: 'mock',
119
+ });
120
+ expect(result.ok).toBe(true);
121
+ const verdict = await fs.readJSON(path.join(tmpDir, 'DARE', 'review-semantic.json'));
122
+ expect(verdict.passed).toBe(false);
123
+ expect(verdict.unmetCriteria).toContain('Missing edge-case tests');
124
+ expect(verdict.notes).toContain('null input');
125
+ });
126
+ it('invalid_schema_does_not_touch_artifact', async () => {
127
+ setMockProviderFactoryForTests(() => new MockAiProvider(() => ({
128
+ ok: true,
129
+ provider: 'mock',
130
+ raw: '{}',
131
+ data: { passed: 'not-a-boolean', unmetCriteria: [] },
132
+ })));
133
+ await fs.ensureDir(path.join(tmpDir, 'DARE'));
134
+ const reviewPath = path.join(tmpDir, 'DARE', 'review-semantic.json');
135
+ await fs.writeJSON(reviewPath, { passed: true, unmetCriteria: [] });
136
+ const result = await runCommandEnrichment({
137
+ command: 'review',
138
+ cwd: tmpDir,
139
+ facts: { taskId: 'task-001' },
140
+ provider: 'mock',
141
+ });
142
+ expect(result.ok).toBe(false);
143
+ const unchanged = await fs.readJSON(reviewPath);
144
+ expect(unchanged.passed).toBe(true);
145
+ });
146
+ });
147
+ //# sourceMappingURL=pipeline.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pipeline.test.js","sourceRoot":"","sources":["../../../src/ai/__tests__/pipeline.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=refine-bridge.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"refine-bridge.test.d.ts","sourceRoot":"","sources":["../../../src/ai/__tests__/refine-bridge.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,17 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { splitProposalFromRefineSemantic } from '../refine-bridge.js';
3
+ describe('refine ai bridge', () => {
4
+ it('maps_semantic_subtasks_to_split_proposal', () => {
5
+ const proposal = splitProposalFromRefineSemantic('task-100', {
6
+ rationale: 'Task spans auth and billing',
7
+ subtasks: [
8
+ { id: 'task-100a', title: 'Auth slice', files: ['src/auth/login.ts'] },
9
+ { id: 'task-100b', title: 'Billing slice', files: ['src/billing/invoice.ts'] },
10
+ ],
11
+ });
12
+ expect(proposal.originalTaskId).toBe('task-100');
13
+ expect(proposal.subtasks).toHaveLength(2);
14
+ expect(proposal.subtasks[0]?.id).toBe('task-100a');
15
+ });
16
+ });
17
+ //# sourceMappingURL=refine-bridge.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"refine-bridge.test.js","sourceRoot":"","sources":["../../../src/ai/__tests__/refine-bridge.test.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,+BAA+B,EAAE,MAAM,qBAAqB,CAAC;AAEtE,QAAQ,CAAC,kBAAkB,EAAE,GAAG,EAAE;IAChC,EAAE,CAAC,0CAA0C,EAAE,GAAG,EAAE;QAClD,MAAM,QAAQ,GAAG,+BAA+B,CAAC,UAAU,EAAE;YAC3D,SAAS,EAAE,6BAA6B;YACxC,QAAQ,EAAE;gBACR,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,YAAY,EAAE,KAAK,EAAE,CAAC,mBAAmB,CAAC,EAAE;gBACtE,EAAE,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,wBAAwB,CAAC,EAAE;aAC/E;SACF,CAAC,CAAC;QACH,MAAM,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjD,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;QAC1C,MAAM,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=resolve.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve.test.d.ts","sourceRoot":"","sources":["../../../src/ai/__tests__/resolve.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,42 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { parseAiConfig } from '../config.js';
3
+ import { resolveProviderName, providerToDriverId, parseAgentDriverOverride, agentDriverFromAiConfig, resolveAgentDriverId, } from '../resolve.js';
4
+ describe('ai/resolve', () => {
5
+ const config = parseAiConfig({
6
+ ai: { defaultProvider: 'claude-code' },
7
+ });
8
+ it('flag_wins_over_config', () => {
9
+ expect(resolveProviderName('codex', config)).toBe('codex');
10
+ });
11
+ it('config_default_when_no_flag', () => {
12
+ expect(resolveProviderName(undefined, config)).toBe('claude-code');
13
+ });
14
+ it('falls_back_to_codex_when_empty_config', () => {
15
+ const empty = parseAiConfig({});
16
+ expect(resolveProviderName(undefined, empty)).toBe('codex');
17
+ });
18
+ it('maps_provider_to_driver_id', () => {
19
+ expect(providerToDriverId('codex')).toBe('codex');
20
+ expect(providerToDriverId('claude-code')).toBe('claude');
21
+ expect(providerToDriverId('cursor-cli')).toBe('cursor');
22
+ expect(providerToDriverId('antigravity-cli')).toBe('antigravity');
23
+ expect(providerToDriverId('mock')).toBe('mock');
24
+ });
25
+ it('parseAgentDriverOverride_accepts_aliases', () => {
26
+ expect(parseAgentDriverOverride('codex-cli')).toBe('codex');
27
+ expect(parseAgentDriverOverride('claude')).toBe('claude');
28
+ expect(parseAgentDriverOverride('cursor-agent')).toBe('cursor');
29
+ expect(parseAgentDriverOverride('dry-run')).toBe('mock');
30
+ });
31
+ it('agentDriverFromAiConfig_requires_explicit_ai_block', () => {
32
+ expect(agentDriverFromAiConfig({})).toBeNull();
33
+ expect(agentDriverFromAiConfig({ ai: {} })).toBeNull();
34
+ expect(agentDriverFromAiConfig({ ai: { defaultProvider: 'codex' } })).toBe('codex');
35
+ });
36
+ it('resolveAgentDriverId_precedence', () => {
37
+ expect(resolveAgentDriverId({ ai: { defaultProvider: 'codex' } }, 'claude-code')).toBe('claude');
38
+ expect(resolveAgentDriverId({ ai: { defaultProvider: 'codex' } }, undefined)).toBe('codex');
39
+ expect(resolveAgentDriverId({}, undefined)).toBe('claude');
40
+ });
41
+ });
42
+ //# sourceMappingURL=resolve.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resolve.test.js","sourceRoot":"","sources":["../../../src/ai/__tests__/resolve.test.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { ProviderCapabilities, AiProviderName } from './types.js';
2
+ export declare function capabilitiesForProvider(name: AiProviderName): ProviderCapabilities;
3
+ //# sourceMappingURL=capabilities.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capabilities.d.ts","sourceRoot":"","sources":["../../src/ai/capabilities.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AAGvE,wBAAgB,uBAAuB,CAAC,IAAI,EAAE,cAAc,GAAG,oBAAoB,CAQlF"}
@@ -0,0 +1,11 @@
1
+ import { providerToDriverId } from './resolve.js';
2
+ export function capabilitiesForProvider(name) {
3
+ if (name === 'mock') {
4
+ return { enrichment: true, execution: true };
5
+ }
6
+ return {
7
+ enrichment: true,
8
+ execution: providerToDriverId(name) !== null,
9
+ };
10
+ }
11
+ //# sourceMappingURL=capabilities.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"capabilities.js","sourceRoot":"","sources":["../../src/ai/capabilities.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAElD,MAAM,UAAU,uBAAuB,CAAC,IAAoB;IAC1D,IAAI,IAAI,KAAK,MAAM,EAAE,CAAC;QACpB,OAAO,EAAE,UAAU,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;IAC/C,CAAC;IACD,OAAO;QACL,UAAU,EAAE,IAAI;QAChB,SAAS,EAAE,kBAAkB,CAAC,IAAI,CAAC,KAAK,IAAI;KAC7C,CAAC;AACJ,CAAC"}
@@ -0,0 +1,10 @@
1
+ import type { Command } from 'commander';
2
+ import type { AiCommandOptions } from './types.js';
3
+ /** Shared CLI flags for heuristic + AI enrichment on DARE commands. */
4
+ export declare function addAiOptions(cmd: Command): Command;
5
+ export declare function aiOptionsFromFlags(flags: AiCommandOptions): {
6
+ enabled: boolean;
7
+ provider?: string;
8
+ json?: boolean;
9
+ };
10
+ //# sourceMappingURL=command-options.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-options.d.ts","sourceRoot":"","sources":["../../src/ai/command-options.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACzC,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEnD,uEAAuE;AACvE,wBAAgB,YAAY,CAAC,GAAG,EAAE,OAAO,GAAG,OAAO,CAQlD;AAED,wBAAgB,kBAAkB,CAAC,KAAK,EAAE,gBAAgB,GAAG;IAC3D,OAAO,EAAE,OAAO,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB,CAMA"}
@@ -0,0 +1,15 @@
1
+ /** Shared CLI flags for heuristic + AI enrichment on DARE commands. */
2
+ export function addAiOptions(cmd) {
3
+ return cmd
4
+ .option('--ai', 'Run terminal AI enrichment after deterministic heuristics', false)
5
+ .option('--provider <name>', 'AI provider override (codex, claude-code, cursor-cli, antigravity-cli, mock)')
6
+ .option('--json', 'Emit structured EnrichmentResult JSON when --ai is used', false);
7
+ }
8
+ export function aiOptionsFromFlags(flags) {
9
+ return {
10
+ enabled: Boolean(flags.ai),
11
+ provider: flags.provider?.trim() || undefined,
12
+ json: Boolean(flags.json),
13
+ };
14
+ }
15
+ //# sourceMappingURL=command-options.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"command-options.js","sourceRoot":"","sources":["../../src/ai/command-options.ts"],"names":[],"mappings":"AAGA,uEAAuE;AACvE,MAAM,UAAU,YAAY,CAAC,GAAY;IACvC,OAAO,GAAG;SACP,MAAM,CAAC,MAAM,EAAE,2DAA2D,EAAE,KAAK,CAAC;SAClF,MAAM,CACL,mBAAmB,EACnB,8EAA8E,CAC/E;SACA,MAAM,CAAC,QAAQ,EAAE,yDAAyD,EAAE,KAAK,CAAC,CAAC;AACxF,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,KAAuB;IAKxD,OAAO;QACL,OAAO,EAAE,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;QAC1B,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,IAAI,EAAE,IAAI,SAAS;QAC7C,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC;KAC1B,CAAC;AACJ,CAAC"}
@@ -0,0 +1,27 @@
1
+ import type { AiProviderName } from './types.js';
2
+ import type { CodexApproval, CodexSandbox } from '../agent/drivers/codex.js';
3
+ export interface CodexProviderConfig {
4
+ readonly command?: string;
5
+ readonly model?: string;
6
+ readonly sandbox?: CodexSandbox;
7
+ readonly approval?: CodexApproval;
8
+ readonly timeoutSeconds?: number;
9
+ }
10
+ export interface ClaudeCodeProviderConfig {
11
+ readonly command?: string;
12
+ readonly model?: string;
13
+ readonly timeoutSeconds?: number;
14
+ }
15
+ export interface CliProviderConfig {
16
+ readonly command?: string;
17
+ readonly timeoutSeconds?: number;
18
+ }
19
+ export interface AiConfig {
20
+ readonly defaultProvider: AiProviderName;
21
+ readonly providers: Partial<Record<AiProviderName, CodexProviderConfig | ClaudeCodeProviderConfig | CliProviderConfig>>;
22
+ }
23
+ export declare function normalizeProviderName(raw: string | undefined): AiProviderName | null;
24
+ export declare function parseAiConfig(raw: Record<string, unknown>): AiConfig;
25
+ export declare function loadAiConfig(cwd: string): Promise<AiConfig>;
26
+ export declare function resolveProviderConfig<T extends Record<string, unknown>>(config: AiConfig, name: AiProviderName): T;
27
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/ai/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,YAAY,CAAC;AACjD,OAAO,KAAK,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAG7E,MAAM,WAAW,mBAAmB;IAClC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,OAAO,CAAC,EAAE,YAAY,CAAC;IAChC,QAAQ,CAAC,QAAQ,CAAC,EAAE,aAAa,CAAC;IAClC,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,wBAAwB;IACvC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IACxB,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,iBAAiB;IAChC,QAAQ,CAAC,OAAO,CAAC,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,cAAc,CAAC,EAAE,MAAM,CAAC;CAClC;AAED,MAAM,WAAW,QAAQ;IACvB,QAAQ,CAAC,eAAe,EAAE,cAAc,CAAC;IACzC,QAAQ,CAAC,SAAS,EAAE,OAAO,CACzB,MAAM,CACJ,cAAc,EACd,mBAAmB,GAAG,wBAAwB,GAAG,iBAAiB,CACnE,CACF,CAAC;CACH;AAkBD,wBAAgB,qBAAqB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,cAAc,GAAG,IAAI,CAGpF;AAED,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,QAAQ,CAsEpE;AAED,wBAAsB,YAAY,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,CAAC,CAOjE;AAED,wBAAgB,qBAAqB,CAAC,CAAC,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EACrE,MAAM,EAAE,QAAQ,EAChB,IAAI,EAAE,cAAc,GACnB,CAAC,CAGH"}
@@ -0,0 +1,89 @@
1
+ import { readProjectConfig } from '../utils/UpdateDetector.js';
2
+ const DEFAULT_PROVIDER = 'codex';
3
+ const PROVIDER_ALIASES = {
4
+ codex: 'codex',
5
+ 'codex-cli': 'codex',
6
+ claude: 'claude-code',
7
+ 'claude-code': 'claude-code',
8
+ 'claude-cli': 'claude-code',
9
+ cursor: 'cursor-cli',
10
+ 'cursor-cli': 'cursor-cli',
11
+ 'cursor-agent': 'cursor-cli',
12
+ antigravity: 'antigravity-cli',
13
+ 'antigravity-cli': 'antigravity-cli',
14
+ mock: 'mock',
15
+ };
16
+ export function normalizeProviderName(raw) {
17
+ if (!raw?.trim())
18
+ return null;
19
+ return PROVIDER_ALIASES[raw.trim().toLowerCase()] ?? null;
20
+ }
21
+ export function parseAiConfig(raw) {
22
+ const ai = typeof raw.ai === 'object' && raw.ai !== null
23
+ ? raw.ai
24
+ : {};
25
+ const agent = typeof raw.agent === 'object' && raw.agent !== null
26
+ ? raw.agent
27
+ : {};
28
+ const defaultRaw = typeof ai.defaultProvider === 'string'
29
+ ? ai.defaultProvider
30
+ : typeof agent.provider === 'string'
31
+ ? agent.provider
32
+ : typeof agent.driver === 'string'
33
+ ? agent.driver
34
+ : undefined;
35
+ const defaultProvider = normalizeProviderName(defaultRaw) ?? DEFAULT_PROVIDER;
36
+ const providersBlock = typeof ai.providers === 'object' && ai.providers !== null
37
+ ? ai.providers
38
+ : {};
39
+ const providers = {};
40
+ for (const [key, value] of Object.entries(providersBlock)) {
41
+ const name = normalizeProviderName(key);
42
+ if (!name || name === 'mock')
43
+ continue;
44
+ if (typeof value === 'object' && value !== null) {
45
+ providers[name] = value;
46
+ }
47
+ }
48
+ // Back-compat: agent.codex / agent.command at root of agent block
49
+ if (!providers.codex && (agent.codex || agent.command || agent.sandbox)) {
50
+ const codex = typeof agent.codex === 'object' && agent.codex !== null
51
+ ? agent.codex
52
+ : {};
53
+ providers.codex = {
54
+ command: typeof agent.command === 'string'
55
+ ? agent.command
56
+ : typeof codex.command === 'string'
57
+ ? codex.command
58
+ : undefined,
59
+ model: typeof agent.model === 'string' ? agent.model : undefined,
60
+ sandbox: typeof agent.sandbox === 'string'
61
+ ? agent.sandbox
62
+ : typeof codex.sandbox === 'string'
63
+ ? codex.sandbox
64
+ : undefined,
65
+ approval: typeof codex.approval === 'string'
66
+ ? codex.approval
67
+ : undefined,
68
+ timeoutSeconds: typeof codex.timeoutSeconds === 'number' ? codex.timeoutSeconds : undefined,
69
+ };
70
+ }
71
+ if (!providers['claude-code'] && typeof agent.model === 'string') {
72
+ providers['claude-code'] = { model: agent.model };
73
+ }
74
+ return { defaultProvider, providers };
75
+ }
76
+ export async function loadAiConfig(cwd) {
77
+ try {
78
+ const raw = (await readProjectConfig(cwd));
79
+ return parseAiConfig(raw);
80
+ }
81
+ catch {
82
+ return parseAiConfig({});
83
+ }
84
+ }
85
+ export function resolveProviderConfig(config, name) {
86
+ const block = config.providers[name];
87
+ return (block ?? {});
88
+ }
89
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/ai/config.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ import type { AiCommandName } from './types.js';
2
+ /** Terminal ↔ chat parity contract for semantic enrichment commands. */
3
+ export interface ParityContract {
4
+ readonly command: AiCommandName;
5
+ readonly skillSlug: string;
6
+ readonly terminal: string;
7
+ readonly artifacts: ReadonlyArray<string>;
8
+ readonly schemaFields: ReadonlyArray<string>;
9
+ }
10
+ export declare const PARITY_CONTRACTS: ReadonlyArray<ParityContract>;
11
+ export declare function parityFor(command: AiCommandName): ParityContract;
12
+ export declare const SEMANTIC_COMMANDS: ReadonlyArray<AiCommandName>;
13
+ //# sourceMappingURL=parity.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parity.d.ts","sourceRoot":"","sources":["../../src/ai/parity.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAEhD,wEAAwE;AACxE,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,OAAO,EAAE,aAAa,CAAC;IAChC,QAAQ,CAAC,SAAS,EAAE,MAAM,CAAC;IAC3B,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAC1B,QAAQ,CAAC,SAAS,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;IAC1C,QAAQ,CAAC,YAAY,EAAE,aAAa,CAAC,MAAM,CAAC,CAAC;CAC9C;AAED,eAAO,MAAM,gBAAgB,EAAE,aAAa,CAAC,cAAc,CA4E1D,CAAC;AAMF,wBAAgB,SAAS,CAAC,OAAO,EAAE,aAAa,GAAG,cAAc,CAMhE;AAED,eAAO,MAAM,iBAAiB,EAAE,aAAa,CAAC,aAAa,CAE1D,CAAC"}
@@ -0,0 +1,87 @@
1
+ export const PARITY_CONTRACTS = [
2
+ {
3
+ command: 'reverse',
4
+ skillSlug: '/dare-reverse',
5
+ terminal: 'dare reverse --ai',
6
+ artifacts: ['DARE/REVERSE/semantic-enrichment.json', 'DARE/IDEIA.md'],
7
+ schemaFields: [
8
+ 'purpose',
9
+ 'domainGlossary',
10
+ 'mainFlowMermaid',
11
+ 'openQuestions',
12
+ 'modulePurposes',
13
+ 'domainRules',
14
+ 'stateMachinesMermaid',
15
+ 'permissionsMarkdown',
16
+ 'c4ContextMermaid',
17
+ 'c4ContainerMermaid',
18
+ ],
19
+ },
20
+ {
21
+ command: 'dna',
22
+ skillSlug: '/dare-dna',
23
+ terminal: 'dare dna --ai',
24
+ artifacts: ['DARE/dna-semantic.json', 'DARE/PROJECT-DNA.md'],
25
+ schemaFields: [
26
+ 'namingNotes',
27
+ 'architecturePattern',
28
+ 'layerRules',
29
+ 'testingStyle',
30
+ 'errorHandling',
31
+ 'goldenRules',
32
+ 'ambiguities',
33
+ ],
34
+ },
35
+ {
36
+ command: 'migrate',
37
+ skillSlug: '/dare-migrate',
38
+ terminal: 'dare migrate --ai',
39
+ artifacts: ['DARE/migrate-semantic.json', 'DARE/MIGRATION/MIGRATION.md'],
40
+ schemaFields: ['strategySummary', 'riskAreas', 'parityNotes', 'blockingGaps'],
41
+ },
42
+ {
43
+ command: 'design',
44
+ skillSlug: '/dare-design',
45
+ terminal: 'dare design "<description>" --ai',
46
+ artifacts: ['DARE/design-semantic.json', 'DARE/DESIGN.md'],
47
+ schemaFields: ['goals', 'constraints', 'successCriteria', 'userJourneys', 'openQuestions'],
48
+ },
49
+ {
50
+ command: 'patterns',
51
+ skillSlug: '/dare-patterns',
52
+ terminal: 'dare patterns --ai',
53
+ artifacts: ['DARE/patterns-semantic.json', 'DARE/PATTERNS.md'],
54
+ schemaFields: ['summary', 'recommendations', 'antiPatterns', 'injectionNotes'],
55
+ },
56
+ {
57
+ command: 'blueprint',
58
+ skillSlug: '/dare-blueprint',
59
+ terminal: 'dare blueprint --ai',
60
+ artifacts: ['DARE/blueprint-semantic.json', 'DARE/BLUEPRINT.md'],
61
+ schemaFields: ['architectureSummary', 'keyDecisions', 'risks', 'taskNotes'],
62
+ },
63
+ {
64
+ command: 'review',
65
+ skillSlug: '/dare-review',
66
+ terminal: 'dare review <task-id> --ai',
67
+ artifacts: ['DARE/review-semantic.json'],
68
+ schemaFields: ['passed', 'unmetCriteria', 'notes'],
69
+ },
70
+ {
71
+ command: 'refine',
72
+ skillSlug: '/dare-refine',
73
+ terminal: 'dare refine <task-id> --split --ai',
74
+ artifacts: ['DARE/refine-semantic.json'],
75
+ schemaFields: ['rationale', 'subtasks'],
76
+ },
77
+ ];
78
+ const BY_COMMAND = new Map(PARITY_CONTRACTS.map((c) => [c.command, c]));
79
+ export function parityFor(command) {
80
+ const contract = BY_COMMAND.get(command);
81
+ if (!contract) {
82
+ throw new Error(`No parity contract for command: ${command}`);
83
+ }
84
+ return contract;
85
+ }
86
+ export const SEMANTIC_COMMANDS = PARITY_CONTRACTS.map((c) => c.command);
87
+ //# sourceMappingURL=parity.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parity.js","sourceRoot":"","sources":["../../src/ai/parity.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Extract JSON object from provider stdout (raw JSON or fenced code block).
3
+ */
4
+ export declare function extractJsonObject(raw: string): unknown;
5
+ //# sourceMappingURL=parse-json-output.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"parse-json-output.d.ts","sourceRoot":"","sources":["../../src/ai/parse-json-output.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAsBtD"}