@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,269 +1,269 @@
1
- # /dare-rust-leptos
2
-
3
- Guia de desenvolvimento Leptos para projetos DARE. Cobre decisão de variante, idioms obrigatórios, antipatterns, tipos compartilhados e templates de tasks.
4
-
5
- ## Como usar
6
-
7
- ```
8
- /dare-rust-leptos ← decide variante + configura workspace
9
- /dare-rust-leptos --csr ← guia específico para CSR + trunk
10
- /dare-rust-leptos --fullstack ← guia específico para SSR + cargo-leptos
11
- /dare-rust-leptos --shared-types ← padrão cfg_attr para tipos server + WASM
12
- ```
13
-
14
- ---
15
-
16
- ## 1. Decisão de variante: CSR vs Fullstack
17
-
18
- | Critério | CSR (trunk) | Fullstack (cargo-leptos) |
19
- |---|---|---|
20
- | SEO necessário | ❌ | ✅ |
21
- | Time-to-interactive crítico | ❌ | ✅ |
22
- | Dashboard interno / admin | ✅ | ✅ |
23
- | Backend Axum existente | indiferente | ✅ integração direta |
24
- | Simplicidade de deploy | ✅ arquivos estáticos (CDN) | ⚠️ binário Axum |
25
- | Server functions (`#[server]`) | ❌ não existe | ✅ |
26
-
27
- **Regra de ouro:**
28
- - Se o projeto vive atrás de login e SEO não importa → **CSR**
29
- - Se precisa de SEO, carregamento inicial rápido, ou server functions → **Fullstack**
30
- - Se já tem `rust-axum` como backend no monorepo → **Fullstack** (workspace unificado)
31
-
32
- ---
33
-
34
- ## 2. Ferramentas — nunca misturar
35
-
36
- | Variante | Build | Dev server | Test |
37
- |---|---|---|---|
38
- | CSR | `trunk build --release` | `trunk serve` | `cargo test --workspace` |
39
- | Fullstack | `cargo leptos build --release` | `cargo leptos watch` | `cargo test --workspace` |
40
-
41
- > ⚠️ `cargo leptos test` **não existe**. Use sempre `cargo test --workspace`.
42
- > ⚠️ Não use `trunk` para fullstack nem `cargo leptos` para CSR — ferramentas erradas para o target errado.
43
-
44
- ---
45
-
46
- ## 3. Idioms obrigatórios Leptos 0.7
47
-
48
- ### Estado reativo
49
- ```rust
50
- // ✅ Fine-grained signals — só re-renderiza o que usa o signal
51
- let (count, set_count) = signal(0);
52
- let doubled = move || count.get() * 2; // derived (memo inline)
53
-
54
- // Para estado complexo ou compartilhado entre componentes:
55
- let count = RwSignal::new(0); // read + write em um só
56
- ```
57
-
58
- ### Dados assíncronos
59
- ```rust
60
- // ✅ Resource — fetch declarativo, integra com Suspense
61
- let user = Resource::new(|| user_id(), |id| async move { fetch_user(id).await });
62
-
63
- // ✅ Suspense — loading state automático
64
- view! {
65
- <Suspense fallback=|| view! { <p>"Loading..."</p> }>
66
- {move || user.get().map(|u| view! { <p>{u.name}</p> })}
67
- </Suspense>
68
- }
69
-
70
- // ❌ Nunca — Effect que faz fetch (re-executa em todo render)
71
- Effect::new(move |_| { spawn_local(async { fetch_user(id).await }); });
72
- ```
73
-
74
- ### Mutações
75
- ```rust
76
- // ✅ Action — para submits, forms, operações que mudam estado
77
- let save = Action::new(|input: &String| {
78
- let input = input.clone();
79
- async move { api::save(input).await }
80
- });
81
-
82
- view! {
83
- <button on:click=move |_| save.dispatch("hello".to_string())>
84
- "Save"
85
- </button>
86
- <Show when=move || save.pending().get()>
87
- <p>"Saving..."</p>
88
- </Show>
89
- }
90
- ```
91
-
92
- ### Renderização condicional e listas
93
- ```rust
94
- // ✅ Show — condicional com lazy evaluation
95
- view! {
96
- <Show when=move || logged_in.get() fallback=|| view! { <Login/> }>
97
- <Dashboard/>
98
- </Show>
99
- }
100
-
101
- // ✅ For — lista reativa com key para reconciliação eficiente
102
- view! {
103
- <For
104
- each=move || items.get()
105
- key=|item| item.id
106
- children=move |item| view! { <ItemRow item=item/> }
107
- />
108
- }
109
- ```
110
-
111
- ### Server functions (fullstack only)
112
- ```rust
113
- // ✅ #[server] macro — compila para HTTP call no client, fn real no server
114
- #[server(SaveUser, "/api")]
115
- pub async fn save_user(name: String) -> Result<User, ServerFnError> {
116
- // Este código só roda no server (feature = "ssr")
117
- let user = db::create_user(name).await?;
118
- Ok(user)
119
- }
120
-
121
- // No componente — usa como Action normal
122
- let save = ServerAction::<SaveUser>::new();
123
- ```
124
-
125
- ---
126
-
127
- ## 4. Tipos compartilhados server + WASM
128
-
129
- Tipos que precisam existir tanto no server (SQLx, Axum) quanto no client (WASM) usam `cfg_attr`:
130
-
131
- ```rust
132
- // crates/<projeto>-domain/src/lib.rs (ou src/models.rs)
133
- use serde::{Deserialize, Serialize};
134
-
135
- #[cfg_attr(feature = "ssr", derive(sqlx::FromRow))] // só no server
136
- #[derive(Clone, Debug, Serialize, Deserialize)] // server + WASM
137
- pub struct SecurityEvent {
138
- pub id: uuid::Uuid,
139
- pub attack_type: String,
140
- pub risk_score: f32,
141
- pub blocked: bool,
142
- }
143
- ```
144
-
145
- **Cargo.toml do crate domain:**
146
- ```toml
147
- [dependencies]
148
- serde = { version = "1.0", features = ["derive"] }
149
- uuid = { version = "1.10", features = ["v4", "serde"] }
150
-
151
- [dependencies.sqlx]
152
- version = "0.8"
153
- features = ["postgres", "runtime-tokio", "uuid"]
154
- optional = true
155
-
156
- [features]
157
- ssr = ["dep:sqlx"]
158
- ```
159
-
160
- > O crate domain é compilado duas vezes: uma para x86 (server, com sqlx) e uma para wasm32 (client, sem sqlx). O `cfg_attr` garante que `sqlx::FromRow` só aparece na compilação server.
161
-
162
- ---
163
-
164
- ## 5. Configuração workspace misto (WASM + nativo)
165
-
166
- Quando o workspace tem crates Leptos/WASM **e** crates nativos (ex: `napi-rs`, `aya`, Axum):
167
-
168
- ```toml
169
- # .cargo/config.toml na raiz do workspace
170
- # NÃO definir [build] target global aqui.
171
- # Cada crate define seu próprio target via features e cargo-leptos/trunk.
172
- ```
173
-
174
- ```toml
175
- # Cargo.toml do workspace
176
- [workspace]
177
- resolver = "2"
178
- members = [
179
- "crates/ars-core", # lib nativa (x86)
180
- "crates/ars-server", # bin nativo — Axum
181
- "crates/ars-web", # bin+lib WASM — Leptos
182
- "crates/ars-cli", # bin nativo
183
- ]
184
- # crates napi-rs ficam em workspace separado ou excluídos do members padrão
185
- ```
186
-
187
- ```toml
188
- # crates/ars-web/Cargo.toml — features separam server de WASM
189
- [features]
190
- default = []
191
- hydrate = ["leptos/hydrate"]
192
- ssr = [
193
- "dep:axum",
194
- "dep:leptos_axum",
195
- "dep:tokio",
196
- "leptos/ssr",
197
- ]
198
- ```
199
-
200
- > ⚠️ **Antipattern crítico**: adicionar `[build] target = "wasm32-unknown-unknown"` no `.cargo/config.toml` raiz quebra todos os crates nativos. `cargo leptos` e `trunk` gerenciam o target WASM internamente — não interfira.
201
-
202
- ---
203
-
204
- ## 6. Antipatterns a evitar
205
-
206
- | Antipattern | Por quê | Alternativa |
207
- |---|---|---|
208
- | `wasm_bindgen` direto | Bypassa abstrações do Leptos, código frágil | Use APIs do Leptos (`web_sys` via feature quando necessário) |
209
- | `panic!` em componentes | Derruba o app inteiro sem `ErrorBoundary` | `Result<_, ServerFnError>` + `ErrorBoundary` |
210
- | `Effect` que faz fetch | Re-executa a cada render, difícil de cancelar | `Resource::new()` |
211
- | `tokio::spawn` no client | `tokio` não existe no WASM | `spawn_local()` (wasm) ou só em server functions |
212
- | `std::thread` no client | Não existe no WASM | Leptos signals para paralelismo reativo |
213
- | `cargo leptos test` | Não existe — comando inválido | `cargo test --workspace` |
214
- | `[build] target` global | Quebra crates nativos no workspace misto | Sem target global; cargo-leptos gerencia internamente |
215
-
216
- ---
217
-
218
- ## 7. Templates de tasks DARE para Leptos
219
-
220
- Cole no `DARE/dare-dag.yaml` após gerar o blueprint:
221
-
222
- ```yaml
223
- # Task 1 — Workspace + AppShell + Router
224
- - id: leptos-001
225
- title: "Workspace, AppShell e Router base"
226
- description: |
227
- Configurar Cargo workspace com resolver = "2".
228
- Criar App component com leptos_router::Router.
229
- Criar layout base (header, main, footer).
230
- Rota "/" → HomePage component.
231
- Ralph Loop: cargo leptos build --release + cargo test --workspace + cargo clippy
232
- depends_on: []
233
-
234
- # Task 2 — Form com Action + server function
235
- - id: leptos-002
236
- title: "Form com Action e validação server-side"
237
- description: |
238
- Criar #[server] fn para processar o form.
239
- Criar componente com ActionForm ou Action manual.
240
- Validar input no server (retorna ServerFnError em caso de erro).
241
- Exibir pending state com Action::pending() signal.
242
- Ralph Loop: cargo leptos build --release + cargo test --workspace
243
- depends_on: [leptos-001]
244
-
245
- # Task 3 — Lista paginada com Resource + Suspense
246
- - id: leptos-003
247
- title: "Lista paginada com Resource, Suspense e error handling"
248
- description: |
249
- Criar Resource que recebe página como signal de parâmetro.
250
- Envolver em Suspense com fallback de loading.
251
- Usar ErrorBoundary para erros de fetch.
252
- Adicionar paginação com For component e key por ID.
253
- Ralph Loop: cargo leptos build --release + cargo test --workspace
254
- depends_on: [leptos-001]
255
- ```
256
-
257
- ---
258
-
259
- ## 8. O que fazer agora
260
-
261
- 1. **Leia `DARE/DESIGN.md`** para entender quais componentes e server functions são necessários
262
- 2. **Rode `cargo leptos watch`** (fullstack) ou **`trunk serve`** (CSR) para confirmar que o scaffold compila
263
- 3. **Gere `DARE/BLUEPRINT.md`** com `/dare-blueprint` — inclua:
264
- - Tabela de componentes (nome, props, signals usados)
265
- - Lista de server functions com assinatura
266
- - Tipos compartilhados no crate domain
267
- 4. **Use `/dare-rust-workspace`** se precisar decidir estrutura multi-crate
268
-
269
- $ARGUMENTS
1
+ # /dare-rust-leptos
2
+
3
+ Guia de desenvolvimento Leptos para projetos DARE. Cobre decisão de variante, idioms obrigatórios, antipatterns, tipos compartilhados e templates de tasks.
4
+
5
+ ## Como usar
6
+
7
+ ```
8
+ /dare-rust-leptos ← decide variante + configura workspace
9
+ /dare-rust-leptos --csr ← guia específico para CSR + trunk
10
+ /dare-rust-leptos --fullstack ← guia específico para SSR + cargo-leptos
11
+ /dare-rust-leptos --shared-types ← padrão cfg_attr para tipos server + WASM
12
+ ```
13
+
14
+ ---
15
+
16
+ ## 1. Decisão de variante: CSR vs Fullstack
17
+
18
+ | Critério | CSR (trunk) | Fullstack (cargo-leptos) |
19
+ |---|---|---|
20
+ | SEO necessário | ❌ | ✅ |
21
+ | Time-to-interactive crítico | ❌ | ✅ |
22
+ | Dashboard interno / admin | ✅ | ✅ |
23
+ | Backend Axum existente | indiferente | ✅ integração direta |
24
+ | Simplicidade de deploy | ✅ arquivos estáticos (CDN) | ⚠️ binário Axum |
25
+ | Server functions (`#[server]`) | ❌ não existe | ✅ |
26
+
27
+ **Regra de ouro:**
28
+ - Se o projeto vive atrás de login e SEO não importa → **CSR**
29
+ - Se precisa de SEO, carregamento inicial rápido, ou server functions → **Fullstack**
30
+ - Se já tem `rust-axum` como backend no monorepo → **Fullstack** (workspace unificado)
31
+
32
+ ---
33
+
34
+ ## 2. Ferramentas — nunca misturar
35
+
36
+ | Variante | Build | Dev server | Test |
37
+ |---|---|---|---|
38
+ | CSR | `trunk build --release` | `trunk serve` | `cargo test --workspace` |
39
+ | Fullstack | `cargo leptos build --release` | `cargo leptos watch` | `cargo test --workspace` |
40
+
41
+ > ⚠️ `cargo leptos test` **não existe**. Use sempre `cargo test --workspace`.
42
+ > ⚠️ Não use `trunk` para fullstack nem `cargo leptos` para CSR — ferramentas erradas para o target errado.
43
+
44
+ ---
45
+
46
+ ## 3. Idioms obrigatórios Leptos 0.7
47
+
48
+ ### Estado reativo
49
+ ```rust
50
+ // ✅ Fine-grained signals — só re-renderiza o que usa o signal
51
+ let (count, set_count) = signal(0);
52
+ let doubled = move || count.get() * 2; // derived (memo inline)
53
+
54
+ // Para estado complexo ou compartilhado entre componentes:
55
+ let count = RwSignal::new(0); // read + write em um só
56
+ ```
57
+
58
+ ### Dados assíncronos
59
+ ```rust
60
+ // ✅ Resource — fetch declarativo, integra com Suspense
61
+ let user = Resource::new(|| user_id(), |id| async move { fetch_user(id).await });
62
+
63
+ // ✅ Suspense — loading state automático
64
+ view! {
65
+ <Suspense fallback=|| view! { <p>"Loading..."</p> }>
66
+ {move || user.get().map(|u| view! { <p>{u.name}</p> })}
67
+ </Suspense>
68
+ }
69
+
70
+ // ❌ Nunca — Effect que faz fetch (re-executa em todo render)
71
+ Effect::new(move |_| { spawn_local(async { fetch_user(id).await }); });
72
+ ```
73
+
74
+ ### Mutações
75
+ ```rust
76
+ // ✅ Action — para submits, forms, operações que mudam estado
77
+ let save = Action::new(|input: &String| {
78
+ let input = input.clone();
79
+ async move { api::save(input).await }
80
+ });
81
+
82
+ view! {
83
+ <button on:click=move |_| save.dispatch("hello".to_string())>
84
+ "Save"
85
+ </button>
86
+ <Show when=move || save.pending().get()>
87
+ <p>"Saving..."</p>
88
+ </Show>
89
+ }
90
+ ```
91
+
92
+ ### Renderização condicional e listas
93
+ ```rust
94
+ // ✅ Show — condicional com lazy evaluation
95
+ view! {
96
+ <Show when=move || logged_in.get() fallback=|| view! { <Login/> }>
97
+ <Dashboard/>
98
+ </Show>
99
+ }
100
+
101
+ // ✅ For — lista reativa com key para reconciliação eficiente
102
+ view! {
103
+ <For
104
+ each=move || items.get()
105
+ key=|item| item.id
106
+ children=move |item| view! { <ItemRow item=item/> }
107
+ />
108
+ }
109
+ ```
110
+
111
+ ### Server functions (fullstack only)
112
+ ```rust
113
+ // ✅ #[server] macro — compila para HTTP call no client, fn real no server
114
+ #[server(SaveUser, "/api")]
115
+ pub async fn save_user(name: String) -> Result<User, ServerFnError> {
116
+ // Este código só roda no server (feature = "ssr")
117
+ let user = db::create_user(name).await?;
118
+ Ok(user)
119
+ }
120
+
121
+ // No componente — usa como Action normal
122
+ let save = ServerAction::<SaveUser>::new();
123
+ ```
124
+
125
+ ---
126
+
127
+ ## 4. Tipos compartilhados server + WASM
128
+
129
+ Tipos que precisam existir tanto no server (SQLx, Axum) quanto no client (WASM) usam `cfg_attr`:
130
+
131
+ ```rust
132
+ // crates/<projeto>-domain/src/lib.rs (ou src/models.rs)
133
+ use serde::{Deserialize, Serialize};
134
+
135
+ #[cfg_attr(feature = "ssr", derive(sqlx::FromRow))] // só no server
136
+ #[derive(Clone, Debug, Serialize, Deserialize)] // server + WASM
137
+ pub struct SecurityEvent {
138
+ pub id: uuid::Uuid,
139
+ pub attack_type: String,
140
+ pub risk_score: f32,
141
+ pub blocked: bool,
142
+ }
143
+ ```
144
+
145
+ **Cargo.toml do crate domain:**
146
+ ```toml
147
+ [dependencies]
148
+ serde = { version = "1.0", features = ["derive"] }
149
+ uuid = { version = "1.10", features = ["v4", "serde"] }
150
+
151
+ [dependencies.sqlx]
152
+ version = "0.8"
153
+ features = ["postgres", "runtime-tokio", "uuid"]
154
+ optional = true
155
+
156
+ [features]
157
+ ssr = ["dep:sqlx"]
158
+ ```
159
+
160
+ > O crate domain é compilado duas vezes: uma para x86 (server, com sqlx) e uma para wasm32 (client, sem sqlx). O `cfg_attr` garante que `sqlx::FromRow` só aparece na compilação server.
161
+
162
+ ---
163
+
164
+ ## 5. Configuração workspace misto (WASM + nativo)
165
+
166
+ Quando o workspace tem crates Leptos/WASM **e** crates nativos (ex: `napi-rs`, `aya`, Axum):
167
+
168
+ ```toml
169
+ # .cargo/config.toml na raiz do workspace
170
+ # NÃO definir [build] target global aqui.
171
+ # Cada crate define seu próprio target via features e cargo-leptos/trunk.
172
+ ```
173
+
174
+ ```toml
175
+ # Cargo.toml do workspace
176
+ [workspace]
177
+ resolver = "2"
178
+ members = [
179
+ "crates/ars-core", # lib nativa (x86)
180
+ "crates/ars-server", # bin nativo — Axum
181
+ "crates/ars-web", # bin+lib WASM — Leptos
182
+ "crates/ars-cli", # bin nativo
183
+ ]
184
+ # crates napi-rs ficam em workspace separado ou excluídos do members padrão
185
+ ```
186
+
187
+ ```toml
188
+ # crates/ars-web/Cargo.toml — features separam server de WASM
189
+ [features]
190
+ default = []
191
+ hydrate = ["leptos/hydrate"]
192
+ ssr = [
193
+ "dep:axum",
194
+ "dep:leptos_axum",
195
+ "dep:tokio",
196
+ "leptos/ssr",
197
+ ]
198
+ ```
199
+
200
+ > ⚠️ **Antipattern crítico**: adicionar `[build] target = "wasm32-unknown-unknown"` no `.cargo/config.toml` raiz quebra todos os crates nativos. `cargo leptos` e `trunk` gerenciam o target WASM internamente — não interfira.
201
+
202
+ ---
203
+
204
+ ## 6. Antipatterns a evitar
205
+
206
+ | Antipattern | Por quê | Alternativa |
207
+ |---|---|---|
208
+ | `wasm_bindgen` direto | Bypassa abstrações do Leptos, código frágil | Use APIs do Leptos (`web_sys` via feature quando necessário) |
209
+ | `panic!` em componentes | Derruba o app inteiro sem `ErrorBoundary` | `Result<_, ServerFnError>` + `ErrorBoundary` |
210
+ | `Effect` que faz fetch | Re-executa a cada render, difícil de cancelar | `Resource::new()` |
211
+ | `tokio::spawn` no client | `tokio` não existe no WASM | `spawn_local()` (wasm) ou só em server functions |
212
+ | `std::thread` no client | Não existe no WASM | Leptos signals para paralelismo reativo |
213
+ | `cargo leptos test` | Não existe — comando inválido | `cargo test --workspace` |
214
+ | `[build] target` global | Quebra crates nativos no workspace misto | Sem target global; cargo-leptos gerencia internamente |
215
+
216
+ ---
217
+
218
+ ## 7. Templates de tasks DARE para Leptos
219
+
220
+ Cole no `DARE/dare-dag.yaml` após gerar o blueprint:
221
+
222
+ ```yaml
223
+ # Task 1 — Workspace + AppShell + Router
224
+ - id: leptos-001
225
+ title: "Workspace, AppShell e Router base"
226
+ description: |
227
+ Configurar Cargo workspace com resolver = "2".
228
+ Criar App component com leptos_router::Router.
229
+ Criar layout base (header, main, footer).
230
+ Rota "/" → HomePage component.
231
+ Ralph Loop: cargo leptos build --release + cargo test --workspace + cargo clippy
232
+ depends_on: []
233
+
234
+ # Task 2 — Form com Action + server function
235
+ - id: leptos-002
236
+ title: "Form com Action e validação server-side"
237
+ description: |
238
+ Criar #[server] fn para processar o form.
239
+ Criar componente com ActionForm ou Action manual.
240
+ Validar input no server (retorna ServerFnError em caso de erro).
241
+ Exibir pending state com Action::pending() signal.
242
+ Ralph Loop: cargo leptos build --release + cargo test --workspace
243
+ depends_on: [leptos-001]
244
+
245
+ # Task 3 — Lista paginada com Resource + Suspense
246
+ - id: leptos-003
247
+ title: "Lista paginada com Resource, Suspense e error handling"
248
+ description: |
249
+ Criar Resource que recebe página como signal de parâmetro.
250
+ Envolver em Suspense com fallback de loading.
251
+ Usar ErrorBoundary para erros de fetch.
252
+ Adicionar paginação com For component e key por ID.
253
+ Ralph Loop: cargo leptos build --release + cargo test --workspace
254
+ depends_on: [leptos-001]
255
+ ```
256
+
257
+ ---
258
+
259
+ ## 8. O que fazer agora
260
+
261
+ 1. **Leia `DARE/DESIGN.md`** para entender quais componentes e server functions são necessários
262
+ 2. **Rode `cargo leptos watch`** (fullstack) ou **`trunk serve`** (CSR) para confirmar que o scaffold compila
263
+ 3. **Gere `DARE/BLUEPRINT.md`** com `/dare-blueprint` — inclua:
264
+ - Tabela de componentes (nome, props, signals usados)
265
+ - Lista de server functions com assinatura
266
+ - Tipos compartilhados no crate domain
267
+ 4. **Use `/dare-rust-workspace`** se precisar decidir estrutura multi-crate
268
+
269
+ $ARGUMENTS