@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,193 +1,193 @@
1
- # BLUEPRINT: [Nome do Projeto]
2
-
3
- > **Gerado a partir de:** `DARE/DESIGN.md` v[X.Y]
4
- > **Data:** YYYY-MM-DD | **Status:** DRAFT → APROVADO
5
-
6
- ---
7
-
8
- ## 1. VISÃO GERAL DA ARQUITETURA
9
-
10
- [Descrição da arquitetura: Monolito modular / Microserviços / Hexagonal / Clean Architecture]
11
-
12
- ```mermaid
13
- graph TD
14
- A[Cliente] --> B[API Gateway / BFF]
15
- B --> C[Auth Service]
16
- B --> D[Core Service]
17
- D --> E[(PostgreSQL)]
18
- D --> F[(Redis)]
19
- ```
20
-
21
- **Decisões arquiteturais principais:**
22
-
23
- | Decisão | Escolha | Justificativa |
24
- |---------|---------|---------------|
25
- | Padrão de módulos | [ex: Hexagonal] | [motivo] |
26
- | Comunicação inter-serviços | [ex: REST síncrono] | [motivo] |
27
- | Autenticação | [ex: JWT stateless] | [motivo] |
28
-
29
- ---
30
-
31
- ## 2. STACK TÉCNICA DEFINIDA
32
-
33
- | Camada | Tecnologia | Versão | Papel |
34
- |--------|-----------|--------|-------|
35
- | Linguagem | | | |
36
- | Framework | | | |
37
- | Banco principal | | | |
38
- | Cache / filas | | | |
39
- | Frontend | | | |
40
- | Container | Docker | latest | Dev + CI |
41
- | Observabilidade | | | Logs, métricas, traces |
42
-
43
- ---
44
-
45
- ## 3. ESTRUTURA DE PASTAS E ARQUIVOS
46
-
47
- ```text
48
- [nome-do-projeto]/
49
- ├── [diretório principal]/
50
- │ ├── [módulo 1]/
51
- │ └── [módulo 2]/
52
- ├── DARE/
53
- │ ├── DESIGN.md
54
- │ ├── BLUEPRINT.md
55
- │ ├── TASKS.md
56
- │ ├── dare-dag.yaml
57
- │ └── EXECUTION/
58
- ├── Dockerfile
59
- ├── docker-compose.yml
60
- └── [arquivo de configuração principal]
61
- ```
62
-
63
- > **Constraints de workspace (Rust):** se Cargo workspace, NÃO definir `[build] target` global no `.cargo/config.toml` (quebra crates WASM + native). Cada crate declara suas próprias features Leptos.
64
-
65
- ---
66
-
67
- ## 4. MODELO DE DADOS
68
-
69
- ### Entidades principais
70
-
71
- ```
72
- [Entidade 1]
73
- - id: UUID (PK)
74
- - [campo]: [tipo] [restrições]
75
- - created_at, updated_at
76
-
77
- [Entidade 2]
78
- - id: UUID (PK)
79
- - [entidade_1_id]: FK → Entidade1
80
- ```
81
-
82
- ### Relacionamentos
83
-
84
- | De | Para | Cardinalidade | Via |
85
- |----|------|---------------|-----|
86
- | [Entidade 1] | [Entidade 2] | 1:N | FK |
87
-
88
- ---
89
-
90
- ## 5. CONTRATOS DE API
91
-
92
- | Método | Endpoint | Auth | Request Body | Response | Status codes |
93
- |--------|----------|------|-------------|----------|--------------|
94
- | POST | `/api/v1/[recurso]` | Não | `{campo1, campo2}` | `{id, ...}` | 201, 400, 422 |
95
- | GET | `/api/v1/[recurso]` | JWT | — | `[{id, ...}]` | 200, 401 |
96
- | GET | `/api/v1/[recurso]/:id` | JWT | — | `{id, ...}` | 200, 401, 404 |
97
- | PUT | `/api/v1/[recurso]/:id` | JWT + Owner | `{campos}` | `{id, ...}` | 200, 401, 403, 404 |
98
- | DELETE | `/api/v1/[recurso]/:id` | JWT + Admin | — | `{}` | 204, 401, 403, 404 |
99
-
100
- ---
101
-
102
- ## 6. PLANO DE EXECUÇÃO (FASES)
103
-
104
- ### Fase 1: Containerização e Setup ← **SEMPRE PRIMEIRA**
105
- **Critério de DONE:** `docker compose up -d` sobe sem erros; healthcheck `/health` retorna 200.
106
- - Dockerfile multi-stage
107
- - docker-compose.yml com todos os serviços
108
- - Variáveis de ambiente via `.env.example`
109
-
110
- ### Fase 2: Banco de Dados e Migrations
111
- **Critério de DONE:** migrations rodando; schema validado; seeds de desenvolvimento funcionando.
112
- - Migrations / schema inicial
113
- - Seeds de desenvolvimento
114
- - Índices para queries críticas
115
-
116
- ### Fase 3: Autenticação e Autorização
117
- **Critério de DONE:** login retorna JWT; endpoint protegido rejeita token inválido com 401; acesso sem permissão retorna 403.
118
- - Registro, login, refresh, logout
119
- - Middleware de autenticação
120
- - Sistema de permissões (RBAC/ACL)
121
-
122
- ### Fase 4: [Módulo de negócio principal]
123
- **Critério de DONE:** [comportamento testável esperado].
124
- - [Descrever aqui]
125
-
126
- ### Fase N-1: Auditoria de Segurança e Dependências
127
- **Critério de DONE:** `[audit-cmd]` sem CVE HIGH/CRITICAL; security headers presentes; sem secrets em código.
128
- - `npm audit --audit-level=high` / `cargo audit` / `pip-audit` / `composer audit`
129
- - Headers HTTP de segurança (HSTS, CSP, X-Frame-Options)
130
- - Scan de secrets no repositório
131
-
132
- ### Fase N: Observabilidade e Documentação
133
- **Critério de DONE:** logs estruturados em JSON; endpoint `/metrics` ou equivalente; documentação API gerada.
134
- - Logs estruturados (JSON) com trace-id
135
- - Métricas de negócio e técnicas
136
- - Documentação API (OpenAPI / Swagger)
137
-
138
- ---
139
-
140
- ## 7. VALIDAÇÃO E SEGURANÇA
141
-
142
- ### Validation Gates (Ralph Loop) por stack
143
-
144
- | Stack | Build | Test | Lint/Audit |
145
- |-------|-------|------|------------|
146
- | Rust/Axum | `cargo build` | `cargo test --workspace` | `cargo clippy && cargo audit` |
147
- | Node/NestJS | `npm run build` | `npm test` | `npx eslint src && npm audit --audit-level=high` |
148
- | Python/FastAPI | `python -m py_compile` | `pytest` | `ruff check . && pip-audit` |
149
- | PHP/Laravel | `php artisan config:cache` | `php artisan test` | `./vendor/bin/phpstan && composer audit` |
150
- | Go | `go build ./...` | `go test ./...` | `golangci-lint run` |
151
-
152
- ### Controles de segurança obrigatórios
153
-
154
- - [ ] Rate limiting em endpoints de autenticação e públicos
155
- - [ ] Input validation no servidor para todos os endpoints
156
- - [ ] Dados sensíveis (PII, tokens, senhas) nunca em logs
157
- - [ ] Todas as dependências sem CVE HIGH/CRITICAL (ver Fase N-1)
158
- - [ ] HTTP Security Headers em produção
159
- - [ ] Secrets apenas em variáveis de ambiente / vault
160
-
161
- ---
162
-
163
- ## 8. ESTRATÉGIA DE TESTES
164
-
165
- | Tipo | Ferramenta | Cobertura mínima | O que cobre |
166
- |------|-----------|------------------|-------------|
167
- | Unitários | [jest/pytest/cargo test] | 80 % das funções críticas | Lógica de negócio isolada |
168
- | Integração | [supertest/httpx/reqwest] | Todos os endpoints | Contrato da API |
169
- | Segurança | [npm audit/cargo audit/pip-audit] | 100 % deps | CVEs conhecidos |
170
- | E2E | [playwright/cypress] se frontend | Fluxo principal | Jornada do usuário |
171
-
172
- ---
173
-
174
- ## 9. ESTRATÉGIA DE DEPLOY
175
-
176
- | Ambiente | Branch | Trigger | Infra |
177
- |----------|--------|---------|-------|
178
- | `dev` | `develop` | Push automático | [ex: Docker local / Railway] |
179
- | `staging` | `main` | PR merge | [ex: OKE / ECS / Fly.io] |
180
- | `prod` | tag `v*.*.*` | Manual | [ex: OKE / ECS / Fly.io] |
181
-
182
- ---
183
-
184
- ## 10. CHECKLIST DE APROVAÇÃO DO BLUEPRINT
185
-
186
- - [ ] Arquitetura revisada e aprovada
187
- - [ ] Modelo de dados validado
188
- - [ ] Contratos de API definidos e completos
189
- - [ ] Fases com critérios de DONE claros
190
- - [ ] Validation gates por stack definidos
191
- - [ ] Controles de segurança mapeados
192
- - [ ] Estratégia de testes cobrindo todos os tipos
193
- - [ ] DAG de tasks gerado (`dare-dag.yaml`)
1
+ # BLUEPRINT: [Nome do Projeto]
2
+
3
+ > **Gerado a partir de:** `DARE/DESIGN.md` v[X.Y]
4
+ > **Data:** YYYY-MM-DD | **Status:** DRAFT → APROVADO
5
+
6
+ ---
7
+
8
+ ## 1. VISÃO GERAL DA ARQUITETURA
9
+
10
+ [Descrição da arquitetura: Monolito modular / Microserviços / Hexagonal / Clean Architecture]
11
+
12
+ ```mermaid
13
+ graph TD
14
+ A[Cliente] --> B[API Gateway / BFF]
15
+ B --> C[Auth Service]
16
+ B --> D[Core Service]
17
+ D --> E[(PostgreSQL)]
18
+ D --> F[(Redis)]
19
+ ```
20
+
21
+ **Decisões arquiteturais principais:**
22
+
23
+ | Decisão | Escolha | Justificativa |
24
+ |---------|---------|---------------|
25
+ | Padrão de módulos | [ex: Hexagonal] | [motivo] |
26
+ | Comunicação inter-serviços | [ex: REST síncrono] | [motivo] |
27
+ | Autenticação | [ex: JWT stateless] | [motivo] |
28
+
29
+ ---
30
+
31
+ ## 2. STACK TÉCNICA DEFINIDA
32
+
33
+ | Camada | Tecnologia | Versão | Papel |
34
+ |--------|-----------|--------|-------|
35
+ | Linguagem | | | |
36
+ | Framework | | | |
37
+ | Banco principal | | | |
38
+ | Cache / filas | | | |
39
+ | Frontend | | | |
40
+ | Container | Docker | latest | Dev + CI |
41
+ | Observabilidade | | | Logs, métricas, traces |
42
+
43
+ ---
44
+
45
+ ## 3. ESTRUTURA DE PASTAS E ARQUIVOS
46
+
47
+ ```text
48
+ [nome-do-projeto]/
49
+ ├── [diretório principal]/
50
+ │ ├── [módulo 1]/
51
+ │ └── [módulo 2]/
52
+ ├── DARE/
53
+ │ ├── DESIGN.md
54
+ │ ├── BLUEPRINT.md
55
+ │ ├── TASKS.md
56
+ │ ├── dare-dag.yaml
57
+ │ └── EXECUTION/
58
+ ├── Dockerfile
59
+ ├── docker-compose.yml
60
+ └── [arquivo de configuração principal]
61
+ ```
62
+
63
+ > **Constraints de workspace (Rust):** se Cargo workspace, NÃO definir `[build] target` global no `.cargo/config.toml` (quebra crates WASM + native). Cada crate declara suas próprias features Leptos.
64
+
65
+ ---
66
+
67
+ ## 4. MODELO DE DADOS
68
+
69
+ ### Entidades principais
70
+
71
+ ```
72
+ [Entidade 1]
73
+ - id: UUID (PK)
74
+ - [campo]: [tipo] [restrições]
75
+ - created_at, updated_at
76
+
77
+ [Entidade 2]
78
+ - id: UUID (PK)
79
+ - [entidade_1_id]: FK → Entidade1
80
+ ```
81
+
82
+ ### Relacionamentos
83
+
84
+ | De | Para | Cardinalidade | Via |
85
+ |----|------|---------------|-----|
86
+ | [Entidade 1] | [Entidade 2] | 1:N | FK |
87
+
88
+ ---
89
+
90
+ ## 5. CONTRATOS DE API
91
+
92
+ | Método | Endpoint | Auth | Request Body | Response | Status codes |
93
+ |--------|----------|------|-------------|----------|--------------|
94
+ | POST | `/api/v1/[recurso]` | Não | `{campo1, campo2}` | `{id, ...}` | 201, 400, 422 |
95
+ | GET | `/api/v1/[recurso]` | JWT | — | `[{id, ...}]` | 200, 401 |
96
+ | GET | `/api/v1/[recurso]/:id` | JWT | — | `{id, ...}` | 200, 401, 404 |
97
+ | PUT | `/api/v1/[recurso]/:id` | JWT + Owner | `{campos}` | `{id, ...}` | 200, 401, 403, 404 |
98
+ | DELETE | `/api/v1/[recurso]/:id` | JWT + Admin | — | `{}` | 204, 401, 403, 404 |
99
+
100
+ ---
101
+
102
+ ## 6. PLANO DE EXECUÇÃO (FASES)
103
+
104
+ ### Fase 1: Containerização e Setup ← **SEMPRE PRIMEIRA**
105
+ **Critério de DONE:** `docker compose up -d` sobe sem erros; healthcheck `/health` retorna 200.
106
+ - Dockerfile multi-stage
107
+ - docker-compose.yml com todos os serviços
108
+ - Variáveis de ambiente via `.env.example`
109
+
110
+ ### Fase 2: Banco de Dados e Migrations
111
+ **Critério de DONE:** migrations rodando; schema validado; seeds de desenvolvimento funcionando.
112
+ - Migrations / schema inicial
113
+ - Seeds de desenvolvimento
114
+ - Índices para queries críticas
115
+
116
+ ### Fase 3: Autenticação e Autorização
117
+ **Critério de DONE:** login retorna JWT; endpoint protegido rejeita token inválido com 401; acesso sem permissão retorna 403.
118
+ - Registro, login, refresh, logout
119
+ - Middleware de autenticação
120
+ - Sistema de permissões (RBAC/ACL)
121
+
122
+ ### Fase 4: [Módulo de negócio principal]
123
+ **Critério de DONE:** [comportamento testável esperado].
124
+ - [Descrever aqui]
125
+
126
+ ### Fase N-1: Auditoria de Segurança e Dependências
127
+ **Critério de DONE:** `[audit-cmd]` sem CVE HIGH/CRITICAL; security headers presentes; sem secrets em código.
128
+ - `npm audit --audit-level=high` / `cargo audit` / `pip-audit` / `composer audit`
129
+ - Headers HTTP de segurança (HSTS, CSP, X-Frame-Options)
130
+ - Scan de secrets no repositório
131
+
132
+ ### Fase N: Observabilidade e Documentação
133
+ **Critério de DONE:** logs estruturados em JSON; endpoint `/metrics` ou equivalente; documentação API gerada.
134
+ - Logs estruturados (JSON) com trace-id
135
+ - Métricas de negócio e técnicas
136
+ - Documentação API (OpenAPI / Swagger)
137
+
138
+ ---
139
+
140
+ ## 7. VALIDAÇÃO E SEGURANÇA
141
+
142
+ ### Validation Gates (Ralph Loop) por stack
143
+
144
+ | Stack | Build | Test | Lint/Audit |
145
+ |-------|-------|------|------------|
146
+ | Rust/Axum | `cargo build` | `cargo test --workspace` | `cargo clippy && cargo audit` |
147
+ | Node/NestJS | `npm run build` | `npm test` | `npx eslint src && npm audit --audit-level=high` |
148
+ | Python/FastAPI | `python -m py_compile` | `pytest` | `ruff check . && pip-audit` |
149
+ | PHP/Laravel | `php artisan config:cache` | `php artisan test` | `./vendor/bin/phpstan && composer audit` |
150
+ | Go | `go build ./...` | `go test ./...` | `golangci-lint run` |
151
+
152
+ ### Controles de segurança obrigatórios
153
+
154
+ - [ ] Rate limiting em endpoints de autenticação e públicos
155
+ - [ ] Input validation no servidor para todos os endpoints
156
+ - [ ] Dados sensíveis (PII, tokens, senhas) nunca em logs
157
+ - [ ] Todas as dependências sem CVE HIGH/CRITICAL (ver Fase N-1)
158
+ - [ ] HTTP Security Headers em produção
159
+ - [ ] Secrets apenas em variáveis de ambiente / vault
160
+
161
+ ---
162
+
163
+ ## 8. ESTRATÉGIA DE TESTES
164
+
165
+ | Tipo | Ferramenta | Cobertura mínima | O que cobre |
166
+ |------|-----------|------------------|-------------|
167
+ | Unitários | [jest/pytest/cargo test] | 80 % das funções críticas | Lógica de negócio isolada |
168
+ | Integração | [supertest/httpx/reqwest] | Todos os endpoints | Contrato da API |
169
+ | Segurança | [npm audit/cargo audit/pip-audit] | 100 % deps | CVEs conhecidos |
170
+ | E2E | [playwright/cypress] se frontend | Fluxo principal | Jornada do usuário |
171
+
172
+ ---
173
+
174
+ ## 9. ESTRATÉGIA DE DEPLOY
175
+
176
+ | Ambiente | Branch | Trigger | Infra |
177
+ |----------|--------|---------|-------|
178
+ | `dev` | `develop` | Push automático | [ex: Docker local / Railway] |
179
+ | `staging` | `main` | PR merge | [ex: OKE / ECS / Fly.io] |
180
+ | `prod` | tag `v*.*.*` | Manual | [ex: OKE / ECS / Fly.io] |
181
+
182
+ ---
183
+
184
+ ## 10. CHECKLIST DE APROVAÇÃO DO BLUEPRINT
185
+
186
+ - [ ] Arquitetura revisada e aprovada
187
+ - [ ] Modelo de dados validado
188
+ - [ ] Contratos de API definidos e completos
189
+ - [ ] Fases com critérios de DONE claros
190
+ - [ ] Validation gates por stack definidos
191
+ - [ ] Controles de segurança mapeados
192
+ - [ ] Estratégia de testes cobrindo todos os tipos
193
+ - [ ] DAG de tasks gerado (`dare-dag.yaml`)
@@ -1,129 +1,129 @@
1
- # DESIGN: [Nome do Projeto / Feature]
2
-
3
- > **Versão:** v1.0 | **Data:** YYYY-MM-DD | **Status:** DRAFT → APROVADO
4
-
5
- ---
6
-
7
- ## 1. DESCRIÇÃO
8
-
9
- [O que é o sistema e qual problema ele resolve — 3 a 5 frases claras e objetivas. Evite jargão.]
10
-
11
- ---
12
-
13
- ## 2. OBJETIVOS E MÉTRICAS DE SUCESSO
14
-
15
- | # | Objetivo | Métrica verificável | Meta |
16
- |---|----------|---------------------|------|
17
- | O-01 | [ex: Reduzir tempo de resposta da API] | p99 latência em produção | < 200 ms |
18
- | O-02 | [ex: Aumentar cobertura de testes] | `coverage --summary` | > 80 % |
19
- | O-03 | | | |
20
-
21
- ---
22
-
23
- ## 3. STAKEHOLDERS
24
-
25
- | Papel | Nome / Time | Interesse principal |
26
- |-------|-------------|---------------------|
27
- | Product Owner | | Aprovação de scope e prioridades |
28
- | Tech Lead | | Decisões arquiteturais |
29
- | Usuário Final | | [Persona] — [necessidade] |
30
- | Operações / SRE | | SLA, alertas, deploys |
31
-
32
- ---
33
-
34
- ## 4. REQUISITOS FUNCIONAIS
35
-
36
- | ID | Requisito | Prioridade | Critério de aceite |
37
- |----|-----------|------------|--------------------|
38
- | RF-01 | | MUST | |
39
- | RF-02 | | SHOULD | |
40
- | RF-03 | | COULD | |
41
-
42
- > Prioridades: **MUST** (bloqueia v1) · **SHOULD** (importante, mas não bloqueia) · **COULD** (nice to have)
43
-
44
- ---
45
-
46
- ## 5. REQUISITOS NÃO-FUNCIONAIS
47
-
48
- | ID | Categoria | Requisito | Meta |
49
- |----|-----------|-----------|------|
50
- | RNF-01 | Performance | [ex: API responde dentro do SLA] | p95 < 500 ms |
51
- | RNF-02 | Disponibilidade | [ex: uptime mensal] | ≥ 99,5 % |
52
- | RNF-03 | Segurança | Autenticação obrigatória em todos os endpoints sensíveis | JWT + refresh |
53
- | RNF-04 | Segurança | Rate limiting em endpoints públicos | ≤ 60 req/min/IP |
54
- | RNF-05 | Segurança | Dados sensíveis (PII, tokens) nunca em logs | auditoria automática |
55
- | RNF-06 | Observabilidade | Logs estruturados (JSON) com trace-id | OpenTelemetry |
56
- | RNF-07 | Manutenibilidade | Cobertura de testes | > 80 % |
57
-
58
- ---
59
-
60
- ## 6. REQUISITOS DE SEGURANÇA
61
-
62
- | ID | Requisito | Referência |
63
- |----|-----------|------------|
64
- | RS-01 | Todas as entradas do usuário validadas no servidor antes de qualquer processamento | OWASP A03 |
65
- | RS-02 | Senhas e segredos nunca armazenados em texto plano; hash Argon2/Bcrypt | OWASP A02 |
66
- | RS-03 | Controle de acesso verificado por recurso (não só por rota) | OWASP A01 |
67
- | RS-04 | Dependências auditadas antes de cada release (sem CVE HIGH/CRITICAL) | OWASP A06 |
68
- | RS-05 | Segredos gerenciados via variáveis de ambiente / vault — nunca em código | Supply chain |
69
- | RS-06 | [Requisito específico do domínio] | |
70
-
71
- ---
72
-
73
- ## 7. STACK TÉCNICA
74
-
75
- | Camada | Tecnologia | Versão |
76
- |--------|-----------|--------|
77
- | Linguagem / Runtime | | |
78
- | Framework principal | | |
79
- | Banco de dados | | |
80
- | Cache | | |
81
- | Frontend | | |
82
- | Infra / deploy | | |
83
- | Observabilidade | | |
84
-
85
- ---
86
-
87
- ## 8. INTEGRAÇÕES EXTERNAS
88
-
89
- | Sistema | Tipo | Protocolo | Direção | Dados trocados | Responsável |
90
- |---------|------|-----------|---------|----------------|-------------|
91
- | [ex: Stripe] | Pagamento | REST/webhook | Saída + entrada | Cobrança, confirmação | Time Pagamentos |
92
- | [ex: Auth0] | IdP | OIDC | Entrada | ID Token, Claims | Time Auth |
93
-
94
- ---
95
-
96
- ## 9. RESTRIÇÕES
97
-
98
- - **Prazo:** [Data de entrega ou milestone]
99
- - **Orçamento de infra:** [Limite de custo mensal ou por request]
100
- - **Limitações técnicas:** [ex: não pode usar banco NoSQL; deve usar Go ≥ 1.22]
101
- - **Regulatórias / Compliance:** [ex: LGPD, GDPR, SOC 2, PCI-DSS se aplicável]
102
-
103
- ---
104
-
105
- ## 10. FORA DO ESCOPO (v1)
106
-
107
- - [Funcionalidade adiada para v2 — e o motivo]
108
- - [Caso de uso que NÃO será tratado nesta versão]
109
-
110
- ---
111
-
112
- ## 11. RISCOS E MITIGAÇÕES
113
-
114
- | # | Risco | Probabilidade | Impacto | Mitigação |
115
- |---|-------|---------------|---------|-----------|
116
- | R-01 | [ex: Latência alta no serviço de terceiros] | Média | Alto | Circuit breaker + fallback |
117
- | R-02 | [ex: Falta de dados históricos para ML] | Alta | Médio | Dataset sintético inicial |
118
- | R-03 | | | | |
119
-
120
- ---
121
-
122
- ## 12. CHECKLIST DE APROVAÇÃO
123
-
124
- - [ ] Requisitos funcionais revisados e priorizados
125
- - [ ] Requisitos de segurança validados pelo Tech Lead
126
- - [ ] Stack técnica aprovada
127
- - [ ] Integrações externas confirmadas com responsáveis
128
- - [ ] Fora do escopo alinhado com Product Owner
129
- - [ ] Riscos críticos com mitigação definida
1
+ # DESIGN: [Nome do Projeto / Feature]
2
+
3
+ > **Versão:** v1.0 | **Data:** YYYY-MM-DD | **Status:** DRAFT → APROVADO
4
+
5
+ ---
6
+
7
+ ## 1. DESCRIÇÃO
8
+
9
+ [O que é o sistema e qual problema ele resolve — 3 a 5 frases claras e objetivas. Evite jargão.]
10
+
11
+ ---
12
+
13
+ ## 2. OBJETIVOS E MÉTRICAS DE SUCESSO
14
+
15
+ | # | Objetivo | Métrica verificável | Meta |
16
+ |---|----------|---------------------|------|
17
+ | O-01 | [ex: Reduzir tempo de resposta da API] | p99 latência em produção | < 200 ms |
18
+ | O-02 | [ex: Aumentar cobertura de testes] | `coverage --summary` | > 80 % |
19
+ | O-03 | | | |
20
+
21
+ ---
22
+
23
+ ## 3. STAKEHOLDERS
24
+
25
+ | Papel | Nome / Time | Interesse principal |
26
+ |-------|-------------|---------------------|
27
+ | Product Owner | | Aprovação de scope e prioridades |
28
+ | Tech Lead | | Decisões arquiteturais |
29
+ | Usuário Final | | [Persona] — [necessidade] |
30
+ | Operações / SRE | | SLA, alertas, deploys |
31
+
32
+ ---
33
+
34
+ ## 4. REQUISITOS FUNCIONAIS
35
+
36
+ | ID | Requisito | Prioridade | Critério de aceite |
37
+ |----|-----------|------------|--------------------|
38
+ | RF-01 | | MUST | |
39
+ | RF-02 | | SHOULD | |
40
+ | RF-03 | | COULD | |
41
+
42
+ > Prioridades: **MUST** (bloqueia v1) · **SHOULD** (importante, mas não bloqueia) · **COULD** (nice to have)
43
+
44
+ ---
45
+
46
+ ## 5. REQUISITOS NÃO-FUNCIONAIS
47
+
48
+ | ID | Categoria | Requisito | Meta |
49
+ |----|-----------|-----------|------|
50
+ | RNF-01 | Performance | [ex: API responde dentro do SLA] | p95 < 500 ms |
51
+ | RNF-02 | Disponibilidade | [ex: uptime mensal] | ≥ 99,5 % |
52
+ | RNF-03 | Segurança | Autenticação obrigatória em todos os endpoints sensíveis | JWT + refresh |
53
+ | RNF-04 | Segurança | Rate limiting em endpoints públicos | ≤ 60 req/min/IP |
54
+ | RNF-05 | Segurança | Dados sensíveis (PII, tokens) nunca em logs | auditoria automática |
55
+ | RNF-06 | Observabilidade | Logs estruturados (JSON) com trace-id | OpenTelemetry |
56
+ | RNF-07 | Manutenibilidade | Cobertura de testes | > 80 % |
57
+
58
+ ---
59
+
60
+ ## 6. REQUISITOS DE SEGURANÇA
61
+
62
+ | ID | Requisito | Referência |
63
+ |----|-----------|------------|
64
+ | RS-01 | Todas as entradas do usuário validadas no servidor antes de qualquer processamento | OWASP A03 |
65
+ | RS-02 | Senhas e segredos nunca armazenados em texto plano; hash Argon2/Bcrypt | OWASP A02 |
66
+ | RS-03 | Controle de acesso verificado por recurso (não só por rota) | OWASP A01 |
67
+ | RS-04 | Dependências auditadas antes de cada release (sem CVE HIGH/CRITICAL) | OWASP A06 |
68
+ | RS-05 | Segredos gerenciados via variáveis de ambiente / vault — nunca em código | Supply chain |
69
+ | RS-06 | [Requisito específico do domínio] | |
70
+
71
+ ---
72
+
73
+ ## 7. STACK TÉCNICA
74
+
75
+ | Camada | Tecnologia | Versão |
76
+ |--------|-----------|--------|
77
+ | Linguagem / Runtime | | |
78
+ | Framework principal | | |
79
+ | Banco de dados | | |
80
+ | Cache | | |
81
+ | Frontend | | |
82
+ | Infra / deploy | | |
83
+ | Observabilidade | | |
84
+
85
+ ---
86
+
87
+ ## 8. INTEGRAÇÕES EXTERNAS
88
+
89
+ | Sistema | Tipo | Protocolo | Direção | Dados trocados | Responsável |
90
+ |---------|------|-----------|---------|----------------|-------------|
91
+ | [ex: Stripe] | Pagamento | REST/webhook | Saída + entrada | Cobrança, confirmação | Time Pagamentos |
92
+ | [ex: Auth0] | IdP | OIDC | Entrada | ID Token, Claims | Time Auth |
93
+
94
+ ---
95
+
96
+ ## 9. RESTRIÇÕES
97
+
98
+ - **Prazo:** [Data de entrega ou milestone]
99
+ - **Orçamento de infra:** [Limite de custo mensal ou por request]
100
+ - **Limitações técnicas:** [ex: não pode usar banco NoSQL; deve usar Go ≥ 1.22]
101
+ - **Regulatórias / Compliance:** [ex: LGPD, GDPR, SOC 2, PCI-DSS se aplicável]
102
+
103
+ ---
104
+
105
+ ## 10. FORA DO ESCOPO (v1)
106
+
107
+ - [Funcionalidade adiada para v2 — e o motivo]
108
+ - [Caso de uso que NÃO será tratado nesta versão]
109
+
110
+ ---
111
+
112
+ ## 11. RISCOS E MITIGAÇÕES
113
+
114
+ | # | Risco | Probabilidade | Impacto | Mitigação |
115
+ |---|-------|---------------|---------|-----------|
116
+ | R-01 | [ex: Latência alta no serviço de terceiros] | Média | Alto | Circuit breaker + fallback |
117
+ | R-02 | [ex: Falta de dados históricos para ML] | Alta | Médio | Dataset sintético inicial |
118
+ | R-03 | | | | |
119
+
120
+ ---
121
+
122
+ ## 12. CHECKLIST DE APROVAÇÃO
123
+
124
+ - [ ] Requisitos funcionais revisados e priorizados
125
+ - [ ] Requisitos de segurança validados pelo Tech Lead
126
+ - [ ] Stack técnica aprovada
127
+ - [ ] Integrações externas confirmadas com responsáveis
128
+ - [ ] Fora do escopo alinhado com Product Owner
129
+ - [ ] Riscos críticos com mitigação definida