@dewtech/dare-cli 2.17.0 → 3.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 (344) hide show
  1. package/README.md +98 -3
  2. package/dist/__tests__/confidence.test.d.ts +2 -0
  3. package/dist/__tests__/confidence.test.d.ts.map +1 -0
  4. package/dist/__tests__/confidence.test.js +73 -0
  5. package/dist/__tests__/confidence.test.js.map +1 -0
  6. package/dist/__tests__/datamodel.test.d.ts +2 -0
  7. package/dist/__tests__/datamodel.test.d.ts.map +1 -0
  8. package/dist/__tests__/datamodel.test.js +131 -0
  9. package/dist/__tests__/datamodel.test.js.map +1 -0
  10. package/dist/__tests__/dna-detector.test.d.ts +2 -0
  11. package/dist/__tests__/dna-detector.test.d.ts.map +1 -0
  12. package/dist/__tests__/dna-detector.test.js +97 -0
  13. package/dist/__tests__/dna-detector.test.js.map +1 -0
  14. package/dist/__tests__/dna-facts.test.d.ts +2 -0
  15. package/dist/__tests__/dna-facts.test.d.ts.map +1 -0
  16. package/dist/__tests__/dna-facts.test.js +44 -0
  17. package/dist/__tests__/dna-facts.test.js.map +1 -0
  18. package/dist/__tests__/graph-renderer.test.d.ts +2 -0
  19. package/dist/__tests__/graph-renderer.test.d.ts.map +1 -0
  20. package/dist/__tests__/graph-renderer.test.js +85 -0
  21. package/dist/__tests__/graph-renderer.test.js.map +1 -0
  22. package/dist/__tests__/migration.test.d.ts +2 -0
  23. package/dist/__tests__/migration.test.d.ts.map +1 -0
  24. package/dist/__tests__/migration.test.js +77 -0
  25. package/dist/__tests__/migration.test.js.map +1 -0
  26. package/dist/__tests__/module-detector.test.d.ts +2 -0
  27. package/dist/__tests__/module-detector.test.d.ts.map +1 -0
  28. package/dist/__tests__/module-detector.test.js +83 -0
  29. package/dist/__tests__/module-detector.test.js.map +1 -0
  30. package/dist/__tests__/refine.test.js +49 -49
  31. package/dist/__tests__/reverse-facts.test.d.ts +2 -0
  32. package/dist/__tests__/reverse-facts.test.d.ts.map +1 -0
  33. package/dist/__tests__/reverse-facts.test.js +78 -0
  34. package/dist/__tests__/reverse-facts.test.js.map +1 -0
  35. package/dist/__tests__/review.test.js +38 -38
  36. package/dist/__tests__/validate.test.js +65 -65
  37. package/dist/bin/dare.js +32 -3
  38. package/dist/bin/dare.js.map +1 -1
  39. package/dist/commands/blueprint.js +122 -122
  40. package/dist/commands/dag.d.ts.map +1 -1
  41. package/dist/commands/dag.js +43 -79
  42. package/dist/commands/dag.js.map +1 -1
  43. package/dist/commands/dna.d.ts +3 -0
  44. package/dist/commands/dna.d.ts.map +1 -0
  45. package/dist/commands/dna.js +69 -0
  46. package/dist/commands/dna.js.map +1 -0
  47. package/dist/commands/migrate.d.ts +3 -0
  48. package/dist/commands/migrate.d.ts.map +1 -0
  49. package/dist/commands/migrate.js +101 -0
  50. package/dist/commands/migrate.js.map +1 -0
  51. package/dist/commands/new.d.ts +16 -0
  52. package/dist/commands/new.d.ts.map +1 -0
  53. package/dist/commands/new.js +103 -0
  54. package/dist/commands/new.js.map +1 -0
  55. package/dist/commands/reverse.d.ts +3 -0
  56. package/dist/commands/reverse.d.ts.map +1 -0
  57. package/dist/commands/reverse.js +201 -0
  58. package/dist/commands/reverse.js.map +1 -0
  59. package/dist/commands/welcome.d.ts +14 -0
  60. package/dist/commands/welcome.d.ts.map +1 -0
  61. package/dist/commands/welcome.js +29 -0
  62. package/dist/commands/welcome.js.map +1 -0
  63. package/dist/skills/commands/add.d.ts +23 -0
  64. package/dist/skills/commands/add.d.ts.map +1 -0
  65. package/dist/skills/commands/add.js +206 -0
  66. package/dist/skills/commands/add.js.map +1 -0
  67. package/dist/skills/commands/info.d.ts +14 -0
  68. package/dist/skills/commands/info.d.ts.map +1 -0
  69. package/dist/skills/commands/info.js +99 -0
  70. package/dist/skills/commands/info.js.map +1 -0
  71. package/dist/skills/commands/list.d.ts +19 -0
  72. package/dist/skills/commands/list.d.ts.map +1 -0
  73. package/dist/skills/commands/list.js +163 -0
  74. package/dist/skills/commands/list.js.map +1 -0
  75. package/dist/skills/commands/publish.d.ts +56 -0
  76. package/dist/skills/commands/publish.d.ts.map +1 -0
  77. package/dist/skills/commands/publish.js +272 -0
  78. package/dist/skills/commands/publish.js.map +1 -0
  79. package/dist/skills/commands/remove.d.ts +19 -0
  80. package/dist/skills/commands/remove.d.ts.map +1 -0
  81. package/dist/skills/commands/remove.js +96 -0
  82. package/dist/skills/commands/remove.js.map +1 -0
  83. package/dist/skills/commands/update.d.ts +31 -0
  84. package/dist/skills/commands/update.d.ts.map +1 -0
  85. package/dist/skills/commands/update.js +132 -0
  86. package/dist/skills/commands/update.js.map +1 -0
  87. package/dist/skills/index.d.ts +22 -0
  88. package/dist/skills/index.d.ts.map +1 -0
  89. package/dist/skills/index.js +33 -0
  90. package/dist/skills/index.js.map +1 -0
  91. package/dist/skills/manifest.d.ts +54 -0
  92. package/dist/skills/manifest.d.ts.map +1 -0
  93. package/dist/skills/manifest.js +162 -0
  94. package/dist/skills/manifest.js.map +1 -0
  95. package/dist/skills/registry-local.d.ts +67 -0
  96. package/dist/skills/registry-local.d.ts.map +1 -0
  97. package/dist/skills/registry-local.js +130 -0
  98. package/dist/skills/registry-local.js.map +1 -0
  99. package/dist/skills/registry-mock.json +109 -0
  100. package/dist/skills/registry-remote.d.ts +110 -0
  101. package/dist/skills/registry-remote.d.ts.map +1 -0
  102. package/dist/skills/registry-remote.js +246 -0
  103. package/dist/skills/registry-remote.js.map +1 -0
  104. package/dist/skills/registry.d.ts +49 -0
  105. package/dist/skills/registry.d.ts.map +1 -0
  106. package/dist/skills/registry.js +94 -0
  107. package/dist/skills/registry.js.map +1 -0
  108. package/dist/skills/tests/manifest.spec.d.ts +8 -0
  109. package/dist/skills/tests/manifest.spec.d.ts.map +1 -0
  110. package/dist/skills/tests/manifest.spec.js +176 -0
  111. package/dist/skills/tests/manifest.spec.js.map +1 -0
  112. package/dist/skills/tests/publish.spec.d.ts +12 -0
  113. package/dist/skills/tests/publish.spec.d.ts.map +1 -0
  114. package/dist/skills/tests/publish.spec.js +276 -0
  115. package/dist/skills/tests/publish.spec.js.map +1 -0
  116. package/dist/skills/tests/registry-local.spec.d.ts +8 -0
  117. package/dist/skills/tests/registry-local.spec.d.ts.map +1 -0
  118. package/dist/skills/tests/registry-local.spec.js +231 -0
  119. package/dist/skills/tests/registry-local.spec.js.map +1 -0
  120. package/dist/skills/tests/registry.spec.d.ts +7 -0
  121. package/dist/skills/tests/registry.spec.d.ts.map +1 -0
  122. package/dist/skills/tests/registry.spec.js +58 -0
  123. package/dist/skills/tests/registry.spec.js.map +1 -0
  124. package/dist/skills/tests/remote-registry.spec.d.ts +9 -0
  125. package/dist/skills/tests/remote-registry.spec.d.ts.map +1 -0
  126. package/dist/skills/tests/remote-registry.spec.js +357 -0
  127. package/dist/skills/tests/remote-registry.spec.js.map +1 -0
  128. package/dist/skills/tests/update.spec.d.ts +9 -0
  129. package/dist/skills/tests/update.spec.d.ts.map +1 -0
  130. package/dist/skills/tests/update.spec.js +166 -0
  131. package/dist/skills/tests/update.spec.js.map +1 -0
  132. package/dist/utils/banner.d.ts +28 -0
  133. package/dist/utils/banner.d.ts.map +1 -0
  134. package/dist/utils/banner.js +77 -0
  135. package/dist/utils/banner.js.map +1 -0
  136. package/dist/utils/banner.spec.d.ts +5 -0
  137. package/dist/utils/banner.spec.d.ts.map +1 -0
  138. package/dist/utils/banner.spec.js +253 -0
  139. package/dist/utils/banner.spec.js.map +1 -0
  140. package/dist/utils/confidence.d.ts +41 -0
  141. package/dist/utils/confidence.d.ts.map +1 -0
  142. package/dist/utils/confidence.js +101 -0
  143. package/dist/utils/confidence.js.map +1 -0
  144. package/dist/utils/datamodel.d.ts +41 -0
  145. package/dist/utils/datamodel.d.ts.map +1 -0
  146. package/dist/utils/datamodel.js +535 -0
  147. package/dist/utils/datamodel.js.map +1 -0
  148. package/dist/utils/dna-detector.d.ts +61 -0
  149. package/dist/utils/dna-detector.d.ts.map +1 -0
  150. package/dist/utils/dna-detector.js +354 -0
  151. package/dist/utils/dna-detector.js.map +1 -0
  152. package/dist/utils/dna-facts.d.ts +13 -0
  153. package/dist/utils/dna-facts.d.ts.map +1 -0
  154. package/dist/utils/dna-facts.js +109 -0
  155. package/dist/utils/dna-facts.js.map +1 -0
  156. package/dist/utils/excalidraw-renderer.d.ts +11 -71
  157. package/dist/utils/excalidraw-renderer.d.ts.map +1 -1
  158. package/dist/utils/excalidraw-renderer.js +29 -162
  159. package/dist/utils/excalidraw-renderer.js.map +1 -1
  160. package/dist/utils/graph-renderer.d.ts +115 -0
  161. package/dist/utils/graph-renderer.d.ts.map +1 -0
  162. package/dist/utils/graph-renderer.js +216 -0
  163. package/dist/utils/graph-renderer.js.map +1 -0
  164. package/dist/utils/migration.d.ts +64 -0
  165. package/dist/utils/migration.d.ts.map +1 -0
  166. package/dist/utils/migration.js +183 -0
  167. package/dist/utils/migration.js.map +1 -0
  168. package/dist/utils/module-detector.d.ts +46 -0
  169. package/dist/utils/module-detector.d.ts.map +1 -0
  170. package/dist/utils/module-detector.js +348 -0
  171. package/dist/utils/module-detector.js.map +1 -0
  172. package/dist/utils/project-generator.js +252 -252
  173. package/dist/utils/reverse-facts.d.ts +50 -0
  174. package/dist/utils/reverse-facts.d.ts.map +1 -0
  175. package/dist/utils/reverse-facts.js +291 -0
  176. package/dist/utils/reverse-facts.js.map +1 -0
  177. package/dist/utils/stack-bootstrap.js +371 -371
  178. package/package.json +8 -3
  179. package/templates/DARE-dag-example.yaml +280 -280
  180. package/templates/UPDATE-MANIFEST.json +48 -48
  181. package/templates/backend/node-nestjs/.env.example +9 -9
  182. package/templates/backend/node-nestjs/nest-cli.json +8 -8
  183. package/templates/backend/node-nestjs/package.json +50 -50
  184. package/templates/backend/node-nestjs/src/app.controller.ts +12 -12
  185. package/templates/backend/node-nestjs/src/app.module.ts +15 -15
  186. package/templates/backend/node-nestjs/src/app.service.ts +8 -8
  187. package/templates/backend/node-nestjs/src/main.ts +24 -24
  188. package/templates/backend/node-nestjs/tsconfig.json +21 -21
  189. package/templates/backend/php-laravel/.env.example +22 -22
  190. package/templates/backend/php-laravel/app/Http/Controllers/HealthController.php +15 -15
  191. package/templates/backend/php-laravel/composer.json +40 -40
  192. package/templates/backend/python-fastapi/.env.example +4 -4
  193. package/templates/backend/python-fastapi/app/api/router.py +8 -8
  194. package/templates/backend/python-fastapi/app/core/config.py +20 -20
  195. package/templates/backend/python-fastapi/main.py +35 -35
  196. package/templates/backend/python-fastapi/requirements.txt +13 -13
  197. package/templates/backend/rust-axum/.env.example +3 -3
  198. package/templates/backend/rust-axum/Cargo.toml +23 -23
  199. package/templates/backend/rust-axum/src/errors.rs +30 -30
  200. package/templates/backend/rust-axum/src/main.rs +32 -32
  201. package/templates/backend/rust-axum/src/routes.rs +6 -6
  202. package/templates/frontend/leptos-csr/.cargo/config.toml +2 -2
  203. package/templates/frontend/leptos-csr/Cargo.toml +16 -16
  204. package/templates/frontend/leptos-csr/Trunk.toml +10 -10
  205. package/templates/frontend/leptos-csr/index.html +11 -11
  206. package/templates/frontend/leptos-csr/src/lib.rs +20 -20
  207. package/templates/frontend/leptos-csr/style/main.scss +19 -19
  208. package/templates/frontend/leptos-fullstack/.cargo/config.toml +4 -4
  209. package/templates/frontend/leptos-fullstack/Cargo.toml +56 -56
  210. package/templates/frontend/leptos-fullstack/src/app.rs +49 -49
  211. package/templates/frontend/leptos-fullstack/src/lib.rs +9 -9
  212. package/templates/frontend/leptos-fullstack/src/main.rs +29 -29
  213. package/templates/frontend/leptos-fullstack/style/main.scss +19 -19
  214. package/templates/frontend/react/index.html +12 -12
  215. package/templates/frontend/react/package.json +35 -35
  216. package/templates/frontend/react/src/App.tsx +25 -25
  217. package/templates/frontend/react/src/main.tsx +9 -9
  218. package/templates/frontend/vue/package.json +32 -32
  219. package/templates/frontend/vue/src/App.vue +7 -7
  220. package/templates/frontend/vue/src/main.ts +10 -10
  221. package/templates/frontend/vue/src/router/index.ts +14 -14
  222. package/templates/frontend/vue/src/views/HomeView.vue +6 -6
  223. package/templates/hooks/pre-commit-dare-validate +24 -24
  224. package/templates/ide/antigravity/.agents/skills/dare-ax/SKILL.md +152 -0
  225. package/templates/ide/antigravity/.agents/skills/dare-dag-build/SKILL.md +154 -0
  226. package/templates/ide/antigravity/.agents/skills/dare-dag-run/SKILL.md +130 -0
  227. package/templates/ide/antigravity/.agents/skills/dare-dag-runner/SKILL.md +203 -203
  228. package/templates/ide/antigravity/.agents/skills/dare-dna/SKILL.md +63 -0
  229. package/templates/ide/antigravity/.agents/skills/dare-docker/SKILL.md +315 -0
  230. package/templates/ide/antigravity/.agents/skills/dare-frontend-design/SKILL.md +192 -0
  231. package/templates/ide/antigravity/.agents/skills/dare-laravel-api/SKILL.md +337 -0
  232. package/templates/ide/antigravity/.agents/skills/dare-layered-design/SKILL.md +166 -0
  233. package/templates/ide/antigravity/.agents/skills/dare-llm-integration/SKILL.md +217 -0
  234. package/templates/ide/antigravity/.agents/skills/dare-migrate/SKILL.md +61 -0
  235. package/templates/ide/antigravity/.agents/skills/dare-quality-telemetry/SKILL.md +187 -0
  236. package/templates/ide/antigravity/.agents/skills/dare-realtime/SKILL.md +217 -0
  237. package/templates/ide/antigravity/.agents/skills/dare-refine/SKILL.md +114 -114
  238. package/templates/ide/antigravity/.agents/skills/dare-reverse/SKILL.md +108 -0
  239. package/templates/ide/antigravity/.agents/skills/dare-review/SKILL.md +111 -111
  240. package/templates/ide/antigravity/.agents/skills/dare-rust-leptos/SKILL.md +263 -0
  241. package/templates/ide/antigravity/.agents/skills/dare-rust-workspace/SKILL.md +275 -275
  242. package/templates/ide/antigravity/.agents/skills/dare-security/SKILL.md +274 -0
  243. package/templates/ide/antigravity/.agents/skills/dare-tasks/SKILL.md +265 -265
  244. package/templates/ide/antigravity/.agents/skills/dare-telemetry/SKILL.md +188 -0
  245. package/templates/ide/antigravity/.agents/skills/skill-fastapi-api/SKILL.md +343 -0
  246. package/templates/ide/antigravity/.agents/skills/skill-go-gin-api/SKILL.md +377 -0
  247. package/templates/ide/antigravity/.agents/skills/skill-mcp-server/SKILL.md +382 -0
  248. package/templates/ide/antigravity/.agents/skills/skill-nestjs-api/SKILL.md +326 -0
  249. package/templates/ide/antigravity/.agents/skills/skill-rails-api/SKILL.md +393 -0
  250. package/templates/ide/antigravity/templates/BLUEPRINT-template.md +193 -193
  251. package/templates/ide/antigravity/templates/DESIGN-template.md +129 -129
  252. package/templates/ide/antigravity/templates/TASK-SPEC-template.md +141 -141
  253. package/templates/ide/claude/.claude/commands/dare-ax.md +131 -0
  254. package/templates/ide/claude/.claude/commands/dare-blueprint.md +134 -134
  255. package/templates/ide/claude/.claude/commands/dare-bugfix-design.md +119 -0
  256. package/templates/ide/claude/.claude/commands/dare-dag-build.md +151 -151
  257. package/templates/ide/claude/.claude/commands/dare-dag-run.md +109 -109
  258. package/templates/ide/claude/.claude/commands/dare-dag-runner.md +117 -0
  259. package/templates/ide/claude/.claude/commands/dare-dag-viz.md +197 -197
  260. package/templates/ide/claude/.claude/commands/dare-design.md +69 -69
  261. package/templates/ide/claude/.claude/commands/dare-dna.md +75 -0
  262. package/templates/ide/claude/.claude/commands/dare-docker.md +207 -0
  263. package/templates/ide/claude/.claude/commands/dare-execute.md +152 -152
  264. package/templates/ide/claude/.claude/commands/dare-feature-design.md +147 -0
  265. package/templates/ide/claude/.claude/commands/dare-frontend-design.md +149 -0
  266. package/templates/ide/claude/.claude/commands/dare-laravel-api.md +211 -0
  267. package/templates/ide/claude/.claude/commands/dare-layered-design.md +124 -0
  268. package/templates/ide/claude/.claude/commands/dare-llm-integration.md +148 -0
  269. package/templates/ide/claude/.claude/commands/dare-migrate.md +72 -0
  270. package/templates/ide/claude/.claude/commands/dare-quality-telemetry.md +166 -0
  271. package/templates/ide/claude/.claude/commands/dare-realtime.md +159 -0
  272. package/templates/ide/claude/.claude/commands/dare-refine.md +145 -145
  273. package/templates/ide/claude/.claude/commands/dare-reverse.md +139 -0
  274. package/templates/ide/claude/.claude/commands/dare-review.md +113 -113
  275. package/templates/ide/claude/.claude/commands/dare-rust-leptos.md +269 -269
  276. package/templates/ide/claude/.claude/commands/dare-rust-workspace.md +209 -209
  277. package/templates/ide/claude/.claude/commands/dare-security.md +232 -232
  278. package/templates/ide/claude/.claude/commands/dare-tasks.md +70 -70
  279. package/templates/ide/claude/.claude/commands/dare-telemetry.md +132 -0
  280. package/templates/ide/claude/.claude/commands/skill-fastapi-api.md +205 -0
  281. package/templates/ide/claude/.claude/commands/skill-go-gin-api.md +232 -0
  282. package/templates/ide/claude/.claude/commands/skill-mcp-server.md +228 -0
  283. package/templates/ide/claude/.claude/commands/skill-nestjs-api.md +210 -0
  284. package/templates/ide/claude/.claude/commands/skill-rails-api.md +236 -0
  285. package/templates/ide/claude/.claude/settings.example.json +35 -35
  286. package/templates/ide/claude/CLAUDE.md +146 -146
  287. package/templates/ide/claude/templates/BLUEPRINT-template.md +193 -193
  288. package/templates/ide/claude/templates/DESIGN-template.md +129 -129
  289. package/templates/ide/claude/templates/TASK-SPEC-template.md +141 -141
  290. package/templates/ide/cursor/.cursor/commands/dag-viz.md +139 -0
  291. package/templates/ide/cursor/.cursor/commands/generate-blueprint.md +86 -86
  292. package/templates/ide/cursor/.cursor/commands/generate-design.md +35 -35
  293. package/templates/ide/cursor/.cursor/commands/generate-tasks.md +184 -184
  294. package/templates/ide/cursor/.cursor/commands/refine-task.md +107 -107
  295. package/templates/ide/cursor/.cursor/commands/review-task.md +91 -91
  296. package/templates/ide/cursor/.cursor/commands/run-dag.md +110 -110
  297. package/templates/ide/cursor/.cursor/rules/skill-ax.mdc +263 -0
  298. package/templates/ide/cursor/.cursor/rules/skill-dag-build.mdc +173 -0
  299. package/templates/ide/cursor/.cursor/rules/skill-dag-run.mdc +134 -0
  300. package/templates/ide/cursor/.cursor/rules/skill-dag-runner.mdc +221 -221
  301. package/templates/ide/cursor/.cursor/rules/skill-dna.mdc +63 -0
  302. package/templates/ide/cursor/.cursor/rules/skill-fastapi-api.mdc +352 -0
  303. package/templates/ide/cursor/.cursor/rules/skill-frontend-design.mdc +244 -0
  304. package/templates/ide/cursor/.cursor/rules/skill-go-gin-api.mdc +371 -0
  305. package/templates/ide/cursor/.cursor/rules/skill-layered-design.mdc +266 -0
  306. package/templates/ide/cursor/.cursor/rules/skill-llm-integration.mdc +295 -0
  307. package/templates/ide/cursor/.cursor/rules/skill-mcp-server.mdc +367 -0
  308. package/templates/ide/cursor/.cursor/rules/skill-migrate.mdc +58 -0
  309. package/templates/ide/cursor/.cursor/rules/skill-nestjs-api.mdc +346 -0
  310. package/templates/ide/cursor/.cursor/rules/skill-quality-telemetry.mdc +248 -0
  311. package/templates/ide/cursor/.cursor/rules/skill-rails-api.mdc +400 -0
  312. package/templates/ide/cursor/.cursor/rules/skill-realtime.mdc +262 -0
  313. package/templates/ide/cursor/.cursor/rules/skill-reverse.mdc +107 -0
  314. package/templates/ide/cursor/.cursor/rules/skill-rust-leptos.mdc +281 -0
  315. package/templates/ide/cursor/.cursor/rules/skill-rust-workspace.mdc +312 -312
  316. package/templates/ide/cursor/.cursor/rules/skill-security.mdc +245 -245
  317. package/templates/ide/cursor/templates/BLUEPRINT-template.md +193 -193
  318. package/templates/ide/cursor/templates/DESIGN-template.md +129 -129
  319. package/templates/ide/cursor/templates/TASK-SPEC-template.md +141 -141
  320. package/templates/shared/docker-compose.yml +41 -41
  321. package/dist/__tests__/dag-runner/adapters.test.d.ts +0 -2
  322. package/dist/__tests__/dag-runner/adapters.test.d.ts.map +0 -1
  323. package/dist/__tests__/dag-runner/adapters.test.js +0 -134
  324. package/dist/__tests__/dag-runner/adapters.test.js.map +0 -1
  325. package/dist/dag-runner/adapters/antigravity.d.ts +0 -6
  326. package/dist/dag-runner/adapters/antigravity.d.ts.map +0 -1
  327. package/dist/dag-runner/adapters/antigravity.js +0 -54
  328. package/dist/dag-runner/adapters/antigravity.js.map +0 -1
  329. package/dist/dag-runner/adapters/claude.d.ts +0 -6
  330. package/dist/dag-runner/adapters/claude.d.ts.map +0 -1
  331. package/dist/dag-runner/adapters/claude.js +0 -48
  332. package/dist/dag-runner/adapters/claude.js.map +0 -1
  333. package/dist/dag-runner/adapters/cursor.d.ts +0 -6
  334. package/dist/dag-runner/adapters/cursor.d.ts.map +0 -1
  335. package/dist/dag-runner/adapters/cursor.js +0 -58
  336. package/dist/dag-runner/adapters/cursor.js.map +0 -1
  337. package/dist/dag-runner/adapters/index.d.ts +0 -46
  338. package/dist/dag-runner/adapters/index.d.ts.map +0 -1
  339. package/dist/dag-runner/adapters/index.js +0 -55
  340. package/dist/dag-runner/adapters/index.js.map +0 -1
  341. package/dist/dag-runner/utils/timeout.d.ts +0 -27
  342. package/dist/dag-runner/utils/timeout.d.ts.map +0 -1
  343. package/dist/dag-runner/utils/timeout.js +0 -55
  344. package/dist/dag-runner/utils/timeout.js.map +0 -1
