@dewtech/dare-cli 2.16.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 (408) hide show
  1. package/README.md +196 -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.d.ts +2 -0
  31. package/dist/__tests__/refine.test.d.ts.map +1 -0
  32. package/dist/__tests__/refine.test.js +186 -0
  33. package/dist/__tests__/refine.test.js.map +1 -0
  34. package/dist/__tests__/reverse-facts.test.d.ts +2 -0
  35. package/dist/__tests__/reverse-facts.test.d.ts.map +1 -0
  36. package/dist/__tests__/reverse-facts.test.js +78 -0
  37. package/dist/__tests__/reverse-facts.test.js.map +1 -0
  38. package/dist/__tests__/review.test.d.ts +2 -0
  39. package/dist/__tests__/review.test.d.ts.map +1 -0
  40. package/dist/__tests__/review.test.js +242 -0
  41. package/dist/__tests__/review.test.js.map +1 -0
  42. package/dist/__tests__/update.test.d.ts +2 -0
  43. package/dist/__tests__/update.test.d.ts.map +1 -0
  44. package/dist/__tests__/update.test.js +150 -0
  45. package/dist/__tests__/update.test.js.map +1 -0
  46. package/dist/__tests__/validate.test.js +65 -65
  47. package/dist/bin/dare.js +38 -3
  48. package/dist/bin/dare.js.map +1 -1
  49. package/dist/commands/blueprint.js +122 -122
  50. package/dist/commands/dag.d.ts.map +1 -1
  51. package/dist/commands/dag.js +43 -79
  52. package/dist/commands/dag.js.map +1 -1
  53. package/dist/commands/dna.d.ts +3 -0
  54. package/dist/commands/dna.d.ts.map +1 -0
  55. package/dist/commands/dna.js +69 -0
  56. package/dist/commands/dna.js.map +1 -0
  57. package/dist/commands/execute.d.ts.map +1 -1
  58. package/dist/commands/execute.js +76 -0
  59. package/dist/commands/execute.js.map +1 -1
  60. package/dist/commands/migrate.d.ts +3 -0
  61. package/dist/commands/migrate.d.ts.map +1 -0
  62. package/dist/commands/migrate.js +101 -0
  63. package/dist/commands/migrate.js.map +1 -0
  64. package/dist/commands/new.d.ts +16 -0
  65. package/dist/commands/new.d.ts.map +1 -0
  66. package/dist/commands/new.js +103 -0
  67. package/dist/commands/new.js.map +1 -0
  68. package/dist/commands/refine.d.ts +16 -0
  69. package/dist/commands/refine.d.ts.map +1 -0
  70. package/dist/commands/refine.js +167 -0
  71. package/dist/commands/refine.js.map +1 -0
  72. package/dist/commands/reverse.d.ts +3 -0
  73. package/dist/commands/reverse.d.ts.map +1 -0
  74. package/dist/commands/reverse.js +201 -0
  75. package/dist/commands/reverse.js.map +1 -0
  76. package/dist/commands/review.d.ts +16 -0
  77. package/dist/commands/review.d.ts.map +1 -0
  78. package/dist/commands/review.js +106 -0
  79. package/dist/commands/review.js.map +1 -0
  80. package/dist/commands/update.d.ts +13 -0
  81. package/dist/commands/update.d.ts.map +1 -0
  82. package/dist/commands/update.js +149 -0
  83. package/dist/commands/update.js.map +1 -0
  84. package/dist/commands/welcome.d.ts +14 -0
  85. package/dist/commands/welcome.d.ts.map +1 -0
  86. package/dist/commands/welcome.js +29 -0
  87. package/dist/commands/welcome.js.map +1 -0
  88. package/dist/skills/commands/add.d.ts +23 -0
  89. package/dist/skills/commands/add.d.ts.map +1 -0
  90. package/dist/skills/commands/add.js +206 -0
  91. package/dist/skills/commands/add.js.map +1 -0
  92. package/dist/skills/commands/info.d.ts +14 -0
  93. package/dist/skills/commands/info.d.ts.map +1 -0
  94. package/dist/skills/commands/info.js +99 -0
  95. package/dist/skills/commands/info.js.map +1 -0
  96. package/dist/skills/commands/list.d.ts +19 -0
  97. package/dist/skills/commands/list.d.ts.map +1 -0
  98. package/dist/skills/commands/list.js +163 -0
  99. package/dist/skills/commands/list.js.map +1 -0
  100. package/dist/skills/commands/publish.d.ts +56 -0
  101. package/dist/skills/commands/publish.d.ts.map +1 -0
  102. package/dist/skills/commands/publish.js +272 -0
  103. package/dist/skills/commands/publish.js.map +1 -0
  104. package/dist/skills/commands/remove.d.ts +19 -0
  105. package/dist/skills/commands/remove.d.ts.map +1 -0
  106. package/dist/skills/commands/remove.js +96 -0
  107. package/dist/skills/commands/remove.js.map +1 -0
  108. package/dist/skills/commands/update.d.ts +31 -0
  109. package/dist/skills/commands/update.d.ts.map +1 -0
  110. package/dist/skills/commands/update.js +132 -0
  111. package/dist/skills/commands/update.js.map +1 -0
  112. package/dist/skills/index.d.ts +22 -0
  113. package/dist/skills/index.d.ts.map +1 -0
  114. package/dist/skills/index.js +33 -0
  115. package/dist/skills/index.js.map +1 -0
  116. package/dist/skills/manifest.d.ts +54 -0
  117. package/dist/skills/manifest.d.ts.map +1 -0
  118. package/dist/skills/manifest.js +162 -0
  119. package/dist/skills/manifest.js.map +1 -0
  120. package/dist/skills/registry-local.d.ts +67 -0
  121. package/dist/skills/registry-local.d.ts.map +1 -0
  122. package/dist/skills/registry-local.js +130 -0
  123. package/dist/skills/registry-local.js.map +1 -0
  124. package/dist/skills/registry-mock.json +109 -0
  125. package/dist/skills/registry-remote.d.ts +110 -0
  126. package/dist/skills/registry-remote.d.ts.map +1 -0
  127. package/dist/skills/registry-remote.js +246 -0
  128. package/dist/skills/registry-remote.js.map +1 -0
  129. package/dist/skills/registry.d.ts +49 -0
  130. package/dist/skills/registry.d.ts.map +1 -0
  131. package/dist/skills/registry.js +94 -0
  132. package/dist/skills/registry.js.map +1 -0
  133. package/dist/skills/tests/manifest.spec.d.ts +8 -0
  134. package/dist/skills/tests/manifest.spec.d.ts.map +1 -0
  135. package/dist/skills/tests/manifest.spec.js +176 -0
  136. package/dist/skills/tests/manifest.spec.js.map +1 -0
  137. package/dist/skills/tests/publish.spec.d.ts +12 -0
  138. package/dist/skills/tests/publish.spec.d.ts.map +1 -0
  139. package/dist/skills/tests/publish.spec.js +276 -0
  140. package/dist/skills/tests/publish.spec.js.map +1 -0
  141. package/dist/skills/tests/registry-local.spec.d.ts +8 -0
  142. package/dist/skills/tests/registry-local.spec.d.ts.map +1 -0
  143. package/dist/skills/tests/registry-local.spec.js +231 -0
  144. package/dist/skills/tests/registry-local.spec.js.map +1 -0
  145. package/dist/skills/tests/registry.spec.d.ts +7 -0
  146. package/dist/skills/tests/registry.spec.d.ts.map +1 -0
  147. package/dist/skills/tests/registry.spec.js +58 -0
  148. package/dist/skills/tests/registry.spec.js.map +1 -0
  149. package/dist/skills/tests/remote-registry.spec.d.ts +9 -0
  150. package/dist/skills/tests/remote-registry.spec.d.ts.map +1 -0
  151. package/dist/skills/tests/remote-registry.spec.js +357 -0
  152. package/dist/skills/tests/remote-registry.spec.js.map +1 -0
  153. package/dist/skills/tests/update.spec.d.ts +9 -0
  154. package/dist/skills/tests/update.spec.d.ts.map +1 -0
  155. package/dist/skills/tests/update.spec.js +166 -0
  156. package/dist/skills/tests/update.spec.js.map +1 -0
  157. package/dist/types/Refine.types.d.ts +96 -0
  158. package/dist/types/Refine.types.d.ts.map +1 -0
  159. package/dist/types/Refine.types.js +19 -0
  160. package/dist/types/Refine.types.js.map +1 -0
  161. package/dist/types/Review.types.d.ts +86 -0
  162. package/dist/types/Review.types.d.ts.map +1 -0
  163. package/dist/types/Review.types.js +15 -0
  164. package/dist/types/Review.types.js.map +1 -0
  165. package/dist/types/UpdateManifest.types.d.ts +91 -0
  166. package/dist/types/UpdateManifest.types.d.ts.map +1 -0
  167. package/dist/types/UpdateManifest.types.js +13 -0
  168. package/dist/types/UpdateManifest.types.js.map +1 -0
  169. package/dist/utils/ReviewRunner.d.ts +42 -0
  170. package/dist/utils/ReviewRunner.d.ts.map +1 -0
  171. package/dist/utils/ReviewRunner.js +175 -0
  172. package/dist/utils/ReviewRunner.js.map +1 -0
  173. package/dist/utils/UpdateApplier.d.ts +42 -0
  174. package/dist/utils/UpdateApplier.d.ts.map +1 -0
  175. package/dist/utils/UpdateApplier.js +207 -0
  176. package/dist/utils/UpdateApplier.js.map +1 -0
  177. package/dist/utils/UpdateDetector.d.ts +56 -0
  178. package/dist/utils/UpdateDetector.d.ts.map +1 -0
  179. package/dist/utils/UpdateDetector.js +164 -0
  180. package/dist/utils/UpdateDetector.js.map +1 -0
  181. package/dist/utils/banner.d.ts +28 -0
  182. package/dist/utils/banner.d.ts.map +1 -0
  183. package/dist/utils/banner.js +77 -0
  184. package/dist/utils/banner.js.map +1 -0
  185. package/dist/utils/banner.spec.d.ts +5 -0
  186. package/dist/utils/banner.spec.d.ts.map +1 -0
  187. package/dist/utils/banner.spec.js +253 -0
  188. package/dist/utils/banner.spec.js.map +1 -0
  189. package/dist/utils/complexity-analyzer.d.ts +60 -0
  190. package/dist/utils/complexity-analyzer.d.ts.map +1 -0
  191. package/dist/utils/complexity-analyzer.js +292 -0
  192. package/dist/utils/complexity-analyzer.js.map +1 -0
  193. package/dist/utils/confidence.d.ts +41 -0
  194. package/dist/utils/confidence.d.ts.map +1 -0
  195. package/dist/utils/confidence.js +101 -0
  196. package/dist/utils/confidence.js.map +1 -0
  197. package/dist/utils/datamodel.d.ts +41 -0
  198. package/dist/utils/datamodel.d.ts.map +1 -0
  199. package/dist/utils/datamodel.js +535 -0
  200. package/dist/utils/datamodel.js.map +1 -0
  201. package/dist/utils/dna-detector.d.ts +61 -0
  202. package/dist/utils/dna-detector.d.ts.map +1 -0
  203. package/dist/utils/dna-detector.js +354 -0
  204. package/dist/utils/dna-detector.js.map +1 -0
  205. package/dist/utils/dna-facts.d.ts +13 -0
  206. package/dist/utils/dna-facts.d.ts.map +1 -0
  207. package/dist/utils/dna-facts.js +109 -0
  208. package/dist/utils/dna-facts.js.map +1 -0
  209. package/dist/utils/excalidraw-renderer.d.ts +11 -71
  210. package/dist/utils/excalidraw-renderer.d.ts.map +1 -1
  211. package/dist/utils/excalidraw-renderer.js +29 -162
  212. package/dist/utils/excalidraw-renderer.js.map +1 -1
  213. package/dist/utils/graph-renderer.d.ts +115 -0
  214. package/dist/utils/graph-renderer.d.ts.map +1 -0
  215. package/dist/utils/graph-renderer.js +216 -0
  216. package/dist/utils/graph-renderer.js.map +1 -0
  217. package/dist/utils/migration.d.ts +64 -0
  218. package/dist/utils/migration.d.ts.map +1 -0
  219. package/dist/utils/migration.js +183 -0
  220. package/dist/utils/migration.js.map +1 -0
  221. package/dist/utils/module-detector.d.ts +46 -0
  222. package/dist/utils/module-detector.d.ts.map +1 -0
  223. package/dist/utils/module-detector.js +348 -0
  224. package/dist/utils/module-detector.js.map +1 -0
  225. package/dist/utils/project-generator.d.ts.map +1 -1
  226. package/dist/utils/project-generator.js +273 -254
  227. package/dist/utils/project-generator.js.map +1 -1
  228. package/dist/utils/reverse-facts.d.ts +50 -0
  229. package/dist/utils/reverse-facts.d.ts.map +1 -0
  230. package/dist/utils/reverse-facts.js +291 -0
  231. package/dist/utils/reverse-facts.js.map +1 -0
  232. package/dist/utils/stack-bootstrap.js +371 -371
  233. package/dist/utils/static-analyzer.d.ts +29 -0
  234. package/dist/utils/static-analyzer.d.ts.map +1 -0
  235. package/dist/utils/static-analyzer.js +390 -0
  236. package/dist/utils/static-analyzer.js.map +1 -0
  237. package/dist/utils/version-compare.d.ts +27 -0
  238. package/dist/utils/version-compare.d.ts.map +1 -0
  239. package/dist/utils/version-compare.js +47 -0
  240. package/dist/utils/version-compare.js.map +1 -0
  241. package/package.json +8 -3
  242. package/templates/DARE-dag-example.yaml +280 -280
  243. package/templates/UPDATE-MANIFEST.json +48 -0
  244. package/templates/backend/node-nestjs/.env.example +9 -9
  245. package/templates/backend/node-nestjs/nest-cli.json +8 -8
  246. package/templates/backend/node-nestjs/package.json +50 -50
  247. package/templates/backend/node-nestjs/src/app.controller.ts +12 -12
  248. package/templates/backend/node-nestjs/src/app.module.ts +15 -15
  249. package/templates/backend/node-nestjs/src/app.service.ts +8 -8
  250. package/templates/backend/node-nestjs/src/main.ts +24 -24
  251. package/templates/backend/node-nestjs/tsconfig.json +21 -21
  252. package/templates/backend/php-laravel/.env.example +22 -22
  253. package/templates/backend/php-laravel/app/Http/Controllers/HealthController.php +15 -15
  254. package/templates/backend/php-laravel/composer.json +40 -40
  255. package/templates/backend/python-fastapi/.env.example +4 -4
  256. package/templates/backend/python-fastapi/app/api/router.py +8 -8
  257. package/templates/backend/python-fastapi/app/core/config.py +20 -20
  258. package/templates/backend/python-fastapi/main.py +35 -35
  259. package/templates/backend/python-fastapi/requirements.txt +13 -13
  260. package/templates/backend/rust-axum/.env.example +3 -3
  261. package/templates/backend/rust-axum/Cargo.toml +23 -23
  262. package/templates/backend/rust-axum/src/errors.rs +30 -30
  263. package/templates/backend/rust-axum/src/main.rs +32 -32
  264. package/templates/backend/rust-axum/src/routes.rs +6 -6
  265. package/templates/frontend/leptos-csr/.cargo/config.toml +2 -2
  266. package/templates/frontend/leptos-csr/Cargo.toml +16 -16
  267. package/templates/frontend/leptos-csr/Trunk.toml +10 -10
  268. package/templates/frontend/leptos-csr/index.html +11 -11
  269. package/templates/frontend/leptos-csr/src/lib.rs +20 -20
  270. package/templates/frontend/leptos-csr/style/main.scss +19 -19
  271. package/templates/frontend/leptos-fullstack/.cargo/config.toml +4 -4
  272. package/templates/frontend/leptos-fullstack/Cargo.toml +56 -56
  273. package/templates/frontend/leptos-fullstack/src/app.rs +49 -49
  274. package/templates/frontend/leptos-fullstack/src/lib.rs +9 -9
  275. package/templates/frontend/leptos-fullstack/src/main.rs +29 -29
  276. package/templates/frontend/leptos-fullstack/style/main.scss +19 -19
  277. package/templates/frontend/react/index.html +12 -12
  278. package/templates/frontend/react/package.json +35 -35
  279. package/templates/frontend/react/src/App.tsx +25 -25
  280. package/templates/frontend/react/src/main.tsx +9 -9
  281. package/templates/frontend/vue/package.json +32 -32
  282. package/templates/frontend/vue/src/App.vue +7 -7
  283. package/templates/frontend/vue/src/main.ts +10 -10
  284. package/templates/frontend/vue/src/router/index.ts +14 -14
  285. package/templates/frontend/vue/src/views/HomeView.vue +6 -6
  286. package/templates/hooks/pre-commit-dare-validate +24 -24
  287. package/templates/ide/antigravity/.agents/skills/dare-ax/SKILL.md +152 -0
  288. package/templates/ide/antigravity/.agents/skills/dare-blueprint/SKILL.md +180 -36
  289. package/templates/ide/antigravity/.agents/skills/dare-dag-build/SKILL.md +154 -0
  290. package/templates/ide/antigravity/.agents/skills/dare-dag-run/SKILL.md +130 -0
  291. package/templates/ide/antigravity/.agents/skills/dare-dag-runner/SKILL.md +203 -203
  292. package/templates/ide/antigravity/.agents/skills/dare-dna/SKILL.md +63 -0
  293. package/templates/ide/antigravity/.agents/skills/dare-docker/SKILL.md +315 -0
  294. package/templates/ide/antigravity/.agents/skills/dare-frontend-design/SKILL.md +192 -0
  295. package/templates/ide/antigravity/.agents/skills/dare-laravel-api/SKILL.md +337 -0
  296. package/templates/ide/antigravity/.agents/skills/dare-layered-design/SKILL.md +166 -0
  297. package/templates/ide/antigravity/.agents/skills/dare-llm-integration/SKILL.md +217 -0
  298. package/templates/ide/antigravity/.agents/skills/dare-migrate/SKILL.md +61 -0
  299. package/templates/ide/antigravity/.agents/skills/dare-quality-telemetry/SKILL.md +187 -0
  300. package/templates/ide/antigravity/.agents/skills/dare-realtime/SKILL.md +217 -0
  301. package/templates/ide/antigravity/.agents/skills/dare-refine/SKILL.md +114 -0
  302. package/templates/ide/antigravity/.agents/skills/dare-reverse/SKILL.md +108 -0
  303. package/templates/ide/antigravity/.agents/skills/dare-review/SKILL.md +111 -0
  304. package/templates/ide/antigravity/.agents/skills/dare-rust-leptos/SKILL.md +263 -0
  305. package/templates/ide/antigravity/.agents/skills/dare-rust-workspace/SKILL.md +275 -275
  306. package/templates/ide/antigravity/.agents/skills/dare-security/SKILL.md +274 -0
  307. package/templates/ide/antigravity/.agents/skills/dare-tasks/SKILL.md +265 -224
  308. package/templates/ide/antigravity/.agents/skills/dare-telemetry/SKILL.md +188 -0
  309. package/templates/ide/antigravity/.agents/skills/skill-fastapi-api/SKILL.md +343 -0
  310. package/templates/ide/antigravity/.agents/skills/skill-go-gin-api/SKILL.md +377 -0
  311. package/templates/ide/antigravity/.agents/skills/skill-mcp-server/SKILL.md +382 -0
  312. package/templates/ide/antigravity/.agents/skills/skill-nestjs-api/SKILL.md +326 -0
  313. package/templates/ide/antigravity/.agents/skills/skill-rails-api/SKILL.md +393 -0
  314. package/templates/ide/antigravity/templates/BLUEPRINT-template.md +193 -193
  315. package/templates/ide/antigravity/templates/DESIGN-template.md +129 -129
  316. package/templates/ide/antigravity/templates/TASK-SPEC-template.md +141 -100
  317. package/templates/ide/claude/.claude/commands/dare-ax.md +131 -0
  318. package/templates/ide/claude/.claude/commands/dare-blueprint.md +134 -78
  319. package/templates/ide/claude/.claude/commands/dare-bugfix-design.md +119 -0
  320. package/templates/ide/claude/.claude/commands/dare-dag-build.md +151 -110
  321. package/templates/ide/claude/.claude/commands/dare-dag-run.md +109 -109
  322. package/templates/ide/claude/.claude/commands/dare-dag-runner.md +117 -0
  323. package/templates/ide/claude/.claude/commands/dare-dag-viz.md +197 -197
  324. package/templates/ide/claude/.claude/commands/dare-design.md +69 -69
  325. package/templates/ide/claude/.claude/commands/dare-dna.md +75 -0
  326. package/templates/ide/claude/.claude/commands/dare-docker.md +207 -0
  327. package/templates/ide/claude/.claude/commands/dare-execute.md +152 -152
  328. package/templates/ide/claude/.claude/commands/dare-feature-design.md +147 -0
  329. package/templates/ide/claude/.claude/commands/dare-frontend-design.md +149 -0
  330. package/templates/ide/claude/.claude/commands/dare-laravel-api.md +211 -0
  331. package/templates/ide/claude/.claude/commands/dare-layered-design.md +124 -0
  332. package/templates/ide/claude/.claude/commands/dare-llm-integration.md +148 -0
  333. package/templates/ide/claude/.claude/commands/dare-migrate.md +72 -0
  334. package/templates/ide/claude/.claude/commands/dare-quality-telemetry.md +166 -0
  335. package/templates/ide/claude/.claude/commands/dare-realtime.md +159 -0
  336. package/templates/ide/claude/.claude/commands/dare-refine.md +145 -0
  337. package/templates/ide/claude/.claude/commands/dare-reverse.md +139 -0
  338. package/templates/ide/claude/.claude/commands/dare-review.md +113 -0
  339. package/templates/ide/claude/.claude/commands/dare-rust-leptos.md +269 -269
  340. package/templates/ide/claude/.claude/commands/dare-rust-workspace.md +209 -209
  341. package/templates/ide/claude/.claude/commands/dare-security.md +232 -232
  342. package/templates/ide/claude/.claude/commands/dare-tasks.md +70 -70
  343. package/templates/ide/claude/.claude/commands/dare-telemetry.md +132 -0
  344. package/templates/ide/claude/.claude/commands/skill-fastapi-api.md +205 -0
  345. package/templates/ide/claude/.claude/commands/skill-go-gin-api.md +232 -0
  346. package/templates/ide/claude/.claude/commands/skill-mcp-server.md +228 -0
  347. package/templates/ide/claude/.claude/commands/skill-nestjs-api.md +210 -0
  348. package/templates/ide/claude/.claude/commands/skill-rails-api.md +236 -0
  349. package/templates/ide/claude/.claude/settings.example.json +35 -35
  350. package/templates/ide/claude/CLAUDE.md +146 -146
  351. package/templates/ide/claude/templates/BLUEPRINT-template.md +193 -193
  352. package/templates/ide/claude/templates/DESIGN-template.md +129 -129
  353. package/templates/ide/claude/templates/TASK-SPEC-template.md +141 -100
  354. package/templates/ide/cursor/.cursor/commands/dag-viz.md +139 -0
  355. package/templates/ide/cursor/.cursor/commands/generate-blueprint.md +86 -41
  356. package/templates/ide/cursor/.cursor/commands/generate-design.md +35 -35
  357. package/templates/ide/cursor/.cursor/commands/generate-tasks.md +184 -142
  358. package/templates/ide/cursor/.cursor/commands/refine-task.md +107 -0
  359. package/templates/ide/cursor/.cursor/commands/review-task.md +91 -0
  360. package/templates/ide/cursor/.cursor/commands/run-dag.md +110 -110
  361. package/templates/ide/cursor/.cursor/rules/skill-ax.mdc +263 -0
  362. package/templates/ide/cursor/.cursor/rules/skill-dag-build.mdc +173 -0
  363. package/templates/ide/cursor/.cursor/rules/skill-dag-run.mdc +134 -0
  364. package/templates/ide/cursor/.cursor/rules/skill-dag-runner.mdc +221 -221
  365. package/templates/ide/cursor/.cursor/rules/skill-dna.mdc +63 -0
  366. package/templates/ide/cursor/.cursor/rules/skill-fastapi-api.mdc +352 -0
  367. package/templates/ide/cursor/.cursor/rules/skill-frontend-design.mdc +244 -0
  368. package/templates/ide/cursor/.cursor/rules/skill-go-gin-api.mdc +371 -0
  369. package/templates/ide/cursor/.cursor/rules/skill-layered-design.mdc +266 -0
  370. package/templates/ide/cursor/.cursor/rules/skill-llm-integration.mdc +295 -0
  371. package/templates/ide/cursor/.cursor/rules/skill-mcp-server.mdc +367 -0
  372. package/templates/ide/cursor/.cursor/rules/skill-migrate.mdc +58 -0
  373. package/templates/ide/cursor/.cursor/rules/skill-nestjs-api.mdc +346 -0
  374. package/templates/ide/cursor/.cursor/rules/skill-quality-telemetry.mdc +248 -0
  375. package/templates/ide/cursor/.cursor/rules/skill-rails-api.mdc +400 -0
  376. package/templates/ide/cursor/.cursor/rules/skill-realtime.mdc +262 -0
  377. package/templates/ide/cursor/.cursor/rules/skill-reverse.mdc +107 -0
  378. package/templates/ide/cursor/.cursor/rules/skill-rust-leptos.mdc +281 -0
  379. package/templates/ide/cursor/.cursor/rules/skill-rust-workspace.mdc +312 -312
  380. package/templates/ide/cursor/.cursor/rules/skill-security.mdc +245 -245
  381. package/templates/ide/cursor/templates/BLUEPRINT-template.md +193 -193
  382. package/templates/ide/cursor/templates/DESIGN-template.md +129 -129
  383. package/templates/ide/cursor/templates/TASK-SPEC-template.md +141 -100
  384. package/templates/shared/docker-compose.yml +41 -41
  385. package/dist/__tests__/dag-runner/adapters.test.d.ts +0 -2
  386. package/dist/__tests__/dag-runner/adapters.test.d.ts.map +0 -1
  387. package/dist/__tests__/dag-runner/adapters.test.js +0 -134
  388. package/dist/__tests__/dag-runner/adapters.test.js.map +0 -1
  389. package/dist/dag-runner/adapters/antigravity.d.ts +0 -6
  390. package/dist/dag-runner/adapters/antigravity.d.ts.map +0 -1
  391. package/dist/dag-runner/adapters/antigravity.js +0 -54
  392. package/dist/dag-runner/adapters/antigravity.js.map +0 -1
  393. package/dist/dag-runner/adapters/claude.d.ts +0 -6
  394. package/dist/dag-runner/adapters/claude.d.ts.map +0 -1
  395. package/dist/dag-runner/adapters/claude.js +0 -48
  396. package/dist/dag-runner/adapters/claude.js.map +0 -1
  397. package/dist/dag-runner/adapters/cursor.d.ts +0 -6
  398. package/dist/dag-runner/adapters/cursor.d.ts.map +0 -1
  399. package/dist/dag-runner/adapters/cursor.js +0 -58
  400. package/dist/dag-runner/adapters/cursor.js.map +0 -1
  401. package/dist/dag-runner/adapters/index.d.ts +0 -46
  402. package/dist/dag-runner/adapters/index.d.ts.map +0 -1
  403. package/dist/dag-runner/adapters/index.js +0 -55
  404. package/dist/dag-runner/adapters/index.js.map +0 -1
  405. package/dist/dag-runner/utils/timeout.d.ts +0 -27
  406. package/dist/dag-runner/utils/timeout.d.ts.map +0 -1
  407. package/dist/dag-runner/utils/timeout.js +0 -55
  408. package/dist/dag-runner/utils/timeout.js.map +0 -1
