@girardelli/architect-agents 8.1.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 (258) hide show
  1. package/dist/src/core/agent-generator/context-enricher.d.ts +17 -0
  2. package/dist/src/core/agent-generator/context-enricher.js +51 -0
  3. package/dist/src/core/agent-generator/context-enricher.js.map +1 -0
  4. package/dist/src/core/agent-generator/detectors/base-detector.d.ts +8 -0
  5. package/dist/src/core/agent-generator/detectors/base-detector.js +12 -0
  6. package/dist/src/core/agent-generator/detectors/base-detector.js.map +1 -0
  7. package/dist/src/core/agent-generator/detectors/dart-detector.d.ts +5 -0
  8. package/dist/src/core/agent-generator/detectors/dart-detector.js +16 -0
  9. package/dist/src/core/agent-generator/detectors/dart-detector.js.map +1 -0
  10. package/dist/src/core/agent-generator/detectors/framework-registry.d.ts +5 -0
  11. package/dist/src/core/agent-generator/detectors/framework-registry.js +81 -0
  12. package/dist/src/core/agent-generator/detectors/framework-registry.js.map +1 -0
  13. package/dist/src/core/agent-generator/detectors/go-detector.d.ts +5 -0
  14. package/dist/src/core/agent-generator/detectors/go-detector.js +25 -0
  15. package/dist/src/core/agent-generator/detectors/go-detector.js.map +1 -0
  16. package/dist/src/core/agent-generator/detectors/java-detector.d.ts +5 -0
  17. package/dist/src/core/agent-generator/detectors/java-detector.js +44 -0
  18. package/dist/src/core/agent-generator/detectors/java-detector.js.map +1 -0
  19. package/dist/src/core/agent-generator/detectors/node-detector.d.ts +5 -0
  20. package/dist/src/core/agent-generator/detectors/node-detector.js +28 -0
  21. package/dist/src/core/agent-generator/detectors/node-detector.js.map +1 -0
  22. package/dist/src/core/agent-generator/detectors/php-detector.d.ts +5 -0
  23. package/dist/src/core/agent-generator/detectors/php-detector.js +28 -0
  24. package/dist/src/core/agent-generator/detectors/php-detector.js.map +1 -0
  25. package/dist/src/core/agent-generator/detectors/python-detector.d.ts +7 -0
  26. package/dist/src/core/agent-generator/detectors/python-detector.js +116 -0
  27. package/dist/src/core/agent-generator/detectors/python-detector.js.map +1 -0
  28. package/dist/src/core/agent-generator/detectors/ruby-detector.d.ts +5 -0
  29. package/dist/src/core/agent-generator/detectors/ruby-detector.js +23 -0
  30. package/dist/src/core/agent-generator/detectors/ruby-detector.js.map +1 -0
  31. package/dist/src/core/agent-generator/detectors/rust-detector.d.ts +5 -0
  32. package/dist/src/core/agent-generator/detectors/rust-detector.js +18 -0
  33. package/dist/src/core/agent-generator/detectors/rust-detector.js.map +1 -0
  34. package/dist/src/core/agent-generator/detectors/structure-detector.d.ts +4 -0
  35. package/dist/src/core/agent-generator/detectors/structure-detector.js +35 -0
  36. package/dist/src/core/agent-generator/detectors/structure-detector.js.map +1 -0
  37. package/dist/src/core/agent-generator/detectors/toolchain-detector.d.ts +5 -0
  38. package/dist/src/core/agent-generator/detectors/toolchain-detector.js +164 -0
  39. package/dist/src/core/agent-generator/detectors/toolchain-detector.js.map +1 -0
  40. package/dist/src/core/agent-generator/domain-inferrer.d.ts +51 -0
  41. package/dist/src/core/agent-generator/domain-inferrer.js +585 -0
  42. package/dist/src/core/agent-generator/domain-inferrer.js.map +1 -0
  43. package/dist/src/core/agent-generator/engines/audit-engine.d.ts +8 -0
  44. package/dist/src/core/agent-generator/engines/audit-engine.js +84 -0
  45. package/dist/src/core/agent-generator/engines/audit-engine.js.map +1 -0
  46. package/dist/src/core/agent-generator/engines/context-builder.d.ts +12 -0
  47. package/dist/src/core/agent-generator/engines/context-builder.js +84 -0
  48. package/dist/src/core/agent-generator/engines/context-builder.js.map +1 -0
  49. package/dist/src/core/agent-generator/engines/generation-engine.d.ts +7 -0
  50. package/dist/src/core/agent-generator/engines/generation-engine.js +160 -0
  51. package/dist/src/core/agent-generator/engines/generation-engine.js.map +1 -0
  52. package/dist/src/core/agent-generator/engines/generation-engine_deps.d.ts +21 -0
  53. package/dist/src/core/agent-generator/engines/generation-engine_deps.js +17 -0
  54. package/dist/src/core/agent-generator/engines/generation-engine_deps.js.map +1 -0
  55. package/dist/src/core/agent-generator/engines/suggestion-engine.d.ts +13 -0
  56. package/dist/src/core/agent-generator/engines/suggestion-engine.js +171 -0
  57. package/dist/src/core/agent-generator/engines/suggestion-engine.js.map +1 -0
  58. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.d.ts +8 -0
  59. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js +5 -0
  60. package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js.map +1 -0
  61. package/dist/src/core/agent-generator/enrichers/analysis-helpers.d.ts +9 -0
  62. package/dist/src/core/agent-generator/enrichers/analysis-helpers.js +51 -0
  63. package/dist/src/core/agent-generator/enrichers/analysis-helpers.js.map +1 -0
  64. package/dist/src/core/agent-generator/enrichers/description-generator.d.ts +4 -0
  65. package/dist/src/core/agent-generator/enrichers/description-generator.js +82 -0
  66. package/dist/src/core/agent-generator/enrichers/description-generator.js.map +1 -0
  67. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.d.ts +7 -0
  68. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js +90 -0
  69. package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js.map +1 -0
  70. package/dist/src/core/agent-generator/enrichers/layer-classifier.d.ts +12 -0
  71. package/dist/src/core/agent-generator/enrichers/layer-classifier.js +152 -0
  72. package/dist/src/core/agent-generator/enrichers/layer-classifier.js.map +1 -0
  73. package/dist/src/core/agent-generator/enrichers/module-extractor.d.ts +10 -0
  74. package/dist/src/core/agent-generator/enrichers/module-extractor.js +173 -0
  75. package/dist/src/core/agent-generator/enrichers/module-extractor.js.map +1 -0
  76. package/dist/src/core/agent-generator/framework-detector.d.ts +17 -0
  77. package/dist/src/core/agent-generator/framework-detector.js +56 -0
  78. package/dist/src/core/agent-generator/framework-detector.js.map +1 -0
  79. package/dist/src/core/agent-generator/index.d.ts +25 -0
  80. package/dist/src/core/agent-generator/index.js +37 -0
  81. package/dist/src/core/agent-generator/index.js.map +1 -0
  82. package/dist/src/core/agent-generator/stack-detector.d.ts +13 -0
  83. package/dist/src/core/agent-generator/stack-detector.js +124 -0
  84. package/dist/src/core/agent-generator/stack-detector.js.map +1 -0
  85. package/dist/src/core/agent-generator/templates/core/agents.d.ts +9 -0
  86. package/dist/src/core/agent-generator/templates/core/agents.js +1127 -0
  87. package/dist/src/core/agent-generator/templates/core/agents.js.map +1 -0
  88. package/dist/src/core/agent-generator/templates/core/architecture-rules.d.ts +6 -0
  89. package/dist/src/core/agent-generator/templates/core/architecture-rules.js +275 -0
  90. package/dist/src/core/agent-generator/templates/core/architecture-rules.js.map +1 -0
  91. package/dist/src/core/agent-generator/templates/core/general-rules.d.ts +7 -0
  92. package/dist/src/core/agent-generator/templates/core/general-rules.js +301 -0
  93. package/dist/src/core/agent-generator/templates/core/general-rules.js.map +1 -0
  94. package/dist/src/core/agent-generator/templates/core/hooks-generator.d.ts +20 -0
  95. package/dist/src/core/agent-generator/templates/core/hooks-generator.js +235 -0
  96. package/dist/src/core/agent-generator/templates/core/hooks-generator.js.map +1 -0
  97. package/dist/src/core/agent-generator/templates/core/index-md.d.ts +6 -0
  98. package/dist/src/core/agent-generator/templates/core/index-md.js +247 -0
  99. package/dist/src/core/agent-generator/templates/core/index-md.js.map +1 -0
  100. package/dist/src/core/agent-generator/templates/core/orchestrator.d.ts +7 -0
  101. package/dist/src/core/agent-generator/templates/core/orchestrator.js +423 -0
  102. package/dist/src/core/agent-generator/templates/core/orchestrator.js.map +1 -0
  103. package/dist/src/core/agent-generator/templates/core/preflight.d.ts +7 -0
  104. package/dist/src/core/agent-generator/templates/core/preflight.js +213 -0
  105. package/dist/src/core/agent-generator/templates/core/preflight.js.map +1 -0
  106. package/dist/src/core/agent-generator/templates/core/quality-gates.d.ts +10 -0
  107. package/dist/src/core/agent-generator/templates/core/quality-gates.js +255 -0
  108. package/dist/src/core/agent-generator/templates/core/quality-gates.js.map +1 -0
  109. package/dist/src/core/agent-generator/templates/core/security-rules.d.ts +6 -0
  110. package/dist/src/core/agent-generator/templates/core/security-rules.js +529 -0
  111. package/dist/src/core/agent-generator/templates/core/security-rules.js.map +1 -0
  112. package/dist/src/core/agent-generator/templates/core/skills-generator.d.ts +18 -0
  113. package/dist/src/core/agent-generator/templates/core/skills-generator.js +547 -0
  114. package/dist/src/core/agent-generator/templates/core/skills-generator.js.map +1 -0
  115. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.d.ts +6 -0
  116. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js +238 -0
  117. package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
  118. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.d.ts +7 -0
  119. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js +321 -0
  120. package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
  121. package/dist/src/core/agent-generator/templates/core/workflow-review.d.ts +6 -0
  122. package/dist/src/core/agent-generator/templates/core/workflow-review.js +105 -0
  123. package/dist/src/core/agent-generator/templates/core/workflow-review.js.map +1 -0
  124. package/dist/src/core/agent-generator/templates/domain/index.d.ts +21 -0
  125. package/dist/src/core/agent-generator/templates/domain/index.js +1179 -0
  126. package/dist/src/core/agent-generator/templates/domain/index.js.map +1 -0
  127. package/dist/src/core/agent-generator/templates/helpers/base-helpers.d.ts +10 -0
  128. package/dist/src/core/agent-generator/templates/helpers/base-helpers.js +20 -0
  129. package/dist/src/core/agent-generator/templates/helpers/base-helpers.js.map +1 -0
  130. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +2 -0
  131. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js +77 -0
  132. package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +1 -0
  133. package/dist/src/core/agent-generator/templates/helpers/security-helpers.d.ts +2 -0
  134. package/dist/src/core/agent-generator/templates/helpers/security-helpers.js +182 -0
  135. package/dist/src/core/agent-generator/templates/helpers/security-helpers.js.map +1 -0
  136. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.d.ts +4 -0
  137. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js +69 -0
  138. package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js.map +1 -0
  139. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.d.ts +2 -0
  140. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js +275 -0
  141. package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js.map +1 -0
  142. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.d.ts +6 -0
  143. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js +56 -0
  144. package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js.map +1 -0
  145. package/dist/src/core/agent-generator/templates/stack/index.d.ts +7 -0
  146. package/dist/src/core/agent-generator/templates/stack/index.js +695 -0
  147. package/dist/src/core/agent-generator/templates/stack/index.js.map +1 -0
  148. package/dist/src/core/agent-generator/templates/template-helpers.d.ts +11 -0
  149. package/dist/src/core/agent-generator/templates/template-helpers.js +12 -0
  150. package/dist/src/core/agent-generator/templates/template-helpers.js.map +1 -0
  151. package/dist/src/core/agent-generator/types/agent.d.ts +39 -0
  152. package/dist/src/core/agent-generator/types/agent.js +27 -0
  153. package/dist/src/core/agent-generator/types/agent.js.map +1 -0
  154. package/dist/src/core/agent-generator/types/domain.d.ts +58 -0
  155. package/dist/src/core/agent-generator/types/domain.js +2 -0
  156. package/dist/src/core/agent-generator/types/domain.js.map +1 -0
  157. package/dist/src/core/agent-generator/types/stack.d.ts +36 -0
  158. package/dist/src/core/agent-generator/types/stack.js +2 -0
  159. package/dist/src/core/agent-generator/types/stack.js.map +1 -0
  160. package/dist/src/core/agent-generator/types/template.d.ts +29 -0
  161. package/dist/src/core/agent-generator/types/template.js +2 -0
  162. package/dist/src/core/agent-generator/types/template.js.map +1 -0
  163. package/dist/src/core/agent-runtime/ai-provider.d.ts +33 -0
  164. package/dist/src/core/agent-runtime/ai-provider.js +146 -0
  165. package/dist/src/core/agent-runtime/ai-provider.js.map +1 -0
  166. package/dist/src/core/agent-runtime/executor.d.ts +13 -0
  167. package/dist/src/core/agent-runtime/executor.js +138 -0
  168. package/dist/src/core/agent-runtime/executor.js.map +1 -0
  169. package/dist/src/core/agent-runtime/human-gate.d.ts +16 -0
  170. package/dist/src/core/agent-runtime/human-gate.js +70 -0
  171. package/dist/src/core/agent-runtime/human-gate.js.map +1 -0
  172. package/dist/tests/agent-generator.test.d.ts +1 -0
  173. package/dist/tests/agent-generator.test.js +349 -0
  174. package/dist/tests/agent-generator.test.js.map +1 -0
  175. package/dist/tests/agent-runtime.test.d.ts +1 -0
  176. package/dist/tests/agent-runtime.test.js +107 -0
  177. package/dist/tests/agent-runtime.test.js.map +1 -0
  178. package/dist/tests/context-enricher.test.d.ts +1 -0
  179. package/dist/tests/context-enricher.test.js +875 -0
  180. package/dist/tests/context-enricher.test.js.map +1 -0
  181. package/dist/tests/framework-detector.test.d.ts +1 -0
  182. package/dist/tests/framework-detector.test.js +882 -0
  183. package/dist/tests/framework-detector.test.js.map +1 -0
  184. package/dist/tests/stack-detector.test.d.ts +1 -0
  185. package/dist/tests/stack-detector.test.js +183 -0
  186. package/dist/tests/stack-detector.test.js.map +1 -0
  187. package/dist/tests/template-generation.test.d.ts +1 -0
  188. package/dist/tests/template-generation.test.js +571 -0
  189. package/dist/tests/template-generation.test.js.map +1 -0
  190. package/dist/tests/template-helpers.test.d.ts +1 -0
  191. package/dist/tests/template-helpers.test.js +967 -0
  192. package/dist/tests/template-helpers.test.js.map +1 -0
  193. package/package.json +24 -0
  194. package/src/core/agent-generator/context-enricher.ts +67 -0
  195. package/src/core/agent-generator/detectors/base-detector.ts +18 -0
  196. package/src/core/agent-generator/detectors/dart-detector.ts +17 -0
  197. package/src/core/agent-generator/detectors/framework-registry.ts +82 -0
  198. package/src/core/agent-generator/detectors/go-detector.ts +26 -0
  199. package/src/core/agent-generator/detectors/java-detector.ts +46 -0
  200. package/src/core/agent-generator/detectors/node-detector.ts +28 -0
  201. package/src/core/agent-generator/detectors/php-detector.ts +28 -0
  202. package/src/core/agent-generator/detectors/python-detector.ts +125 -0
  203. package/src/core/agent-generator/detectors/ruby-detector.ts +24 -0
  204. package/src/core/agent-generator/detectors/rust-detector.ts +19 -0
  205. package/src/core/agent-generator/detectors/structure-detector.ts +38 -0
  206. package/src/core/agent-generator/detectors/toolchain-detector.ts +181 -0
  207. package/src/core/agent-generator/domain-inferrer.ts +630 -0
  208. package/src/core/agent-generator/engines/audit-engine.ts +98 -0
  209. package/src/core/agent-generator/engines/context-builder.ts +96 -0
  210. package/src/core/agent-generator/engines/generation-engine.ts +184 -0
  211. package/src/core/agent-generator/engines/generation-engine_deps.ts +21 -0
  212. package/src/core/agent-generator/engines/suggestion-engine.ts +202 -0
  213. package/src/core/agent-generator/engines/suggestion-engine_deps.ts +8 -0
  214. package/src/core/agent-generator/enrichers/analysis-helpers.ts +58 -0
  215. package/src/core/agent-generator/enrichers/description-generator.ts +91 -0
  216. package/src/core/agent-generator/enrichers/endpoint-extractor.ts +114 -0
  217. package/src/core/agent-generator/enrichers/layer-classifier.ts +156 -0
  218. package/src/core/agent-generator/enrichers/module-extractor.ts +203 -0
  219. package/src/core/agent-generator/framework-detector.ts +66 -0
  220. package/src/core/agent-generator/index.ts +55 -0
  221. package/src/core/agent-generator/stack-detector.ts +115 -0
  222. package/src/core/agent-generator/templates/core/agents.ts +1168 -0
  223. package/src/core/agent-generator/templates/core/architecture-rules.ts +288 -0
  224. package/src/core/agent-generator/templates/core/general-rules.ts +306 -0
  225. package/src/core/agent-generator/templates/core/hooks-generator.ts +244 -0
  226. package/src/core/agent-generator/templates/core/index-md.ts +261 -0
  227. package/src/core/agent-generator/templates/core/orchestrator.ts +462 -0
  228. package/src/core/agent-generator/templates/core/preflight.ts +216 -0
  229. package/src/core/agent-generator/templates/core/quality-gates.ts +257 -0
  230. package/src/core/agent-generator/templates/core/security-rules.ts +544 -0
  231. package/src/core/agent-generator/templates/core/skills-generator.ts +586 -0
  232. package/src/core/agent-generator/templates/core/workflow-fix-bug.ts +240 -0
  233. package/src/core/agent-generator/templates/core/workflow-new-feature.ts +323 -0
  234. package/src/core/agent-generator/templates/core/workflow-review.ts +107 -0
  235. package/src/core/agent-generator/templates/domain/index.ts +1204 -0
  236. package/src/core/agent-generator/templates/helpers/base-helpers.ts +33 -0
  237. package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +79 -0
  238. package/src/core/agent-generator/templates/helpers/security-helpers.ts +198 -0
  239. package/src/core/agent-generator/templates/helpers/stack-helpers.ts +80 -0
  240. package/src/core/agent-generator/templates/helpers/structure-helpers.ts +293 -0
  241. package/src/core/agent-generator/templates/helpers/summary-helpers.ts +67 -0
  242. package/src/core/agent-generator/templates/stack/index.ts +705 -0
  243. package/src/core/agent-generator/templates/template-helpers.ts +12 -0
  244. package/src/core/agent-generator/types/agent.ts +65 -0
  245. package/src/core/agent-generator/types/domain.ts +63 -0
  246. package/src/core/agent-generator/types/stack.ts +38 -0
  247. package/src/core/agent-generator/types/template.ts +31 -0
  248. package/src/core/agent-runtime/ai-provider.ts +178 -0
  249. package/src/core/agent-runtime/executor.ts +148 -0
  250. package/src/core/agent-runtime/human-gate.ts +69 -0
  251. package/tests/agent-generator.test.ts +428 -0
  252. package/tests/agent-runtime.test.ts +125 -0
  253. package/tests/context-enricher.test.ts +972 -0
  254. package/tests/framework-detector.test.ts +1172 -0
  255. package/tests/stack-detector.test.ts +241 -0
  256. package/tests/template-generation.test.ts +709 -0
  257. package/tests/template-helpers.test.ts +1130 -0
  258. package/tsconfig.json +14 -0