@@ -1,35 +1,35 @@
1
- # Comando: /generate-design
2
-
3
- ## Descrição
4
- Inicia o Método DARE (fase Design) gerando `DARE/DESIGN.md` a partir de uma ideia inicial.
5
-
6
- ## Instruções para o Cursor Composer
7
-
8
- 1. **Leia o contexto:** `package.json` / `Cargo.toml` / `composer.json` / `go.mod` / `requirements.txt` para identificar a stack atual. Leia `.cursorrules` para entender padrões do projeto. Se `DARE/DESIGN.md` já existir, não sobrescreva sem aprovação explícita.
9
-
10
- 2. **Leia o template:** `templates/DESIGN-template.md` — siga a estrutura fielmente.
11
-
12
- 3. **Gere `DARE/DESIGN.md` com as seções obrigatórias:**
13
-
14
- - **Descrição** — 3 a 5 frases: o que é, qual problema resolve, quem usa
15
- - **Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica
16
- - **Stakeholders** — tabela: papel, time, interesse principal
17
- - **Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite
18
- - **Requisitos Não-Funcionais** — tabela numerada (RNF-01…): performance, disponibilidade, segurança, observabilidade, manutenibilidade
19
- - **Requisitos de Segurança** — tabela numerada (RS-01…). **Sempre inclua:**
20
- - RS-01: validação de entrada no servidor (OWASP A03)
21
- - RS-02: hash de senhas / proteção de dados sensíveis (OWASP A02)
22
- - RS-03: controle de acesso por recurso (OWASP A01)
23
- - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
24
- - RS-05: secrets via variáveis de ambiente — nunca em código
25
- - Requisitos específicos do domínio do projeto
26
- - **Stack Técnica** — tabela por camada com versões fixas
27
- - **Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados, responsável
28
- - **Restrições** — prazo, orçamento, técnicas, compliance
29
- - **Fora do Escopo (v1)** — lista explícita
30
- - **Riscos e Mitigações** — tabela com probabilidade, impacto e mitigação concreta
31
- - **Checklist de Aprovação** — checkboxes para revisão humana
32
-
33
- 4. **Qualidade:** O DESIGN.md deve responder claramente: O QUÊ, POR QUÊ, PARA QUEM, O QUE NÃO e QUAIS RISCOS. Use "[A definir]" para informações não disponíveis, mas nunca omita seções.
34
-
35
- 5. **Salve** `DARE/DESIGN.md` e informe: _"DESIGN.md gerado. Revise as seções, especialmente os Requisitos de Segurança (RS-*) e Riscos. Quando aprovado, execute `/generate-blueprint`."_
1
+ # Comando: /generate-design
2
+
3
+ ## Descrição
4
+ Inicia o Método DARE (fase Design) gerando `DARE/DESIGN.md` a partir de uma ideia inicial.
5
+
6
+ ## Instruções para o Cursor Composer
7
+
8
+ 1. **Leia o contexto:** `package.json` / `Cargo.toml` / `composer.json` / `go.mod` / `requirements.txt` para identificar a stack atual. Leia `.cursorrules` para entender padrões do projeto. Se `DARE/DESIGN.md` já existir, não sobrescreva sem aprovação explícita.
9
+
10
+ 2. **Leia o template:** `templates/DESIGN-template.md` — siga a estrutura fielmente.
11
+
12
+ 3. **Gere `DARE/DESIGN.md` com as seções obrigatórias:**
13
+
14
+ - **Descrição** — 3 a 5 frases: o que é, qual problema resolve, quem usa
15
+ - **Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica
16
+ - **Stakeholders** — tabela: papel, time, interesse principal
17
+ - **Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite
18
+ - **Requisitos Não-Funcionais** — tabela numerada (RNF-01…): performance, disponibilidade, segurança, observabilidade, manutenibilidade
19
+ - **Requisitos de Segurança** — tabela numerada (RS-01…). **Sempre inclua:**
20
+ - RS-01: validação de entrada no servidor (OWASP A03)
21
+ - RS-02: hash de senhas / proteção de dados sensíveis (OWASP A02)
22
+ - RS-03: controle de acesso por recurso (OWASP A01)
23
+ - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
24
+ - RS-05: secrets via variáveis de ambiente — nunca em código
25
+ - Requisitos específicos do domínio do projeto
26
+ - **Stack Técnica** — tabela por camada com versões fixas
27
+ - **Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados, responsável
28
+ - **Restrições** — prazo, orçamento, técnicas, compliance
29
+ - **Fora do Escopo (v1)** — lista explícita
30
+ - **Riscos e Mitigações** — tabela com probabilidade, impacto e mitigação concreta
31
+ - **Checklist de Aprovação** — checkboxes para revisão humana
32
+
33
+ 4. **Qualidade:** O DESIGN.md deve responder claramente: O QUÊ, POR QUÊ, PARA QUEM, O QUE NÃO e QUAIS RISCOS. Use "[A definir]" para informações não disponíveis, mas nunca omita seções.
34
+
35
+ 5. **Salve** `DARE/DESIGN.md` e informe: _"DESIGN.md gerado. Revise as seções, especialmente os Requisitos de Segurança (RS-*) e Riscos. Quando aprovado, execute `/generate-blueprint`."_
@@ -1,184 +1,184 @@
1
- # Comando: /generate-tasks
2
-
3
- ## Descrição
4
- Avança o Método DARE lendo o Blueprint aprovado e gerando os **três artefatos**
5
- da fase de execução: `TASKS.md` (visão humana), `dare-dag.yaml` (grafo
6
- executável pelo CLI) e `EXECUTION/task-<id>.md` (specs detalhadas por task).
7
-
8
- ## Pré-requisitos
9
-
10
- - `DARE/BLUEPRINT.md` aprovado pelo usuário.
11
- - Você deve seguir as regras de construção do DAG definidas em
12
- `.cursor/rules/skill-dag-runner.mdc` — leia antes de gerar.
13
-
14
- ## Instruções para o Cursor Composer
15
-
16
- ### 1. Ler o contexto
17
-
18
- - Leia `$ARGUMENTS` (geralmente `DARE/BLUEPRINT.md`).
19
- - Leia os templates: `templates/TASKS-template.md` e `templates/TASK-SPEC-template.md`.
20
- - Leia `.cursorrules` para convenções do projeto.
21
- - Leia a skill `skill-dag-runner.mdc` para regras de DAG (depends_on mínimo,
22
- complexity, prompt self-contained, output cap 4000, parent context 2000).
23
-
24
- ### 2. Decompor o Blueprint em tasks atômicas
25
-
26
- - Cada fase do Blueprint vira tasks pequenas o suficiente para um único prompt
27
- do Composer.
28
- - Tarefas de segurança (FormRequests, middlewares, Bcrypt, rate limit) devem
29
- ter tasks específicas ou estar explícitas nas tasks relevantes.
30
- - Atribua `complexity` a cada task: LOW / MED / HIGH.
31
-
32
- #### Regras inegociáveis de ordenação
33
-
34
- 1. **A primeira task deve preparar o ambiente local** — Dockerfile +
35
- `docker-compose.yml` + healthcheck. Sem isso o Ralph Loop não tem onde
36
- rodar build/test/lint. Exceção: projeto que já vive em monorepo
37
- containerizado.
38
- 2. **Não crie task "Ralph Loop final" / "Hardening final"** — o Ralph Loop
39
- roda automático em cada `dare execute --complete`. Não é uma task; é um
40
- gate por task.
41
- 3. **Tests devem ter assertions reais** desde a task que os escreve.
42
- Placeholders (`assertTrue(true)` etc.) fazem o gate `test` falhar e a
43
- task vai para FAILED.
44
-
45
- ### 3. Gerar `DARE/TASKS.md` (visão humana)
46
-
47
- Tabela com todas as tasks e dependências em formato legível:
48
-
49
- ```markdown
50
- | ID | Título | Status | Depends On | Complexity |
51
- |----------|---------------------------|-------------|------------------|------------|
52
- | task-001 | Setup project structure | ⏳ PENDING | — | LOW |
53
- | task-002 | DB migrations | ⏳ PENDING | — | MED |
54
- | task-003 | Auth controllers | ⏳ PENDING | task-001, 002 | HIGH |
55
- ```
56
-
57
- Inclua: total de tasks, fases agrupadas, tempo estimado, próximos passos.
58
-
59
- ### 4. Gerar `DARE/dare-dag.yaml` (grafo executável)
60
-
61
- Schema canônico (alinhado com `skill-dag-runner.mdc`):
62
-
63
- ```yaml
64
- title: "<Nome do Projeto> - Development Tasks"
65
- version: "1.0.0"
66
-
67
- limits:
68
- parent_context_chars: 2000
69
- task_output_chars: 4000
70
- timeout_seconds: 600
71
-
72
- models:
73
- cursor: { HIGH: gpt-5.3-codex, MED: composer-2, LOW: auto-low }
74
- claude: { HIGH: claude-sonnet-4-5, MED: claude-haiku-4, LOW: claude-haiku-4 }
75
- antigravity: { HIGH: gemini-2.5-pro, MED: gemini-2.5-flash, LOW: gemini-2.5-flash }
76
-
77
- tasks:
78
- - id: task-001
79
- title: "Setup project structure"
80
- depends_on: []
81
- complexity: LOW
82
- spec_file: EXECUTION/task-001.md
83
- subtask_prompt: |
84
- Setup base project structure following DARE/BLUEPRINT.md.
85
- Create directories: src/, tests/, docs/. Initialize package files.
86
- No business logic yet. Validation gate: project builds.
87
- ```
88
-
89
- **Regras inegociáveis:**
90
- - `id` em kebab-case e único.
91
- - `depends_on` mínimo — só adicione quando a task filha **literalmente** não
92
- pode começar sem o output da pai (arquivo, schema, decisão exportada).
93
- - `subtask_prompt` totalmente self-contained (o subagente recebe só ele +
94
- snippets de 2000 chars dos pais).
95
- - Pelo menos 2 tasks no rank 0 (com `depends_on: []`) para haver paralelismo
96
- real.
97
- - Cadeia linear (`001 → 002 → 003 → ...`) é antipattern. Reanalise.
98
-
99
- ### 5. Gerar `DARE/EXECUTION/task-<id>.md` (uma spec por task)
100
-
101
- Para CADA task em `dare-dag.yaml`, crie a spec correspondente seguindo
102
- `templates/TASK-SPEC-template.md`:
103
-
104
- - **Objetivo** claro
105
- - **Arquivos a criar/modificar**
106
- - **Validation Gates** (build, test, lint específicos da stack)
107
- - **Testes esperados**
108
- - **Considerações de segurança**
109
- - **Próxima task** sugerida
110
-
111
- O `subtask_prompt` no YAML pode referenciar a spec via
112
- `spec_file: EXECUTION/task-<id>.md` para que o subagente leia a spec na hora
113
- de executar.
114
-
115
- ### 5.1 ANTI-STUB CONTRACT (inegociável)
116
-
117
- > Tasks geradas com `subtask_prompt` ou spec genéricos forçam o agente a inventar — e ele vai produzir mock, stub ou esqueleto. **Não é negociável**. O comando `dare review <task-id>` (v2.17+) detecta isso e marca a task como FAILED.
118
-
119
- Cada `subtask_prompt` e `EXECUTION/task-<id>.md` deve atender este contrato:
120
-
121
- **O `subtask_prompt` deve ser auto-suficiente**
122
-
123
- O subagente recebe **apenas** o `subtask_prompt` + snippets de 2000 chars dos pais. Tudo que ele precisa para implementar **sem inventar** deve estar ali ou na `spec_file`. Inclua:
124
-
125
- - Caminho exato dos arquivos a criar/modificar
126
- - Assinaturas exatas das funções/endpoints (`fn name(params: T) -> R`)
127
- - Schema de request/response com tipos
128
- - Validações específicas (não "validar input" — `email: regex /^.../`, `senha: ≥ 8 chars + 1 maiúscula + 1 dígito`)
129
- - Edge cases enumerados (input vazio, duplicado, expirado, sem permissão)
130
- - Lista de testes esperados com nome + comportamento (`should_reject_duplicate_email_with_409`)
131
-
132
- **A `spec_file` (`EXECUTION/task-<id>.md`) deve ter Definition of Done anti-stub:**
133
-
134
- ```markdown
135
- ## Definition of Done (ANTI-STUB)
136
-
137
- - [ ] Nenhum `TODO`, `FIXME`, `XXX` ou `HACK` em arquivos modificados
138
- - [ ] Nenhuma função vazia (`fn x() {}`, `def x(): pass`, `function x() {}`)
139
- - [ ] Nenhum `throw new Error('not implemented')`, `unimplemented!()`, `todo!()`, `NotImplementedError`
140
- - [ ] Nenhum `return null` / `return undefined` / `return {}` como única statement de função pública
141
- - [ ] Mocks **somente** dentro de `*.test.*`, `*.spec.*`, `__tests__/`, `tests/`, `spec/` — NUNCA em código de produção
142
- - [ ] Todos os endpoints declarados na seção 3 retornam dados reais (não fixos / hardcoded)
143
- - [ ] Cada validação da spec produz erro real com status code correto (testado)
144
- - [ ] Cada edge case da spec tem teste unitário ou integração demonstrando comportamento
145
- ```
146
-
147
- **Verificação automatizável:** o agente que executar a task vai rodar `dare review <id>` antes de marcar DONE. Se a review falhar, a task volta para revisão.
148
-
149
- **Sinais de spec rasa** (auto-validar antes de salvar):
150
-
151
- - ❌ "Implementar X" — sem assinatura, sem retorno, sem validações
152
- - ❌ "Tratar erros adequadamente" — quais erros? como? que código?
153
- - ❌ "Adicionar validações" — quais regras?
154
- - ❌ Arquivos listados sem dizer **o que cada um contém**
155
- - ✅ "Implementar `POST /auth/login` retornando `{ token: string, refresh: string }` com 200 se credenciais válidas, 401 se inválidas, 429 se rate limit"
156
-
157
- ### 6. Validar consistência dos 3 artefatos
158
-
159
- - Mesmos `id`s em `TASKS.md`, `dare-dag.yaml` e `EXECUTION/task-*.md`.
160
- - Mesmas `depends_on` em `TASKS.md` e `dare-dag.yaml`.
161
- - Mesmas `complexity`.
162
- - Sem ciclos.
163
-
164
- ### 7. Regenerar a visualização do DAG
165
-
166
- Depois de salvar o `dare-dag.yaml`, rode:
167
-
168
- ```bash
169
- dare dag viz -o DARE/dag-graph.mmd
170
- ```
171
-
172
- Isso reescreve `DARE/dag-graph.mmd` (Mermaid) refletindo o grafo atualizado.
173
- O usuário pode abrir o arquivo no Cursor com a extensão Mermaid Preview.
174
-
175
- ### 8. Mensagem final ao usuário
176
-
177
- > Gerados 4 artefatos da fase de execução:
178
- > - `DARE/TASKS.md` ([N] tasks, visão humana)
179
- > - `DARE/dare-dag.yaml` (grafo executável, [N] ranks paralelos)
180
- > - `DARE/EXECUTION/task-*.md` ([N] specs detalhadas)
181
- > - `DARE/dag-graph.mmd` (visualização Mermaid do DAG)
182
- >
183
- > Revise (abra `dag-graph.mmd` para ver o grafo). Para executar:
184
- > `/run-dag` ou `dare execute --next`.
1
+ # Comando: /generate-tasks
2
+
3
+ ## Descrição
4
+ Avança o Método DARE lendo o Blueprint aprovado e gerando os **três artefatos**
5
+ da fase de execução: `TASKS.md` (visão humana), `dare-dag.yaml` (grafo
6
+ executável pelo CLI) e `EXECUTION/task-<id>.md` (specs detalhadas por task).
7
+
8
+ ## Pré-requisitos
9
+
10
+ - `DARE/BLUEPRINT.md` aprovado pelo usuário.
11
+ - Você deve seguir as regras de construção do DAG definidas em
12
+ `.cursor/rules/skill-dag-runner.mdc` — leia antes de gerar.
13
+
14
+ ## Instruções para o Cursor Composer
15
+
16
+ ### 1. Ler o contexto
17
+
18
+ - Leia `$ARGUMENTS` (geralmente `DARE/BLUEPRINT.md`).
19
+ - Leia os templates: `templates/TASKS-template.md` e `templates/TASK-SPEC-template.md`.
20
+ - Leia `.cursorrules` para convenções do projeto.
21
+ - Leia a skill `skill-dag-runner.mdc` para regras de DAG (depends_on mínimo,
22
+ complexity, prompt self-contained, output cap 4000, parent context 2000).
23
+
24
+ ### 2. Decompor o Blueprint em tasks atômicas
25
+
26
+ - Cada fase do Blueprint vira tasks pequenas o suficiente para um único prompt
27
+ do Composer.
28
+ - Tarefas de segurança (FormRequests, middlewares, Bcrypt, rate limit) devem
29
+ ter tasks específicas ou estar explícitas nas tasks relevantes.
30
+ - Atribua `complexity` a cada task: LOW / MED / HIGH.
31
+
32
+ #### Regras inegociáveis de ordenação
33
+
34
+ 1. **A primeira task deve preparar o ambiente local** — Dockerfile +
35
+ `docker-compose.yml` + healthcheck. Sem isso o Ralph Loop não tem onde
36
+ rodar build/test/lint. Exceção: projeto que já vive em monorepo
37
+ containerizado.
38
+ 2. **Não crie task "Ralph Loop final" / "Hardening final"** — o Ralph Loop
39
+ roda automático em cada `dare execute --complete`. Não é uma task; é um
40
+ gate por task.
41
+ 3. **Tests devem ter assertions reais** desde a task que os escreve.
42
+ Placeholders (`assertTrue(true)` etc.) fazem o gate `test` falhar e a
43
+ task vai para FAILED.
44
+
45
+ ### 3. Gerar `DARE/TASKS.md` (visão humana)
46
+
47
+ Tabela com todas as tasks e dependências em formato legível:
48
+
49
+ ```markdown
50
+ | ID | Título | Status | Depends On | Complexity |
51
+ |----------|---------------------------|-------------|------------------|------------|
52
+ | task-001 | Setup project structure | ⏳ PENDING | — | LOW |
53
+ | task-002 | DB migrations | ⏳ PENDING | — | MED |
54
+ | task-003 | Auth controllers | ⏳ PENDING | task-001, 002 | HIGH |
55
+ ```
56
+
57
+ Inclua: total de tasks, fases agrupadas, tempo estimado, próximos passos.
58
+
59
+ ### 4. Gerar `DARE/dare-dag.yaml` (grafo executável)
60
+
61
+ Schema canônico (alinhado com `skill-dag-runner.mdc`):
62
+
63
+ ```yaml
64
+ title: "<Nome do Projeto> - Development Tasks"
65
+ version: "1.0.0"
66
+
67
+ limits:
68
+ parent_context_chars: 2000
69
+ task_output_chars: 4000
70
+ timeout_seconds: 600
71
+
72
+ models:
73
+ cursor: { HIGH: gpt-5.3-codex, MED: composer-2, LOW: auto-low }
74
+ claude: { HIGH: claude-sonnet-4-5, MED: claude-haiku-4, LOW: claude-haiku-4 }
75
+ antigravity: { HIGH: gemini-2.5-pro, MED: gemini-2.5-flash, LOW: gemini-2.5-flash }
76
+
77
+ tasks:
78
+ - id: task-001
79
+ title: "Setup project structure"
80
+ depends_on: []
81
+ complexity: LOW
82
+ spec_file: EXECUTION/task-001.md
83
+ subtask_prompt: |
84
+ Setup base project structure following DARE/BLUEPRINT.md.
85
+ Create directories: src/, tests/, docs/. Initialize package files.
86
+ No business logic yet. Validation gate: project builds.
87
+ ```
88
+
89
+ **Regras inegociáveis:**
90
+ - `id` em kebab-case e único.
91
+ - `depends_on` mínimo — só adicione quando a task filha **literalmente** não
92
+ pode começar sem o output da pai (arquivo, schema, decisão exportada).
93
+ - `subtask_prompt` totalmente self-contained (o subagente recebe só ele +
94
+ snippets de 2000 chars dos pais).
95
+ - Pelo menos 2 tasks no rank 0 (com `depends_on: []`) para haver paralelismo
96
+ real.
97
+ - Cadeia linear (`001 → 002 → 003 → ...`) é antipattern. Reanalise.
98
+
99
+ ### 5. Gerar `DARE/EXECUTION/task-<id>.md` (uma spec por task)
100
+
101
+ Para CADA task em `dare-dag.yaml`, crie a spec correspondente seguindo
102
+ `templates/TASK-SPEC-template.md`:
103
+
104
+ - **Objetivo** claro
105
+ - **Arquivos a criar/modificar**
106
+ - **Validation Gates** (build, test, lint específicos da stack)
107
+ - **Testes esperados**
108
+ - **Considerações de segurança**
109
+ - **Próxima task** sugerida
110
+
111
+ O `subtask_prompt` no YAML pode referenciar a spec via
112
+ `spec_file: EXECUTION/task-<id>.md` para que o subagente leia a spec na hora
113
+ de executar.
114
+
115
+ ### 5.1 ANTI-STUB CONTRACT (inegociável)
116
+
117
+ > Tasks geradas com `subtask_prompt` ou spec genéricos forçam o agente a inventar — e ele vai produzir mock, stub ou esqueleto. **Não é negociável**. O comando `dare review <task-id>` (v2.17+) detecta isso e marca a task como FAILED.
118
+
119
+ Cada `subtask_prompt` e `EXECUTION/task-<id>.md` deve atender este contrato:
120
+
121
+ **O `subtask_prompt` deve ser auto-suficiente**
122
+
123
+ O subagente recebe **apenas** o `subtask_prompt` + snippets de 2000 chars dos pais. Tudo que ele precisa para implementar **sem inventar** deve estar ali ou na `spec_file`. Inclua:
124
+
125
+ - Caminho exato dos arquivos a criar/modificar
126
+ - Assinaturas exatas das funções/endpoints (`fn name(params: T) -> R`)
127
+ - Schema de request/response com tipos
128
+ - Validações específicas (não "validar input" — `email: regex /^.../`, `senha: ≥ 8 chars + 1 maiúscula + 1 dígito`)
129
+ - Edge cases enumerados (input vazio, duplicado, expirado, sem permissão)
130
+ - Lista de testes esperados com nome + comportamento (`should_reject_duplicate_email_with_409`)
131
+
132
+ **A `spec_file` (`EXECUTION/task-<id>.md`) deve ter Definition of Done anti-stub:**
133
+
134
+ ```markdown
135
+ ## Definition of Done (ANTI-STUB)
136
+
137
+ - [ ] Nenhum `TODO`, `FIXME`, `XXX` ou `HACK` em arquivos modificados
138
+ - [ ] Nenhuma função vazia (`fn x() {}`, `def x(): pass`, `function x() {}`)
139
+ - [ ] Nenhum `throw new Error('not implemented')`, `unimplemented!()`, `todo!()`, `NotImplementedError`
140
+ - [ ] Nenhum `return null` / `return undefined` / `return {}` como única statement de função pública
141
+ - [ ] Mocks **somente** dentro de `*.test.*`, `*.spec.*`, `__tests__/`, `tests/`, `spec/` — NUNCA em código de produção
142
+ - [ ] Todos os endpoints declarados na seção 3 retornam dados reais (não fixos / hardcoded)
143
+ - [ ] Cada validação da spec produz erro real com status code correto (testado)
144
+ - [ ] Cada edge case da spec tem teste unitário ou integração demonstrando comportamento
145
+ ```
146
+
147
+ **Verificação automatizável:** o agente que executar a task vai rodar `dare review <id>` antes de marcar DONE. Se a review falhar, a task volta para revisão.
148
+
149
+ **Sinais de spec rasa** (auto-validar antes de salvar):
150
+
151
+ - ❌ "Implementar X" — sem assinatura, sem retorno, sem validações
152
+ - ❌ "Tratar erros adequadamente" — quais erros? como? que código?
153
+ - ❌ "Adicionar validações" — quais regras?
154
+ - ❌ Arquivos listados sem dizer **o que cada um contém**
155
+ - ✅ "Implementar `POST /auth/login` retornando `{ token: string, refresh: string }` com 200 se credenciais válidas, 401 se inválidas, 429 se rate limit"
156
+
157
+ ### 6. Validar consistência dos 3 artefatos
158
+
159
+ - Mesmos `id`s em `TASKS.md`, `dare-dag.yaml` e `EXECUTION/task-*.md`.
160
+ - Mesmas `depends_on` em `TASKS.md` e `dare-dag.yaml`.
161
+ - Mesmas `complexity`.
162
+ - Sem ciclos.
163
+
164
+ ### 7. Regenerar a visualização do DAG
165
+
166
+ Depois de salvar o `dare-dag.yaml`, rode:
167
+
168
+ ```bash
169
+ dare dag viz -o DARE/dag-graph.mmd
170
+ ```
171
+
172
+ Isso reescreve `DARE/dag-graph.mmd` (Mermaid) refletindo o grafo atualizado.
173
+ O usuário pode abrir o arquivo no Cursor com a extensão Mermaid Preview.
174
+
175
+ ### 8. Mensagem final ao usuário
176
+
177
+ > Gerados 4 artefatos da fase de execução:
178
+ > - `DARE/TASKS.md` ([N] tasks, visão humana)
179
+ > - `DARE/dare-dag.yaml` (grafo executável, [N] ranks paralelos)
180
+ > - `DARE/EXECUTION/task-*.md` ([N] specs detalhadas)
181
+ > - `DARE/dag-graph.mmd` (visualização Mermaid do DAG)
182
+ >
183
+ > Revise (abra `dag-graph.mmd` para ver o grafo). Para executar:
184
+ > `/run-dag` ou `dare execute --next`.
@@ -1,107 +1,107 @@
1
- # Comando: /refine-task
2
-
3
- ## Descrição
4
-
5
- Analisa a complexidade de uma task e, quando alta, **quebra em sub-tasks menores** com escopo bem delimitado. Pode ser chamada:
6
-
7
- - Automaticamente pela skill `/generate-tasks` após gerar o DAG (para cada task ≥ MED)
8
- - Manualmente pelo dev: `/refine-task task-034`
9
- - Após mudança de escopo: quando o BLUEPRINT mudou e uma task ficou grande
10
-
11
- A camada determinística (heurística de complexidade) é feita pelo CLI: `dare refine <id>`. Este comando adiciona a camada **semântica** — você lê a spec, decide se a quebra é necessária e produz sub-tasks coerentes.
12
-
13
- ## Instruções para o Cursor Composer
14
-
15
- ### 1. Rodar a heurística determinística
16
-
17
- ```bash
18
- dare refine $ARGUMENTS --split --format json > .dare/refine-$ARGUMENTS.json
19
- ```
20
-
21
- Esse JSON traz:
22
- - `report.score`, `report.level` (LOW/MED/HIGH/CRITICAL)
23
- - `report.signals` — explica a pontuação
24
- - `report.recommendsSplit` — true se HIGH/CRITICAL
25
- - `proposal.subtasks` — quebra inicial coarse (por diretório)
26
-
27
- ### 2. Decidir se vale quebrar
28
-
29
- **Quebrar quando:**
30
- - `recommendsSplit: true` (HIGH/CRITICAL)
31
- - Mais de 6 arquivos a criar/modificar
32
- - Mistura responsabilidades (modelo + controller + teste + migration)
33
- - Inclui refactor + feature juntos
34
- - Keyword "pesada" (refactor/migrate/integrate) + score MED+
35
-
36
- **Manter inteira quando:**
37
- - LOW ou MED baixo
38
- - Todos arquivos no mesmo módulo
39
- - Cabe em uma conversa do Composer (15–60 min)
40
-
41
- ### 3. Se quebrar — eixos de split
42
-
43
- | Eixo | Quando |
44
- |---|---|
45
- | **Por camada** | Modelo / Controller / Service / Test separados |
46
- | **Por endpoint** | 4 endpoints REST → 4 sub-tasks |
47
- | **Por feature** | Auth = register + login + refresh → split por verbo |
48
- | **Refactor + feature** | "1. refactor X" + "2. feature Y em cima" |
49
- | **Migration + código** | "1. migration + seeds" + "2. código novo" |
50
-
51
- Cada sub-task precisa de:
52
- - `subtask_prompt` auto-suficiente (Anti-Stub Contract!)
53
- - spec própria em `DARE/EXECUTION/<sub-id>.md`
54
- - `depends_on` mínimo mas correto
55
- - complexity honesta — se sub ainda for HIGH, quebrar de novo
56
-
57
- ### 4. Emitir verdito
58
-
59
- `.dare/refine-verdict-$ARGUMENTS.json`:
60
-
61
- ```json
62
- {
63
- "manageable": false,
64
- "reasons": ["Score 18 (HIGH) — 7 endpoints + migration", "Mistura refactor com features novas"],
65
- "proposedSubtasks": [
66
- {
67
- "id": "task-034a",
68
- "title": "Refactor UserService",
69
- "files": ["src/services/UserService.ts", "tests/services/UserService.test.ts"],
70
- "rationale": "Refactor isolado antes da feature",
71
- "estimatedLevel": "MED"
72
- }
73
- ]
74
- }
75
- ```
76
-
77
- Se manuseável:
78
-
79
- ```json
80
- {
81
- "manageable": true,
82
- "reasons": ["Score 7 (MED), 4 arquivos mesmo módulo, 6 testes"]
83
- }
84
- ```
85
-
86
- ### 5. Aplicar o split
87
-
88
- 1. Edite `DARE/dare-dag.yaml` substituindo a task pelas sub-tasks
89
- 2. Crie as specs em `DARE/EXECUTION/<sub-id>.md` (template + Anti-Stub Contract)
90
- 3. Atualize `DARE/TASKS.md` (visão humana)
91
- 4. Regenere Mermaid: `dare dag viz -o DARE/dag-graph.mmd`
92
- 5. Marque a task original como SPLIT no TASKS.md
93
-
94
- ### 6. Mensagem ao usuário
95
-
96
- Manuseável:
97
- > ✅ Task `$ARGUMENTS` está bem-dimensionada (score X, level Y). Sem split.
98
-
99
- Quebrada:
100
- > 🪓 Task `$ARGUMENTS` quebrada em N sub-tasks: [lista]. Revise com `dare validate` e `dare dag viz`.
101
-
102
- ## Regras inegociáveis
103
-
104
- - Não quebrar tasks LOW
105
- - Não inventar dependências falsas
106
- - Cada sub-task testável independentemente
107
- - Anti-Stub Contract aplica em cada sub-task
1
+ # Comando: /refine-task
2
+
3
+ ## Descrição
4
+
5
+ Analisa a complexidade de uma task e, quando alta, **quebra em sub-tasks menores** com escopo bem delimitado. Pode ser chamada:
6
+
7
+ - Automaticamente pela skill `/generate-tasks` após gerar o DAG (para cada task ≥ MED)
8
+ - Manualmente pelo dev: `/refine-task task-034`
9
+ - Após mudança de escopo: quando o BLUEPRINT mudou e uma task ficou grande
10
+
11
+ A camada determinística (heurística de complexidade) é feita pelo CLI: `dare refine <id>`. Este comando adiciona a camada **semântica** — você lê a spec, decide se a quebra é necessária e produz sub-tasks coerentes.
12
+
13
+ ## Instruções para o Cursor Composer
14
+
15
+ ### 1. Rodar a heurística determinística
16
+
17
+ ```bash
18
+ dare refine $ARGUMENTS --split --format json > .dare/refine-$ARGUMENTS.json
19
+ ```
20
+
21
+ Esse JSON traz:
22
+ - `report.score`, `report.level` (LOW/MED/HIGH/CRITICAL)
23
+ - `report.signals` — explica a pontuação
24
+ - `report.recommendsSplit` — true se HIGH/CRITICAL
25
+ - `proposal.subtasks` — quebra inicial coarse (por diretório)
26
+
27
+ ### 2. Decidir se vale quebrar
28
+
29
+ **Quebrar quando:**
30
+ - `recommendsSplit: true` (HIGH/CRITICAL)
31
+ - Mais de 6 arquivos a criar/modificar
32
+ - Mistura responsabilidades (modelo + controller + teste + migration)
33
+ - Inclui refactor + feature juntos
34
+ - Keyword "pesada" (refactor/migrate/integrate) + score MED+
35
+
36
+ **Manter inteira quando:**
37
+ - LOW ou MED baixo
38
+ - Todos arquivos no mesmo módulo
39
+ - Cabe em uma conversa do Composer (15–60 min)
40
+
41
+ ### 3. Se quebrar — eixos de split
42
+
43
+ | Eixo | Quando |
44
+ |---|---|
45
+ | **Por camada** | Modelo / Controller / Service / Test separados |
46
+ | **Por endpoint** | 4 endpoints REST → 4 sub-tasks |
47
+ | **Por feature** | Auth = register + login + refresh → split por verbo |
48
+ | **Refactor + feature** | "1. refactor X" + "2. feature Y em cima" |
49
+ | **Migration + código** | "1. migration + seeds" + "2. código novo" |
50
+
51
+ Cada sub-task precisa de:
52
+ - `subtask_prompt` auto-suficiente (Anti-Stub Contract!)
53
+ - spec própria em `DARE/EXECUTION/<sub-id>.md`
54
+ - `depends_on` mínimo mas correto
55
+ - complexity honesta — se sub ainda for HIGH, quebrar de novo
56
+
57
+ ### 4. Emitir verdito
58
+
59
+ `.dare/refine-verdict-$ARGUMENTS.json`:
60
+
61
+ ```json
62
+ {
63
+ "manageable": false,
64
+ "reasons": ["Score 18 (HIGH) — 7 endpoints + migration", "Mistura refactor com features novas"],
65
+ "proposedSubtasks": [
66
+ {
67
+ "id": "task-034a",
68
+ "title": "Refactor UserService",
69
+ "files": ["src/services/UserService.ts", "tests/services/UserService.test.ts"],
70
+ "rationale": "Refactor isolado antes da feature",
71
+ "estimatedLevel": "MED"
72
+ }
73
+ ]
74
+ }
75
+ ```
76
+
77
+ Se manuseável:
78
+
79
+ ```json
80
+ {
81
+ "manageable": true,
82
+ "reasons": ["Score 7 (MED), 4 arquivos mesmo módulo, 6 testes"]
83
+ }
84
+ ```
85
+
86
+ ### 5. Aplicar o split
87
+
88
+ 1. Edite `DARE/dare-dag.yaml` substituindo a task pelas sub-tasks
89
+ 2. Crie as specs em `DARE/EXECUTION/<sub-id>.md` (template + Anti-Stub Contract)
90
+ 3. Atualize `DARE/TASKS.md` (visão humana)
91
+ 4. Regenere Mermaid: `dare dag viz -o DARE/dag-graph.mmd`
92
+ 5. Marque a task original como SPLIT no TASKS.md
93
+
94
+ ### 6. Mensagem ao usuário
95
+
96
+ Manuseável:
97
+ > ✅ Task `$ARGUMENTS` está bem-dimensionada (score X, level Y). Sem split.
98
+
99
+ Quebrada:
100
+ > 🪓 Task `$ARGUMENTS` quebrada em N sub-tasks: [lista]. Revise com `dare validate` e `dare dag viz`.
101
+
102
+ ## Regras inegociáveis
103
+
104
+ - Não quebrar tasks LOW
105
+ - Não inventar dependências falsas
106
+ - Cada sub-task testável independentemente
107
+ - Anti-Stub Contract aplica em cada sub-task