@@ -1,245 +1,245 @@
1
- ---
2
- description: Diretrizes de Segurança — OWASP Top 10, Supply Chain, Segredos e Dependências Vulneráveis para todas as fases do DARE
3
- globs: *.md, *.php, *.py, *.go, *.vue, *.js, *.ts, *.rs, *.toml, *.yaml, *.yml
4
- ---
5
-
6
- # Diretrizes de Segurança DARE
7
-
8
- Você é um Especialista em AppSec. Garanta que **Design → Blueprint → Tasks → Execução** sigam rigorosamente as práticas a seguir.
9
-
10
- ---
11
-
12
- ## Aplicação nas Fases do DARE
13
-
14
- ### Fase 1 — Design (`/generate-design` / `/dare-design`)
15
-
16
- - **Requisitos de segurança obrigatórios** (seção RS-*):
17
- - RS-01: validação de entrada (OWASP A03)
18
- - RS-02: hash de senhas / proteção de dados sensíveis (OWASP A02)
19
- - RS-03: controle de acesso por recurso (OWASP A01)
20
- - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
21
- - RS-05: secrets via variáveis de ambiente — nunca em código
22
- - Identifique vetores de ataque na ideia inicial e adicione mitigações em **Riscos**
23
-
24
- ### Fase 2 — Architect (`/generate-blueprint` / `/dare-blueprint`)
25
-
26
- - Endpoints da API: inclua coluna `Auth` (JWT/apiKey/público) e middleware de rate limiting
27
- - Modelo de dados: marque campos sensíveis (PII, tokens, hashes) e como são protegidos
28
- - Fases do plano: inclua **Fase N-1 = Auditoria de Segurança e Dependências** com critério de DONE explícito
29
- - Validation gates por stack devem incluir o comando de auditoria de dependências
30
-
31
- ### Fase 3 — Tasks (`/generate-tasks`)
32
-
33
- - Toda task que adiciona dependência externa → validation gate inclui `npm audit` / `cargo audit` / `pip-audit` / `composer audit`
34
- - Crie task dedicada para: headers de segurança HTTP, rate limiting, scan de secrets
35
- - Seção "Considerações de Segurança" obrigatória em cada `EXECUTION/task-*.md`
36
-
37
- ### Fase 4 — Execute (`/execute-task`)
38
-
39
- Aplique as proteções abaixo ao implementar qualquer código.
40
-
41
- ---
42
-
43
- ## OWASP Top 10 — Implementação
44
-
45
- ### A01 — Broken Access Control
46
-
47
- - Verifique permissão no **recurso**, não só na rota: `user.can('update', post)` / `authorize('update', $post)` / `check_permission(user, resource)`
48
- - Princípio do menor privilégio: tokens têm escopos mínimos necessários
49
- - Nunca exponha IDs sequenciais em URLs para recursos privados — use UUID ou ULID
50
- - Multi-tenant: **sempre** filtre por `tenant_id` / `org_id` em toda query
51
-
52
- ```ts
53
- // ✅ certo — verifica ownership antes de retornar
54
- const post = await db.post.findFirst({ where: { id, authorId: session.userId } });
55
- if (!post) throw new ForbiddenError();
56
-
57
- // ❌ errado — qualquer usuário autenticado acessa qualquer post
58
- const post = await db.post.findUnique({ where: { id } });
59
- ```
60
-
61
- ### A02 — Cryptographic Failures
62
-
63
- - Senhas: **Argon2id** (preferido) ou Bcrypt (min cost 12) — nunca MD5/SHA1/SHA256 para senhas
64
- - Dados sensíveis em repouso: criptografar PII com AES-256-GCM
65
- - Dados em trânsito: HTTPS obrigatório; HSTS header em produção
66
- - Nunca logue senha, token, chave de API, número de cartão, CPF completo
67
- - JWT: assine com RS256 (chave assimétrica) para tokens públicos; HS256 + segredo forte (≥ 256 bits) para internos
68
-
69
- ```rust
70
- // ✅ Rust — Argon2 via argon2 crate
71
- use argon2::{Argon2, PasswordHash, PasswordHasher, PasswordVerifier};
72
- let hash = Argon2::default().hash_password(password.as_bytes(), &salt)?;
73
- ```
74
-
75
- ### A03 — Injection
76
-
77
- **SQL Injection:**
78
- ```python
79
- # ✅ SQLAlchemy — parametrizado
80
- result = db.execute(select(User).where(User.email == email))
81
-
82
- # ❌ nunca
83
- db.execute(f"SELECT * FROM users WHERE email = '{email}'")
84
- ```
85
-
86
- **Command Injection:**
87
- ```go
88
- // ✅ Go — lista de args, não shell string
89
- cmd := exec.Command("convert", inputFile, outputFile)
90
-
91
- // ❌ nunca
92
- exec.Command("sh", "-c", "convert "+userInput)
93
- ```
94
-
95
- **XSS:** escape de saída no frontend; `Content-Security-Policy` no backend; evite `innerHTML` / `dangerouslySetInnerHTML` com dados do usuário.
96
-
97
- **Prompt Injection (IA):** se o projeto processa entradas de usuários em prompts LLM:
98
- - Separe instrução do sistema e dados do usuário por delimitadores claros
99
- - Valide e sanitize a entrada antes de inserir no prompt
100
- - Nunca confie em output do LLM como código a ser executado sem sandboxing
101
-
102
- ### A04 — Insecure Design
103
-
104
- - Valide **no servidor** sempre, mesmo que o frontend já valide
105
- - Allowlists > blocklists para validação de campos, tipos de arquivo, domínios
106
- - Implemente rate limiting antes de qualquer lógica de negócio em endpoints públicos
107
-
108
- ### A05 — Security Misconfiguration
109
-
110
- - Stack traces e erros detalhados: **apenas em desenvolvimento** — produção retorna mensagem genérica
111
- - Headers de segurança obrigatórios em produção:
112
- ```
113
- Strict-Transport-Security: max-age=31536000; includeSubDomains
114
- X-Frame-Options: DENY
115
- X-Content-Type-Options: nosniff
116
- Content-Security-Policy: default-src 'self'
117
- Referrer-Policy: strict-origin-when-cross-origin
118
- Permissions-Policy: camera=(), microphone=(), geolocation=()
119
- ```
120
- - CORS: nunca `Access-Control-Allow-Origin: *` para endpoints autenticados
121
- - Desabilite métodos HTTP desnecessários (TRACE, OPTIONS em APIs simples)
122
-
123
- ### A06 — Vulnerable and Outdated Components ← **crítico para Ralph Loop**
124
-
125
- **Comandos de auditoria por stack:**
126
-
127
- ```bash
128
- # Node.js / npm — rodar antes de todo commit com novas deps
129
- npm audit --audit-level=high
130
- npm audit fix # corrige automaticamente quando possível
131
-
132
- # Rust / Cargo
133
- cargo install cargo-audit # uma vez
134
- cargo audit # detecta CVEs no RustSec Advisory DB
135
- cargo update # bumpa versões compatíveis
136
-
137
- # Python
138
- pip install pip-audit
139
- pip-audit # CVEs via OSV + PyPI
140
- pip-audit --fix # auto-fix quando possível
141
-
142
- # PHP / Composer
143
- composer audit # nativo desde Composer 2.4
144
- composer update --with-all-dependencies [pacote] # fix pontual
145
-
146
- # Go
147
- go list -json -m all | nancy sleuth # ou govulncheck
148
- govulncheck ./... # ferramenta oficial Google
149
-
150
- # Docker images
151
- docker scout cves [imagem] # se Docker Scout disponível
152
- ```
153
-
154
- **Critério inegociável:** nenhuma dependência com CVE de nível **HIGH** ou **CRITICAL** pode entrar em produção sem justificativa documentada e plano de upgrade.
155
-
156
- ### A07 — Authentication Failures
157
-
158
- - Rate limiting no endpoint de login: máx 5 tentativas / 15 min por IP + por usuário
159
- - Tokens JWT: `exp` máx 15 min para access token; refresh token com rotação
160
- - Logout: invalide refresh token no servidor (não confie só no lado cliente)
161
- - Senhas: mínimo 12 caracteres; bloquear senhas da lista HaveIBeenPwned
162
- - MFA: ofereça TOTP (RFC 6238) para contas com acesso a dados sensíveis
163
-
164
- ### A08 — Software and Data Integrity
165
-
166
- - Valide assinatura / checksum de artefatos externos antes de usar
167
- - Nunca confie em dados enviados pelo cliente para decisões de autorização
168
- - CI/CD: pins de versão em actions (`actions/checkout@v4` não `@main`)
169
- - Lockfiles (`package-lock.json`, `Cargo.lock`, `poetry.lock`) devem ser commitados
170
-
171
- ### A09 — Security Logging and Monitoring
172
-
173
- Logue (estruturado JSON, sem dados sensíveis):
174
- - Autenticação: login OK/FAIL, logout, refresh, MFA challenge
175
- - Autorização: acesso negado (403) com recurso e userId
176
- - Erros 5xx em produção com trace-id (sem stack trace completo)
177
- - Operações destrutivas: delete, disable, role change
178
-
179
- Nunca logue: senhas, tokens, chaves de API, números de cartão, CPF/SSN completo.
180
-
181
- ### A10 — SSRF
182
-
183
- - Se a aplicação faz requisições para URLs fornecidas pelo usuário:
184
- - Valide contra allowlist de domínios
185
- - Bloqueie IPs privados (`127.x`, `10.x`, `172.16-31.x`, `192.168.x`, `169.254.x`)
186
- - Bloqueie acesso a metadados de cloud (`169.254.169.254`)
187
- - Use timeout agressivo (máx 5s) e sem redirects automáticos
188
-
189
- ---
190
-
191
- ## Segredos e Supply Chain
192
-
193
- ### Nunca em código
194
-
195
- ```bash
196
- # Padrões proibidos em commits — configure pre-commit hook ou git-secrets:
197
- password = "..."
198
- api_key = "..."
199
- secret_key = "..."
200
- AWS_SECRET_ACCESS_KEY = "..."
201
- DATABASE_URL = "postgres://user:password@..."
202
- ```
203
-
204
- ### Gestão de segredos
205
-
206
- - Desenvolvimento: arquivo `.env` (no `.gitignore`) com `.env.example` sem valores reais
207
- - CI/CD: variáveis de ambiente ou secrets do pipeline (GitHub Actions Secrets, etc.)
208
- - Produção: vault (HashiCorp Vault, AWS Secrets Manager, GCP Secret Manager)
209
- - Rotação: tokens de serviço rotacionados a cada 90 dias
210
-
211
- ### Verificação pre-commit (recomendado)
212
-
213
- ```bash
214
- # Instalar detect-secrets
215
- pip install detect-secrets
216
- detect-secrets scan > .secrets.baseline
217
- detect-secrets audit .secrets.baseline
218
-
219
- # Ou git-secrets
220
- git secrets --install
221
- git secrets --register-aws
222
- ```
223
-
224
- ---
225
-
226
- ## Validation Gates de Segurança no Ralph Loop
227
-
228
- Adicione ao ciclo de cada task que mexe em dependências ou configuração:
229
-
230
- ```bash
231
- # 1. Auditoria de dependências (obrigatório se houve mudança em deps)
232
- npm audit --audit-level=high # Node
233
- cargo audit # Rust
234
- pip-audit # Python
235
- composer audit # PHP
236
-
237
- # 2. Scan de secrets (obrigatório em tasks de config/infra/CI)
238
- detect-secrets scan --baseline .secrets.baseline
239
-
240
- # 3. Headers de segurança (para tasks de configuração de servidor)
241
- # Verificar manualmente ou com curl:
242
- curl -I https://staging.example.com | grep -E "Strict-Transport|X-Frame|X-Content|Content-Security"
243
- ```
244
-
245
- > **Gate obrigatório:** CVE HIGH/CRITICAL nas dependências = task **FAILED** até corrigi-las.
1
+ ---
2
+ description: Diretrizes de Segurança — OWASP Top 10, Supply Chain, Segredos e Dependências Vulneráveis para todas as fases do DARE
3
+ globs: *.md, *.php, *.py, *.go, *.vue, *.js, *.ts, *.rs, *.toml, *.yaml, *.yml
4
+ ---
5
+
6
+ # Diretrizes de Segurança DARE
7
+
8
+ Você é um Especialista em AppSec. Garanta que **Design → Blueprint → Tasks → Execução** sigam rigorosamente as práticas a seguir.
9
+
10
+ ---
11
+
12
+ ## Aplicação nas Fases do DARE
13
+
14
+ ### Fase 1 — Design (`/generate-design` / `/dare-design`)
15
+
16
+ - **Requisitos de segurança obrigatórios** (seção RS-*):
17
+ - RS-01: validação de entrada (OWASP A03)
18
+ - RS-02: hash de senhas / proteção de dados sensíveis (OWASP A02)
19
+ - RS-03: controle de acesso por recurso (OWASP A01)
20
+ - RS-04: auditoria de dependências sem CVE HIGH/CRITICAL (OWASP A06)
21
+ - RS-05: secrets via variáveis de ambiente — nunca em código
22
+ - Identifique vetores de ataque na ideia inicial e adicione mitigações em **Riscos**
23
+
24
+ ### Fase 2 — Architect (`/generate-blueprint` / `/dare-blueprint`)
25
+
26
+ - Endpoints da API: inclua coluna `Auth` (JWT/apiKey/público) e middleware de rate limiting
27
+ - Modelo de dados: marque campos sensíveis (PII, tokens, hashes) e como são protegidos
28
+ - Fases do plano: inclua **Fase N-1 = Auditoria de Segurança e Dependências** com critério de DONE explícito
29
+ - Validation gates por stack devem incluir o comando de auditoria de dependências
30
+
31
+ ### Fase 3 — Tasks (`/generate-tasks`)
32
+
33
+ - Toda task que adiciona dependência externa → validation gate inclui `npm audit` / `cargo audit` / `pip-audit` / `composer audit`
34
+ - Crie task dedicada para: headers de segurança HTTP, rate limiting, scan de secrets
35
+ - Seção "Considerações de Segurança" obrigatória em cada `EXECUTION/task-*.md`
36
+
37
+ ### Fase 4 — Execute (`/execute-task`)
38
+
39
+ Aplique as proteções abaixo ao implementar qualquer código.
40
+
41
+ ---
42
+
43
+ ## OWASP Top 10 — Implementação
44
+
45
+ ### A01 — Broken Access Control
46
+
47
+ - Verifique permissão no **recurso**, não só na rota: `user.can('update', post)` / `authorize('update', $post)` / `check_permission(user, resource)`
48
+ - Princípio do menor privilégio: tokens têm escopos mínimos necessários
49
+ - Nunca exponha IDs sequenciais em URLs para recursos privados — use UUID ou ULID
50
+ - Multi-tenant: **sempre** filtre por `tenant_id` / `org_id` em toda query
51
+
52
+ ```ts
53
+ // ✅ certo — verifica ownership antes de retornar
54
+ const post = await db.post.findFirst({ where: { id, authorId: session.userId } });
55
+ if (!post) throw new ForbiddenError();
56
+
57
+ // ❌ errado — qualquer usuário autenticado acessa qualquer post
58
+ const post = await db.post.findUnique({ where: { id } });
59
+ ```
60
+
61
+ ### A02 — Cryptographic Failures
62
+
63
+ - Senhas: **Argon2id** (preferido) ou Bcrypt (min cost 12) — nunca MD5/SHA1/SHA256 para senhas
64
+ - Dados sensíveis em repouso: criptografar PII com AES-256-GCM
65
+ - Dados em trânsito: HTTPS obrigatório; HSTS header em produção
66
+ - Nunca logue senha, token, chave de API, número de cartão, CPF completo
67
+ - JWT: assine com RS256 (chave assimétrica) para tokens públicos; HS256 + segredo forte (≥ 256 bits) para internos
68
+
69
+ ```rust
70
+ // ✅ Rust — Argon2 via argon2 crate
71
+ use argon2::{Argon2, PasswordHash, PasswordHasher, PasswordVerifier};
72
+ let hash = Argon2::default().hash_password(password.as_bytes(), &salt)?;
73
+ ```
74
+
75
+ ### A03 — Injection
76
+
77
+ **SQL Injection:**
78
+ ```python
79
+ # ✅ SQLAlchemy — parametrizado
80
+ result = db.execute(select(User).where(User.email == email))
81
+
82
+ # ❌ nunca
83
+ db.execute(f"SELECT * FROM users WHERE email = '{email}'")
84
+ ```
85
+
86
+ **Command Injection:**
87
+ ```go
88
+ // ✅ Go — lista de args, não shell string
89
+ cmd := exec.Command("convert", inputFile, outputFile)
90
+
91
+ // ❌ nunca
92
+ exec.Command("sh", "-c", "convert "+userInput)
93
+ ```
94
+
95
+ **XSS:** escape de saída no frontend; `Content-Security-Policy` no backend; evite `innerHTML` / `dangerouslySetInnerHTML` com dados do usuário.
96
+
97
+ **Prompt Injection (IA):** se o projeto processa entradas de usuários em prompts LLM:
98
+ - Separe instrução do sistema e dados do usuário por delimitadores claros
99
+ - Valide e sanitize a entrada antes de inserir no prompt
100
+ - Nunca confie em output do LLM como código a ser executado sem sandboxing
101
+
102
+ ### A04 — Insecure Design
103
+
104
+ - Valide **no servidor** sempre, mesmo que o frontend já valide
105
+ - Allowlists > blocklists para validação de campos, tipos de arquivo, domínios
106
+ - Implemente rate limiting antes de qualquer lógica de negócio em endpoints públicos
107
+
108
+ ### A05 — Security Misconfiguration
109
+
110
+ - Stack traces e erros detalhados: **apenas em desenvolvimento** — produção retorna mensagem genérica
111
+ - Headers de segurança obrigatórios em produção:
112
+ ```
113
+ Strict-Transport-Security: max-age=31536000; includeSubDomains
114
+ X-Frame-Options: DENY
115
+ X-Content-Type-Options: nosniff
116
+ Content-Security-Policy: default-src 'self'
117
+ Referrer-Policy: strict-origin-when-cross-origin
118
+ Permissions-Policy: camera=(), microphone=(), geolocation=()
119
+ ```
120
+ - CORS: nunca `Access-Control-Allow-Origin: *` para endpoints autenticados
121
+ - Desabilite métodos HTTP desnecessários (TRACE, OPTIONS em APIs simples)
122
+
123
+ ### A06 — Vulnerable and Outdated Components ← **crítico para Ralph Loop**
124
+
125
+ **Comandos de auditoria por stack:**
126
+
127
+ ```bash
128
+ # Node.js / npm — rodar antes de todo commit com novas deps
129
+ npm audit --audit-level=high
130
+ npm audit fix # corrige automaticamente quando possível
131
+
132
+ # Rust / Cargo
133
+ cargo install cargo-audit # uma vez
134
+ cargo audit # detecta CVEs no RustSec Advisory DB
135
+ cargo update # bumpa versões compatíveis
136
+
137
+ # Python
138
+ pip install pip-audit
139
+ pip-audit # CVEs via OSV + PyPI
140
+ pip-audit --fix # auto-fix quando possível
141
+
142
+ # PHP / Composer
143
+ composer audit # nativo desde Composer 2.4
144
+ composer update --with-all-dependencies [pacote] # fix pontual
145
+
146
+ # Go
147
+ go list -json -m all | nancy sleuth # ou govulncheck
148
+ govulncheck ./... # ferramenta oficial Google
149
+
150
+ # Docker images
151
+ docker scout cves [imagem] # se Docker Scout disponível
152
+ ```
153
+
154
+ **Critério inegociável:** nenhuma dependência com CVE de nível **HIGH** ou **CRITICAL** pode entrar em produção sem justificativa documentada e plano de upgrade.
155
+
156
+ ### A07 — Authentication Failures
157
+
158
+ - Rate limiting no endpoint de login: máx 5 tentativas / 15 min por IP + por usuário
159
+ - Tokens JWT: `exp` máx 15 min para access token; refresh token com rotação
160
+ - Logout: invalide refresh token no servidor (não confie só no lado cliente)
161
+ - Senhas: mínimo 12 caracteres; bloquear senhas da lista HaveIBeenPwned
162
+ - MFA: ofereça TOTP (RFC 6238) para contas com acesso a dados sensíveis
163
+
164
+ ### A08 — Software and Data Integrity
165
+
166
+ - Valide assinatura / checksum de artefatos externos antes de usar
167
+ - Nunca confie em dados enviados pelo cliente para decisões de autorização
168
+ - CI/CD: pins de versão em actions (`actions/checkout@v4` não `@main`)
169
+ - Lockfiles (`package-lock.json`, `Cargo.lock`, `poetry.lock`) devem ser commitados
170
+
171
+ ### A09 — Security Logging and Monitoring
172
+
173
+ Logue (estruturado JSON, sem dados sensíveis):
174
+ - Autenticação: login OK/FAIL, logout, refresh, MFA challenge
175
+ - Autorização: acesso negado (403) com recurso e userId
176
+ - Erros 5xx em produção com trace-id (sem stack trace completo)
177
+ - Operações destrutivas: delete, disable, role change
178
+
179
+ Nunca logue: senhas, tokens, chaves de API, números de cartão, CPF/SSN completo.
180
+
181
+ ### A10 — SSRF
182
+
183
+ - Se a aplicação faz requisições para URLs fornecidas pelo usuário:
184
+ - Valide contra allowlist de domínios
185
+ - Bloqueie IPs privados (`127.x`, `10.x`, `172.16-31.x`, `192.168.x`, `169.254.x`)
186
+ - Bloqueie acesso a metadados de cloud (`169.254.169.254`)
187
+ - Use timeout agressivo (máx 5s) e sem redirects automáticos
188
+
189
+ ---
190
+
191
+ ## Segredos e Supply Chain
192
+
193
+ ### Nunca em código
194
+
195
+ ```bash
196
+ # Padrões proibidos em commits — configure pre-commit hook ou git-secrets:
197
+ password = "..."
198
+ api_key = "..."
199
+ secret_key = "..."
200
+ AWS_SECRET_ACCESS_KEY = "..."
201
+ DATABASE_URL = "postgres://user:password@..."
202
+ ```
203
+
204
+ ### Gestão de segredos
205
+
206
+ - Desenvolvimento: arquivo `.env` (no `.gitignore`) com `.env.example` sem valores reais
207
+ - CI/CD: variáveis de ambiente ou secrets do pipeline (GitHub Actions Secrets, etc.)
208
+ - Produção: vault (HashiCorp Vault, AWS Secrets Manager, GCP Secret Manager)
209
+ - Rotação: tokens de serviço rotacionados a cada 90 dias
210
+
211
+ ### Verificação pre-commit (recomendado)
212
+
213
+ ```bash
214
+ # Instalar detect-secrets
215
+ pip install detect-secrets
216
+ detect-secrets scan > .secrets.baseline
217
+ detect-secrets audit .secrets.baseline
218
+
219
+ # Ou git-secrets
220
+ git secrets --install
221
+ git secrets --register-aws
222
+ ```
223
+
224
+ ---
225
+
226
+ ## Validation Gates de Segurança no Ralph Loop
227
+
228
+ Adicione ao ciclo de cada task que mexe em dependências ou configuração:
229
+
230
+ ```bash
231
+ # 1. Auditoria de dependências (obrigatório se houve mudança em deps)
232
+ npm audit --audit-level=high # Node
233
+ cargo audit # Rust
234
+ pip-audit # Python
235
+ composer audit # PHP
236
+
237
+ # 2. Scan de secrets (obrigatório em tasks de config/infra/CI)
238
+ detect-secrets scan --baseline .secrets.baseline
239
+
240
+ # 3. Headers de segurança (para tasks de configuração de servidor)
241
+ # Verificar manualmente ou com curl:
242
+ curl -I https://staging.example.com | grep -E "Strict-Transport|X-Frame|X-Content|Content-Security"
243
+ ```
244
+
245
+ > **Gate obrigatório:** CVE HIGH/CRITICAL nas dependências = task **FAILED** até corrigi-las.