@@ -0,0 +1,462 @@
1
+ import { TemplateContext, EnrichedTemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
2
+ import {
3
+ // @ts-ignore - Audit cleanup unused variable
4
+ getEnriched,
5
+ isEnriched,
6
+ // @ts-ignore - Audit cleanup unused variable
7
+ depthScale,
8
+ depthAtLeast,
9
+ domainBadge,
10
+ complianceBadges,
11
+ depthIndicator,
12
+ modulesSummaryTable,
13
+ integrationsSummary,
14
+ frameworkBadge,
15
+ toolchainCommands,
16
+ projectStructureBadge,
17
+ } from '../template-helpers.js';
18
+
19
+ /**
20
+ * Generates enterprise-grade AGENT-ORCHESTRATOR.md
21
+ * ~800+ lines: 5-phase protocol, mandatory artifact gates, business interrogation,
22
+ * parallel dispatch, C4/BDD/TDD inline templates, risk matrix, implementation order.
23
+ */
24
+ export function generateOrchestrator(ctx: TemplateContext | EnrichedTemplateContext): string {
25
+ // @ts-ignore - Audit cleanup unused variable
26
+ const { report, stack, projectName, stackLabel, plan, config } = ctx;
27
+ const layers = report.layers.map(l => l.name).join(', ') || 'Not detected';
28
+ const antiPatterns = report.antiPatterns.map(a => `${a.name} (${a.severity})`).join(', ') || 'None';
29
+ const agentDispatch = buildAgentDispatch(ctx);
30
+ const businessQuestions = buildBusinessQuestions(ctx);
31
+
32
+ // Extract toolchain commands for Quality Gates (dynamic per-stack)
33
+ const enrichedCtx = isEnriched(ctx) ? ctx : null;
34
+ const buildCmd = enrichedCtx?.toolchain?.buildCmd || 'npm run build';
35
+ const testCmd = enrichedCtx?.toolchain?.testCmd || 'npm run test';
36
+
37
+ return `---
38
+ antigravity:
39
+ trigger: 'always_on'
40
+ globs: ['**/*']
41
+ description: 'META-AGENT ORQUESTRADOR — Centro de comando para ${projectName}'
42
+ priority: CRITICAL
43
+ agent_card:
44
+ id: 'orchestrator'
45
+ name: 'Agent Orchestrator'
46
+ role: 'coordination'
47
+ capabilities: [request-decomposition, agent-dispatch, plan-consolidation, quality-verification, artifact-gating]
48
+ inputs: [user-story, feature-request, bug-report, refactoring-request]
49
+ outputs: [consolidated-plan, implementation-blocks, effort-estimate, architecture-docs]
50
+ depends_on: []
51
+ version: 3.1.0
52
+ ---
53
+
54
+ # 🎭 AGENT-ORCHESTRATOR: ${projectName}
55
+
56
+ > **Centro de comando.** Toda requisição passa por aqui.
57
+ > **Nenhuma linha de código é escrita sem os artefatos obrigatórios.**
58
+
59
+ ---
60
+
61
+ ## ⛔ REGRA ABSOLUTA: ARTEFATOS ANTES DE CÓDIGO
62
+
63
+ \`\`\`
64
+ ╔══════════════════════════════════════════════════════════════╗
65
+ ║ ║
66
+ ║ ANTES de escrever QUALQUER linha de código, os seguintes ║
67
+ ║ artefatos DEVEM existir e ser APROVADOS pelo humano: ║
68
+ ║ ║
69
+ ║ 1. 🎨 MOCKUP (se tem UI) ║
70
+ ║ → Todas as telas, estados, erros, modais, mensagens ║
71
+ ║ → Seguir padrão visual do sistema ║
72
+ ║ ║
73
+ ║ 2. 📖 USER STORIES ║
74
+ ║ → Como [ator], quero [ação], para [benefício] ║
75
+ ║ → Critérios de aceite mensuráveis ║
76
+ ║ ║
77
+ ║ 3. 🏗️ ARQUITETURA (C4) ║
78
+ ║ → Contexto, Container, Componente, Código ║
79
+ ║ → Decisões arquiteturais (ADR) ║
80
+ ║ ║
81
+ ║ 4. 📋 TAREFAS ║
82
+ ║ → Breakdown com TASK-XXX ║
83
+ ║ → Estimativa T-shirt (XS/S/M/L/XL) ║
84
+ ║ ║
85
+ ║ 5. 🧪 BDD (cenários) ║
86
+ ║ → Given/When/Then para cada critério de aceite ║
87
+ ║ ║
88
+ ║ 6. 🔬 TDD (casos de teste) ║
89
+ ║ → RED → GREEN → REFACTOR ║
90
+ ║ → Cobertura mínima: ${config.coverageMinimum}% ║
91
+ ║ ║
92
+ ║ ⚠️ PRODUZIR APENAS UM IMPLEMENTATION PLAN SEM ESTES ║
93
+ ║ ARTEFATOS É VIOLAÇÃO DO PROTOCOLO. ║
94
+ ║ ║
95
+ ║ ORDEM DE IMPLEMENTAÇÃO: ║
96
+ ║ 1° Backend → 2° Doc. Integração → 3° Frontend/App ║
97
+ ║ ║
98
+ ╚══════════════════════════════════════════════════════════════╝
99
+ \`\`\`
100
+
101
+ ---
102
+
103
+ ## 📊 Contexto do Projeto
104
+
105
+ | Métrica | Valor |
106
+ |---------|-------|
107
+ | **Projeto** | ${projectName} |
108
+ | **Stack** | ${stackLabel} |
109
+ | **Score Atual** | ${report.score.overall}/100 |
110
+ | **Meta de Score** | ${Math.min(100, report.score.overall + 10)}/100 |
111
+ | **Camadas** | ${layers} |
112
+ | **Anti-Patterns** | ${antiPatterns} |
113
+ | **Arquivos** | ${report.projectInfo.totalFiles} |
114
+ | **Linhas** | ${report.projectInfo.totalLines.toLocaleString()} |
115
+ | **Cobertura Mínima** | ${config.coverageMinimum}% |
116
+ | **Refatorações Pendentes** | ${plan.steps.length} steps |
117
+
118
+ ${depthAtLeast(ctx, 'medium') ? `\n---\n\n## 📍 Contexto Enriquecido\n\n${depthIndicator(ctx)} · ${projectStructureBadge(ctx)}\n\n${frameworkBadge(ctx)}\n${domainBadge(ctx)}${modulesSummaryTable(ctx) ? `\n### 📦 Resumo de Módulos\n\n${modulesSummaryTable(ctx)}` : ''}${integrationsSummary(ctx)}${complianceBadges(ctx)}${toolchainCommands(ctx)}` : ''}
119
+
120
+ ---
121
+
122
+ ## 🔄 Protocolo de Orquestração (5 Fases)
123
+
124
+ ### FASE 0: Parsing da Requisição
125
+
126
+ Ao receber qualquer requisição, CLASSIFICAR imediatamente:
127
+
128
+ \`\`\`
129
+ ✓ Nome da feature/fix: _______________
130
+ ✓ Tipo: [ ] Feature [ ] Bug Fix [ ] Refactoring [ ] Documentation
131
+ ✓ Camadas tocadas: [ ] Backend [ ] Frontend [ ] Mobile [ ] Database
132
+ ✓ Tem UI: [ ] Sim [ ] Não
133
+ ✓ Complexidade: [ ] XS (<2h) [ ] S (2-4h) [ ] M (4-8h) [ ] L (1-3d) [ ] XL (3d+)
134
+ ✓ Assunções (listar): _______________
135
+ ✓ Riscos identificados: _______________
136
+ \`\`\`
137
+
138
+ Se houver QUALQUER dúvida na classificação → **PERGUNTAR ao humano**.
139
+
140
+ ### FASE 1: Interrogação de Negócio
141
+
142
+ Antes de qualquer design, RESPONDER estas perguntas:
143
+
144
+ ${businessQuestions}
145
+
146
+ > **Se não conseguir responder ≥ 70% das perguntas relevantes → PERGUNTAR ao humano.**
147
+
148
+ ### FASE 2: Disparo de Agentes (Paralelo)
149
+
150
+ \`\`\`
151
+ ORQUESTRADOR decompõe a requisição
152
+
153
+ ${agentDispatch} │
154
+ └──→ CONSOLIDAÇÃO
155
+ \`\`\`
156
+
157
+ Cada agente recebe:
158
+ - Contexto do projeto (score, stack, anti-patterns)
159
+ - Requisição decomposta (sua parte)
160
+ - Constraints (regras, patterns proibidos)
161
+ - Output esperado (formato e escopo)
162
+
163
+ ### FASE 3: Consolidação
164
+
165
+ O orquestrador consolida as respostas dos agentes em:
166
+
167
+ 1. **Plano Unificado** com:
168
+ - Diagrama de arquitetura (C4)
169
+ - Cenários BDD
170
+ - Casos de teste TDD
171
+ - Estimativa de esforço (T-shirt)
172
+ - Riscos e mitigações
173
+ - Decisões arquiteturais (ADR)
174
+
175
+ 2. **6 Gates para Aprovação** (apresentar um de cada vez):
176
+ - Gate 1: MOCKUP → \`/approved\`
177
+ - Gate 2: User Stories → \`/approved\`
178
+ - Gate 3: Arquitetura → \`/approved\`
179
+ - Gate 4: Tasks → \`/approved\`
180
+ - Gate 5: BDD → \`/approved\`
181
+ - Gate 6: TDD → \`/approved\`
182
+
183
+ ### FASE 4: Implementação (Após Todas Aprovações)
184
+
185
+ \`\`\`
186
+ ╔════════════════════════════════════════════════╗
187
+ ║ ORDEM OBRIGATÓRIA DE IMPLEMENTAÇÃO: ║
188
+ ║ ║
189
+ ║ 1° BACKEND ║
190
+ ║ └─→ Controllers, Services, Entities, DTOs ║
191
+ ║ └─→ Testes unitários + integração ║
192
+ ║ └─→ Migrations (se houver) ║
193
+ ║ ║
194
+ ║ 2° DOCUMENTO DE INTEGRAÇÃO ║
195
+ ║ └─→ Endpoints, payloads, erros ║
196
+ ║ └─→ Exemplos de request/response ║
197
+ ║ └─→ Contrato para frontend/app ║
198
+ ║ ║
199
+ ║ 3° FRONTEND / APP ║
200
+ ║ └─→ Baseado no documento de integração ║
201
+ ║ └─→ Componentes, pages, state ║
202
+ ║ └─→ Testes e2e ║
203
+ ╚════════════════════════════════════════════════╝
204
+ \`\`\`
205
+
206
+ ### FASE 5: Verificação e Entrega
207
+
208
+ \`\`\`
209
+ □ Build compila sem erros
210
+ □ Todos os testes passam
211
+ □ Cobertura ≥ ${config.coverageMinimum}%
212
+ □ Score ≥ ${config.scoreThreshold}/100
213
+ □ Zero anti-patterns CRITICAL novos
214
+ □ Sem regressão de score
215
+ □ Lint sem warnings
216
+ □ Documentação atualizada
217
+ \`\`\`
218
+
219
+ ---
220
+
221
+ ## 📐 Templates Inline
222
+
223
+ ### Template: User Story
224
+
225
+ \`\`\`markdown
226
+ ## US-XXX: [Título]
227
+
228
+ **Como** [ator],
229
+ **Quero** [ação],
230
+ **Para** [benefício].
231
+
232
+ ### Critérios de Aceite
233
+
234
+ - CA1: [critério mensurável]
235
+ - CA2: [critério mensurável]
236
+ - CA3: [critério mensurável]
237
+
238
+ ### Regras de Negócio
239
+
240
+ - RN1: [regra]
241
+ - RN2: [regra]
242
+
243
+ ### Notas Técnicas
244
+
245
+ - [observação relevante]
246
+ \`\`\`
247
+
248
+ ### Template: Task Breakdown
249
+
250
+ \`\`\`markdown
251
+ ## TASK-XXX: [Título]
252
+
253
+ **User Story:** US-XXX
254
+ **Estimativa:** [XS|S|M|L|XL]
255
+ **Camada:** [Backend|Frontend|App|Database]
256
+ **Agente:** [nome do agente]
257
+
258
+ ### Descrição
259
+ [o que precisa ser feito]
260
+
261
+ ### Critério de Done
262
+ - [ ] Implementado
263
+ - [ ] Testado (cobertura ≥ ${config.coverageMinimum}%)
264
+ - [ ] Code review
265
+ - [ ] Documentação
266
+ \`\`\`
267
+
268
+ ### Template: ADR (Architecture Decision Record)
269
+
270
+ \`\`\`markdown
271
+ ## ADR-XXX: [Título da Decisão]
272
+
273
+ **Status:** [proposed | accepted | deprecated | superseded]
274
+ **Data:** [YYYY-MM-DD]
275
+
276
+ ### Contexto
277
+ [Por que essa decisão é necessária?]
278
+
279
+ ### Decisão
280
+ [O que foi decidido?]
281
+
282
+ ### Consequências
283
+ [Positivas e negativas]
284
+
285
+ ### Alternativas Consideradas
286
+ 1. [alternativa 1] — descartada porque...
287
+ 2. [alternativa 2] — descartada porque...
288
+ \`\`\`
289
+
290
+ ---
291
+
292
+ ## ⚖️ Matriz de Risco
293
+
294
+ | Risco | Probabilidade | Impacto | Mitigação |
295
+ |-------|-------------|---------|-----------|
296
+ | Regressão de testes | Média | Alto | CI/CD com gate obrigatório |
297
+ | Degradação de score | Média | Médio | architect score antes de PR |
298
+ | Breaking changes em API | Alta | Crítico | Versionamento + integration doc |
299
+ | Security vulnerability | Baixa | Crítico | SECURITY-AUDITOR em toda feature |
300
+ | Performance degradation | Média | Alto | Benchmark antes/depois |
301
+
302
+ ---
303
+
304
+ ## 🏷️ T-Shirt Sizing
305
+
306
+ | Size | Duração | Scope | Gates |
307
+ |------|---------|-------|-------|
308
+ | **XS** | < 2h | Fix pontual, 1 arquivo | Simplificado (skip mockup se sem UI) |
309
+ | **S** | 2-4h | Fix + teste, 2-3 arquivos | Gates 2, 5, 6 obrigatórios |
310
+ | **M** | 4-8h | Feature pequena, 1 camada | Todos os 6 gates |
311
+ | **L** | 1-3 dias | Feature multi-camada | Todos + ADR |
312
+ | **XL** | 3+ dias | Feature épica | Todos + ADR + Threat Model |
313
+
314
+ ---
315
+
316
+ ## 🔀 Protocolo de Conflitos
317
+
318
+ Quando dois agentes discordam:
319
+
320
+ 1. **Identificar** o ponto de conflito
321
+ 2. **Documentar** ambas as posições com prós/contras
322
+ 3. **Escalar** ao humano com recomendação
323
+ 4. **Registrar** a decisão como ADR
324
+
325
+ > **NUNCA resolver conflitos automaticamente.** O humano decide.
326
+
327
+ ---
328
+
329
+ ## 🔧 Quality Gates (Enforcement)
330
+
331
+ \`\`\`
332
+ ╔══════════════════════════════════════════╗
333
+ ║ BUILD GATE ║
334
+ ║ $ ${buildCmd}
335
+ ║ Resultado: PASS ou BLOCK ║
336
+ ╠══════════════════════════════════════════╣
337
+ ║ TEST GATE ║
338
+ ║ $ ${testCmd}
339
+
340
+ ║ Resultado: PASS ou BLOCK ║
341
+ ╠══════════════════════════════════════════╣
342
+ ║ COVERAGE GATE ║
343
+ ║ Mínimo: ${config.coverageMinimum}% ║
344
+ ║ Resultado: PASS ou BLOCK ║
345
+ ║ ⚠️ INEGOCIÁVEL ║
346
+ ╠══════════════════════════════════════════╣
347
+ ║ SCORE GATE ║
348
+ ║ $ architect score ./src ║
349
+ ║ Mínimo: ${config.scoreThreshold}/100 ║
350
+ ║ Regressão: NÃO PERMITIDA ║
351
+ ╚══════════════════════════════════════════╝
352
+ \`\`\`
353
+
354
+ ---
355
+
356
+ **Gerado por Architect v8.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
357
+ `;
358
+ }
359
+
360
+ function buildAgentDispatch(ctx: TemplateContext | EnrichedTemplateContext): string {
361
+ const { stack } = ctx;
362
+ let dispatch = '';
363
+
364
+ // Add module context if enriched
365
+ const enriched = isEnriched(ctx) ? ctx : null;
366
+ const moduleContext = enriched?.modules?.length
367
+ ? ` (${enriched.modules.slice(0, 3).map((m: any) => m.name).join(', ')})`
368
+ : '';
369
+
370
+ if (stack.hasBackend) {
371
+ dispatch += ` ├──→ [${stack.primary.toUpperCase()}-BACKEND-DEVELOPER]${moduleContext}\n`;
372
+ dispatch += ` │ • Arquitetura de serviços e APIs\n`;
373
+ dispatch += ` │ • Lógica de negócio e validações\n`;
374
+ dispatch += ` │ • Entities, DTOs, migrations\n`;
375
+ dispatch += ` │\n`;
376
+ }
377
+ if (stack.hasFrontend) {
378
+ const fw = stack.frameworks.find(f => ['Angular', 'Vue', 'Next.js', 'React'].includes(f)) || 'FRONTEND';
379
+ dispatch += ` ├──→ [${fw.toUpperCase().replace('.', '')}-FRONTEND-DEVELOPER]\n`;
380
+ dispatch += ` │ • Componentes e páginas\n`;
381
+ dispatch += ` │ • State management e formulários\n`;
382
+ dispatch += ` │ • UX responsiva\n`;
383
+ dispatch += ` │\n`;
384
+ }
385
+ if (stack.hasMobile) {
386
+ dispatch += ` ├──→ [FLUTTER-UI-DEVELOPER]\n`;
387
+ dispatch += ` │ • Screens e widgets\n`;
388
+ dispatch += ` │ • Navegação e integração API\n`;
389
+ dispatch += ` │\n`;
390
+ }
391
+ if (stack.hasDatabase) {
392
+ dispatch += ` ├──→ [DATABASE-ENGINEER]\n`;
393
+ dispatch += ` │ • Schema design e migrations\n`;
394
+ dispatch += ` │ • Índices e performance de queries\n`;
395
+ dispatch += ` │\n`;
396
+ }
397
+
398
+ dispatch += ` ├──→ [SECURITY-AUDITOR]\n`;
399
+ dispatch += ` │ • Análise de ameaças (STRIDE)\n`;
400
+ dispatch += ` │ • Compliance check\n`;
401
+ dispatch += ` │\n`;
402
+ dispatch += ` ├──→ [QA-TEST-ENGINEER]\n`;
403
+ dispatch += ` │ • Plano de testes\n`;
404
+ dispatch += ` │ • Cobertura mínima: ${ctx.config.coverageMinimum}%\n`;
405
+ dispatch += ` │\n`;
406
+ dispatch += ` └──→ [TECH-DEBT-CONTROLLER]\n`;
407
+ dispatch += ` • Débito técnico existente\n`;
408
+ dispatch += ` • Refatorações pré-requisito\n`;
409
+
410
+ return dispatch;
411
+ }
412
+
413
+ function buildBusinessQuestions(ctx: TemplateContext | EnrichedTemplateContext): string {
414
+ const questions = [
415
+ 'Q1: Quem são os atores envolvidos? (personas)',
416
+ 'Q2: Qual o impacto em receita/negócio?',
417
+ 'Q3: Existem regras de negócio específicas?',
418
+ 'Q4: Quais métricas de sucesso?',
419
+ 'Q5: Há requisitos de compliance (LGPD, PCI, etc)?',
420
+ 'Q6: Quais módulos/serviços são afetados?',
421
+ 'Q7: Quais entidades de banco são tocadas?',
422
+ 'Q8: Existe fluxo de dados entre sistemas?',
423
+ 'Q9: Precisa de versionamento de API?',
424
+ 'Q10: Há integrações externas envolvidas?',
425
+ ];
426
+
427
+ // Add domain-specific questions if enriched context available
428
+ const enriched = isEnriched(ctx) ? ctx : null;
429
+ if (enriched?.domain) {
430
+ const { domain } = enriched;
431
+ questions.push(`Q11: Como isso se alinha com o domínio ${domain.domain}?`);
432
+
433
+ if (domain.compliance?.length) {
434
+ const complianceNames = domain.compliance.map((c: any) => c.name).join(', ');
435
+ questions.push(`Q12: Como garantir conformidade com ${complianceNames}?`);
436
+ }
437
+
438
+ if (domain.integrations?.length) {
439
+ const integrationNames = domain.integrations.slice(0, 3).map((i: any) => i.name).join(', ');
440
+ questions.push(`Q13: Como essa mudança afeta as integrações com ${integrationNames}?`);
441
+ }
442
+ }
443
+
444
+ if (ctx.stack.hasDatabase) {
445
+ const startIdx = enriched?.domain ? 14 : 11;
446
+ questions.push(
447
+ `Q${startIdx}: Volume estimado de dados?`,
448
+ `Q${startIdx + 1}: Há picos de uso previsíveis?`,
449
+ `Q${startIdx + 2}: Processamento síncrono ou assíncrono?`,
450
+ );
451
+ }
452
+
453
+ let nextQ = questions.length + 1;
454
+ questions.push(
455
+ `Q${nextQ++}: Quem precisa de autenticação?`,
456
+ `Q${nextQ++}: Quais permissões são necessárias?`,
457
+ `Q${nextQ++}: Há dados sensíveis envolvidos?`,
458
+ `Q${nextQ++}: Quais ameaças são relevantes?`,
459
+ );
460
+
461
+ return questions.map(q => `- **${q}**`).join('\n');
462
+ }
@@ -0,0 +1,216 @@
1
+ // @ts-ignore - Audit cleanup unused variable
2
+ import { TemplateContext, EnrichedTemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
3
+ import { getEnriched } from '../template-helpers.js';
4
+
5
+ /**
6
+ * Generates enterprise-grade PREFLIGHT.md
7
+ * 6-phase checklist: mental prep → mandatory reads → environment → business rules →
8
+ * before-code by layer → before-done. Red flags, diagnostic template, delivery checklist.
9
+ */
10
+ export function generatePreflight(ctx: TemplateContext): string {
11
+ const { stack, projectName, config, report } = ctx;
12
+ const enriched = getEnriched(ctx);
13
+ const tc = enriched.toolchain;
14
+
15
+ return `---
16
+ antigravity:
17
+ trigger: 'always_on'
18
+ globs: ['**/*']
19
+ description: 'PREFLIGHT — Checklist obrigatório pré-ação para ${projectName}'
20
+ priority: CRITICAL
21
+ ---
22
+
23
+ # ✈️ PREFLIGHT — Checklist Pré-Ação
24
+
25
+ > **NENHUMA ação de código é permitida antes de completar este checklist.**
26
+ > Pular qualquer fase é violação do protocolo.
27
+
28
+ ---
29
+
30
+ ## FASE 0: Preparação Mental
31
+
32
+ Antes de abrir qualquer arquivo:
33
+
34
+ \`\`\`
35
+ □ Li e entendi a requisição COMPLETAMENTE
36
+ □ Sei qual WORKFLOW estou seguindo (new-feature / fix-bug / review)
37
+ □ Identifiquei as CAMADAS envolvidas (Backend / Frontend / App / Database)
38
+ □ Tenho CLAREZA sobre o que é esperado como entrega
39
+ □ Se algo não está claro → PAREI e PERGUNTEI ao humano
40
+ \`\`\`
41
+
42
+ ---
43
+
44
+ ## FASE 1: Leitura Obrigatória
45
+
46
+ \`\`\`
47
+ □ [00-general.md](../rules/00-general.md) → Regras de Ouro do projeto
48
+ □ [QUALITY-GATES.md](./QUALITY-GATES.md) → Métricas e blockers
49
+ □ LESSONS-LEARNED.md (se existir) → Erros passados
50
+ □ ERROR-PATTERNS.md (se existir) → Padrões de erro conhecidos
51
+ □ BUSINESS-RULES.md (se existir) → Regras de negócio do domínio
52
+ \`\`\`
53
+
54
+ > **Objetivo:** Não repetir erros e entender o contexto antes de agir.
55
+
56
+ ---
57
+
58
+ ## FASE 2: Verificação de Ambiente
59
+
60
+ \`\`\`bash
61
+ # Git: verificar branch e status
62
+ git branch --show-current # NUNCA em main/develop direto
63
+ git status # Limpo antes de começar
64
+ git pull origin <branch> # Sincronizado
65
+
66
+ # Deps: verificar se está tudo instalado
67
+ ${tc?.installCmd || (stack.packageManager === 'npm' ? 'npm ci' : stack.packageManager === 'pip' ? 'pip install -r requirements.txt' : stack.packageManager === 'pub' ? 'flutter pub get' : `${stack.packageManager} install`)}
68
+
69
+ # Build: verificar se compila
70
+ ${tc?.buildCmd || (stack.packageManager === 'npm' ? 'npm run build' : stack.packageManager === 'pub' ? 'flutter build' : 'make build')}
71
+
72
+ # Tests: verificar se passam ANTES de começar
73
+ ${tc?.testCmd || (stack.testFramework === 'pytest' ? 'pytest' : stack.testFramework === 'flutter_test' ? 'flutter test' : stack.testFramework === 'go test' ? 'go test ./...' : 'npm run test')}
74
+ \`\`\`
75
+
76
+ \`\`\`
77
+ □ Branch correta (NUNCA main/develop)
78
+ □ Working tree limpa
79
+ □ Dependências instaladas
80
+ □ Build passando
81
+ □ Testes passando ANTES da minha alteração
82
+ \`\`\`
83
+
84
+ ---
85
+
86
+ ## FASE 3: Verificação de Regras de Negócio
87
+
88
+ \`\`\`
89
+ □ Entendo QUEM são os atores afetados
90
+ □ Entendo QUAL é a regra de negócio envolvida
91
+ □ Verifiquei se existe documentação do domínio
92
+ □ Se a feature envolve dinheiro/pagamento → ATENÇÃO REDOBRADA
93
+ □ Se a feature envolve dados pessoais → verificar LGPD/compliance
94
+ □ Se a feature muda um fluxo existente → verificar impacto em features dependentes
95
+ \`\`\`
96
+
97
+ ---
98
+
99
+ ## FASE 4: Before-Code Checklist (por Camada)
100
+
101
+ ### 4A: Backend ${stack.hasBackend ? '✅' : '⬜ (skip se não aplicável)'}
102
+
103
+ \`\`\`
104
+ □ Entendo a estrutura de módulos existente
105
+ □ Sei onde criar/modificar controllers, services, entities
106
+ □ Verifiquei se já existe código similar (DRY)
107
+ □ DTOs e validações planejados
108
+ □ Tratamento de erros definido
109
+ □ Sei qual padrão de teste usar (unitário + integração)
110
+ □ Migrations planejadas (se houver alteração de banco)
111
+ \`\`\`
112
+
113
+ ### 4B: Frontend ${stack.hasFrontend ? '✅' : '⬜ (skip se não aplicável)'}
114
+
115
+ \`\`\`
116
+ □ MOCKUP aprovado pelo humano
117
+ □ Entendo o state management utilizado
118
+ □ Sei onde criar/modificar componentes
119
+ □ Verificar padrão visual (cores, fontes, espaçamentos)
120
+ □ Responsividade considerada
121
+ □ Acessibilidade básica (labels, aria, contraste)
122
+ □ Documento de integração do backend disponível
123
+ \`\`\`
124
+
125
+ ### 4C: Mobile (Flutter) ${stack.hasMobile ? '✅' : '⬜ (skip se não aplicável)'}
126
+
127
+ \`\`\`
128
+ □ MOCKUP aprovado pelo humano
129
+ □ Entendo a navegação atual do app
130
+ □ Sei onde criar/modificar screens e widgets
131
+ □ Verificar padrão visual do app
132
+ □ Comportamento offline considerado
133
+ □ Documento de integração do backend disponível
134
+ \`\`\`
135
+
136
+ ### 4D: Database ${stack.hasDatabase ? '✅' : '⬜ (skip se não aplicável)'}
137
+
138
+ \`\`\`
139
+ □ Schema atual compreendido
140
+ □ Migration reversível planejada
141
+ □ Índices necessários identificados
142
+ □ Impacto em queries existentes avaliado
143
+ □ Seed data / fixtures atualizados
144
+ □ Backup strategy para dados existentes
145
+ \`\`\`
146
+
147
+ ---
148
+
149
+ ## FASE 5: Before-Commit
150
+
151
+ \`\`\`
152
+ □ Build compila sem erros
153
+ □ TODOS os testes passam (velhos + novos)
154
+ □ Cobertura ≥ ${config.coverageMinimum}%
155
+ □ Lint sem warnings
156
+ □ Sem console.log / print() em produção
157
+ □ Sem TODO / FIXME sem issue
158
+ □ Sem secrets hardcoded
159
+ □ Sem arquivos > 500 linhas sem justificativa
160
+ □ Commit message segue padrão (feat: / fix: / refactor: / docs:)
161
+ □ Branch está atualizada com base (rebase se necessário)
162
+ \`\`\`
163
+
164
+ ---
165
+
166
+ ## FASE 6: Before-Done
167
+
168
+ \`\`\`
169
+ □ TODOS os critérios de aceite estão cobertos
170
+ □ Score não regrediu: architect score ./src ≥ ${config.scoreThreshold}/100
171
+ □ Documentação atualizada (se necessário)
172
+ □ LESSONS-LEARNED atualizado (se descobri algo novo)
173
+ □ PR criado com descrição completa
174
+ □ Code review solicitado
175
+ \`\`\`
176
+
177
+ ---
178
+
179
+ ## 🚩 Red Flags — PARE IMEDIATAMENTE SE:
180
+
181
+ | Red Flag | Ação |
182
+ |----------|------|
183
+ | Não entendo a requisição | PARAR → Perguntar ao humano |
184
+ | Código que mexo tem 0% de cobertura | PARAR → Escrever testes ANTES |
185
+ | Estou modificando > 10 arquivos | PARAR → Reavaliar escopo |
186
+ | Build quebrou após minha mudança | PARAR → Reverter → Investigar |
187
+ | Estou copiando/colando código | PARAR → Extrair abstração |
188
+ | Estou trabalhando em main/develop | PARAR → Criar branch |
189
+ | Não tenho mockup e a feature tem UI | PARAR → Gate 1 primeiro |
190
+ | Estou escrevendo código sem testes | PARAR → TDD |
191
+
192
+ ---
193
+
194
+ ## 🔍 Template de Diagnóstico
195
+
196
+ Execute antes de qualquer implementação:
197
+
198
+ \`\`\`bash
199
+ # Estrutura do projeto
200
+ find . -type f -name "*.${stack.primary === 'Python' ? 'py' : stack.primary === 'Dart' ? 'dart' : 'ts'}" | head -30
201
+
202
+ # Dependências do módulo que vou modificar
203
+ grep -r "import.*${stack.primary === 'Python' ? 'from' : 'from'}" --include="*.${stack.primary === 'Python' ? 'py' : 'ts'}" [modulo]/ | head -20
204
+
205
+ # Testes existentes
206
+ find . -name "*.test.*" -o -name "*.spec.*" -o -name "*_test.*" | head -20
207
+
208
+ # Score atual
209
+ npx @girardelli/architect score .
210
+ \`\`\`
211
+
212
+ ---
213
+
214
+ **Gerado por Architect v8.1 · Score: ${report.score.overall}/100 · ${new Date().toISOString().split('T')[0]}**
215
+ `;
216
+ }