@vyuhlabs/dxkit 1.5.1 → 1.6.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/CHANGELOG.md +264 -0
- package/README.md +265 -352
- package/THIRD_PARTY_NOTICES.md +40 -0
- package/dist/analyzers/developer/detailed.d.ts +26 -0
- package/dist/analyzers/developer/detailed.d.ts.map +1 -0
- package/dist/analyzers/developer/detailed.js +193 -0
- package/dist/analyzers/developer/detailed.js.map +1 -0
- package/dist/analyzers/developer/gather.d.ts +11 -0
- package/dist/analyzers/developer/gather.d.ts.map +1 -0
- package/dist/analyzers/developer/gather.js +167 -0
- package/dist/analyzers/developer/gather.js.map +1 -0
- package/dist/analyzers/developer/index.d.ts +8 -0
- package/dist/analyzers/developer/index.d.ts.map +1 -0
- package/dist/analyzers/developer/index.js +168 -0
- package/dist/analyzers/developer/index.js.map +1 -0
- package/dist/analyzers/developer/types.d.ts +49 -0
- package/dist/analyzers/developer/types.d.ts.map +1 -0
- package/dist/analyzers/developer/types.js +6 -0
- package/dist/analyzers/developer/types.js.map +1 -0
- package/dist/analyzers/docs/shallow.d.ts +9 -0
- package/dist/analyzers/docs/shallow.d.ts.map +1 -0
- package/dist/analyzers/docs/shallow.js +8 -0
- package/dist/analyzers/docs/shallow.js.map +1 -0
- package/dist/analyzers/dx/shallow.d.ts +9 -0
- package/dist/analyzers/dx/shallow.d.ts.map +1 -0
- package/dist/analyzers/dx/shallow.js +8 -0
- package/dist/analyzers/dx/shallow.js.map +1 -0
- package/dist/analyzers/evidence.d.ts +36 -0
- package/dist/analyzers/evidence.d.ts.map +1 -0
- package/dist/analyzers/evidence.js +3 -0
- package/dist/analyzers/evidence.js.map +1 -0
- package/dist/analyzers/health/actions.d.ts +10 -0
- package/dist/analyzers/health/actions.d.ts.map +1 -0
- package/dist/analyzers/health/actions.js +284 -0
- package/dist/analyzers/health/actions.js.map +1 -0
- package/dist/analyzers/health/detailed.d.ts +26 -0
- package/dist/analyzers/health/detailed.d.ts.map +1 -0
- package/dist/analyzers/health/detailed.js +147 -0
- package/dist/analyzers/health/detailed.js.map +1 -0
- package/dist/analyzers/health.d.ts +22 -0
- package/dist/analyzers/health.d.ts.map +1 -0
- package/dist/analyzers/health.js +270 -0
- package/dist/analyzers/health.js.map +1 -0
- package/dist/analyzers/index.d.ts +3 -0
- package/dist/analyzers/index.d.ts.map +1 -0
- package/dist/analyzers/index.js +6 -0
- package/dist/analyzers/index.js.map +1 -0
- package/dist/analyzers/maintainability/shallow.d.ts +9 -0
- package/dist/analyzers/maintainability/shallow.d.ts.map +1 -0
- package/dist/analyzers/maintainability/shallow.js +8 -0
- package/dist/analyzers/maintainability/shallow.js.map +1 -0
- package/dist/analyzers/quality/actions.d.ts +5 -0
- package/dist/analyzers/quality/actions.d.ts.map +1 -0
- package/dist/analyzers/quality/actions.js +158 -0
- package/dist/analyzers/quality/actions.js.map +1 -0
- package/dist/analyzers/quality/detailed.d.ts +17 -0
- package/dist/analyzers/quality/detailed.d.ts.map +1 -0
- package/dist/analyzers/quality/detailed.js +122 -0
- package/dist/analyzers/quality/detailed.js.map +1 -0
- package/dist/analyzers/quality/gather.d.ts +38 -0
- package/dist/analyzers/quality/gather.d.ts.map +1 -0
- package/dist/analyzers/quality/gather.js +279 -0
- package/dist/analyzers/quality/gather.js.map +1 -0
- package/dist/analyzers/quality/index.d.ts +12 -0
- package/dist/analyzers/quality/index.d.ts.map +1 -0
- package/dist/analyzers/quality/index.js +281 -0
- package/dist/analyzers/quality/index.js.map +1 -0
- package/dist/analyzers/quality/shallow.d.ts +9 -0
- package/dist/analyzers/quality/shallow.d.ts.map +1 -0
- package/dist/analyzers/quality/shallow.js +8 -0
- package/dist/analyzers/quality/shallow.js.map +1 -0
- package/dist/analyzers/quality/types.d.ts +66 -0
- package/dist/analyzers/quality/types.d.ts.map +1 -0
- package/dist/analyzers/quality/types.js +3 -0
- package/dist/analyzers/quality/types.js.map +1 -0
- package/dist/analyzers/remediation.d.ts +42 -0
- package/dist/analyzers/remediation.d.ts.map +1 -0
- package/dist/analyzers/remediation.js +28 -0
- package/dist/analyzers/remediation.js.map +1 -0
- package/dist/analyzers/scoring.d.ts +32 -0
- package/dist/analyzers/scoring.d.ts.map +1 -0
- package/dist/analyzers/scoring.js +410 -0
- package/dist/analyzers/scoring.js.map +1 -0
- package/dist/analyzers/security/actions.d.ts +7 -0
- package/dist/analyzers/security/actions.d.ts.map +1 -0
- package/dist/analyzers/security/actions.js +104 -0
- package/dist/analyzers/security/actions.js.map +1 -0
- package/dist/analyzers/security/detailed.d.ts +14 -0
- package/dist/analyzers/security/detailed.d.ts.map +1 -0
- package/dist/analyzers/security/detailed.js +124 -0
- package/dist/analyzers/security/detailed.js.map +1 -0
- package/dist/analyzers/security/gather.d.ts +12 -0
- package/dist/analyzers/security/gather.d.ts.map +1 -0
- package/dist/analyzers/security/gather.js +195 -0
- package/dist/analyzers/security/gather.js.map +1 -0
- package/dist/analyzers/security/index.d.ts +8 -0
- package/dist/analyzers/security/index.d.ts.map +1 -0
- package/dist/analyzers/security/index.js +173 -0
- package/dist/analyzers/security/index.js.map +1 -0
- package/dist/analyzers/security/scoring.d.ts +29 -0
- package/dist/analyzers/security/scoring.d.ts.map +1 -0
- package/dist/analyzers/security/scoring.js +40 -0
- package/dist/analyzers/security/scoring.js.map +1 -0
- package/dist/analyzers/security/shallow.d.ts +10 -0
- package/dist/analyzers/security/shallow.d.ts.map +1 -0
- package/dist/analyzers/security/shallow.js +8 -0
- package/dist/analyzers/security/shallow.js.map +1 -0
- package/dist/analyzers/security/types.d.ts +43 -0
- package/dist/analyzers/security/types.d.ts.map +1 -0
- package/dist/analyzers/security/types.js +6 -0
- package/dist/analyzers/security/types.js.map +1 -0
- package/dist/analyzers/tests/actions.d.ts +6 -0
- package/dist/analyzers/tests/actions.d.ts.map +1 -0
- package/dist/analyzers/tests/actions.js +80 -0
- package/dist/analyzers/tests/actions.js.map +1 -0
- package/dist/analyzers/tests/detailed.d.ts +14 -0
- package/dist/analyzers/tests/detailed.d.ts.map +1 -0
- package/dist/analyzers/tests/detailed.js +121 -0
- package/dist/analyzers/tests/detailed.js.map +1 -0
- package/dist/analyzers/tests/gather.d.ts +5 -0
- package/dist/analyzers/tests/gather.d.ts.map +1 -0
- package/dist/analyzers/tests/gather.js +270 -0
- package/dist/analyzers/tests/gather.js.map +1 -0
- package/dist/analyzers/tests/import-graph.d.ts +48 -0
- package/dist/analyzers/tests/import-graph.d.ts.map +1 -0
- package/dist/analyzers/tests/import-graph.js +231 -0
- package/dist/analyzers/tests/import-graph.js.map +1 -0
- package/dist/analyzers/tests/index.d.ts +8 -0
- package/dist/analyzers/tests/index.d.ts.map +1 -0
- package/dist/analyzers/tests/index.js +247 -0
- package/dist/analyzers/tests/index.js.map +1 -0
- package/dist/analyzers/tests/scoring.d.ts +27 -0
- package/dist/analyzers/tests/scoring.d.ts.map +1 -0
- package/dist/analyzers/tests/scoring.js +38 -0
- package/dist/analyzers/tests/scoring.js.map +1 -0
- package/dist/analyzers/tests/shallow.d.ts +9 -0
- package/dist/analyzers/tests/shallow.d.ts.map +1 -0
- package/dist/analyzers/tests/shallow.js +8 -0
- package/dist/analyzers/tests/shallow.js.map +1 -0
- package/dist/analyzers/tests/types.d.ts +49 -0
- package/dist/analyzers/tests/types.d.ts.map +1 -0
- package/dist/analyzers/tests/types.js +6 -0
- package/dist/analyzers/tests/types.js.map +1 -0
- package/dist/analyzers/tools/cloc.d.ts +8 -0
- package/dist/analyzers/tools/cloc.d.ts.map +1 -0
- package/dist/analyzers/tools/cloc.js +49 -0
- package/dist/analyzers/tools/cloc.js.map +1 -0
- package/dist/analyzers/tools/coverage.d.ts +59 -0
- package/dist/analyzers/tools/coverage.d.ts.map +1 -0
- package/dist/analyzers/tools/coverage.js +280 -0
- package/dist/analyzers/tools/coverage.js.map +1 -0
- package/dist/analyzers/tools/cvss-v4-lookup.d.ts +10 -0
- package/dist/analyzers/tools/cvss-v4-lookup.d.ts.map +1 -0
- package/dist/analyzers/tools/cvss-v4-lookup.js +284 -0
- package/dist/analyzers/tools/cvss-v4-lookup.js.map +1 -0
- package/dist/analyzers/tools/cvss-v4.d.ts +24 -0
- package/dist/analyzers/tools/cvss-v4.d.ts.map +1 -0
- package/dist/analyzers/tools/cvss-v4.js +362 -0
- package/dist/analyzers/tools/cvss-v4.js.map +1 -0
- package/dist/analyzers/tools/default-exclusions.gitignore +56 -0
- package/dist/analyzers/tools/exclusions.d.ts +70 -0
- package/dist/analyzers/tools/exclusions.d.ts.map +1 -0
- package/dist/analyzers/tools/exclusions.js +250 -0
- package/dist/analyzers/tools/exclusions.js.map +1 -0
- package/dist/analyzers/tools/generic.d.ts +4 -0
- package/dist/analyzers/tools/generic.d.ts.map +1 -0
- package/dist/analyzers/tools/generic.js +198 -0
- package/dist/analyzers/tools/generic.js.map +1 -0
- package/dist/analyzers/tools/gitleaks.d.ts +8 -0
- package/dist/analyzers/tools/gitleaks.d.ts.map +1 -0
- package/dist/analyzers/tools/gitleaks.js +58 -0
- package/dist/analyzers/tools/gitleaks.js.map +1 -0
- package/dist/analyzers/tools/graphify.d.ts +4 -0
- package/dist/analyzers/tools/graphify.d.ts.map +1 -0
- package/dist/analyzers/tools/graphify.js +222 -0
- package/dist/analyzers/tools/graphify.js.map +1 -0
- package/dist/analyzers/tools/osv.d.ts +51 -0
- package/dist/analyzers/tools/osv.d.ts.map +1 -0
- package/dist/analyzers/tools/osv.js +188 -0
- package/dist/analyzers/tools/osv.js.map +1 -0
- package/dist/analyzers/tools/parallel.d.ts +8 -0
- package/dist/analyzers/tools/parallel.d.ts.map +1 -0
- package/dist/analyzers/tools/parallel.js +195 -0
- package/dist/analyzers/tools/parallel.js.map +1 -0
- package/dist/analyzers/tools/runner.d.ts +13 -0
- package/dist/analyzers/tools/runner.d.ts.map +1 -0
- package/dist/analyzers/tools/runner.js +109 -0
- package/dist/analyzers/tools/runner.js.map +1 -0
- package/dist/analyzers/tools/suppressions.d.ts +55 -0
- package/dist/analyzers/tools/suppressions.d.ts.map +1 -0
- package/dist/analyzers/tools/suppressions.js +203 -0
- package/dist/analyzers/tools/suppressions.js.map +1 -0
- package/dist/analyzers/tools/timing.d.ts +9 -0
- package/dist/analyzers/tools/timing.d.ts.map +1 -0
- package/dist/analyzers/tools/timing.js +29 -0
- package/dist/analyzers/tools/timing.js.map +1 -0
- package/dist/analyzers/tools/tool-registry.d.ts +86 -0
- package/dist/analyzers/tools/tool-registry.d.ts.map +1 -0
- package/dist/analyzers/tools/tool-registry.js +705 -0
- package/dist/analyzers/tools/tool-registry.js.map +1 -0
- package/dist/analyzers/types.d.ts +125 -0
- package/dist/analyzers/types.d.ts.map +1 -0
- package/dist/analyzers/types.js +11 -0
- package/dist/analyzers/types.js.map +1 -0
- package/dist/cli.d.ts.map +1 -1
- package/dist/cli.js +405 -0
- package/dist/cli.js.map +1 -1
- package/dist/detect.d.ts.map +1 -1
- package/dist/detect.js +24 -15
- package/dist/detect.js.map +1 -1
- package/dist/languages/csharp.d.ts +5 -0
- package/dist/languages/csharp.d.ts.map +1 -0
- package/dist/languages/csharp.js +265 -0
- package/dist/languages/csharp.js.map +1 -0
- package/dist/languages/go.d.ts +11 -0
- package/dist/languages/go.d.ts.map +1 -0
- package/dist/languages/go.js +321 -0
- package/dist/languages/go.js.map +1 -0
- package/dist/languages/index.d.ts +6 -0
- package/dist/languages/index.d.ts.map +1 -0
- package/dist/languages/index.js +18 -0
- package/dist/languages/index.js.map +1 -0
- package/dist/languages/python.d.ts +3 -0
- package/dist/languages/python.d.ts.map +1 -0
- package/dist/languages/python.js +284 -0
- package/dist/languages/python.js.map +1 -0
- package/dist/languages/rust.d.ts +17 -0
- package/dist/languages/rust.d.ts.map +1 -0
- package/dist/languages/rust.js +333 -0
- package/dist/languages/rust.js.map +1 -0
- package/dist/languages/types.d.ts +38 -0
- package/dist/languages/types.d.ts.map +1 -0
- package/dist/languages/types.js +3 -0
- package/dist/languages/types.js.map +1 -0
- package/dist/languages/typescript.d.ts +15 -0
- package/dist/languages/typescript.d.ts.map +1 -0
- package/dist/languages/typescript.js +353 -0
- package/dist/languages/typescript.js.map +1 -0
- package/dist/logger.d.ts +1 -0
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +25 -12
- package/dist/logger.js.map +1 -1
- package/dist/project-yaml.d.ts.map +1 -1
- package/dist/project-yaml.js +1 -0
- package/dist/project-yaml.js.map +1 -1
- package/dist/tools-cli.d.ts +2 -0
- package/dist/tools-cli.d.ts.map +1 -0
- package/dist/tools-cli.js +231 -0
- package/dist/tools-cli.js.map +1 -0
- package/dist/types.d.ts +10 -0
- package/dist/types.d.ts.map +1 -1
- package/package.json +6 -2
- package/templates/.claude/commands/dev-report.md +34 -4
- package/templates/.claude/commands/health.md +45 -2
- package/templates/.claude/commands/quality.md.template +38 -15
- package/templates/.claude/commands/test-gaps.md +36 -2
- package/templates/.claude/commands/vulnerabilities.md +36 -2
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tool-registry.js","sourceRoot":"","sources":["../../../src/analyzers/tools/tool-registry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Core types for deterministic analyzers.
|
|
3
|
+
*
|
|
4
|
+
* Design principles:
|
|
5
|
+
* - Metrics come from tools, not LLM
|
|
6
|
+
* - Scores come from formulas, not judgment
|
|
7
|
+
* - Tools are layered: always-available (grep/find/git) -> project tools -> optional tools
|
|
8
|
+
*/
|
|
9
|
+
/** Raw metrics gathered by tool runners. All values are exact counts -- no estimates. */
|
|
10
|
+
export interface HealthMetrics {
|
|
11
|
+
sourceFiles: number;
|
|
12
|
+
testFiles: number;
|
|
13
|
+
totalLines: number;
|
|
14
|
+
testsPass: boolean | null;
|
|
15
|
+
testsPassing: number;
|
|
16
|
+
testsFailing: number;
|
|
17
|
+
testFramework: string | null;
|
|
18
|
+
coveragePercent: number | null;
|
|
19
|
+
coverageConfigExists: boolean;
|
|
20
|
+
lintErrors: number;
|
|
21
|
+
lintWarnings: number;
|
|
22
|
+
lintTool: string | null;
|
|
23
|
+
typeErrors: number | null;
|
|
24
|
+
filesOver500Lines: number;
|
|
25
|
+
largestFileLines: number;
|
|
26
|
+
largestFilePath: string;
|
|
27
|
+
consoleLogCount: number;
|
|
28
|
+
anyTypeCount: number;
|
|
29
|
+
readmeLines: number;
|
|
30
|
+
readmeExists: boolean;
|
|
31
|
+
docCommentFiles: number;
|
|
32
|
+
apiDocsExist: boolean;
|
|
33
|
+
architectureDocsExist: boolean;
|
|
34
|
+
contributingExists: boolean;
|
|
35
|
+
changelogExists: boolean;
|
|
36
|
+
secretFindings: number;
|
|
37
|
+
secretDetails: Array<{
|
|
38
|
+
file: string;
|
|
39
|
+
line: number;
|
|
40
|
+
rule: string;
|
|
41
|
+
severity: string;
|
|
42
|
+
}>;
|
|
43
|
+
/** Count of gitleaks findings filtered by `.dxkit-suppressions.json`. */
|
|
44
|
+
secretSuppressed?: number;
|
|
45
|
+
evalCount: number;
|
|
46
|
+
privateKeyFiles: number;
|
|
47
|
+
envFilesInGit: number;
|
|
48
|
+
tlsDisabledCount: number;
|
|
49
|
+
depVulnCritical: number;
|
|
50
|
+
depVulnHigh: number;
|
|
51
|
+
depVulnMedium: number;
|
|
52
|
+
depVulnLow: number;
|
|
53
|
+
depAuditTool: string | null;
|
|
54
|
+
controllers: number;
|
|
55
|
+
models: number;
|
|
56
|
+
directories: number;
|
|
57
|
+
languages: Array<{
|
|
58
|
+
name: string;
|
|
59
|
+
files: number;
|
|
60
|
+
lines: number;
|
|
61
|
+
percentage: number;
|
|
62
|
+
}>;
|
|
63
|
+
nodeEngineVersion: string | null;
|
|
64
|
+
ciConfigCount: number;
|
|
65
|
+
dockerConfigCount: number;
|
|
66
|
+
precommitConfigCount: number;
|
|
67
|
+
makefileExists: boolean;
|
|
68
|
+
envExampleExists: boolean;
|
|
69
|
+
npmScriptsCount: number;
|
|
70
|
+
toolsUsed: string[];
|
|
71
|
+
toolsUnavailable: string[];
|
|
72
|
+
clocLanguages: Array<{
|
|
73
|
+
language: string;
|
|
74
|
+
files: number;
|
|
75
|
+
code: number;
|
|
76
|
+
comment: number;
|
|
77
|
+
blank: number;
|
|
78
|
+
}> | null;
|
|
79
|
+
functionCount: number | null;
|
|
80
|
+
classCount: number | null;
|
|
81
|
+
maxFunctionsInFile: number | null;
|
|
82
|
+
maxFunctionsFilePath: string | null;
|
|
83
|
+
godNodeCount: number | null;
|
|
84
|
+
communityCount: number | null;
|
|
85
|
+
avgCohesion: number | null;
|
|
86
|
+
orphanModuleCount: number | null;
|
|
87
|
+
deadImportCount: number | null;
|
|
88
|
+
commentedCodeRatio: number | null;
|
|
89
|
+
}
|
|
90
|
+
/** Score for a single dimension (0-100). */
|
|
91
|
+
export interface DimensionScore {
|
|
92
|
+
score: number;
|
|
93
|
+
maxScore: number;
|
|
94
|
+
status: 'critical' | 'poor' | 'fair' | 'good' | 'excellent';
|
|
95
|
+
metrics: Record<string, number | string | boolean | null>;
|
|
96
|
+
details: string;
|
|
97
|
+
}
|
|
98
|
+
/** Complete health report. */
|
|
99
|
+
export interface HealthReport {
|
|
100
|
+
repo: string;
|
|
101
|
+
analyzedAt: string;
|
|
102
|
+
commitSha: string;
|
|
103
|
+
branch: string;
|
|
104
|
+
summary: {
|
|
105
|
+
overallScore: number;
|
|
106
|
+
grade: 'A' | 'B' | 'C' | 'D' | 'F';
|
|
107
|
+
};
|
|
108
|
+
dimensions: {
|
|
109
|
+
testing: DimensionScore;
|
|
110
|
+
quality: DimensionScore;
|
|
111
|
+
documentation: DimensionScore;
|
|
112
|
+
security: DimensionScore;
|
|
113
|
+
maintainability: DimensionScore;
|
|
114
|
+
developerExperience: DimensionScore;
|
|
115
|
+
};
|
|
116
|
+
languages: Array<{
|
|
117
|
+
name: string;
|
|
118
|
+
files: number;
|
|
119
|
+
lines: number;
|
|
120
|
+
percentage: number;
|
|
121
|
+
}>;
|
|
122
|
+
toolsUsed: string[];
|
|
123
|
+
toolsUnavailable: string[];
|
|
124
|
+
}
|
|
125
|
+
//# sourceMappingURL=types.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/analyzers/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Core types for deterministic analyzers.
|
|
4
|
+
*
|
|
5
|
+
* Design principles:
|
|
6
|
+
* - Metrics come from tools, not LLM
|
|
7
|
+
* - Scores come from formulas, not judgment
|
|
8
|
+
* - Tools are layered: always-available (grep/find/git) -> project tools -> optional tools
|
|
9
|
+
*/
|
|
10
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
11
|
+
//# sourceMappingURL=types.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/analyzers/types.ts"],"names":[],"mappings":";AAAA;;;;;;;GAOG"}
|
package/dist/cli.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"AA2DA,wBAAsB,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAmfvD"}
|
package/dist/cli.js
CHANGED
|
@@ -53,6 +53,13 @@ function printUsage() {
|
|
|
53
53
|
vyuh-dxkit init [options] Initialize Claude Code DX in this repo
|
|
54
54
|
vyuh-dxkit update [options] Re-generate (preserves evolved files)
|
|
55
55
|
vyuh-dxkit doctor Verify setup
|
|
56
|
+
vyuh-dxkit health [path] Run deterministic health analysis
|
|
57
|
+
vyuh-dxkit vulnerabilities [path] Run deep security scan
|
|
58
|
+
vyuh-dxkit test-gaps [path] Analyze test coverage gaps
|
|
59
|
+
vyuh-dxkit quality [path] Code quality + slop detection
|
|
60
|
+
vyuh-dxkit dev-report [path] Developer activity analysis
|
|
61
|
+
vyuh-dxkit tools [path] Show required analysis tools status
|
|
62
|
+
vyuh-dxkit tools install Interactively install missing tools
|
|
56
63
|
|
|
57
64
|
${logger.bold('Init options:')}
|
|
58
65
|
--dx-only Just .claude/ + CLAUDE.md (default)
|
|
@@ -68,6 +75,13 @@ function printUsage() {
|
|
|
68
75
|
--force Overwrite modified files (except evolved)
|
|
69
76
|
--rescan Re-run codebase analysis
|
|
70
77
|
|
|
78
|
+
${logger.bold('Analyzer options (health, vulnerabilities, test-gaps, quality, dev-report):')}
|
|
79
|
+
--json Print report as JSON to stdout
|
|
80
|
+
--verbose Print per-tool timing to stderr
|
|
81
|
+
--no-save Skip writing the markdown report file
|
|
82
|
+
--detailed Also write <name>-detailed.md + .json with evidence + ranked actions
|
|
83
|
+
--since Dev-report: start date (YYYY-MM-DD)
|
|
84
|
+
|
|
71
85
|
${logger.bold('Examples:')}
|
|
72
86
|
npx vyuh-dxkit init # Interactive
|
|
73
87
|
npx vyuh-dxkit init --detect # Auto-detect, just DX
|
|
@@ -91,6 +105,11 @@ async function run(argv) {
|
|
|
91
105
|
name: { type: 'string' },
|
|
92
106
|
'no-scan': { type: 'boolean', default: false },
|
|
93
107
|
rescan: { type: 'boolean', default: false },
|
|
108
|
+
json: { type: 'boolean', default: false },
|
|
109
|
+
since: { type: 'string' },
|
|
110
|
+
verbose: { type: 'boolean', default: false },
|
|
111
|
+
'no-save': { type: 'boolean', default: false },
|
|
112
|
+
detailed: { type: 'boolean', default: false },
|
|
94
113
|
},
|
|
95
114
|
allowPositionals: true,
|
|
96
115
|
strict: false,
|
|
@@ -103,6 +122,8 @@ async function run(argv) {
|
|
|
103
122
|
console.log(constants_1.VERSION);
|
|
104
123
|
return;
|
|
105
124
|
}
|
|
125
|
+
// Route logger output to stderr in --json mode so stdout stays pure JSON.
|
|
126
|
+
logger.setJsonMode(!!values.json);
|
|
106
127
|
const command = positionals[0] || 'init';
|
|
107
128
|
const cwd = process.cwd();
|
|
108
129
|
switch (command) {
|
|
@@ -198,12 +219,396 @@ async function run(argv) {
|
|
|
198
219
|
await (0, doctor_1.runDoctor)(cwd);
|
|
199
220
|
break;
|
|
200
221
|
}
|
|
222
|
+
case 'health': {
|
|
223
|
+
const targetPath = positionals[1] || cwd;
|
|
224
|
+
const { analyzeHealth, analyzeHealthWithMetrics } = await Promise.resolve().then(() => __importStar(require('./analyzers/health')));
|
|
225
|
+
logger.header('vyuh-dxkit health');
|
|
226
|
+
logger.info(`Analyzing ${targetPath}...`);
|
|
227
|
+
const startTime = Date.now();
|
|
228
|
+
// Detailed mode needs HealthMetrics for remediation planning; pull both.
|
|
229
|
+
const healthResult = values.detailed
|
|
230
|
+
? await analyzeHealthWithMetrics(targetPath, { verbose: !!values.verbose })
|
|
231
|
+
: {
|
|
232
|
+
report: await analyzeHealth(targetPath, { verbose: !!values.verbose }),
|
|
233
|
+
metrics: null,
|
|
234
|
+
};
|
|
235
|
+
const report = healthResult.report;
|
|
236
|
+
const healthMetrics = healthResult.metrics;
|
|
237
|
+
const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
|
|
238
|
+
if (values.json) {
|
|
239
|
+
console.log(JSON.stringify(report, null, 2));
|
|
240
|
+
}
|
|
241
|
+
else {
|
|
242
|
+
// Console output
|
|
243
|
+
console.log('');
|
|
244
|
+
console.log(` ${logger.bold('Overall:')} ${report.summary.overallScore}/100 (Grade: ${report.summary.grade})`);
|
|
245
|
+
console.log('');
|
|
246
|
+
const dims = report.dimensions;
|
|
247
|
+
const order = [
|
|
248
|
+
['Testing', dims.testing],
|
|
249
|
+
['Code Quality', dims.quality],
|
|
250
|
+
['Documentation', dims.documentation],
|
|
251
|
+
['Security', dims.security],
|
|
252
|
+
['Maintainability', dims.maintainability],
|
|
253
|
+
['Developer Experience', dims.developerExperience],
|
|
254
|
+
];
|
|
255
|
+
for (const [name, dim] of order) {
|
|
256
|
+
const bar = '█'.repeat(Math.round(dim.score / 5)) + '░'.repeat(20 - Math.round(dim.score / 5));
|
|
257
|
+
console.log(` ${name.padEnd(22)} ${bar} ${dim.score.toString().padStart(3)}/100 ${dim.status}`);
|
|
258
|
+
}
|
|
259
|
+
console.log('');
|
|
260
|
+
logger.dim('Tools: ' + report.toolsUsed.join(', '));
|
|
261
|
+
if (report.toolsUnavailable.length > 0) {
|
|
262
|
+
logger.dim('Unavailable: ' + report.toolsUnavailable.join(', '));
|
|
263
|
+
}
|
|
264
|
+
logger.dim(`Completed in ${elapsed}s`);
|
|
265
|
+
// Save markdown report (unless --no-save)
|
|
266
|
+
if (!values['no-save']) {
|
|
267
|
+
const reportDir = path.join(targetPath, '.ai', 'reports');
|
|
268
|
+
const date = new Date().toISOString().slice(0, 10);
|
|
269
|
+
const reportPath = path.join(reportDir, `health-audit-${date}.md`);
|
|
270
|
+
fs.mkdirSync(reportDir, { recursive: true });
|
|
271
|
+
fs.writeFileSync(reportPath, formatMarkdownReport(report, elapsed));
|
|
272
|
+
console.log('');
|
|
273
|
+
logger.success(`Report saved to ${path.relative(targetPath, reportPath)}`);
|
|
274
|
+
if (values.detailed && healthMetrics) {
|
|
275
|
+
const { buildHealthDetailed, formatHealthDetailedMarkdown } = await Promise.resolve().then(() => __importStar(require('./analyzers/health/detailed')));
|
|
276
|
+
const detailed = buildHealthDetailed(report, healthMetrics);
|
|
277
|
+
const detailedMdPath = path.join(reportDir, `health-audit-${date}-detailed.md`);
|
|
278
|
+
const detailedJsonPath = path.join(reportDir, `health-audit-${date}-detailed.json`);
|
|
279
|
+
fs.writeFileSync(detailedMdPath, formatHealthDetailedMarkdown(detailed, elapsed));
|
|
280
|
+
fs.writeFileSync(detailedJsonPath, JSON.stringify(detailed, null, 2));
|
|
281
|
+
logger.success(`Detailed report saved to ${path.relative(targetPath, detailedMdPath)}`);
|
|
282
|
+
logger.success(`Detailed JSON saved to ${path.relative(targetPath, detailedJsonPath)}`);
|
|
283
|
+
}
|
|
284
|
+
}
|
|
285
|
+
// Hint about missing tools (exclude project-side config errors)
|
|
286
|
+
const PROJECT_ISSUES = ['config error', 'legacy .eslintrc', 'no eslint config'];
|
|
287
|
+
const trulyMissing = report.toolsUnavailable.filter((t) => !PROJECT_ISSUES.some((p) => t.includes(p)));
|
|
288
|
+
if (trulyMissing.length > 0) {
|
|
289
|
+
console.log('');
|
|
290
|
+
logger.dim('💡 Run `vyuh-dxkit tools install` to install missing tools for more accurate results.');
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
break;
|
|
294
|
+
}
|
|
295
|
+
case 'tools': {
|
|
296
|
+
const subCommand = positionals[1];
|
|
297
|
+
const targetPath = positionals[2] || cwd;
|
|
298
|
+
const { runToolsCommand } = await Promise.resolve().then(() => __importStar(require('./tools-cli')));
|
|
299
|
+
await runToolsCommand(targetPath, subCommand, !!values.yes);
|
|
300
|
+
break;
|
|
301
|
+
}
|
|
302
|
+
case 'vulnerabilities':
|
|
303
|
+
case 'vuln': {
|
|
304
|
+
const targetPath = positionals[1] || cwd;
|
|
305
|
+
const { analyzeSecurity, formatSecurityReport } = await Promise.resolve().then(() => __importStar(require('./analyzers/security')));
|
|
306
|
+
logger.header('vyuh-dxkit vulnerabilities');
|
|
307
|
+
logger.info(`Scanning ${targetPath}...`);
|
|
308
|
+
const startTime = Date.now();
|
|
309
|
+
const report = analyzeSecurity(targetPath, { verbose: !!values.verbose });
|
|
310
|
+
const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
|
|
311
|
+
if (values.json) {
|
|
312
|
+
console.log(JSON.stringify(report, null, 2));
|
|
313
|
+
}
|
|
314
|
+
else {
|
|
315
|
+
const s = report.summary.findings;
|
|
316
|
+
const d = report.summary.dependencies;
|
|
317
|
+
console.log('');
|
|
318
|
+
console.log(` ${logger.bold('Code findings:')}`);
|
|
319
|
+
console.log(` CRITICAL: ${s.critical} HIGH: ${s.high} MEDIUM: ${s.medium} LOW: ${s.low} Total: ${s.total}`);
|
|
320
|
+
if (d.tool) {
|
|
321
|
+
console.log(` ${logger.bold('Dependency vulns:')}`);
|
|
322
|
+
console.log(` ${d.critical}C ${d.high}H ${d.medium}M ${d.low}L (${d.total} total)`);
|
|
323
|
+
}
|
|
324
|
+
console.log('');
|
|
325
|
+
logger.dim('Tools: ' + report.toolsUsed.join(', '));
|
|
326
|
+
if (report.toolsUnavailable.length > 0) {
|
|
327
|
+
logger.dim('Unavailable: ' + report.toolsUnavailable.join(', '));
|
|
328
|
+
}
|
|
329
|
+
logger.dim(`Completed in ${elapsed}s`);
|
|
330
|
+
if (!values['no-save']) {
|
|
331
|
+
const reportDir = path.join(targetPath, '.ai', 'reports');
|
|
332
|
+
const date = new Date().toISOString().slice(0, 10);
|
|
333
|
+
const reportPath = path.join(reportDir, `vulnerability-scan-${date}.md`);
|
|
334
|
+
fs.mkdirSync(reportDir, { recursive: true });
|
|
335
|
+
fs.writeFileSync(reportPath, formatSecurityReport(report, elapsed));
|
|
336
|
+
console.log('');
|
|
337
|
+
logger.success(`Report saved to ${path.relative(targetPath, reportPath)}`);
|
|
338
|
+
if (values.detailed) {
|
|
339
|
+
const { buildSecurityDetailed, formatSecurityDetailedMarkdown } = await Promise.resolve().then(() => __importStar(require('./analyzers/security/detailed')));
|
|
340
|
+
const detailed = buildSecurityDetailed(report);
|
|
341
|
+
const detailedMdPath = path.join(reportDir, `vulnerability-scan-${date}-detailed.md`);
|
|
342
|
+
const detailedJsonPath = path.join(reportDir, `vulnerability-scan-${date}-detailed.json`);
|
|
343
|
+
fs.writeFileSync(detailedMdPath, formatSecurityDetailedMarkdown(detailed, elapsed));
|
|
344
|
+
fs.writeFileSync(detailedJsonPath, JSON.stringify(detailed, null, 2));
|
|
345
|
+
logger.success(`Detailed report saved to ${path.relative(targetPath, detailedMdPath)}`);
|
|
346
|
+
logger.success(`Detailed JSON saved to ${path.relative(targetPath, detailedJsonPath)}`);
|
|
347
|
+
}
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
break;
|
|
351
|
+
}
|
|
352
|
+
case 'test-gaps': {
|
|
353
|
+
const targetPath = positionals[1] || cwd;
|
|
354
|
+
const { analyzeTestGaps, formatTestGapsReport } = await Promise.resolve().then(() => __importStar(require('./analyzers/tests')));
|
|
355
|
+
logger.header('vyuh-dxkit test-gaps');
|
|
356
|
+
logger.info(`Analyzing ${targetPath}...`);
|
|
357
|
+
const startTime = Date.now();
|
|
358
|
+
const report = analyzeTestGaps(targetPath, { verbose: !!values.verbose });
|
|
359
|
+
const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
|
|
360
|
+
if (values.json) {
|
|
361
|
+
console.log(JSON.stringify(report, null, 2));
|
|
362
|
+
}
|
|
363
|
+
else {
|
|
364
|
+
const s = report.summary;
|
|
365
|
+
console.log('');
|
|
366
|
+
console.log(` ${logger.bold('Effective coverage:')} ${s.effectiveCoverage}%`);
|
|
367
|
+
console.log(` Test files: ${s.testFiles} (${s.activeTestFiles} active, ${s.commentedOutFiles} commented-out)`);
|
|
368
|
+
console.log(` Source files: ${s.sourceFiles}`);
|
|
369
|
+
console.log('');
|
|
370
|
+
console.log(` ${logger.bold('Untested by risk:')}`);
|
|
371
|
+
console.log(` CRITICAL: ${s.untestedCritical} HIGH: ${s.untestedHigh} MEDIUM: ${s.untestedMedium} LOW: ${s.untestedLow}`);
|
|
372
|
+
console.log('');
|
|
373
|
+
logger.dim('Tools: ' + report.toolsUsed.join(', '));
|
|
374
|
+
logger.dim(`Completed in ${elapsed}s`);
|
|
375
|
+
if (!values['no-save']) {
|
|
376
|
+
const reportDir = path.join(targetPath, '.ai', 'reports');
|
|
377
|
+
const date = new Date().toISOString().slice(0, 10);
|
|
378
|
+
const reportPath = path.join(reportDir, `test-gaps-${date}.md`);
|
|
379
|
+
fs.mkdirSync(reportDir, { recursive: true });
|
|
380
|
+
fs.writeFileSync(reportPath, formatTestGapsReport(report, elapsed));
|
|
381
|
+
console.log('');
|
|
382
|
+
logger.success(`Report saved to ${path.relative(targetPath, reportPath)}`);
|
|
383
|
+
if (values.detailed) {
|
|
384
|
+
const { buildTestGapsDetailed, formatTestGapsDetailedMarkdown } = await Promise.resolve().then(() => __importStar(require('./analyzers/tests/detailed')));
|
|
385
|
+
const detailed = buildTestGapsDetailed(report);
|
|
386
|
+
const detailedMdPath = path.join(reportDir, `test-gaps-${date}-detailed.md`);
|
|
387
|
+
const detailedJsonPath = path.join(reportDir, `test-gaps-${date}-detailed.json`);
|
|
388
|
+
fs.writeFileSync(detailedMdPath, formatTestGapsDetailedMarkdown(detailed, elapsed));
|
|
389
|
+
fs.writeFileSync(detailedJsonPath, JSON.stringify(detailed, null, 2));
|
|
390
|
+
logger.success(`Detailed report saved to ${path.relative(targetPath, detailedMdPath)}`);
|
|
391
|
+
logger.success(`Detailed JSON saved to ${path.relative(targetPath, detailedJsonPath)}`);
|
|
392
|
+
}
|
|
393
|
+
}
|
|
394
|
+
}
|
|
395
|
+
break;
|
|
396
|
+
}
|
|
397
|
+
case 'quality': {
|
|
398
|
+
const targetPath = positionals[1] || cwd;
|
|
399
|
+
const { analyzeQuality, formatQualityReport } = await Promise.resolve().then(() => __importStar(require('./analyzers/quality')));
|
|
400
|
+
logger.header('vyuh-dxkit quality');
|
|
401
|
+
logger.info(`Analyzing ${targetPath}...`);
|
|
402
|
+
const startTime = Date.now();
|
|
403
|
+
const report = await analyzeQuality(targetPath, {
|
|
404
|
+
verbose: !!values.verbose,
|
|
405
|
+
detailed: !!values.detailed,
|
|
406
|
+
});
|
|
407
|
+
const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
|
|
408
|
+
if (values.json) {
|
|
409
|
+
console.log(JSON.stringify(report, null, 2));
|
|
410
|
+
}
|
|
411
|
+
else {
|
|
412
|
+
const m = report.metrics;
|
|
413
|
+
const slopLabel = report.slopScore >= 80
|
|
414
|
+
? 'clean'
|
|
415
|
+
: report.slopScore >= 60
|
|
416
|
+
? 'fair'
|
|
417
|
+
: report.slopScore >= 40
|
|
418
|
+
? 'messy'
|
|
419
|
+
: 'sloppy';
|
|
420
|
+
console.log('');
|
|
421
|
+
console.log(` ${logger.bold('Slop Score:')} ${report.slopScore}/100 (${slopLabel})`);
|
|
422
|
+
console.log('');
|
|
423
|
+
if (m.duplication) {
|
|
424
|
+
console.log(` Duplication: ${m.duplication.percentage}% (${m.duplication.cloneCount} clones)`);
|
|
425
|
+
}
|
|
426
|
+
if (m.commentRatio !== null) {
|
|
427
|
+
console.log(` Comment ratio: ${(m.commentRatio * 100).toFixed(1)}%`);
|
|
428
|
+
}
|
|
429
|
+
console.log(` Lint: ${m.lintErrors} errors, ${m.lintWarnings} warnings`);
|
|
430
|
+
console.log(` TODO/FIXME/HACK: ${m.todoCount}/${m.fixmeCount}/${m.hackCount}`);
|
|
431
|
+
console.log(` Console stmts: ${m.consoleLogCount}`);
|
|
432
|
+
if (m.functionCount !== null) {
|
|
433
|
+
console.log(` Functions: ${m.functionCount} (max ${m.maxFunctionsInFile} in one file)`);
|
|
434
|
+
}
|
|
435
|
+
if (m.deadImportCount !== null) {
|
|
436
|
+
console.log(` Dead imports: ${m.deadImportCount}`);
|
|
437
|
+
}
|
|
438
|
+
console.log('');
|
|
439
|
+
logger.dim('Tools: ' + report.toolsUsed.join(', '));
|
|
440
|
+
if (report.toolsUnavailable.length > 0) {
|
|
441
|
+
logger.dim('Unavailable: ' + report.toolsUnavailable.join(', '));
|
|
442
|
+
}
|
|
443
|
+
logger.dim(`Completed in ${elapsed}s`);
|
|
444
|
+
if (!values['no-save']) {
|
|
445
|
+
const reportDir = path.join(targetPath, '.ai', 'reports');
|
|
446
|
+
const date = new Date().toISOString().slice(0, 10);
|
|
447
|
+
const reportPath = path.join(reportDir, `quality-review-${date}.md`);
|
|
448
|
+
fs.mkdirSync(reportDir, { recursive: true });
|
|
449
|
+
fs.writeFileSync(reportPath, formatQualityReport(report, elapsed));
|
|
450
|
+
console.log('');
|
|
451
|
+
logger.success(`Report saved to ${path.relative(targetPath, reportPath)}`);
|
|
452
|
+
if (values.detailed) {
|
|
453
|
+
const { buildQualityDetailed, formatQualityDetailedMarkdown } = await Promise.resolve().then(() => __importStar(require('./analyzers/quality/detailed')));
|
|
454
|
+
const detailed = buildQualityDetailed(report);
|
|
455
|
+
const detailedMdPath = path.join(reportDir, `quality-review-${date}-detailed.md`);
|
|
456
|
+
const detailedJsonPath = path.join(reportDir, `quality-review-${date}-detailed.json`);
|
|
457
|
+
fs.writeFileSync(detailedMdPath, formatQualityDetailedMarkdown(detailed, elapsed));
|
|
458
|
+
fs.writeFileSync(detailedJsonPath, JSON.stringify(detailed, null, 2));
|
|
459
|
+
logger.success(`Detailed report saved to ${path.relative(targetPath, detailedMdPath)}`);
|
|
460
|
+
logger.success(`Detailed JSON saved to ${path.relative(targetPath, detailedJsonPath)}`);
|
|
461
|
+
}
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
break;
|
|
465
|
+
}
|
|
466
|
+
case 'dev-report': {
|
|
467
|
+
const targetPath = positionals[1] || cwd;
|
|
468
|
+
const sinceFlag = values.since;
|
|
469
|
+
const { analyzeDevActivity, formatDevReport } = await Promise.resolve().then(() => __importStar(require('./analyzers/developer')));
|
|
470
|
+
logger.header('vyuh-dxkit dev-report');
|
|
471
|
+
logger.info(`Analyzing ${targetPath}...`);
|
|
472
|
+
const startTime = Date.now();
|
|
473
|
+
const report = analyzeDevActivity(targetPath, sinceFlag, { verbose: !!values.verbose });
|
|
474
|
+
const elapsed = ((Date.now() - startTime) / 1000).toFixed(1);
|
|
475
|
+
if (values.json) {
|
|
476
|
+
console.log(JSON.stringify(report, null, 2));
|
|
477
|
+
}
|
|
478
|
+
else {
|
|
479
|
+
const s = report.summary;
|
|
480
|
+
console.log('');
|
|
481
|
+
console.log(` ${logger.bold('Period:')} ${report.period.since} to ${report.period.until}`);
|
|
482
|
+
console.log(` ${logger.bold('Commits:')} ${s.totalCommits} (${s.nonMergeCommits} non-merge, ${s.mergeCommits} merge)`);
|
|
483
|
+
console.log(` ${logger.bold('Contributors:')} ${s.contributors}`);
|
|
484
|
+
console.log(` ${logger.bold('Merge ratio:')} ${(s.mergeRatio * 100).toFixed(1)}%`);
|
|
485
|
+
console.log(` ${logger.bold('Conventional commits:')} ${report.commitQuality.conventionalPercent}%`);
|
|
486
|
+
console.log('');
|
|
487
|
+
if (report.hotFiles.length > 0) {
|
|
488
|
+
console.log(` ${logger.bold('Hot files:')}`);
|
|
489
|
+
for (const f of report.hotFiles.slice(0, 5)) {
|
|
490
|
+
console.log(` ${f.changes.toString().padStart(3)} changes ${f.path}`);
|
|
491
|
+
}
|
|
492
|
+
}
|
|
493
|
+
console.log('');
|
|
494
|
+
logger.dim('Tools: ' + report.toolsUsed.join(', '));
|
|
495
|
+
logger.dim(`Completed in ${elapsed}s`);
|
|
496
|
+
if (!values['no-save']) {
|
|
497
|
+
const reportDir = path.join(targetPath, '.ai', 'reports');
|
|
498
|
+
const date = new Date().toISOString().slice(0, 10);
|
|
499
|
+
const reportPath = path.join(reportDir, `developer-report-${date}.md`);
|
|
500
|
+
fs.mkdirSync(reportDir, { recursive: true });
|
|
501
|
+
fs.writeFileSync(reportPath, formatDevReport(report, elapsed));
|
|
502
|
+
console.log('');
|
|
503
|
+
logger.success(`Report saved to ${path.relative(targetPath, reportPath)}`);
|
|
504
|
+
if (values.detailed) {
|
|
505
|
+
const { buildDevDetailed, formatDevDetailedMarkdown } = await Promise.resolve().then(() => __importStar(require('./analyzers/developer/detailed')));
|
|
506
|
+
const { gatherVagueCommitExamples } = await Promise.resolve().then(() => __importStar(require('./analyzers/developer/gather')));
|
|
507
|
+
const sinceDate = sinceFlag ||
|
|
508
|
+
new Date(Date.now() - 90 * 24 * 60 * 60 * 1000).toISOString().slice(0, 10);
|
|
509
|
+
const vague = gatherVagueCommitExamples(targetPath, sinceDate);
|
|
510
|
+
const detailed = buildDevDetailed(report, vague);
|
|
511
|
+
const detailedMdPath = path.join(reportDir, `developer-report-${date}-detailed.md`);
|
|
512
|
+
const detailedJsonPath = path.join(reportDir, `developer-report-${date}-detailed.json`);
|
|
513
|
+
fs.writeFileSync(detailedMdPath, formatDevDetailedMarkdown(detailed, elapsed));
|
|
514
|
+
fs.writeFileSync(detailedJsonPath, JSON.stringify(detailed, null, 2));
|
|
515
|
+
logger.success(`Detailed report saved to ${path.relative(targetPath, detailedMdPath)}`);
|
|
516
|
+
logger.success(`Detailed JSON saved to ${path.relative(targetPath, detailedJsonPath)}`);
|
|
517
|
+
}
|
|
518
|
+
}
|
|
519
|
+
}
|
|
520
|
+
break;
|
|
521
|
+
}
|
|
201
522
|
default:
|
|
202
523
|
console.error(`Unknown command: ${command}`);
|
|
203
524
|
printUsage();
|
|
204
525
|
process.exit(1);
|
|
205
526
|
}
|
|
206
527
|
}
|
|
528
|
+
function formatMarkdownReport(report, elapsed) {
|
|
529
|
+
const lines = [];
|
|
530
|
+
lines.push('# Codebase Health Audit');
|
|
531
|
+
lines.push('');
|
|
532
|
+
lines.push(`**Date:** ${report.analyzedAt.slice(0, 10)}`);
|
|
533
|
+
lines.push(`**Repository:** ${report.repo}`);
|
|
534
|
+
lines.push(`**Branch:** ${report.branch}`);
|
|
535
|
+
lines.push(`**Commit:** ${report.commitSha}`);
|
|
536
|
+
lines.push('');
|
|
537
|
+
lines.push('---');
|
|
538
|
+
lines.push('');
|
|
539
|
+
lines.push(`## Overall Health Score: ${report.summary.overallScore}/100 (Grade: ${report.summary.grade})`);
|
|
540
|
+
lines.push('');
|
|
541
|
+
lines.push('| Dimension | Score | Status |');
|
|
542
|
+
lines.push('|---|---|---|');
|
|
543
|
+
const dimNames = {
|
|
544
|
+
testing: 'Tests',
|
|
545
|
+
quality: 'Code Quality',
|
|
546
|
+
documentation: 'Documentation',
|
|
547
|
+
security: 'Security',
|
|
548
|
+
maintainability: 'Maintainability',
|
|
549
|
+
developerExperience: 'Developer Experience (DX)',
|
|
550
|
+
};
|
|
551
|
+
for (const [key, dim] of Object.entries(report.dimensions)) {
|
|
552
|
+
const name = dimNames[key] || key;
|
|
553
|
+
lines.push(`| ${name} | ${dim.score}/100 | ${dim.status.charAt(0).toUpperCase() + dim.status.slice(1)} |`);
|
|
554
|
+
}
|
|
555
|
+
lines.push('');
|
|
556
|
+
lines.push('---');
|
|
557
|
+
lines.push('');
|
|
558
|
+
// Dimension details
|
|
559
|
+
for (const [key, dim] of Object.entries(report.dimensions)) {
|
|
560
|
+
const name = dimNames[key] || key;
|
|
561
|
+
lines.push(`## ${name} (${dim.score}/100) -- ${dim.status.charAt(0).toUpperCase() + dim.status.slice(1)}`);
|
|
562
|
+
lines.push('');
|
|
563
|
+
lines.push(dim.details);
|
|
564
|
+
lines.push('');
|
|
565
|
+
lines.push('| Metric | Value |');
|
|
566
|
+
lines.push('|---|---|');
|
|
567
|
+
for (const [mk, mv] of Object.entries(dim.metrics)) {
|
|
568
|
+
if (mv !== null && mv !== undefined) {
|
|
569
|
+
lines.push(`| ${mk} | ${mv} |`);
|
|
570
|
+
}
|
|
571
|
+
}
|
|
572
|
+
lines.push('');
|
|
573
|
+
lines.push('---');
|
|
574
|
+
lines.push('');
|
|
575
|
+
}
|
|
576
|
+
// Score calculation table
|
|
577
|
+
lines.push('## Score Calculation');
|
|
578
|
+
lines.push('');
|
|
579
|
+
lines.push('| Dimension | Weight | Score | Weighted |');
|
|
580
|
+
lines.push('|---|---|---|---|');
|
|
581
|
+
const weights = {
|
|
582
|
+
testing: 0.25,
|
|
583
|
+
quality: 0.2,
|
|
584
|
+
documentation: 0.1,
|
|
585
|
+
security: 0.2,
|
|
586
|
+
maintainability: 0.1,
|
|
587
|
+
developerExperience: 0.15,
|
|
588
|
+
};
|
|
589
|
+
for (const [key, dim] of Object.entries(report.dimensions)) {
|
|
590
|
+
const name = dimNames[key] || key;
|
|
591
|
+
const w = weights[key] || 0;
|
|
592
|
+
lines.push(`| ${name} | ${(w * 100).toFixed(0)}% | ${dim.score} | ${(dim.score * w).toFixed(2)} |`);
|
|
593
|
+
}
|
|
594
|
+
lines.push(`| **Overall** | **100%** | | **${report.summary.overallScore}** |`);
|
|
595
|
+
lines.push('');
|
|
596
|
+
// Footer
|
|
597
|
+
lines.push('---');
|
|
598
|
+
lines.push('');
|
|
599
|
+
if (report.languages.length > 0) {
|
|
600
|
+
lines.push('**Languages:** ' + report.languages.map((l) => `${l.name} (${l.percentage}%)`).join(', '));
|
|
601
|
+
lines.push('');
|
|
602
|
+
}
|
|
603
|
+
lines.push(`**Tools used:** ${report.toolsUsed.join(', ')}`);
|
|
604
|
+
if (report.toolsUnavailable.length > 0) {
|
|
605
|
+
lines.push(`**Tools unavailable:** ${report.toolsUnavailable.join(', ')}`);
|
|
606
|
+
}
|
|
607
|
+
lines.push(`**Analysis time:** ${elapsed}s`);
|
|
608
|
+
lines.push('');
|
|
609
|
+
lines.push('*Generated by [VyuhLabs DXKit](https://www.npmjs.com/package/@vyuhlabs/dxkit)*');
|
|
610
|
+
return lines.join('\n');
|
|
611
|
+
}
|
|
207
612
|
const STEALTH_HEADER = '# dxkit (stealth mode — local only, not committed)';
|
|
208
613
|
/**
|
|
209
614
|
* Add only files created in this run to .gitignore.
|