@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,197 +1,197 @@
1
- # /dare-dag-viz — Visualizar DAG com Excalidraw
2
-
3
- Gera diagrama interativo `.excalidraw` a partir do `dare-dag.yaml` atual, com cores semânticas por complexidade e status visual das tasks.
4
-
5
- ## O que faz
6
-
7
- 1. **Lê** `DARE/dare-dag.yaml` (grafo de tasks + dependências)
8
- 2. **Mapeia** cada task para um retângulo Excalidraw com:
9
- - Cor baseada em `complexity` (LOW=azul, MED=laranja, HIGH=rosa)
10
- - Status visual (PENDING/RUNNING/DONE/FAILED)
11
- - ID + nome da task
12
- 3. **Agrupa** tasks por `rank` em colunas verticais (swim lanes)
13
- 4. **Cria** setas para cada dependência (`depends_on`)
14
- 5. **Salva** em `DARE/dag-graph.excalidraw`
15
-
16
- Output é um arquivo **editável e interativo** — abre direto em https://excalidraw.com.
17
-
18
- ## Convenções visuais
19
-
20
- Referência: `/docs/DESIGN-TOKENS-EXCALIDRAW.md`
21
-
22
- **Cores por complexidade:**
23
- - 🔵 **Azul** (#e3f2fd) = LOW
24
- - 🟠 **Laranja** (#fff3e0) = MEDIUM
25
- - 🔴 **Rosa** (#fce4ec) = HIGH
26
-
27
- **Status:**
28
- - ⏳ PENDING = cinza, stroke normal
29
- - ⚙️ RUNNING = azul, stroke pontilhado
30
- - ✅ DONE = verde
31
- - ❌ FAILED = vermelho
32
-
33
- **Posicionamento:**
34
- - Cada task ocupa 120×60px
35
- - Tasks no mesmo rank ficam lado a lado (swim lane)
36
- - Setas conectam dependências
37
-
38
- ## Exemplo de output
39
-
40
- Arquivo `DARE/dag-graph.excalidraw` com estrutura:
41
-
42
- ```
43
- Rank 1
44
- ├── task-001 (LOW, DONE)
45
- ├── task-002 (HIGH, PENDING)
46
-
47
- Rank 2
48
- ├── task-003 (MEDIUM, RUNNING) ← depende de task-001
49
- ├── task-004 (LOW, PENDING) ← depende de task-001
50
-
51
- Rank 3
52
- └── task-005 (HIGH, PENDING) ← depende de task-003 e task-004
53
- ```
54
-
55
- ## Como usar
56
-
57
- ### Primeira vez
58
-
59
- ```bash
60
- /dare-dag-viz
61
- ```
62
-
63
- Claude Code vai:
64
- 1. Ler `DARE/dare-dag.yaml`
65
- 2. Gerar JSON `.excalidraw`
66
- 3. Salvar em `DARE/dag-graph.excalidraw`
67
- 4. Output: "✅ DAG gerado — abra em https://excalidraw.com"
68
-
69
- ### Atualizar após mudanças
70
-
71
- Sempre que você atualiza `dare-dag.yaml`:
72
-
73
- ```bash
74
- /dare-dag-viz
75
- ```
76
-
77
- Isso regenera o diagrama com as novas tasks/dependências.
78
-
79
- ### Abrir e editar
80
-
81
- 1. Acesse https://excalidraw.com
82
- 2. File → Open → selecione `DARE/dag-graph.excalidraw`
83
- 3. Edite livremente:
84
- - Mova elementos
85
- - Customize cores/textos
86
- - Adicione anotações
87
- 4. Salve no mesmo arquivo
88
-
89
- Dica: Se editou manualmente e quer regenerar com `dare-dag-viz` de novo, faça backup antes.
90
-
91
- ## Detalhes técnicos
92
-
93
- ### Estrutura do JSON gerado
94
-
95
- ```json
96
- {
97
- "elements": [
98
- {
99
- "id": "task-001",
100
- "type": "rectangle",
101
- "x": 20, "y": 20,
102
- "width": 120, "height": 60,
103
- "backgroundColor": "#e3f2fd",
104
- "stroke": "#1976d2",
105
- "text": "task-001\nSetup Auth\n[LOW]",
106
- "fontSize": 12,
107
- "roundness": { "type": 2, "value": 6 }
108
- },
109
- {
110
- "type": "arrow",
111
- "startBinding": { "elementId": "task-001" },
112
- "endBinding": { "elementId": "task-003" },
113
- "stroke": "#999"
114
- }
115
- ],
116
- "appState": {
117
- "gridMode": "grid",
118
- "gridSize": 20
119
- }
120
- }
121
- ```
122
-
123
- ### Algoritmo de posicionamento
124
-
125
- 1. **Calcular ranks** — depth-first do DAG
126
- ```
127
- rank = 1 + max(rank of dependencies)
128
- ```
129
-
130
- 2. **Agrupar por rank**
131
- ```
132
- Rank 1: [task-001, task-002]
133
- Rank 2: [task-003, task-004]
134
- ```
135
-
136
- 3. **Posicionar**
137
- ```
138
- x = 20 + (taskIndex * 140)
139
- y = 20 + (rank - 1) * 160
140
- ```
141
-
142
- 4. **Desenhar setas**
143
- ```
144
- Para cada depends_on: arrow(source → target)
145
- ```
146
-
147
- ## Campos esperados em dare-dag.yaml
148
-
149
- ```yaml
150
- tasks:
151
- task-001:
152
- name: "Setup Auth"
153
- complexity: "LOW" # ← determina cor
154
- rank: 1 # ← se não existir, é calculado
155
- depends_on: [] # ← usada para setas
156
- status: "DONE" # ← determina stroke/fill
157
- subtask_prompt: "..." # ← (opcional)
158
- ```
159
-
160
- **Campos obrigatórios:** `name`, `complexity`
161
- **Campos opcionais:** `rank` (calculado), `status` (default PENDING), `depends_on` (default [])
162
-
163
- ## Troubleshooting
164
-
165
- ### "File not found: DARE/dare-dag.yaml"
166
- Certifique-se de que está em um projeto DARE. Se não, rode:
167
- ```bash
168
- dare discover
169
- ```
170
-
171
- ### "JSON inválido"
172
- Valide seu `dare-dag.yaml`:
173
- ```bash
174
- dare dag validate
175
- ```
176
-
177
- ### Diagrama muito grande/pequeno
178
- Abra em Excalidraw e ajuste com Ctrl+Mouse ou pinch zoom.
179
-
180
- ## Próximos passos
181
-
182
- - 🎨 Customize as cores em `docs/DESIGN-TOKENS-EXCALIDRAW.md`
183
- - 📤 Exporte para PNG com botão "Export to Image" no Excalidraw
184
- - 🔄 Atualize após cada `dare design` ou `dare execute`
185
- - 📊 Compartilhe com stakeholders (Excalidraw é colaborativo)
186
-
187
- ## Referência de design
188
-
189
- Ver `/docs/DESIGN-TOKENS-EXCALIDRAW.md` para detalhes de cores, fonts, tamanhos, e créditos.
190
-
191
- ## Licença
192
-
193
- Esta skill é parte do DARE CLI e está sob AGPL v3.
194
-
195
- Você pode usar, modificar e compartilhar mas contribuições voltam ao DARE.
196
-
197
- Créditos: Inspiração na [Excalidraw Diagram Skill](https://github.com/coleam00/excalidraw-diagram-skill) por Cole Medin.
1
+ # /dare-dag-viz — Visualizar DAG com Excalidraw
2
+
3
+ Gera diagrama interativo `.excalidraw` a partir do `dare-dag.yaml` atual, com cores semânticas por complexidade e status visual das tasks.
4
+
5
+ ## O que faz
6
+
7
+ 1. **Lê** `DARE/dare-dag.yaml` (grafo de tasks + dependências)
8
+ 2. **Mapeia** cada task para um retângulo Excalidraw com:
9
+ - Cor baseada em `complexity` (LOW=azul, MED=laranja, HIGH=rosa)
10
+ - Status visual (PENDING/RUNNING/DONE/FAILED)
11
+ - ID + nome da task
12
+ 3. **Agrupa** tasks por `rank` em colunas verticais (swim lanes)
13
+ 4. **Cria** setas para cada dependência (`depends_on`)
14
+ 5. **Salva** em `DARE/dag-graph.excalidraw`
15
+
16
+ Output é um arquivo **editável e interativo** — abre direto em https://excalidraw.com.
17
+
18
+ ## Convenções visuais
19
+
20
+ Referência: `/docs/DESIGN-TOKENS-EXCALIDRAW.md`
21
+
22
+ **Cores por complexidade:**
23
+ - 🔵 **Azul** (#e3f2fd) = LOW
24
+ - 🟠 **Laranja** (#fff3e0) = MEDIUM
25
+ - 🔴 **Rosa** (#fce4ec) = HIGH
26
+
27
+ **Status:**
28
+ - ⏳ PENDING = cinza, stroke normal
29
+ - ⚙️ RUNNING = azul, stroke pontilhado
30
+ - ✅ DONE = verde
31
+ - ❌ FAILED = vermelho
32
+
33
+ **Posicionamento:**
34
+ - Cada task ocupa 120×60px
35
+ - Tasks no mesmo rank ficam lado a lado (swim lane)
36
+ - Setas conectam dependências
37
+
38
+ ## Exemplo de output
39
+
40
+ Arquivo `DARE/dag-graph.excalidraw` com estrutura:
41
+
42
+ ```
43
+ Rank 1
44
+ ├── task-001 (LOW, DONE)
45
+ ├── task-002 (HIGH, PENDING)
46
+
47
+ Rank 2
48
+ ├── task-003 (MEDIUM, RUNNING) ← depende de task-001
49
+ ├── task-004 (LOW, PENDING) ← depende de task-001
50
+
51
+ Rank 3
52
+ └── task-005 (HIGH, PENDING) ← depende de task-003 e task-004
53
+ ```
54
+
55
+ ## Como usar
56
+
57
+ ### Primeira vez
58
+
59
+ ```bash
60
+ /dare-dag-viz
61
+ ```
62
+
63
+ Claude Code vai:
64
+ 1. Ler `DARE/dare-dag.yaml`
65
+ 2. Gerar JSON `.excalidraw`
66
+ 3. Salvar em `DARE/dag-graph.excalidraw`
67
+ 4. Output: "✅ DAG gerado — abra em https://excalidraw.com"
68
+
69
+ ### Atualizar após mudanças
70
+
71
+ Sempre que você atualiza `dare-dag.yaml`:
72
+
73
+ ```bash
74
+ /dare-dag-viz
75
+ ```
76
+
77
+ Isso regenera o diagrama com as novas tasks/dependências.
78
+
79
+ ### Abrir e editar
80
+
81
+ 1. Acesse https://excalidraw.com
82
+ 2. File → Open → selecione `DARE/dag-graph.excalidraw`
83
+ 3. Edite livremente:
84
+ - Mova elementos
85
+ - Customize cores/textos
86
+ - Adicione anotações
87
+ 4. Salve no mesmo arquivo
88
+
89
+ Dica: Se editou manualmente e quer regenerar com `dare-dag-viz` de novo, faça backup antes.
90
+
91
+ ## Detalhes técnicos
92
+
93
+ ### Estrutura do JSON gerado
94
+
95
+ ```json
96
+ {
97
+ "elements": [
98
+ {
99
+ "id": "task-001",
100
+ "type": "rectangle",
101
+ "x": 20, "y": 20,
102
+ "width": 120, "height": 60,
103
+ "backgroundColor": "#e3f2fd",
104
+ "stroke": "#1976d2",
105
+ "text": "task-001\nSetup Auth\n[LOW]",
106
+ "fontSize": 12,
107
+ "roundness": { "type": 2, "value": 6 }
108
+ },
109
+ {
110
+ "type": "arrow",
111
+ "startBinding": { "elementId": "task-001" },
112
+ "endBinding": { "elementId": "task-003" },
113
+ "stroke": "#999"
114
+ }
115
+ ],
116
+ "appState": {
117
+ "gridMode": "grid",
118
+ "gridSize": 20
119
+ }
120
+ }
121
+ ```
122
+
123
+ ### Algoritmo de posicionamento
124
+
125
+ 1. **Calcular ranks** — depth-first do DAG
126
+ ```
127
+ rank = 1 + max(rank of dependencies)
128
+ ```
129
+
130
+ 2. **Agrupar por rank**
131
+ ```
132
+ Rank 1: [task-001, task-002]
133
+ Rank 2: [task-003, task-004]
134
+ ```
135
+
136
+ 3. **Posicionar**
137
+ ```
138
+ x = 20 + (taskIndex * 140)
139
+ y = 20 + (rank - 1) * 160
140
+ ```
141
+
142
+ 4. **Desenhar setas**
143
+ ```
144
+ Para cada depends_on: arrow(source → target)
145
+ ```
146
+
147
+ ## Campos esperados em dare-dag.yaml
148
+
149
+ ```yaml
150
+ tasks:
151
+ task-001:
152
+ name: "Setup Auth"
153
+ complexity: "LOW" # ← determina cor
154
+ rank: 1 # ← se não existir, é calculado
155
+ depends_on: [] # ← usada para setas
156
+ status: "DONE" # ← determina stroke/fill
157
+ subtask_prompt: "..." # ← (opcional)
158
+ ```
159
+
160
+ **Campos obrigatórios:** `name`, `complexity`
161
+ **Campos opcionais:** `rank` (calculado), `status` (default PENDING), `depends_on` (default [])
162
+
163
+ ## Troubleshooting
164
+
165
+ ### "File not found: DARE/dare-dag.yaml"
166
+ Certifique-se de que está em um projeto DARE. Se não, rode:
167
+ ```bash
168
+ dare discover
169
+ ```
170
+
171
+ ### "JSON inválido"
172
+ Valide seu `dare-dag.yaml`:
173
+ ```bash
174
+ dare dag validate
175
+ ```
176
+
177
+ ### Diagrama muito grande/pequeno
178
+ Abra em Excalidraw e ajuste com Ctrl+Mouse ou pinch zoom.
179
+
180
+ ## Próximos passos
181
+
182
+ - 🎨 Customize as cores em `docs/DESIGN-TOKENS-EXCALIDRAW.md`
183
+ - 📤 Exporte para PNG com botão "Export to Image" no Excalidraw
184
+ - 🔄 Atualize após cada `dare design` ou `dare execute`
185
+ - 📊 Compartilhe com stakeholders (Excalidraw é colaborativo)
186
+
187
+ ## Referência de design
188
+
189
+ Ver `/docs/DESIGN-TOKENS-EXCALIDRAW.md` para detalhes de cores, fonts, tamanhos, e créditos.
190
+
191
+ ## Licença
192
+
193
+ Esta skill é parte do DARE CLI e está sob licença MIT (D-001).
194
+
195
+ Você pode usar, modificar, compartilhar e distribuir livremente.
196
+
197
+ Créditos: Inspiração na [Excalidraw Diagram Skill](https://github.com/coleam00/excalidraw-diagram-skill) por Cole Medin.
@@ -1,69 +1,69 @@
1
- # /dare-design
2
-
3
- Gera ou atualiza o `DARE/DESIGN.md` a partir de uma descrição do projeto ou feature.
4
-
5
- ## Como usar
6
-
7
- ```
8
- /dare-design Quero uma API REST de autenticação com JWT e refresh token
9
- /dare-design Adicionar módulo de pagamentos com Stripe e webhook
10
- ```
11
-
12
- ## O que fazer
13
-
14
- ### 1. Leia o contexto atual do projeto
15
-
16
- - `package.json` / `composer.json` / `Cargo.toml` / `go.mod` / `requirements.txt` — stack atual
17
- - Estrutura de pastas existente
18
- - `DARE/DESIGN.md` se já existir — não sobrescreva sem aprovação explícita do usuário
19
-
20
- ### 2. Gere `DARE/DESIGN.md` com as seguintes seções obrigatórias
21
-
22
- **2.1 Descrição** — 3 a 5 frases claras: o que é, qual problema resolve, quem usa.
23
-
24
- **2.2 Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica para cada objetivo. Evite objetivos vagos como "melhorar performance" — use "p99 < 200 ms".
25
-
26
- **2.3 Stakeholders** — tabela: papel, nome/time, interesse principal.
27
-
28
- **2.4 Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite verificável para cada um.
29
-
30
- **2.5 Requisitos Não-Funcionais** — tabela numerada (RNF-01…) cobrindo: performance, disponibilidade, segurança (autenticação, rate limiting, segredos), observabilidade, manutenibilidade.
31
-
32
- **2.6 Requisitos de Segurança** — tabela numerada (RS-01…). Inclua **sempre**:
33
- - RS-01: validação de entrada (OWASP A03)
34
- - RS-02: proteção de dados sensíveis / hash de senhas (OWASP A02)
35
- - RS-03: controle de acesso por recurso (OWASP A01)
36
- - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
37
- - RS-05: secrets via variáveis de ambiente — nunca em código
38
- - Adicione requisitos específicos do domínio do projeto
39
-
40
- **2.7 Stack Técnica** — tabela por camada com tecnologia e versão.
41
-
42
- **2.8 Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados trocados, responsável. Inclua apenas integrações confirmadas; marque incertas como "A confirmar".
43
-
44
- **2.9 Restrições** — prazo, orçamento de infra, limitações técnicas, compliance regulatório.
45
-
46
- **2.10 Fora do Escopo (v1)** — lista explícita do que NÃO será feito e o motivo.
47
-
48
- **2.11 Riscos e Mitigações** — tabela: risco, probabilidade (Alta/Média/Baixa), impacto (Alto/Médio/Baixo), mitigação concreta.
49
-
50
- **2.12 Checklist de Aprovação** — checkboxes para o usuário revisar antes de avançar ao `/dare-blueprint`.
51
-
52
- ### 3. Use o template em `templates/DESIGN-template.md`
53
-
54
- Siga o template fielmente. Não omita seções — use "[A definir]" se a informação não estiver disponível ainda, mas deixe a seção explícita para o usuário preencher.
55
-
56
- ### 4. Qualidade esperada
57
-
58
- O DESIGN.md gerado deve permitir que qualquer engenheiro novo no projeto entenda:
59
- - **O QUÊ** vai ser construído (requisitos funcionais)
60
- - **POR QUÊ** (objetivos e métricas)
61
- - **PARA QUEM** (stakeholders e personas)
62
- - **O QUE NÃO** vai ser feito (escopo)
63
- - **QUAIS RISCOS** existem (com mitigação)
64
-
65
- ### 5. Confirme com o usuário antes de prosseguir
66
-
67
- Após gerar o DESIGN.md, apresente um resumo das seções geradas e pergunte se o usuário quer ajustar algo antes de rodar `/dare-blueprint`.
68
-
69
- $ARGUMENTS
1
+ # /dare-design
2
+
3
+ Gera ou atualiza o `DARE/DESIGN.md` a partir de uma descrição do projeto ou feature.
4
+
5
+ ## Como usar
6
+
7
+ ```
8
+ /dare-design Quero uma API REST de autenticação com JWT e refresh token
9
+ /dare-design Adicionar módulo de pagamentos com Stripe e webhook
10
+ ```
11
+
12
+ ## O que fazer
13
+
14
+ ### 1. Leia o contexto atual do projeto
15
+
16
+ - `package.json` / `composer.json` / `Cargo.toml` / `go.mod` / `requirements.txt` — stack atual
17
+ - Estrutura de pastas existente
18
+ - `DARE/DESIGN.md` se já existir — não sobrescreva sem aprovação explícita do usuário
19
+
20
+ ### 2. Gere `DARE/DESIGN.md` com as seguintes seções obrigatórias
21
+
22
+ **2.1 Descrição** — 3 a 5 frases claras: o que é, qual problema resolve, quem usa.
23
+
24
+ **2.2 Objetivos e Métricas de Sucesso** — tabela numerada (O-01, O-02…) com métrica verificável e meta numérica para cada objetivo. Evite objetivos vagos como "melhorar performance" — use "p99 < 200 ms".
25
+
26
+ **2.3 Stakeholders** — tabela: papel, nome/time, interesse principal.
27
+
28
+ **2.4 Requisitos Funcionais** — tabela numerada (RF-01, RF-02…) com prioridade MUST/SHOULD/COULD e critério de aceite verificável para cada um.
29
+
30
+ **2.5 Requisitos Não-Funcionais** — tabela numerada (RNF-01…) cobrindo: performance, disponibilidade, segurança (autenticação, rate limiting, segredos), observabilidade, manutenibilidade.
31
+
32
+ **2.6 Requisitos de Segurança** — tabela numerada (RS-01…). Inclua **sempre**:
33
+ - RS-01: validação de entrada (OWASP A03)
34
+ - RS-02: proteção de dados sensíveis / hash de senhas (OWASP A02)
35
+ - RS-03: controle de acesso por recurso (OWASP A01)
36
+ - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
37
+ - RS-05: secrets via variáveis de ambiente — nunca em código
38
+ - Adicione requisitos específicos do domínio do projeto
39
+
40
+ **2.7 Stack Técnica** — tabela por camada com tecnologia e versão.
41
+
42
+ **2.8 Integrações Externas** — tabela: sistema, tipo, protocolo, direção, dados trocados, responsável. Inclua apenas integrações confirmadas; marque incertas como "A confirmar".
43
+
44
+ **2.9 Restrições** — prazo, orçamento de infra, limitações técnicas, compliance regulatório.
45
+
46
+ **2.10 Fora do Escopo (v1)** — lista explícita do que NÃO será feito e o motivo.
47
+
48
+ **2.11 Riscos e Mitigações** — tabela: risco, probabilidade (Alta/Média/Baixa), impacto (Alto/Médio/Baixo), mitigação concreta.
49
+
50
+ **2.12 Checklist de Aprovação** — checkboxes para o usuário revisar antes de avançar ao `/dare-blueprint`.
51
+
52
+ ### 3. Use o template em `templates/DESIGN-template.md`
53
+
54
+ Siga o template fielmente. Não omita seções — use "[A definir]" se a informação não estiver disponível ainda, mas deixe a seção explícita para o usuário preencher.
55
+
56
+ ### 4. Qualidade esperada
57
+
58
+ O DESIGN.md gerado deve permitir que qualquer engenheiro novo no projeto entenda:
59
+ - **O QUÊ** vai ser construído (requisitos funcionais)
60
+ - **POR QUÊ** (objetivos e métricas)
61
+ - **PARA QUEM** (stakeholders e personas)
62
+ - **O QUE NÃO** vai ser feito (escopo)
63
+ - **QUAIS RISCOS** existem (com mitigação)
64
+
65
+ ### 5. Confirme com o usuário antes de prosseguir
66
+
67
+ Após gerar o DESIGN.md, apresente um resumo das seções geradas e pergunte se o usuário quer ajustar algo antes de rodar `/dare-blueprint`.
68
+
69
+ $ARGUMENTS
@@ -0,0 +1,75 @@
1
+ # /dare-dna
2
+
3
+ Camada semântica da extração de DNA do projeto. Roda **depois** do comando `dare dna`, que já varreu
4
+ o código e extraiu os fatos de convenção. Sua função é **transformar fatos em regras acionáveis** —
5
+ o "como esse codebase faz as coisas" que uma nova feature deve respeitar.
6
+
7
+ ## Como usar
8
+
9
+ ```
10
+ /dare-dna # preenche o PROJECT-DNA.md gerado por `dare dna`
11
+ ```
12
+
13
+ > Pré-requisito: rodar `dare dna` antes (gera `DARE/PROJECT-DNA.md` e `DARE/dna-facts.json`).
14
+ > Se não existirem, instrua o usuário a rodar `dare dna` primeiro.
15
+
16
+ ## Quando usar
17
+
18
+ - Projeto **legado** que vai adotar o DARE para novas features, sem reescrever o existente.
19
+ - Acabou de rodar `dare dna` e o `PROJECT-DNA.md` tem seções `<!-- AGENT -->` em aberto.
20
+ - O objetivo é um **ruleset** que faça o agente seguir o padrão da casa, não o default genérico.
21
+
22
+ ## O que fazer
23
+
24
+ ### 1. Carregar os fatos (não re-varrer tudo)
25
+
26
+ - Leia `DARE/dna-facts.json` — fonte determinística (tooling, naming, camadas, testes, libs, commits).
27
+ - Abra **2-5 arquivos representativos por camada** (um controller, um service, um model, um teste) para
28
+ inferir os padrões que o CLI não detecta (tratamento de erro, validação, estilo de teste).
29
+
30
+ ### 2. Preencher `DARE/PROJECT-DNA.md`
31
+
32
+ Substitua cada bloco `<!-- AGENT: ... -->`:
33
+
34
+ - **Convenções de Nomenclatura** — confirme o estilo detectado e documente exceções (ex.: componentes
35
+ em PascalCase, utilitários em kebab).
36
+ - **Arquitetura & Camadas** — nomeie o padrão com confiança (MVC / Layered / Hexagonal) e escreva as
37
+ **regras de onde cada coisa mora** (ex.: "controllers só orquestram; regra de negócio vai em services;
38
+ acesso a dados só em repositories").
39
+ - **Padrões de Teste** — onde os testes ficam, naming, assertions reais (não `expect(true)`), uso de
40
+ mocks/fixtures.
41
+ - **Tratamento de Erros & Validação** — como o projeto trata erros (exceptions, Result/Either, try/catch)
42
+ e valida inputs. Dê **exemplos concretos** do código real.
43
+ - **Regras de Ouro do Projeto** — liste o que **SEMPRE** e o que **NUNCA** fazer neste codebase.
44
+ - **⚠️ Incertezas / Inconsistências** — convenções ambíguas/misturadas que o humano precisa decidir.
45
+
46
+ **Não toque** nos fatos determinísticos já preenchidos pelo CLI (tooling, tabela de naming, libs).
47
+
48
+ ### 3. Apresentar ao usuário
49
+
50
+ Resumo: arquitetura nomeada, principais regras de ouro, inconsistências encontradas. Reforce que o
51
+ `PROJECT-DNA.md` vira referência para `/dare-feature-design` e `/dare-execute` respeitarem o legado.
52
+
53
+ ## Regras de ouro
54
+
55
+ 1. **Descritivo, não aspiracional** — documente como o código É, não como deveria ser.
56
+ 2. **Exemplos reais** — cite arquivos/trechos do próprio projeto nas regras.
57
+ 3. **Sinalize inconsistência** — se o legado mistura padrões, diga isso em "⚠️ Incertezas", não invente um padrão único.
58
+ 4. **Não re-varra** — os fatos já estão em `dna-facts.json`.
59
+ 5. **Preserve o determinístico** — não reescreva tooling/naming/libs gerados pelo CLI.
60
+
61
+ ## Antipatterns
62
+
63
+ | AP | Antipattern | Por quê |
64
+ |---|---|---|
65
+ | AP-01 | Documentar o padrão "ideal" em vez do real | O agente vai gerar código fora do estilo do legado |
66
+ | AP-02 | Forçar um padrão único onde o legado é inconsistente | Esconde a realidade; melhor sinalizar a incerteza |
67
+ | AP-03 | Reescrever os fatos determinísticos do CLI | Quebra a fonte de verdade |
68
+ | AP-04 | Regras vagas ("siga boas práticas") | Inúteis — o valor está na regra específica do projeto |
69
+ | AP-05 | Ignorar os testes existentes ao descrever o estilo de teste | Nova feature nasce inconsistente |
70
+
71
+ $ARGUMENTS
72
+
73
+ ---
74
+
75
+ Skill MIT — parte do DARE Method. DNA do projeto (brownfield). Pareia com o comando `dare dna`.