@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.
- package/dist/src/core/agent-generator/context-enricher.d.ts +17 -0
- package/dist/src/core/agent-generator/context-enricher.js +51 -0
- package/dist/src/core/agent-generator/context-enricher.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/base-detector.d.ts +8 -0
- package/dist/src/core/agent-generator/detectors/base-detector.js +12 -0
- package/dist/src/core/agent-generator/detectors/base-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/dart-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/dart-detector.js +16 -0
- package/dist/src/core/agent-generator/detectors/dart-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/framework-registry.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/framework-registry.js +81 -0
- package/dist/src/core/agent-generator/detectors/framework-registry.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/go-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/go-detector.js +25 -0
- package/dist/src/core/agent-generator/detectors/go-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/java-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/java-detector.js +44 -0
- package/dist/src/core/agent-generator/detectors/java-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/node-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/node-detector.js +28 -0
- package/dist/src/core/agent-generator/detectors/node-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/php-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/php-detector.js +28 -0
- package/dist/src/core/agent-generator/detectors/php-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/python-detector.d.ts +7 -0
- package/dist/src/core/agent-generator/detectors/python-detector.js +116 -0
- package/dist/src/core/agent-generator/detectors/python-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/ruby-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/ruby-detector.js +23 -0
- package/dist/src/core/agent-generator/detectors/ruby-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/rust-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/rust-detector.js +18 -0
- package/dist/src/core/agent-generator/detectors/rust-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/structure-detector.d.ts +4 -0
- package/dist/src/core/agent-generator/detectors/structure-detector.js +35 -0
- package/dist/src/core/agent-generator/detectors/structure-detector.js.map +1 -0
- package/dist/src/core/agent-generator/detectors/toolchain-detector.d.ts +5 -0
- package/dist/src/core/agent-generator/detectors/toolchain-detector.js +164 -0
- package/dist/src/core/agent-generator/detectors/toolchain-detector.js.map +1 -0
- package/dist/src/core/agent-generator/domain-inferrer.d.ts +51 -0
- package/dist/src/core/agent-generator/domain-inferrer.js +585 -0
- package/dist/src/core/agent-generator/domain-inferrer.js.map +1 -0
- package/dist/src/core/agent-generator/engines/audit-engine.d.ts +8 -0
- package/dist/src/core/agent-generator/engines/audit-engine.js +84 -0
- package/dist/src/core/agent-generator/engines/audit-engine.js.map +1 -0
- package/dist/src/core/agent-generator/engines/context-builder.d.ts +12 -0
- package/dist/src/core/agent-generator/engines/context-builder.js +84 -0
- package/dist/src/core/agent-generator/engines/context-builder.js.map +1 -0
- package/dist/src/core/agent-generator/engines/generation-engine.d.ts +7 -0
- package/dist/src/core/agent-generator/engines/generation-engine.js +160 -0
- package/dist/src/core/agent-generator/engines/generation-engine.js.map +1 -0
- package/dist/src/core/agent-generator/engines/generation-engine_deps.d.ts +21 -0
- package/dist/src/core/agent-generator/engines/generation-engine_deps.js +17 -0
- package/dist/src/core/agent-generator/engines/generation-engine_deps.js.map +1 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine.d.ts +13 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine.js +171 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine.js.map +1 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine_deps.d.ts +8 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js +5 -0
- package/dist/src/core/agent-generator/engines/suggestion-engine_deps.js.map +1 -0
- package/dist/src/core/agent-generator/enrichers/analysis-helpers.d.ts +9 -0
- package/dist/src/core/agent-generator/enrichers/analysis-helpers.js +51 -0
- package/dist/src/core/agent-generator/enrichers/analysis-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/enrichers/description-generator.d.ts +4 -0
- package/dist/src/core/agent-generator/enrichers/description-generator.js +82 -0
- package/dist/src/core/agent-generator/enrichers/description-generator.js.map +1 -0
- package/dist/src/core/agent-generator/enrichers/endpoint-extractor.d.ts +7 -0
- package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js +90 -0
- package/dist/src/core/agent-generator/enrichers/endpoint-extractor.js.map +1 -0
- package/dist/src/core/agent-generator/enrichers/layer-classifier.d.ts +12 -0
- package/dist/src/core/agent-generator/enrichers/layer-classifier.js +152 -0
- package/dist/src/core/agent-generator/enrichers/layer-classifier.js.map +1 -0
- package/dist/src/core/agent-generator/enrichers/module-extractor.d.ts +10 -0
- package/dist/src/core/agent-generator/enrichers/module-extractor.js +173 -0
- package/dist/src/core/agent-generator/enrichers/module-extractor.js.map +1 -0
- package/dist/src/core/agent-generator/framework-detector.d.ts +17 -0
- package/dist/src/core/agent-generator/framework-detector.js +56 -0
- package/dist/src/core/agent-generator/framework-detector.js.map +1 -0
- package/dist/src/core/agent-generator/index.d.ts +25 -0
- package/dist/src/core/agent-generator/index.js +37 -0
- package/dist/src/core/agent-generator/index.js.map +1 -0
- package/dist/src/core/agent-generator/stack-detector.d.ts +13 -0
- package/dist/src/core/agent-generator/stack-detector.js +124 -0
- package/dist/src/core/agent-generator/stack-detector.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/agents.d.ts +9 -0
- package/dist/src/core/agent-generator/templates/core/agents.js +1127 -0
- package/dist/src/core/agent-generator/templates/core/agents.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/architecture-rules.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/core/architecture-rules.js +275 -0
- package/dist/src/core/agent-generator/templates/core/architecture-rules.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/general-rules.d.ts +7 -0
- package/dist/src/core/agent-generator/templates/core/general-rules.js +301 -0
- package/dist/src/core/agent-generator/templates/core/general-rules.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/hooks-generator.d.ts +20 -0
- package/dist/src/core/agent-generator/templates/core/hooks-generator.js +235 -0
- package/dist/src/core/agent-generator/templates/core/hooks-generator.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/index-md.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/core/index-md.js +247 -0
- package/dist/src/core/agent-generator/templates/core/index-md.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/orchestrator.d.ts +7 -0
- package/dist/src/core/agent-generator/templates/core/orchestrator.js +423 -0
- package/dist/src/core/agent-generator/templates/core/orchestrator.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/preflight.d.ts +7 -0
- package/dist/src/core/agent-generator/templates/core/preflight.js +213 -0
- package/dist/src/core/agent-generator/templates/core/preflight.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/quality-gates.d.ts +10 -0
- package/dist/src/core/agent-generator/templates/core/quality-gates.js +255 -0
- package/dist/src/core/agent-generator/templates/core/quality-gates.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/security-rules.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/core/security-rules.js +529 -0
- package/dist/src/core/agent-generator/templates/core/security-rules.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/skills-generator.d.ts +18 -0
- package/dist/src/core/agent-generator/templates/core/skills-generator.js +547 -0
- package/dist/src/core/agent-generator/templates/core/skills-generator.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js +238 -0
- package/dist/src/core/agent-generator/templates/core/workflow-fix-bug.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/workflow-new-feature.d.ts +7 -0
- package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js +321 -0
- package/dist/src/core/agent-generator/templates/core/workflow-new-feature.js.map +1 -0
- package/dist/src/core/agent-generator/templates/core/workflow-review.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/core/workflow-review.js +105 -0
- package/dist/src/core/agent-generator/templates/core/workflow-review.js.map +1 -0
- package/dist/src/core/agent-generator/templates/domain/index.d.ts +21 -0
- package/dist/src/core/agent-generator/templates/domain/index.js +1179 -0
- package/dist/src/core/agent-generator/templates/domain/index.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/base-helpers.d.ts +10 -0
- package/dist/src/core/agent-generator/templates/helpers/base-helpers.js +20 -0
- package/dist/src/core/agent-generator/templates/helpers/base-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.d.ts +2 -0
- package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js +77 -0
- package/dist/src/core/agent-generator/templates/helpers/cross-ref-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/security-helpers.d.ts +2 -0
- package/dist/src/core/agent-generator/templates/helpers/security-helpers.js +182 -0
- package/dist/src/core/agent-generator/templates/helpers/security-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/stack-helpers.d.ts +4 -0
- package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js +69 -0
- package/dist/src/core/agent-generator/templates/helpers/stack-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/structure-helpers.d.ts +2 -0
- package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js +275 -0
- package/dist/src/core/agent-generator/templates/helpers/structure-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/helpers/summary-helpers.d.ts +6 -0
- package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js +56 -0
- package/dist/src/core/agent-generator/templates/helpers/summary-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/templates/stack/index.d.ts +7 -0
- package/dist/src/core/agent-generator/templates/stack/index.js +695 -0
- package/dist/src/core/agent-generator/templates/stack/index.js.map +1 -0
- package/dist/src/core/agent-generator/templates/template-helpers.d.ts +11 -0
- package/dist/src/core/agent-generator/templates/template-helpers.js +12 -0
- package/dist/src/core/agent-generator/templates/template-helpers.js.map +1 -0
- package/dist/src/core/agent-generator/types/agent.d.ts +39 -0
- package/dist/src/core/agent-generator/types/agent.js +27 -0
- package/dist/src/core/agent-generator/types/agent.js.map +1 -0
- package/dist/src/core/agent-generator/types/domain.d.ts +58 -0
- package/dist/src/core/agent-generator/types/domain.js +2 -0
- package/dist/src/core/agent-generator/types/domain.js.map +1 -0
- package/dist/src/core/agent-generator/types/stack.d.ts +36 -0
- package/dist/src/core/agent-generator/types/stack.js +2 -0
- package/dist/src/core/agent-generator/types/stack.js.map +1 -0
- package/dist/src/core/agent-generator/types/template.d.ts +29 -0
- package/dist/src/core/agent-generator/types/template.js +2 -0
- package/dist/src/core/agent-generator/types/template.js.map +1 -0
- package/dist/src/core/agent-runtime/ai-provider.d.ts +33 -0
- package/dist/src/core/agent-runtime/ai-provider.js +146 -0
- package/dist/src/core/agent-runtime/ai-provider.js.map +1 -0
- package/dist/src/core/agent-runtime/executor.d.ts +13 -0
- package/dist/src/core/agent-runtime/executor.js +138 -0
- package/dist/src/core/agent-runtime/executor.js.map +1 -0
- package/dist/src/core/agent-runtime/human-gate.d.ts +16 -0
- package/dist/src/core/agent-runtime/human-gate.js +70 -0
- package/dist/src/core/agent-runtime/human-gate.js.map +1 -0
- package/dist/tests/agent-generator.test.d.ts +1 -0
- package/dist/tests/agent-generator.test.js +349 -0
- package/dist/tests/agent-generator.test.js.map +1 -0
- package/dist/tests/agent-runtime.test.d.ts +1 -0
- package/dist/tests/agent-runtime.test.js +107 -0
- package/dist/tests/agent-runtime.test.js.map +1 -0
- package/dist/tests/context-enricher.test.d.ts +1 -0
- package/dist/tests/context-enricher.test.js +875 -0
- package/dist/tests/context-enricher.test.js.map +1 -0
- package/dist/tests/framework-detector.test.d.ts +1 -0
- package/dist/tests/framework-detector.test.js +882 -0
- package/dist/tests/framework-detector.test.js.map +1 -0
- package/dist/tests/stack-detector.test.d.ts +1 -0
- package/dist/tests/stack-detector.test.js +183 -0
- package/dist/tests/stack-detector.test.js.map +1 -0
- package/dist/tests/template-generation.test.d.ts +1 -0
- package/dist/tests/template-generation.test.js +571 -0
- package/dist/tests/template-generation.test.js.map +1 -0
- package/dist/tests/template-helpers.test.d.ts +1 -0
- package/dist/tests/template-helpers.test.js +967 -0
- package/dist/tests/template-helpers.test.js.map +1 -0
- package/package.json +24 -0
- package/src/core/agent-generator/context-enricher.ts +67 -0
- package/src/core/agent-generator/detectors/base-detector.ts +18 -0
- package/src/core/agent-generator/detectors/dart-detector.ts +17 -0
- package/src/core/agent-generator/detectors/framework-registry.ts +82 -0
- package/src/core/agent-generator/detectors/go-detector.ts +26 -0
- package/src/core/agent-generator/detectors/java-detector.ts +46 -0
- package/src/core/agent-generator/detectors/node-detector.ts +28 -0
- package/src/core/agent-generator/detectors/php-detector.ts +28 -0
- package/src/core/agent-generator/detectors/python-detector.ts +125 -0
- package/src/core/agent-generator/detectors/ruby-detector.ts +24 -0
- package/src/core/agent-generator/detectors/rust-detector.ts +19 -0
- package/src/core/agent-generator/detectors/structure-detector.ts +38 -0
- package/src/core/agent-generator/detectors/toolchain-detector.ts +181 -0
- package/src/core/agent-generator/domain-inferrer.ts +630 -0
- package/src/core/agent-generator/engines/audit-engine.ts +98 -0
- package/src/core/agent-generator/engines/context-builder.ts +96 -0
- package/src/core/agent-generator/engines/generation-engine.ts +184 -0
- package/src/core/agent-generator/engines/generation-engine_deps.ts +21 -0
- package/src/core/agent-generator/engines/suggestion-engine.ts +202 -0
- package/src/core/agent-generator/engines/suggestion-engine_deps.ts +8 -0
- package/src/core/agent-generator/enrichers/analysis-helpers.ts +58 -0
- package/src/core/agent-generator/enrichers/description-generator.ts +91 -0
- package/src/core/agent-generator/enrichers/endpoint-extractor.ts +114 -0
- package/src/core/agent-generator/enrichers/layer-classifier.ts +156 -0
- package/src/core/agent-generator/enrichers/module-extractor.ts +203 -0
- package/src/core/agent-generator/framework-detector.ts +66 -0
- package/src/core/agent-generator/index.ts +55 -0
- package/src/core/agent-generator/stack-detector.ts +115 -0
- package/src/core/agent-generator/templates/core/agents.ts +1168 -0
- package/src/core/agent-generator/templates/core/architecture-rules.ts +288 -0
- package/src/core/agent-generator/templates/core/general-rules.ts +306 -0
- package/src/core/agent-generator/templates/core/hooks-generator.ts +244 -0
- package/src/core/agent-generator/templates/core/index-md.ts +261 -0
- package/src/core/agent-generator/templates/core/orchestrator.ts +462 -0
- package/src/core/agent-generator/templates/core/preflight.ts +216 -0
- package/src/core/agent-generator/templates/core/quality-gates.ts +257 -0
- package/src/core/agent-generator/templates/core/security-rules.ts +544 -0
- package/src/core/agent-generator/templates/core/skills-generator.ts +586 -0
- package/src/core/agent-generator/templates/core/workflow-fix-bug.ts +240 -0
- package/src/core/agent-generator/templates/core/workflow-new-feature.ts +323 -0
- package/src/core/agent-generator/templates/core/workflow-review.ts +107 -0
- package/src/core/agent-generator/templates/domain/index.ts +1204 -0
- package/src/core/agent-generator/templates/helpers/base-helpers.ts +33 -0
- package/src/core/agent-generator/templates/helpers/cross-ref-helpers.ts +79 -0
- package/src/core/agent-generator/templates/helpers/security-helpers.ts +198 -0
- package/src/core/agent-generator/templates/helpers/stack-helpers.ts +80 -0
- package/src/core/agent-generator/templates/helpers/structure-helpers.ts +293 -0
- package/src/core/agent-generator/templates/helpers/summary-helpers.ts +67 -0
- package/src/core/agent-generator/templates/stack/index.ts +705 -0
- package/src/core/agent-generator/templates/template-helpers.ts +12 -0
- package/src/core/agent-generator/types/agent.ts +65 -0
- package/src/core/agent-generator/types/domain.ts +63 -0
- package/src/core/agent-generator/types/stack.ts +38 -0
- package/src/core/agent-generator/types/template.ts +31 -0
- package/src/core/agent-runtime/ai-provider.ts +178 -0
- package/src/core/agent-runtime/executor.ts +148 -0
- package/src/core/agent-runtime/human-gate.ts +69 -0
- package/tests/agent-generator.test.ts +428 -0
- package/tests/agent-runtime.test.ts +125 -0
- package/tests/context-enricher.test.ts +972 -0
- package/tests/framework-detector.test.ts +1172 -0
- package/tests/stack-detector.test.ts +241 -0
- package/tests/template-generation.test.ts +709 -0
- package/tests/template-helpers.test.ts +1130 -0
- package/tsconfig.json +14 -0
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { existsSync, readdirSync, readFileSync } from 'fs';
|
|
2
|
+
import { join } from 'path';
|
|
3
|
+
export class AuditEngine {
|
|
4
|
+
auditExisting(agentDir, stack, report, plan) {
|
|
5
|
+
const findings = [];
|
|
6
|
+
const checkExists = (subpath, category, desc) => {
|
|
7
|
+
const full = join(agentDir, subpath);
|
|
8
|
+
if (!existsSync(full)) {
|
|
9
|
+
findings.push({ type: 'MISSING', category, file: subpath, description: desc });
|
|
10
|
+
}
|
|
11
|
+
else {
|
|
12
|
+
findings.push({ type: 'OK', category, file: subpath, description: `${subpath} exists` });
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
checkExists('INDEX.md', 'core', 'Master navigation guide');
|
|
16
|
+
checkExists('agents/AGENT-ORCHESTRATOR.md', 'agents', 'Orchestrator agent with approval gates');
|
|
17
|
+
checkExists('rules/00-general.md', 'rules', 'Golden rules and conventions');
|
|
18
|
+
checkExists('rules/01-architecture.md', 'rules', 'Layer rules, dependency direction, module patterns');
|
|
19
|
+
checkExists('rules/02-security.md', 'rules', 'OWASP, input validation, secrets management');
|
|
20
|
+
checkExists('guards/PREFLIGHT.md', 'guards', '6-phase preflight checklist');
|
|
21
|
+
checkExists('guards/QUALITY-GATES.md', 'guards', '3-level quality gates');
|
|
22
|
+
checkExists('guards/CODE-REVIEW-CHECKLIST.md', 'guards', 'Structured code review checklist');
|
|
23
|
+
checkExists('workflows/new-feature.md', 'workflows', '10-step feature workflow with approval gates');
|
|
24
|
+
checkExists('workflows/fix-bug.md', 'workflows', 'Diagnostic bug fix workflow');
|
|
25
|
+
checkExists('templates/C4.md', 'templates', 'C4 architecture template');
|
|
26
|
+
checkExists('templates/BDD.md', 'templates', 'BDD scenario template');
|
|
27
|
+
checkExists('templates/TDD.md', 'templates', 'TDD test template');
|
|
28
|
+
checkExists('templates/ADR.md', 'templates', 'ADR decision record template');
|
|
29
|
+
checkExists('templates/THREAT-MODEL.md', 'templates', 'STRIDE threat model template');
|
|
30
|
+
if (stack.hasBackend) {
|
|
31
|
+
const found = this.findAgentByRole(agentDir, 'backend');
|
|
32
|
+
if (!found) {
|
|
33
|
+
findings.push({
|
|
34
|
+
type: 'MISSING', category: 'agents',
|
|
35
|
+
file: `agents/${stack.primary.toUpperCase()}-BACKEND-DEVELOPER.md`,
|
|
36
|
+
description: `No backend developer agent for ${stack.primary}`,
|
|
37
|
+
});
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
if (stack.hasFrontend) {
|
|
41
|
+
const found = this.findAgentByRole(agentDir, 'frontend');
|
|
42
|
+
if (!found) {
|
|
43
|
+
findings.push({
|
|
44
|
+
type: 'MISSING', category: 'agents',
|
|
45
|
+
file: 'agents/FRONTEND-DEVELOPER.md',
|
|
46
|
+
description: 'No frontend developer agent',
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
if (plan.steps.length > 0) {
|
|
51
|
+
const found = this.findAgentByRole(agentDir, 'tech-debt');
|
|
52
|
+
if (!found) {
|
|
53
|
+
findings.push({
|
|
54
|
+
type: 'IMPROVEMENT', category: 'agents',
|
|
55
|
+
file: 'agents/TECH-DEBT-CONTROLLER.md',
|
|
56
|
+
description: `${plan.steps.length} refactoring steps found but no Tech Debt agent`,
|
|
57
|
+
suggestion: 'Create a Tech Debt Controller to track and prioritize refactoring',
|
|
58
|
+
});
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
if (report.score.overall < 80) {
|
|
62
|
+
findings.push({
|
|
63
|
+
type: 'IMPROVEMENT', category: 'guards',
|
|
64
|
+
file: 'guards/QUALITY-GATES.md',
|
|
65
|
+
description: `Score is ${report.score.overall}/100 — quality gates should enforce improvement`,
|
|
66
|
+
suggestion: `Set minimum score threshold to ${report.score.overall + 5} and add regression guards`,
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
return findings;
|
|
70
|
+
}
|
|
71
|
+
findAgentByRole(agentDir, role) {
|
|
72
|
+
const dir = join(agentDir, 'agents');
|
|
73
|
+
if (!existsSync(dir))
|
|
74
|
+
return null;
|
|
75
|
+
const files = readdirSync(dir);
|
|
76
|
+
for (const file of files) {
|
|
77
|
+
const content = readFileSync(join(dir, file), 'utf-8').toLowerCase();
|
|
78
|
+
if (content.includes(role))
|
|
79
|
+
return file;
|
|
80
|
+
}
|
|
81
|
+
return null;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=audit-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"audit-engine.js","sourceRoot":"","sources":["../../../../../src/core/agent-generator/engines/audit-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { AnalysisReport } from '@girardelli/architect-core/src/core/types/core.js';
|
|
2
|
+
import { RefactoringPlan } from '@girardelli/architect-core/src/core/types/rules.js';
|
|
3
|
+
import { StackInfo } from '@girardelli/architect-agents/src/core/agent-generator/types/stack.js';
|
|
4
|
+
import { EnrichedTemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
|
|
5
|
+
export declare class ContextBuilder {
|
|
6
|
+
private contextEnricher;
|
|
7
|
+
static readonly MAX_FILE_LINES = 500;
|
|
8
|
+
static readonly EXCLUDED_SEGMENTS: string[];
|
|
9
|
+
sanitizeReport(report: AnalysisReport): AnalysisReport;
|
|
10
|
+
capContent(content: string): string;
|
|
11
|
+
buildContext(report: AnalysisReport, plan: RefactoringPlan, stack: StackInfo, projectPath?: string): EnrichedTemplateContext;
|
|
12
|
+
}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
import { DEFAULT_AGENT_CONFIG } from '@girardelli/architect-agents/src/core/agent-generator/types/agent.js';
|
|
2
|
+
import { ContextEnricher } from '../context-enricher.js';
|
|
3
|
+
export class ContextBuilder {
|
|
4
|
+
contextEnricher = new ContextEnricher();
|
|
5
|
+
static MAX_FILE_LINES = 500;
|
|
6
|
+
static EXCLUDED_SEGMENTS = [
|
|
7
|
+
'node_modules', '/dist/', '/build/', '/coverage/',
|
|
8
|
+
'/.next/', '/venv/', '/__pycache__/', '/target/',
|
|
9
|
+
];
|
|
10
|
+
sanitizeReport(report) {
|
|
11
|
+
const isProjectPath = (path) => {
|
|
12
|
+
const normalized = path.replace(/\\/g, '/');
|
|
13
|
+
return !ContextBuilder.EXCLUDED_SEGMENTS.some(seg => normalized.includes(seg));
|
|
14
|
+
};
|
|
15
|
+
return {
|
|
16
|
+
...report,
|
|
17
|
+
antiPatterns: report.antiPatterns.filter(ap => {
|
|
18
|
+
if (!isProjectPath(ap.location))
|
|
19
|
+
return false;
|
|
20
|
+
if (ap.affectedFiles?.some(f => !isProjectPath(f))) {
|
|
21
|
+
ap.affectedFiles = ap.affectedFiles.filter(f => isProjectPath(f));
|
|
22
|
+
}
|
|
23
|
+
return true;
|
|
24
|
+
}),
|
|
25
|
+
dependencyGraph: {
|
|
26
|
+
nodes: report.dependencyGraph.nodes.filter(n => isProjectPath(n)),
|
|
27
|
+
edges: report.dependencyGraph.edges.filter(e => isProjectPath(e.from) && isProjectPath(e.to)),
|
|
28
|
+
},
|
|
29
|
+
suggestions: report.suggestions.filter(s => !s.description.includes('node_modules')),
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
capContent(content) {
|
|
33
|
+
const lines = content.split('\n');
|
|
34
|
+
if (lines.length <= ContextBuilder.MAX_FILE_LINES)
|
|
35
|
+
return content;
|
|
36
|
+
const truncated = lines.slice(0, ContextBuilder.MAX_FILE_LINES);
|
|
37
|
+
truncated.push('');
|
|
38
|
+
truncated.push('<!-- Content truncated at ' + ContextBuilder.MAX_FILE_LINES + ' lines. Run `architect agents` to regenerate. -->');
|
|
39
|
+
return truncated.join('\n');
|
|
40
|
+
}
|
|
41
|
+
buildContext(report, plan, stack, projectPath) {
|
|
42
|
+
if (projectPath) {
|
|
43
|
+
return this.contextEnricher.enrich(report, plan, stack, projectPath);
|
|
44
|
+
}
|
|
45
|
+
// Fallback to basic enriched context for backward compatibility
|
|
46
|
+
return {
|
|
47
|
+
report,
|
|
48
|
+
plan,
|
|
49
|
+
stack,
|
|
50
|
+
projectName: report.projectInfo.name || 'Project',
|
|
51
|
+
stackLabel: [...stack.languages, ...stack.frameworks].join(' + '),
|
|
52
|
+
config: DEFAULT_AGENT_CONFIG,
|
|
53
|
+
domain: {
|
|
54
|
+
domain: 'general',
|
|
55
|
+
subDomain: 'general',
|
|
56
|
+
description: '',
|
|
57
|
+
businessEntities: [],
|
|
58
|
+
compliance: [],
|
|
59
|
+
integrations: [],
|
|
60
|
+
keywords: [],
|
|
61
|
+
confidence: 0,
|
|
62
|
+
},
|
|
63
|
+
modules: [],
|
|
64
|
+
endpoints: [],
|
|
65
|
+
untestedModules: [],
|
|
66
|
+
criticalPaths: [],
|
|
67
|
+
projectDepth: 'small',
|
|
68
|
+
detectedFrameworks: [],
|
|
69
|
+
primaryFramework: null,
|
|
70
|
+
toolchain: {
|
|
71
|
+
buildCmd: 'echo "No build command detected"',
|
|
72
|
+
testCmd: 'echo "No test command detected"',
|
|
73
|
+
lintCmd: 'echo "No lint command detected"',
|
|
74
|
+
runCmd: 'echo "No run command detected"',
|
|
75
|
+
coverageCmd: 'echo "No coverage command detected"',
|
|
76
|
+
installCmd: 'echo "No install command detected"',
|
|
77
|
+
migrateCmd: null,
|
|
78
|
+
depsFile: 'unknown',
|
|
79
|
+
},
|
|
80
|
+
projectStructure: 'unknown',
|
|
81
|
+
};
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=context-builder.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"context-builder.js","sourceRoot":"","sources":["../../../../../src/core/agent-generator/engines/context-builder.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AnalysisReport, RefactoringPlan, StackInfo, AgentAuditFinding, EnrichedTemplateContext } from './generation-engine_deps.js';
|
|
2
|
+
export declare class GenerationEngine {
|
|
3
|
+
private contextBuilder;
|
|
4
|
+
generateFull(agentDir: string, report: AnalysisReport, plan: RefactoringPlan, stack: StackInfo, projectPath: string): string[];
|
|
5
|
+
generateMissing(agentDir: string, audit: AgentAuditFinding[], report: AnalysisReport, plan: RefactoringPlan, stack: StackInfo, projectPath: string): string[];
|
|
6
|
+
getTemplateFor(file: string, ctx: EnrichedTemplateContext): string | null;
|
|
7
|
+
}
|
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { ContextBuilder, generateIndexMd, generateOrchestrator, generatePreflight, generateQualityGates, generateGeneralRules, generateArchitectureRules, generateSecurityRules, generateNewFeatureWorkflow, generateFixBugWorkflow, generateReviewWorkflow, generateBackendAgent, generateFrontendAgent, generateSecurityAgent, generateQAAgent, generateTechDebtAgent, generateCodeReviewChecklist, generateDatabaseAgent, generateMobileAgent, generateStackRules, getStackRuleFileName, generateC4Template, generateBddTemplate, generateTddTemplate, generateAdrTemplate, generateThreatModelTemplate, generateProjectSkills, generateArchitectIntegrationSkill, generateCIPipelineSkill, generateMonorepoGuideSkill, generatePreCommitHook, generatePrePushHook, generatePostAnalysisHook } from './generation-engine_deps.js';
|
|
2
|
+
import { existsSync, mkdirSync, writeFileSync } from "fs";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
// ── Core Templates (Enterprise-Grade) ──
|
|
5
|
+
// ── Stack-Specific Templates ──
|
|
6
|
+
// ── Domain Templates ──
|
|
7
|
+
// ── Skills Generator ──
|
|
8
|
+
// ── Hooks Generator ──
|
|
9
|
+
export class GenerationEngine {
|
|
10
|
+
contextBuilder = new ContextBuilder();
|
|
11
|
+
generateFull(agentDir, report, plan, stack, projectPath) {
|
|
12
|
+
const generated = [];
|
|
13
|
+
const ctx = this.contextBuilder.buildContext(report, plan, stack, projectPath);
|
|
14
|
+
// Create directories
|
|
15
|
+
const dirs = ['agents', 'rules', 'guards', 'workflows', 'templates', 'skills', 'hooks'];
|
|
16
|
+
for (const d of dirs)
|
|
17
|
+
mkdirSync(join(agentDir, d), { recursive: true });
|
|
18
|
+
// ── Core files (Enterprise-Grade) ──
|
|
19
|
+
const coreFiles = {
|
|
20
|
+
'INDEX.md': generateIndexMd(ctx),
|
|
21
|
+
'agents/AGENT-ORCHESTRATOR.md': generateOrchestrator(ctx),
|
|
22
|
+
'guards/PREFLIGHT.md': generatePreflight(ctx),
|
|
23
|
+
'guards/QUALITY-GATES.md': generateQualityGates(ctx),
|
|
24
|
+
'guards/CODE-REVIEW-CHECKLIST.md': generateCodeReviewChecklist(ctx),
|
|
25
|
+
'rules/00-general.md': generateGeneralRules(ctx),
|
|
26
|
+
'rules/01-architecture.md': generateArchitectureRules(ctx),
|
|
27
|
+
'rules/02-security.md': generateSecurityRules(ctx),
|
|
28
|
+
'workflows/new-feature.md': generateNewFeatureWorkflow(ctx),
|
|
29
|
+
'workflows/fix-bug.md': generateFixBugWorkflow(ctx),
|
|
30
|
+
'workflows/review.md': generateReviewWorkflow(ctx),
|
|
31
|
+
};
|
|
32
|
+
// ── Stack-specific agents ──
|
|
33
|
+
if (stack.hasBackend) {
|
|
34
|
+
coreFiles[`agents/${stack.primary.toUpperCase()}-BACKEND-DEVELOPER.md`] = generateBackendAgent(ctx);
|
|
35
|
+
}
|
|
36
|
+
if (stack.hasFrontend) {
|
|
37
|
+
const FRONTEND_FWS = ['Angular', 'Vue', 'Vue.js', 'Next.js', 'React', 'Nuxt', 'Svelte', 'Remix'];
|
|
38
|
+
const detectedFw = ctx.detectedFrameworks?.find(f => FRONTEND_FWS.includes(f.name));
|
|
39
|
+
const fwName = detectedFw?.name ||
|
|
40
|
+
stack.frameworks.find(f => FRONTEND_FWS.includes(f)) || 'Frontend';
|
|
41
|
+
coreFiles[`agents/${fwName.toUpperCase().replace('.', '').replace(/\s/g, '-')}-FRONTEND-DEVELOPER.md`] = generateFrontendAgent(ctx);
|
|
42
|
+
}
|
|
43
|
+
if (stack.hasMobile) {
|
|
44
|
+
coreFiles['agents/FLUTTER-UI-DEVELOPER.md'] = generateMobileAgent(ctx);
|
|
45
|
+
}
|
|
46
|
+
if (stack.hasDatabase) {
|
|
47
|
+
coreFiles['agents/DATABASE-ENGINEER.md'] = generateDatabaseAgent(ctx);
|
|
48
|
+
}
|
|
49
|
+
coreFiles['agents/SECURITY-AUDITOR.md'] = generateSecurityAgent(ctx);
|
|
50
|
+
coreFiles['agents/QA-TEST-ENGINEER.md'] = generateQAAgent(ctx);
|
|
51
|
+
coreFiles['agents/TECH-DEBT-CONTROLLER.md'] = generateTechDebtAgent(ctx);
|
|
52
|
+
// ── Stack-specific rules ──
|
|
53
|
+
const stackRuleContent = generateStackRules(ctx);
|
|
54
|
+
const stackRuleFile = getStackRuleFileName(ctx);
|
|
55
|
+
if (stackRuleContent && stackRuleFile) {
|
|
56
|
+
coreFiles[`rules/${stackRuleFile}.md`] = stackRuleContent;
|
|
57
|
+
}
|
|
58
|
+
// ── Domain templates ──
|
|
59
|
+
coreFiles['templates/C4.md'] = generateC4Template(ctx);
|
|
60
|
+
coreFiles['templates/BDD.md'] = generateBddTemplate(ctx);
|
|
61
|
+
coreFiles['templates/TDD.md'] = generateTddTemplate(ctx);
|
|
62
|
+
coreFiles['templates/ADR.md'] = generateAdrTemplate(ctx);
|
|
63
|
+
coreFiles['templates/THREAT-MODEL.md'] = generateThreatModelTemplate(ctx);
|
|
64
|
+
// ── Project Skills (padrões detectados) ──
|
|
65
|
+
const skillsContent = generateProjectSkills(ctx);
|
|
66
|
+
if (skillsContent) {
|
|
67
|
+
coreFiles['skills/PROJECT-PATTERNS.md'] = skillsContent;
|
|
68
|
+
}
|
|
69
|
+
// ── Data-driven Skills (real project data) ──
|
|
70
|
+
coreFiles['skills/ARCHITECT-INTEGRATION.md'] = generateArchitectIntegrationSkill(ctx);
|
|
71
|
+
coreFiles['skills/CI-PIPELINE.md'] = generateCIPipelineSkill(ctx);
|
|
72
|
+
const monorepoGuide = generateMonorepoGuideSkill(ctx);
|
|
73
|
+
if (monorepoGuide) {
|
|
74
|
+
coreFiles['skills/MONOREPO-GUIDE.md'] = monorepoGuide;
|
|
75
|
+
}
|
|
76
|
+
// ── Executable Hooks ──
|
|
77
|
+
coreFiles['hooks/pre-commit.sh'] = generatePreCommitHook(ctx);
|
|
78
|
+
coreFiles['hooks/pre-push.sh'] = generatePrePushHook(ctx);
|
|
79
|
+
coreFiles['hooks/post-analysis.sh'] = generatePostAnalysisHook(ctx);
|
|
80
|
+
// ── Write all files (with size cap) ──
|
|
81
|
+
for (const [path, content] of Object.entries(coreFiles)) {
|
|
82
|
+
const fullPath = join(agentDir, path);
|
|
83
|
+
const dir = join(fullPath, '..');
|
|
84
|
+
if (!existsSync(dir))
|
|
85
|
+
mkdirSync(dir, { recursive: true });
|
|
86
|
+
writeFileSync(fullPath, this.contextBuilder.capContent(content));
|
|
87
|
+
generated.push(path);
|
|
88
|
+
}
|
|
89
|
+
return generated;
|
|
90
|
+
}
|
|
91
|
+
generateMissing(agentDir, audit, report, plan, stack, projectPath) {
|
|
92
|
+
const generated = [];
|
|
93
|
+
const missing = audit.filter(f => f.type === 'MISSING');
|
|
94
|
+
const ctx = this.contextBuilder.buildContext(report, plan, stack, projectPath);
|
|
95
|
+
for (const finding of missing) {
|
|
96
|
+
const fullPath = join(agentDir, finding.file);
|
|
97
|
+
const dir = join(fullPath, '..');
|
|
98
|
+
if (!existsSync(dir))
|
|
99
|
+
mkdirSync(dir, { recursive: true });
|
|
100
|
+
const content = this.getTemplateFor(finding.file, ctx);
|
|
101
|
+
if (content) {
|
|
102
|
+
writeFileSync(fullPath, content);
|
|
103
|
+
generated.push(finding.file);
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
return generated;
|
|
107
|
+
}
|
|
108
|
+
getTemplateFor(file, ctx) {
|
|
109
|
+
if (file.includes('INDEX'))
|
|
110
|
+
return generateIndexMd(ctx);
|
|
111
|
+
if (file.includes('ORCHESTRATOR'))
|
|
112
|
+
return generateOrchestrator(ctx);
|
|
113
|
+
if (file.includes('PREFLIGHT'))
|
|
114
|
+
return generatePreflight(ctx);
|
|
115
|
+
if (file.includes('QUALITY-GATES'))
|
|
116
|
+
return generateQualityGates(ctx);
|
|
117
|
+
if (file.includes('CODE-REVIEW'))
|
|
118
|
+
return generateCodeReviewChecklist(ctx);
|
|
119
|
+
if (file.includes('SECURITY'))
|
|
120
|
+
return generateSecurityAgent(ctx);
|
|
121
|
+
if (file.includes('QA'))
|
|
122
|
+
return generateQAAgent(ctx);
|
|
123
|
+
if (file.includes('TECH-DEBT'))
|
|
124
|
+
return generateTechDebtAgent(ctx);
|
|
125
|
+
if (file.includes('BACKEND'))
|
|
126
|
+
return generateBackendAgent(ctx);
|
|
127
|
+
if (file.includes('FRONTEND'))
|
|
128
|
+
return generateFrontendAgent(ctx);
|
|
129
|
+
if (file.includes('FLUTTER'))
|
|
130
|
+
return generateMobileAgent(ctx);
|
|
131
|
+
if (file.includes('DATABASE'))
|
|
132
|
+
return generateDatabaseAgent(ctx);
|
|
133
|
+
if (file.includes('00-general'))
|
|
134
|
+
return generateGeneralRules(ctx);
|
|
135
|
+
if (file.includes('01-architecture'))
|
|
136
|
+
return generateArchitectureRules(ctx);
|
|
137
|
+
if (file.includes('02-security'))
|
|
138
|
+
return generateSecurityRules(ctx);
|
|
139
|
+
if (file.includes('03-'))
|
|
140
|
+
return generateStackRules(ctx);
|
|
141
|
+
if (file.includes('new-feature') || file.includes('develop'))
|
|
142
|
+
return generateNewFeatureWorkflow(ctx);
|
|
143
|
+
if (file.includes('fix-bug'))
|
|
144
|
+
return generateFixBugWorkflow(ctx);
|
|
145
|
+
if (file.includes('review'))
|
|
146
|
+
return generateReviewWorkflow(ctx);
|
|
147
|
+
if (file.includes('C4'))
|
|
148
|
+
return generateC4Template(ctx);
|
|
149
|
+
if (file.includes('BDD'))
|
|
150
|
+
return generateBddTemplate(ctx);
|
|
151
|
+
if (file.includes('TDD'))
|
|
152
|
+
return generateTddTemplate(ctx);
|
|
153
|
+
if (file.includes('ADR'))
|
|
154
|
+
return generateAdrTemplate(ctx);
|
|
155
|
+
if (file.includes('THREAT'))
|
|
156
|
+
return generateThreatModelTemplate(ctx);
|
|
157
|
+
return null;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
//# sourceMappingURL=generation-engine.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generation-engine.js","sourceRoot":"","sources":["../../../../../src/core/agent-generator/engines/generation-engine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
export type { AnalysisReport } from '@girardelli/architect-core/src/core/types/core.js';
|
|
2
|
+
export type { RefactoringPlan } from '@girardelli/architect-core/src/core/types/rules.js';
|
|
3
|
+
export type { StackInfo } from '@girardelli/architect-agents/src/core/agent-generator/types/stack.js';
|
|
4
|
+
export type { AgentAuditFinding } from '@girardelli/architect-agents/src/core/agent-generator/types/agent.js';
|
|
5
|
+
export type { EnrichedTemplateContext } from '@girardelli/architect-agents/src/core/agent-generator/types/template.js';
|
|
6
|
+
export { ContextBuilder } from './context-builder.js';
|
|
7
|
+
export { generateIndexMd } from '../templates/core/index-md.js';
|
|
8
|
+
export { generateOrchestrator } from '../templates/core/orchestrator.js';
|
|
9
|
+
export { generatePreflight } from '../templates/core/preflight.js';
|
|
10
|
+
export { generateQualityGates } from '../templates/core/quality-gates.js';
|
|
11
|
+
export { generateGeneralRules } from '../templates/core/general-rules.js';
|
|
12
|
+
export { generateArchitectureRules } from '../templates/core/architecture-rules.js';
|
|
13
|
+
export { generateSecurityRules } from '../templates/core/security-rules.js';
|
|
14
|
+
export { generateNewFeatureWorkflow } from '../templates/core/workflow-new-feature.js';
|
|
15
|
+
export { generateFixBugWorkflow } from '../templates/core/workflow-fix-bug.js';
|
|
16
|
+
export { generateReviewWorkflow } from '../templates/core/workflow-review.js';
|
|
17
|
+
export { generateBackendAgent, generateFrontendAgent, generateSecurityAgent, generateQAAgent, generateTechDebtAgent, generateCodeReviewChecklist, generateDatabaseAgent, generateMobileAgent } from '../templates/core/agents.js';
|
|
18
|
+
export { generateStackRules, getStackRuleFileName } from '../templates/stack/index.js';
|
|
19
|
+
export { generateC4Template, generateBddTemplate, generateTddTemplate, generateAdrTemplate, generateThreatModelTemplate } from '../templates/domain/index.js';
|
|
20
|
+
export { generateProjectSkills, generateArchitectIntegrationSkill, generateCIPipelineSkill, generateMonorepoGuideSkill } from '../templates/core/skills-generator.js';
|
|
21
|
+
export { generatePreCommitHook, generatePrePushHook, generatePostAnalysisHook } from '../templates/core/hooks-generator.js';
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
export { ContextBuilder } from './context-builder.js';
|
|
2
|
+
export { generateIndexMd } from '../templates/core/index-md.js';
|
|
3
|
+
export { generateOrchestrator } from '../templates/core/orchestrator.js';
|
|
4
|
+
export { generatePreflight } from '../templates/core/preflight.js';
|
|
5
|
+
export { generateQualityGates } from '../templates/core/quality-gates.js';
|
|
6
|
+
export { generateGeneralRules } from '../templates/core/general-rules.js';
|
|
7
|
+
export { generateArchitectureRules } from '../templates/core/architecture-rules.js';
|
|
8
|
+
export { generateSecurityRules } from '../templates/core/security-rules.js';
|
|
9
|
+
export { generateNewFeatureWorkflow } from '../templates/core/workflow-new-feature.js';
|
|
10
|
+
export { generateFixBugWorkflow } from '../templates/core/workflow-fix-bug.js';
|
|
11
|
+
export { generateReviewWorkflow } from '../templates/core/workflow-review.js';
|
|
12
|
+
export { generateBackendAgent, generateFrontendAgent, generateSecurityAgent, generateQAAgent, generateTechDebtAgent, generateCodeReviewChecklist, generateDatabaseAgent, generateMobileAgent } from '../templates/core/agents.js';
|
|
13
|
+
export { generateStackRules, getStackRuleFileName } from '../templates/stack/index.js';
|
|
14
|
+
export { generateC4Template, generateBddTemplate, generateTddTemplate, generateAdrTemplate, generateThreatModelTemplate } from '../templates/domain/index.js';
|
|
15
|
+
export { generateProjectSkills, generateArchitectIntegrationSkill, generateCIPipelineSkill, generateMonorepoGuideSkill } from '../templates/core/skills-generator.js';
|
|
16
|
+
export { generatePreCommitHook, generatePrePushHook, generatePostAnalysisHook } from '../templates/core/hooks-generator.js';
|
|
17
|
+
//# sourceMappingURL=generation-engine_deps.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"generation-engine_deps.js","sourceRoot":"","sources":["../../../../../src/core/agent-generator/engines/generation-engine_deps.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,mCAAmC,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACnE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,oCAAoC,CAAC;AAC1E,OAAO,EAAE,yBAAyB,EAAE,MAAM,yCAAyC,CAAC;AACpF,OAAO,EAAE,qBAAqB,EAAE,MAAM,qCAAqC,CAAC;AAC5E,OAAO,EAAE,0BAA0B,EAAE,MAAM,2CAA2C,CAAC;AACvF,OAAO,EAAE,sBAAsB,EAAE,MAAM,uCAAuC,CAAC;AAC/E,OAAO,EAAE,sBAAsB,EAAE,MAAM,sCAAsC,CAAC;AAC9E,OAAO,EAAE,oBAAoB,EAAE,qBAAqB,EAAE,qBAAqB,EAAE,eAAe,EAAE,qBAAqB,EAAE,2BAA2B,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,MAAM,6BAA6B,CAAC;AAClO,OAAO,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACvF,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,2BAA2B,EAAE,MAAM,8BAA8B,CAAC;AAC9J,OAAO,EAAE,qBAAqB,EAAE,iCAAiC,EAAE,uBAAuB,EAAE,0BAA0B,EAAE,MAAM,uCAAuC,CAAC;AACtK,OAAO,EAAE,qBAAqB,EAAE,mBAAmB,EAAE,wBAAwB,EAAE,MAAM,sCAAsC,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { AnalysisReport, RefactoringPlan, StackInfo, AgentItemStatus, AgentSuggestion } from './suggestion-engine_deps.js';
|
|
2
|
+
export declare class SuggestionEngine {
|
|
3
|
+
private stackDetector;
|
|
4
|
+
private contextBuilder;
|
|
5
|
+
private auditEngine;
|
|
6
|
+
suggest(report: AnalysisReport, plan: RefactoringPlan, projectPath: string): AgentSuggestion;
|
|
7
|
+
buildSkillEntries(stack: StackInfo, existing: Set<string>): {
|
|
8
|
+
name: string;
|
|
9
|
+
source: string;
|
|
10
|
+
description: string;
|
|
11
|
+
status: AgentItemStatus;
|
|
12
|
+
}[];
|
|
13
|
+
}
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import { StackDetector, ContextBuilder, AuditEngine, getStackRuleFileName } from './suggestion-engine_deps.js';
|
|
2
|
+
import { existsSync, readdirSync, statSync } from "fs";
|
|
3
|
+
import { join } from "path";
|
|
4
|
+
export class SuggestionEngine {
|
|
5
|
+
stackDetector = new StackDetector();
|
|
6
|
+
contextBuilder = new ContextBuilder();
|
|
7
|
+
auditEngine = new AuditEngine();
|
|
8
|
+
suggest(report, plan, projectPath) {
|
|
9
|
+
const cleanReport = this.contextBuilder.sanitizeReport(report);
|
|
10
|
+
const stack = this.stackDetector.detect(cleanReport);
|
|
11
|
+
const agentDir = join(projectPath, '.agent');
|
|
12
|
+
const isExisting = existsSync(agentDir);
|
|
13
|
+
const existingFiles = (subdir) => {
|
|
14
|
+
const dir = join(agentDir, subdir);
|
|
15
|
+
if (!existsSync(dir))
|
|
16
|
+
return new Set();
|
|
17
|
+
return new Set(readdirSync(dir).map(f => f.replace(/\.md$/, '')));
|
|
18
|
+
};
|
|
19
|
+
let audit = [];
|
|
20
|
+
if (isExisting) {
|
|
21
|
+
audit = this.auditEngine.auditExisting(agentDir, stack, report, plan);
|
|
22
|
+
}
|
|
23
|
+
const ctx = this.contextBuilder.buildContext(cleanReport, plan, stack, projectPath);
|
|
24
|
+
const existingAgents = existingFiles('agents');
|
|
25
|
+
const existingRules = existingFiles('rules');
|
|
26
|
+
const existingGuards = existingFiles('guards');
|
|
27
|
+
const existingWorkflows = existingFiles('workflows');
|
|
28
|
+
const existingSkillsDir = join(agentDir, 'skills');
|
|
29
|
+
const existingSkillNames = existsSync(existingSkillsDir)
|
|
30
|
+
? new Set(readdirSync(existingSkillsDir).filter(f => {
|
|
31
|
+
try {
|
|
32
|
+
return statSync(join(existingSkillsDir, f)).isDirectory();
|
|
33
|
+
}
|
|
34
|
+
catch {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
37
|
+
}))
|
|
38
|
+
: new Set();
|
|
39
|
+
const itemStatus = (name, existing) => {
|
|
40
|
+
const found = [...existing].some(e => e.toLowerCase() === name.toLowerCase());
|
|
41
|
+
if (!found)
|
|
42
|
+
return 'CREATE';
|
|
43
|
+
const hasImprovement = audit.some(f => f.file.toLowerCase().includes(name.toLowerCase()) && (f.type === 'IMPROVEMENT' || f.type === 'OUTDATED'));
|
|
44
|
+
return hasImprovement ? 'MODIFY' : 'KEEP';
|
|
45
|
+
};
|
|
46
|
+
// ── Agent definitions ──
|
|
47
|
+
const agentDefs = [
|
|
48
|
+
{ name: 'AGENT-ORCHESTRATOR', desc: 'Centro de comando — decompõe requisições, enforça gates, coordena agentes' },
|
|
49
|
+
];
|
|
50
|
+
if (stack.hasBackend)
|
|
51
|
+
agentDefs.push({
|
|
52
|
+
name: `${stack.primary.toUpperCase()}-BACKEND-DEVELOPER`,
|
|
53
|
+
desc: `Especialista em ${stack.primary} — APIs, serviços, lógica de negócio, integration docs`,
|
|
54
|
+
});
|
|
55
|
+
if (stack.hasFrontend) {
|
|
56
|
+
const FRONTEND_FWS = ['Angular', 'Vue', 'Vue.js', 'Next.js', 'React', 'Nuxt', 'Svelte', 'Remix'];
|
|
57
|
+
const detectedFw = ctx.detectedFrameworks?.find(f => FRONTEND_FWS.includes(f.name));
|
|
58
|
+
const fw = detectedFw?.name ||
|
|
59
|
+
stack.frameworks.find(f => FRONTEND_FWS.includes(f)) || 'FRONTEND';
|
|
60
|
+
agentDefs.push({
|
|
61
|
+
name: `${fw.toUpperCase().replace('.', '').replace(/\s/g, '-')}-FRONTEND-DEVELOPER`,
|
|
62
|
+
desc: `Componentes ${fw}, state management, UX responsiva, todos os estados UI`,
|
|
63
|
+
});
|
|
64
|
+
}
|
|
65
|
+
if (stack.hasMobile)
|
|
66
|
+
agentDefs.push({
|
|
67
|
+
name: 'FLUTTER-UI-DEVELOPER',
|
|
68
|
+
desc: 'Screens mobile, widgets, navegação, integração API, padrão visual do app',
|
|
69
|
+
});
|
|
70
|
+
if (stack.hasDatabase)
|
|
71
|
+
agentDefs.push({
|
|
72
|
+
name: 'DATABASE-ENGINEER',
|
|
73
|
+
desc: 'Schema design, migrations reversíveis, indexação, performance de queries',
|
|
74
|
+
});
|
|
75
|
+
agentDefs.push({ name: 'SECURITY-AUDITOR', desc: 'OWASP Top 10, STRIDE threat model, compliance, vulnerabilidades' }, { name: 'QA-TEST-ENGINEER', desc: 'BDD/TDD, cobertura mínima, planos de teste, regressão' }, { name: 'TECH-DEBT-CONTROLLER', desc: 'Score tracking, anti-patterns, refatorações, metas de qualidade' });
|
|
76
|
+
const ruleDefs = [
|
|
77
|
+
{ name: '00-general', desc: '9 Regras de Ouro, Git Flow, naming conventions, ações proibidas' },
|
|
78
|
+
{ name: '01-architecture', desc: 'Separação de camadas, dependency rules, padrões de módulo' },
|
|
79
|
+
{ name: '02-security', desc: 'Sanitização, secrets management, validação, OWASP' },
|
|
80
|
+
];
|
|
81
|
+
const stackRuleName = getStackRuleFileName(ctx);
|
|
82
|
+
if (stackRuleName) {
|
|
83
|
+
const fwLabel = stack.frameworks[0] || stack.primary;
|
|
84
|
+
ruleDefs.push({ name: stackRuleName, desc: `Regras específicas ${fwLabel} — patterns, anti-patterns, checklist` });
|
|
85
|
+
}
|
|
86
|
+
const guardDefs = [
|
|
87
|
+
{ name: 'PREFLIGHT', desc: '6-phase checklist pré-ação: ambiente → leitura → negócio → camada → commit → done' },
|
|
88
|
+
{ name: 'QUALITY-GATES', desc: '3 níveis (CRITICAL/IMPORTANT/DESIRABLE), métricas, blockers, verificação em 4 estágios' },
|
|
89
|
+
{ name: 'CODE-REVIEW-CHECKLIST', desc: 'Review em 6 dimensões: funcional, qualidade, testes, segurança, performance, arquitetura' },
|
|
90
|
+
];
|
|
91
|
+
const workflowDefs = [
|
|
92
|
+
{ name: 'new-feature', desc: '10 steps com 6 approval gates, mockup-first, backend-first, integration doc' },
|
|
93
|
+
{ name: 'fix-bug', desc: '10 steps: diagnóstico → root cause → RED test → fix mínimo → regressão → docs' },
|
|
94
|
+
{ name: 'review', desc: 'Code review em 6 dimensões com checklist estruturado' },
|
|
95
|
+
];
|
|
96
|
+
// Build items
|
|
97
|
+
const suggestedAgents = agentDefs.map(({ name, desc }) => ({
|
|
98
|
+
name, status: itemStatus(name, existingAgents), description: desc,
|
|
99
|
+
}));
|
|
100
|
+
for (const existing of existingAgents) {
|
|
101
|
+
if (!agentDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
|
|
102
|
+
suggestedAgents.push({ name: existing, status: 'KEEP', reason: 'Custom agent', description: 'Agente customizado do projeto' });
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
const suggestedRules = ruleDefs.map(({ name, desc }) => ({
|
|
106
|
+
name, status: itemStatus(name, existingRules), description: desc,
|
|
107
|
+
}));
|
|
108
|
+
for (const existing of existingRules) {
|
|
109
|
+
if (!ruleDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
|
|
110
|
+
suggestedRules.push({ name: existing, status: 'KEEP', reason: 'Custom rule' });
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
const suggestedGuards = guardDefs.map(({ name, desc }) => ({
|
|
114
|
+
name, status: itemStatus(name, existingGuards), description: desc,
|
|
115
|
+
}));
|
|
116
|
+
const suggestedWorkflows = workflowDefs.map(({ name, desc }) => ({
|
|
117
|
+
name, status: itemStatus(name, existingWorkflows), description: desc,
|
|
118
|
+
}));
|
|
119
|
+
for (const existing of existingWorkflows) {
|
|
120
|
+
if (!workflowDefs.some(d => d.name.toLowerCase() === existing.toLowerCase())) {
|
|
121
|
+
suggestedWorkflows.push({ name: existing, status: 'KEEP', reason: 'Custom workflow' });
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
// Skills
|
|
125
|
+
const skillEntries = this.buildSkillEntries(stack, existingSkillNames);
|
|
126
|
+
return {
|
|
127
|
+
stack,
|
|
128
|
+
hasExistingAgents: isExisting,
|
|
129
|
+
suggestedAgents,
|
|
130
|
+
suggestedRules,
|
|
131
|
+
suggestedGuards,
|
|
132
|
+
suggestedWorkflows,
|
|
133
|
+
suggestedSkills: skillEntries,
|
|
134
|
+
audit,
|
|
135
|
+
command: `architect agents ${projectPath}`,
|
|
136
|
+
};
|
|
137
|
+
}
|
|
138
|
+
buildSkillEntries(stack, existing) {
|
|
139
|
+
const entries = [
|
|
140
|
+
{ name: 'test-driven-development', source: 'anthropic/courses/test-driven-development', description: 'TDD: Red → Green → Refactor', status: 'CREATE' },
|
|
141
|
+
{ name: 'systematic-debugging', source: 'anthropic/courses/systematic-debugging', description: 'Structured debugging methodology', status: 'CREATE' },
|
|
142
|
+
{ name: 'code-review', source: 'anthropic/courses/requesting-code-review', description: 'Code review best practices', status: 'CREATE' },
|
|
143
|
+
{ name: 'security-best-practices', source: 'anthropic/courses/security-best-practices', description: 'Security patterns and vulnerability prevention', status: 'CREATE' },
|
|
144
|
+
{ name: 'performance-optimization', source: 'anthropic/courses/performance-optimization', description: 'Performance analysis and optimization', status: 'CREATE' },
|
|
145
|
+
{ name: 'git-workflow', source: 'anthropic/courses/git-workflow', description: 'Git branching, commits, collaboration', status: 'CREATE' },
|
|
146
|
+
];
|
|
147
|
+
// Stack-specific skills
|
|
148
|
+
if (stack.languages.includes('TypeScript') || stack.languages.includes('JavaScript')) {
|
|
149
|
+
entries.push({ name: 'api-design-principles', source: 'anthropic/courses/api-design-principles', description: 'REST/GraphQL API design', status: 'CREATE' });
|
|
150
|
+
}
|
|
151
|
+
if (stack.frameworks.includes('Angular') || stack.frameworks.includes('Vue') || stack.frameworks.includes('React') || stack.frameworks.includes('Next.js')) {
|
|
152
|
+
entries.push({ name: 'frontend-design', source: 'anthropic/courses/frontend-design', description: 'Modern frontend patterns', status: 'CREATE' }, { name: 'web-accessibility', source: 'anthropic/courses/web-accessibility', description: 'WCAG accessibility standards', status: 'CREATE' });
|
|
153
|
+
}
|
|
154
|
+
if (stack.languages.includes('Dart') || stack.frameworks.includes('Flutter')) {
|
|
155
|
+
entries.push({ name: 'flutter-animations', source: 'anthropic/courses/flutter-animations', description: 'Flutter animation patterns', status: 'CREATE' });
|
|
156
|
+
}
|
|
157
|
+
if (stack.languages.includes('Python')) {
|
|
158
|
+
entries.push({ name: 'python-performance', source: 'anthropic/courses/python-performance-optimization', description: 'Python optimization and profiling', status: 'CREATE' });
|
|
159
|
+
}
|
|
160
|
+
if (stack.hasDatabase) {
|
|
161
|
+
entries.push({ name: 'database-schema-design', source: 'anthropic/courses/database-schema-design', description: 'Schema design, indexing, migrations', status: 'CREATE' });
|
|
162
|
+
}
|
|
163
|
+
// Update status based on existing
|
|
164
|
+
for (const entry of entries) {
|
|
165
|
+
if (existing.has(entry.name))
|
|
166
|
+
entry.status = 'KEEP';
|
|
167
|
+
}
|
|
168
|
+
return entries;
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
//# sourceMappingURL=suggestion-engine.js.map
|