@standards-kit/conform 0.1.3 → 0.3.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/{chunk-PZ2NVKI7.js → chunk-FJZMUGYW.js} +30 -13
- package/dist/chunk-FJZMUGYW.js.map +1 -0
- package/dist/chunk-O745CMWG.js +29 -0
- package/dist/chunk-O745CMWG.js.map +1 -0
- package/dist/chunk-RHM53NLG.js +49 -0
- package/dist/chunk-RHM53NLG.js.map +1 -0
- package/dist/{chunk-RXA4FO7L.js → chunk-YKKWXHYS.js} +13 -9
- package/dist/chunk-YKKWXHYS.js.map +1 -0
- package/dist/cli/index.d.ts +3 -0
- package/dist/cli/process.d.ts +2 -0
- package/dist/cli/utils.d.ts +19 -0
- package/dist/cli/validate.d.ts +2 -0
- package/dist/cli.js +3905 -3875
- package/dist/cli.js.map +1 -1
- package/dist/{cloudwatch-KSZ4A256.js → cloudwatch-3LTDYG6G.js} +6 -10
- package/dist/cloudwatch-3LTDYG6G.js.map +1 -0
- package/dist/constants.d.ts +69 -0
- package/dist/core/schema.d.ts +170 -1684
- package/dist/{core-KB2W6SE2.js → core-LFX2BFLG.js} +3 -2
- package/dist/{dynamodb-5KVESCVJ.js → dynamodb-HQH3IMAI.js} +6 -10
- package/dist/dynamodb-HQH3IMAI.js.map +1 -0
- package/dist/{ec2-HKPE6GZV.js → ec2-AEPT735A.js} +6 -10
- package/dist/ec2-AEPT735A.js.map +1 -0
- package/dist/{ecs-OS3NJZTA.js → ecs-UHKCH5A7.js} +6 -10
- package/dist/ecs-UHKCH5A7.js.map +1 -0
- package/dist/{elasticache-7TCRHYYM.js → elasticache-5Y6K7GKJ.js} +6 -10
- package/dist/elasticache-5Y6K7GKJ.js.map +1 -0
- package/dist/{elb-PEDLXW5R.js → elb-CN6ELVM5.js} +6 -10
- package/dist/elb-CN6ELVM5.js.map +1 -0
- package/dist/{iam-7H5HFWVQ.js → iam-YXMHK2MV.js} +6 -2
- package/dist/iam-YXMHK2MV.js.map +1 -0
- package/dist/index.d.ts +1 -1
- package/dist/index.js +93 -121
- package/dist/index.js.map +1 -1
- package/dist/infra/checkers/client-factory.d.ts +45 -0
- package/dist/infra/schemas.d.ts +41 -533
- package/dist/{infra-ZQRXX7AW.js → infra-RFEWGWPW.js} +20 -18
- package/dist/{infra-ZQRXX7AW.js.map → infra-RFEWGWPW.js.map} +1 -1
- package/dist/{lambda-NFB5UILT.js → lambda-YTJOCYV5.js} +6 -10
- package/dist/lambda-YTJOCYV5.js.map +1 -0
- package/dist/mcp/standards/parser.d.ts +2 -14
- package/dist/{mcp-WXYRFNEV.js → mcp-T2JFU4E2.js} +4 -3
- package/dist/{mcp-WXYRFNEV.js.map → mcp-T2JFU4E2.js.map} +1 -1
- package/dist/projects/tier-loader.d.ts +10 -3
- package/dist/projects/types.d.ts +4 -4
- package/dist/{rds-KLG5O5SI.js → rds-GZ5RVPIU.js} +6 -10
- package/dist/rds-GZ5RVPIU.js.map +1 -0
- package/dist/{registry-7CDIMOLZ.js → registry-J2LVW3M2.js} +3 -2
- package/dist/{s3-2DH7PRVR.js → s3-53UELUWT.js} +16 -12
- package/dist/s3-53UELUWT.js.map +1 -0
- package/dist/s3-S4GXNR7H.js +53 -0
- package/dist/s3-S4GXNR7H.js.map +1 -0
- package/dist/{scan-IKEHLZXV.js → scan-BZH5IR3Z.js} +4 -3
- package/dist/scan-BZH5IR3Z.js.map +1 -0
- package/dist/{secretsmanager-MOOIHLAO.js → secretsmanager-FJKTPIXI.js} +6 -10
- package/dist/secretsmanager-FJKTPIXI.js.map +1 -0
- package/dist/{sns-Y36LVTWA.js → sns-RV64OMK2.js} +6 -10
- package/dist/sns-RV64OMK2.js.map +1 -0
- package/dist/{sqs-RRS3GRHK.js → sqs-MHBW6UFC.js} +6 -10
- package/dist/sqs-MHBW6UFC.js.map +1 -0
- package/dist/{standards-RXK5G4IG.js → standards-ALMA4VIU.js} +3 -2
- package/dist/{sync-XV6XBLVZ.js → sync-EGJ2CSYK.js} +3 -2
- package/dist/sync-EGJ2CSYK.js.map +1 -0
- package/dist/validate/index.d.ts +1 -1
- package/dist/validate/tier.d.ts +3 -0
- package/dist/validate/types.d.ts +3 -9
- package/dist/{validate-DKEJICCK.js → validate-X4K2SHYT.js} +53 -84
- package/dist/validate-X4K2SHYT.js.map +1 -0
- package/package.json +10 -16
- package/dist/chunk-PZ2NVKI7.js.map +0 -1
- package/dist/chunk-RXA4FO7L.js.map +0 -1
- package/dist/cloudwatch-KSZ4A256.js.map +0 -1
- package/dist/dynamodb-5KVESCVJ.js.map +0 -1
- package/dist/ec2-HKPE6GZV.js.map +0 -1
- package/dist/ecs-OS3NJZTA.js.map +0 -1
- package/dist/elasticache-7TCRHYYM.js.map +0 -1
- package/dist/elb-PEDLXW5R.js.map +0 -1
- package/dist/iam-7H5HFWVQ.js.map +0 -1
- package/dist/lambda-NFB5UILT.js.map +0 -1
- package/dist/rds-KLG5O5SI.js.map +0 -1
- package/dist/s3-2DH7PRVR.js.map +0 -1
- package/dist/scan-IKEHLZXV.js.map +0 -1
- package/dist/secretsmanager-MOOIHLAO.js.map +0 -1
- package/dist/sns-Y36LVTWA.js.map +0 -1
- package/dist/sqs-RRS3GRHK.js.map +0 -1
- package/dist/sync-XV6XBLVZ.js.map +0 -1
- package/dist/validate-DKEJICCK.js.map +0 -1
- /package/dist/{core-KB2W6SE2.js.map → core-LFX2BFLG.js.map} +0 -0
- /package/dist/{registry-7CDIMOLZ.js.map → registry-J2LVW3M2.js.map} +0 -0
- /package/dist/{standards-RXK5G4IG.js.map → standards-ALMA4VIU.js.map} +0 -0
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import {
|
|
2
2
|
frontmatterSchema
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-YKKWXHYS.js";
|
|
4
4
|
import {
|
|
5
5
|
ExitCode
|
|
6
6
|
} from "./chunk-DXIYZR62.js";
|
|
7
7
|
import {
|
|
8
|
-
findConfigFile
|
|
9
|
-
|
|
10
|
-
|
|
8
|
+
findConfigFile
|
|
9
|
+
} from "./chunk-FJZMUGYW.js";
|
|
10
|
+
import "./chunk-RHM53NLG.js";
|
|
11
11
|
|
|
12
12
|
// src/validate/guidelines.ts
|
|
13
13
|
import * as fs from "fs";
|
|
@@ -47,7 +47,7 @@ function validateGuidelinesDir(dirPath) {
|
|
|
47
47
|
result.invalidCount++;
|
|
48
48
|
result.errors.push({
|
|
49
49
|
file,
|
|
50
|
-
errors: parseResult.error.
|
|
50
|
+
errors: parseResult.error.issues.map((e) => `${e.path.join(".")}: ${e.message}`)
|
|
51
51
|
});
|
|
52
52
|
}
|
|
53
53
|
}
|
|
@@ -87,63 +87,16 @@ async function runValidateGuidelines(dirPath, options) {
|
|
|
87
87
|
}
|
|
88
88
|
|
|
89
89
|
// src/validate/tier.ts
|
|
90
|
-
import { execSync } from "child_process";
|
|
91
90
|
import * as fs2 from "fs";
|
|
92
91
|
import * as path2 from "path";
|
|
93
92
|
import TOML from "@iarna/toml";
|
|
94
93
|
import chalk2 from "chalk";
|
|
95
|
-
import * as yaml from "js-yaml";
|
|
96
94
|
|
|
97
95
|
// src/validate/types.ts
|
|
98
96
|
var VALID_TIERS = ["production", "internal", "prototype"];
|
|
99
97
|
|
|
100
98
|
// src/validate/tier.ts
|
|
101
99
|
var DEFAULT_TIER = "internal";
|
|
102
|
-
function findGitRoot(startDir) {
|
|
103
|
-
try {
|
|
104
|
-
const gitRoot = execSync("git rev-parse --show-toplevel", {
|
|
105
|
-
cwd: startDir,
|
|
106
|
-
encoding: "utf-8",
|
|
107
|
-
stdio: ["pipe", "pipe", "pipe"]
|
|
108
|
-
}).trim();
|
|
109
|
-
return gitRoot;
|
|
110
|
-
} catch {
|
|
111
|
-
return null;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
function readFileContent(filePath) {
|
|
115
|
-
if (!fs2.existsSync(filePath)) {
|
|
116
|
-
return null;
|
|
117
|
-
}
|
|
118
|
-
try {
|
|
119
|
-
return fs2.readFileSync(filePath, "utf-8");
|
|
120
|
-
} catch {
|
|
121
|
-
return null;
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
function parseYamlContent(content) {
|
|
125
|
-
try {
|
|
126
|
-
const parsed = yaml.load(content);
|
|
127
|
-
if (parsed === void 0 || parsed === null) {
|
|
128
|
-
return { metadata: null, sourceDetail: "default (file empty)" };
|
|
129
|
-
}
|
|
130
|
-
return { metadata: parsed, sourceDetail: "repo-metadata.yaml" };
|
|
131
|
-
} catch (error) {
|
|
132
|
-
const parseError = error instanceof Error ? error.message : String(error);
|
|
133
|
-
return { metadata: null, sourceDetail: "default (parse error)", parseError };
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
function loadRepoMetadata(projectRoot) {
|
|
137
|
-
const metadataPath = path2.join(projectRoot, "repo-metadata.yaml");
|
|
138
|
-
const content = readFileContent(metadataPath);
|
|
139
|
-
if (content === null) {
|
|
140
|
-
return { metadata: null, sourceDetail: "default (file not found)" };
|
|
141
|
-
}
|
|
142
|
-
if (!content.trim()) {
|
|
143
|
-
return { metadata: null, sourceDetail: "default (file empty)" };
|
|
144
|
-
}
|
|
145
|
-
return parseYamlContent(content);
|
|
146
|
-
}
|
|
147
100
|
function loadExtendsConfig(configPath) {
|
|
148
101
|
try {
|
|
149
102
|
const content = fs2.readFileSync(configPath, "utf-8");
|
|
@@ -153,24 +106,48 @@ function loadExtendsConfig(configPath) {
|
|
|
153
106
|
return null;
|
|
154
107
|
}
|
|
155
108
|
}
|
|
156
|
-
function
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
109
|
+
function loadTierFromStandardsToml(configPath) {
|
|
110
|
+
if (!fs2.existsSync(configPath)) {
|
|
111
|
+
return {
|
|
112
|
+
tier: DEFAULT_TIER,
|
|
113
|
+
source: "default",
|
|
114
|
+
sourceDetail: "default (file not found)"
|
|
115
|
+
};
|
|
163
116
|
}
|
|
164
|
-
|
|
165
|
-
|
|
117
|
+
try {
|
|
118
|
+
const content = fs2.readFileSync(configPath, "utf-8");
|
|
119
|
+
const parsed = TOML.parse(content);
|
|
120
|
+
if (!parsed.metadata) {
|
|
121
|
+
return {
|
|
122
|
+
tier: DEFAULT_TIER,
|
|
123
|
+
source: "default",
|
|
124
|
+
sourceDetail: "default (no metadata)"
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
if (parsed.metadata.tier === void 0) {
|
|
128
|
+
return {
|
|
129
|
+
tier: DEFAULT_TIER,
|
|
130
|
+
source: "default",
|
|
131
|
+
sourceDetail: "default (tier not specified)"
|
|
132
|
+
};
|
|
133
|
+
}
|
|
134
|
+
const tier = parsed.metadata.tier;
|
|
135
|
+
if (!VALID_TIERS.includes(tier)) {
|
|
136
|
+
return {
|
|
137
|
+
tier: DEFAULT_TIER,
|
|
138
|
+
source: "default",
|
|
139
|
+
sourceDetail: "default (invalid value)",
|
|
140
|
+
invalidValue: String(tier)
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
return { tier, source: "standards.toml", sourceDetail: "standards.toml" };
|
|
144
|
+
} catch {
|
|
166
145
|
return {
|
|
167
146
|
tier: DEFAULT_TIER,
|
|
168
147
|
source: "default",
|
|
169
|
-
sourceDetail: "default (
|
|
170
|
-
invalidValue: String(tier)
|
|
148
|
+
sourceDetail: "default (file not found)"
|
|
171
149
|
};
|
|
172
150
|
}
|
|
173
|
-
return { tier, source: "repo-metadata.yaml", sourceDetail: "repo-metadata.yaml" };
|
|
174
151
|
}
|
|
175
152
|
function findMatchingRulesets(rulesets, tier) {
|
|
176
153
|
const suffix = `-${tier}`;
|
|
@@ -188,6 +165,7 @@ function createNotFoundResult() {
|
|
|
188
165
|
valid: false,
|
|
189
166
|
tier: DEFAULT_TIER,
|
|
190
167
|
tierSource: "default",
|
|
168
|
+
tierSourceDetail: "default (file not found)",
|
|
191
169
|
rulesets: [],
|
|
192
170
|
expectedPattern: `*-${DEFAULT_TIER}`,
|
|
193
171
|
matchedRulesets: [],
|
|
@@ -203,20 +181,16 @@ function buildResult(options) {
|
|
|
203
181
|
matchedRulesets,
|
|
204
182
|
invalidTierValue,
|
|
205
183
|
hasEmptyRulesets,
|
|
206
|
-
registryUrl
|
|
207
|
-
parseError
|
|
184
|
+
registryUrl
|
|
208
185
|
} = options;
|
|
209
186
|
const warnings = options.warnings ?? [];
|
|
210
187
|
const expectedPattern = `*-${tier}`;
|
|
211
188
|
const valid = rulesets.length === 0 || matchedRulesets.length > 0;
|
|
212
189
|
if (invalidTierValue) {
|
|
213
190
|
warnings.push(
|
|
214
|
-
`Invalid tier '${invalidTierValue}' in
|
|
191
|
+
`Invalid tier '${invalidTierValue}' in standards.toml [metadata]. Valid values are: ${VALID_TIERS.join(", ")}`
|
|
215
192
|
);
|
|
216
193
|
}
|
|
217
|
-
if (parseError) {
|
|
218
|
-
warnings.push(`Failed to parse repo-metadata.yaml: ${parseError}`);
|
|
219
|
-
}
|
|
220
194
|
if (hasEmptyRulesets && registryUrl) {
|
|
221
195
|
warnings.push(
|
|
222
196
|
`[extends] is configured with registry '${registryUrl}' but rulesets is empty - no standards will be inherited`
|
|
@@ -242,26 +216,21 @@ function validateTierRuleset(options = {}) {
|
|
|
242
216
|
if (!configPath) {
|
|
243
217
|
return createNotFoundResult();
|
|
244
218
|
}
|
|
245
|
-
const
|
|
246
|
-
const gitRoot = findGitRoot(configDir);
|
|
247
|
-
const metadataSearchPath = gitRoot ?? configDir;
|
|
248
|
-
const metadataResult = loadRepoMetadata(metadataSearchPath);
|
|
249
|
-
const { tier, source, sourceDetail, invalidValue } = getTier(metadataResult);
|
|
219
|
+
const tierResult = loadTierFromStandardsToml(configPath);
|
|
250
220
|
const extendsConfig = loadExtendsConfig(configPath);
|
|
251
221
|
const rulesets = extendsConfig?.rulesets ?? [];
|
|
252
|
-
const matchedRulesets = rulesets.length > 0 ? findMatchingRulesets(rulesets, tier) : [];
|
|
222
|
+
const matchedRulesets = rulesets.length > 0 ? findMatchingRulesets(rulesets, tierResult.tier) : [];
|
|
253
223
|
const hasEmptyRulesets = extendsConfig !== null && rulesets.length === 0;
|
|
254
224
|
const registryUrl = extendsConfig?.registry;
|
|
255
225
|
return buildResult({
|
|
256
|
-
tier,
|
|
257
|
-
source,
|
|
258
|
-
sourceDetail,
|
|
226
|
+
tier: tierResult.tier,
|
|
227
|
+
source: tierResult.source,
|
|
228
|
+
sourceDetail: tierResult.sourceDetail,
|
|
259
229
|
rulesets,
|
|
260
230
|
matchedRulesets,
|
|
261
|
-
invalidTierValue: invalidValue,
|
|
231
|
+
invalidTierValue: tierResult.invalidValue,
|
|
262
232
|
hasEmptyRulesets,
|
|
263
|
-
registryUrl
|
|
264
|
-
parseError: metadataResult.parseError
|
|
233
|
+
registryUrl
|
|
265
234
|
});
|
|
266
235
|
}
|
|
267
236
|
function formatWarnings(warnings) {
|
|
@@ -295,7 +264,7 @@ function formatFailedValidation(result, sourceDisplay) {
|
|
|
295
264
|
lines.push("");
|
|
296
265
|
lines.push(
|
|
297
266
|
chalk2.cyan(
|
|
298
|
-
` Hint: Update
|
|
267
|
+
` Hint: Update standards.toml [metadata].tier to use a valid value: ${VALID_TIERS.join(", ")}`
|
|
299
268
|
)
|
|
300
269
|
);
|
|
301
270
|
}
|
|
@@ -324,4 +293,4 @@ export {
|
|
|
324
293
|
validateGuidelinesDir,
|
|
325
294
|
validateTierRuleset
|
|
326
295
|
};
|
|
327
|
-
//# sourceMappingURL=validate-
|
|
296
|
+
//# sourceMappingURL=validate-X4K2SHYT.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../src/validate/guidelines.ts","../src/validate/tier.ts","../src/validate/types.ts"],"sourcesContent":["/**\n * Validate guideline markdown files against the frontmatter schema\n */\nimport * as fs from \"node:fs\";\nimport * as path from \"node:path\";\n\nimport chalk from \"chalk\";\nimport matter from \"gray-matter\";\n\nimport { frontmatterSchema } from \"../mcp/standards/index.js\";\nimport { ExitCode } from \"../core/index.js\";\n\n/** Single file validation error */\nexport interface GuidelineValidationError {\n file: string;\n errors: string[];\n}\n\n/** Overall validation result */\nexport interface GuidelineValidationResult {\n valid: boolean;\n validCount: number;\n invalidCount: number;\n errors: GuidelineValidationError[];\n}\n\n/** Format text output for validation result */\nfunction formatTextOutput(result: GuidelineValidationResult): string {\n if (result.valid) {\n return chalk.green(`✓ All ${result.validCount} guideline(s) valid`);\n }\n const lines = [chalk.red(`✗ Found ${result.invalidCount} invalid guideline(s)`), \"\"];\n for (const err of result.errors) {\n lines.push(chalk.red(` ${err.file}:`));\n for (const e of err.errors) {\n lines.push(chalk.red(` - ${e}`));\n }\n }\n return lines.join(\"\\n\");\n}\n\n/** Validate a directory of guideline files */\nexport function validateGuidelinesDir(dirPath: string): GuidelineValidationResult {\n const files = fs.readdirSync(dirPath).filter((f) => f.endsWith(\".md\"));\n const result: GuidelineValidationResult = {\n valid: true,\n validCount: 0,\n invalidCount: 0,\n errors: [],\n };\n\n for (const file of files) {\n const filePath = path.join(dirPath, file);\n const content = fs.readFileSync(filePath, \"utf-8\");\n const { data } = matter(content);\n\n const parseResult = frontmatterSchema.safeParse(data);\n if (parseResult.success) {\n result.validCount++;\n } else {\n result.valid = false;\n result.invalidCount++;\n result.errors.push({\n file,\n errors: parseResult.error.issues.map((e) => `${e.path.join(\".\")}: ${e.message}`),\n });\n }\n }\n\n return result;\n}\n\n/** Output error and exit */\nfunction exitWithError(error: string, format: string): never {\n if (format === \"json\") {\n process.stdout.write(`${JSON.stringify({ valid: false, error }, null, 2)}\\n`);\n } else {\n console.error(chalk.red(`✗ ${error}`));\n }\n process.exit(ExitCode.CONFIG_ERROR);\n}\n\n/** Resolve and validate directory path */\nfunction resolveAndValidatePath(dirPath: string, format: string): string {\n const resolvedPath = path.isAbsolute(dirPath) ? dirPath : path.resolve(process.cwd(), dirPath);\n\n if (!fs.existsSync(resolvedPath)) {\n exitWithError(`Path does not exist: ${resolvedPath}`, format);\n }\n\n const stats = fs.statSync(resolvedPath);\n if (!stats.isDirectory()) {\n exitWithError(`Path is not a directory: ${resolvedPath}`, format);\n }\n\n return resolvedPath;\n}\n\n/** Run the validate guidelines command */\nexport async function runValidateGuidelines(\n dirPath: string,\n options: { format: string }\n): Promise<void> {\n const resolvedPath = resolveAndValidatePath(dirPath, options.format);\n const result = validateGuidelinesDir(resolvedPath);\n\n if (options.format === \"json\") {\n process.stdout.write(`${JSON.stringify(result, null, 2)}\\n`);\n } else {\n process.stdout.write(`${formatTextOutput(result)}\\n`);\n }\n\n process.exit(result.valid ? ExitCode.SUCCESS : ExitCode.CONFIG_ERROR);\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\n\nimport TOML from \"@iarna/toml\";\nimport chalk from \"chalk\";\n\nimport { findConfigFile } from \"../core/index.js\";\nimport {\n type Tier,\n type TierSourceDetail,\n VALID_TIERS,\n type ValidateTierOptions,\n type ValidateTierResult,\n} from \"./types.js\";\n\n/** Default tier when not specified */\nconst DEFAULT_TIER: Tier = \"internal\";\n\n/** Extends section from standards.toml */\ninterface ExtendsConfig {\n registry?: string;\n rulesets?: string[];\n}\n\n/** Metadata section from standards.toml */\ninterface MetadataConfig {\n tier?: Tier;\n project?: string;\n organisation?: string;\n status?: string;\n}\n\n/** Raw standards.toml structure (just what we need) */\ninterface RawConfig {\n metadata?: MetadataConfig;\n extends?: ExtendsConfig;\n}\n\n/** Result of getTier with detailed info */\ninterface GetTierResult {\n tier: Tier;\n source: \"standards.toml\" | \"default\";\n sourceDetail: TierSourceDetail;\n invalidValue?: string;\n}\n\n/**\n * Load and parse standards.toml to get extends section\n */\nfunction loadExtendsConfig(configPath: string): ExtendsConfig | null {\n try {\n const content = fs.readFileSync(configPath, \"utf-8\");\n const parsed = TOML.parse(content) as RawConfig;\n return parsed.extends ?? null;\n } catch {\n return null;\n }\n}\n\n/**\n * Load tier from standards.toml [metadata] section\n */\nfunction loadTierFromStandardsToml(configPath: string): GetTierResult {\n if (!fs.existsSync(configPath)) {\n return {\n tier: DEFAULT_TIER,\n source: \"default\",\n sourceDetail: \"default (file not found)\",\n };\n }\n\n try {\n const content = fs.readFileSync(configPath, \"utf-8\");\n const parsed = TOML.parse(content) as RawConfig;\n\n if (!parsed.metadata) {\n return {\n tier: DEFAULT_TIER,\n source: \"default\",\n sourceDetail: \"default (no metadata)\",\n };\n }\n\n if (parsed.metadata.tier === undefined) {\n return {\n tier: DEFAULT_TIER,\n source: \"default\",\n sourceDetail: \"default (tier not specified)\",\n };\n }\n\n const tier = parsed.metadata.tier;\n\n // Check if tier value is valid\n if (!VALID_TIERS.includes(tier)) {\n return {\n tier: DEFAULT_TIER,\n source: \"default\",\n sourceDetail: \"default (invalid value)\",\n invalidValue: String(tier),\n };\n }\n\n return { tier, source: \"standards.toml\", sourceDetail: \"standards.toml\" };\n } catch {\n return {\n tier: DEFAULT_TIER,\n source: \"default\",\n sourceDetail: \"default (file not found)\",\n };\n }\n}\n\n/**\n * Check if rulesets include a tier-matching ruleset\n */\nfunction findMatchingRulesets(rulesets: string[], tier: Tier): string[] {\n const suffix = `-${tier}`;\n return rulesets.filter((ruleset) => ruleset.endsWith(suffix));\n}\n\n/**\n * Resolve the config path from options\n */\nfunction resolveConfigPath(options: ValidateTierOptions): string | null {\n if (options.config) {\n const absolutePath = path.resolve(options.config);\n return fs.existsSync(absolutePath) ? absolutePath : null;\n }\n return findConfigFile();\n}\n\n/**\n * Create result for missing config\n */\nfunction createNotFoundResult(): ValidateTierResult {\n return {\n valid: false,\n tier: DEFAULT_TIER,\n tierSource: \"default\",\n tierSourceDetail: \"default (file not found)\",\n rulesets: [],\n expectedPattern: `*-${DEFAULT_TIER}`,\n matchedRulesets: [],\n error: \"No standards.toml found\",\n };\n}\n\n/** Options for building the result */\ninterface BuildResultOptions {\n tier: Tier;\n source: \"standards.toml\" | \"default\";\n sourceDetail: TierSourceDetail;\n rulesets: string[];\n matchedRulesets: string[];\n invalidTierValue?: string;\n hasEmptyRulesets?: boolean;\n registryUrl?: string;\n warnings?: string[];\n}\n\n/**\n * Build the validation result\n */\nfunction buildResult(options: BuildResultOptions): ValidateTierResult {\n const {\n tier,\n source,\n sourceDetail,\n rulesets,\n matchedRulesets,\n invalidTierValue,\n hasEmptyRulesets,\n registryUrl,\n } = options;\n const warnings: string[] = options.warnings ?? [];\n\n const expectedPattern = `*-${tier}`;\n const valid = rulesets.length === 0 || matchedRulesets.length > 0;\n\n // Add warning for invalid tier value\n if (invalidTierValue) {\n warnings.push(\n `Invalid tier '${invalidTierValue}' in standards.toml [metadata]. Valid values are: ${VALID_TIERS.join(\", \")}`\n );\n }\n\n // Add warning for empty rulesets with registry configured\n if (hasEmptyRulesets && registryUrl) {\n warnings.push(\n `[extends] is configured with registry '${registryUrl}' but rulesets is empty - no standards will be inherited`\n );\n }\n\n return {\n valid,\n tier,\n tierSource: source,\n tierSourceDetail: sourceDetail,\n rulesets,\n expectedPattern,\n matchedRulesets,\n error: valid\n ? undefined\n : `No ruleset matching pattern '${expectedPattern}' found. Rulesets: [${rulesets.join(\", \")}]`,\n invalidTierValue,\n hasEmptyRulesets,\n registryUrl,\n warnings: warnings.length > 0 ? warnings : undefined,\n };\n}\n\n/**\n * Validate that project tier matches its rulesets.\n * This is the programmatic API exported for library consumers.\n *\n * Tier is loaded from standards.toml [metadata].tier\n * Defaults to \"internal\" if not specified\n */\nexport function validateTierRuleset(options: ValidateTierOptions = {}): ValidateTierResult {\n const configPath = resolveConfigPath(options);\n if (!configPath) {\n return createNotFoundResult();\n }\n\n const tierResult = loadTierFromStandardsToml(configPath);\n\n const extendsConfig = loadExtendsConfig(configPath);\n const rulesets = extendsConfig?.rulesets ?? [];\n const matchedRulesets = rulesets.length > 0 ? findMatchingRulesets(rulesets, tierResult.tier) : [];\n\n // Detect empty rulesets with registry configured\n const hasEmptyRulesets = extendsConfig !== null && rulesets.length === 0;\n const registryUrl = extendsConfig?.registry;\n\n return buildResult({\n tier: tierResult.tier,\n source: tierResult.source,\n sourceDetail: tierResult.sourceDetail,\n rulesets,\n matchedRulesets,\n invalidTierValue: tierResult.invalidValue,\n hasEmptyRulesets,\n registryUrl,\n });\n}\n\n/** Format warnings section */\nfunction formatWarnings(warnings: string[] | undefined): string[] {\n if (!warnings || warnings.length === 0) {\n return [];\n }\n const lines = warnings.map((w) => chalk.yellow(`⚠ Warning: ${w}`));\n lines.push(\"\"); // Empty line after warnings\n return lines;\n}\n\n/** Format the rulesets message based on configuration */\nfunction formatRulesetsMessage(result: ValidateTierResult): string {\n if (result.matchedRulesets.length > 0) {\n return ` Matching rulesets: ${result.matchedRulesets.join(\", \")}`;\n }\n if (result.hasEmptyRulesets) {\n return \" No rulesets specified (no tier constraint)\";\n }\n return \" No extends configured (no tier constraint)\";\n}\n\n/** Format the failed validation section */\nfunction formatFailedValidation(result: ValidateTierResult, sourceDisplay: string): string[] {\n const lines = [\n chalk.red(\"✗ Tier validation failed\"),\n ` Tier: ${result.tier} (source: ${sourceDisplay})`,\n ` Expected pattern: ${result.expectedPattern}`,\n ` Rulesets: [${result.rulesets.join(\", \")}]`,\n ];\n if (result.error) {\n lines.push(chalk.red(` Error: ${result.error}`));\n }\n if (result.invalidTierValue) {\n lines.push(\"\");\n lines.push(\n chalk.cyan(\n ` Hint: Update standards.toml [metadata].tier to use a valid value: ${VALID_TIERS.join(\", \")}`\n )\n );\n }\n return lines;\n}\n\n/**\n * Format tier validation result as text\n */\nexport function formatTierResultText(result: ValidateTierResult): string {\n const lines: string[] = formatWarnings(result.warnings);\n const sourceDisplay = result.tierSourceDetail ?? result.tierSource;\n\n if (result.valid) {\n lines.push(chalk.green(\"✓ Tier validation passed\"));\n lines.push(` Tier: ${result.tier} (source: ${sourceDisplay})`);\n lines.push(formatRulesetsMessage(result));\n } else {\n lines.push(...formatFailedValidation(result, sourceDisplay));\n }\n\n return lines.join(\"\\n\");\n}\n\n/**\n * Format tier validation result as JSON\n */\nexport function formatTierResultJson(result: ValidateTierResult): string {\n return JSON.stringify(result, null, 2);\n}\n","/**\n * Valid project tiers\n */\nexport type Tier = \"production\" | \"internal\" | \"prototype\";\n\n/**\n * Valid tier values as a constant array for validation and export\n */\nexport const VALID_TIERS: readonly Tier[] = [\"production\", \"internal\", \"prototype\"];\n\n/**\n * Detailed tier source indicating why a default was used\n */\nexport type TierSourceDetail =\n | \"standards.toml\" // Tier was read from [metadata] section\n | \"default\" // Generic default (for backwards compatibility)\n | \"default (file not found)\" // standards.toml doesn't exist\n | \"default (no metadata)\" // standards.toml exists but no [metadata] section\n | \"default (tier not specified)\" // [metadata] exists but no tier key\n | \"default (invalid value)\"; // [metadata] has tier but value is invalid\n\n/**\n * Options for the tier validation command\n */\nexport interface ValidateTierOptions {\n /** Path to standards.toml config file */\n config?: string;\n /** Output format */\n format?: \"text\" | \"json\";\n}\n\n/**\n * Result of tier validation\n */\nexport interface ValidateTierResult {\n /** Whether validation passed */\n valid: boolean;\n /** Project tier from standards.toml [metadata] (defaults to \"internal\") */\n tier: Tier;\n /** Source of tier value */\n tierSource: \"standards.toml\" | \"default\";\n /** Detailed source of tier value with reason for default */\n tierSourceDetail?: TierSourceDetail;\n /** Rulesets from standards.toml extends section */\n rulesets: string[];\n /** Expected ruleset suffix pattern */\n expectedPattern: string;\n /** Matched rulesets (those that satisfy the tier requirement) */\n matchedRulesets: string[];\n /** Error message if invalid */\n error?: string;\n /** Invalid tier value that was rejected (for error messages) */\n invalidTierValue?: string;\n /** Whether extends is configured but has empty rulesets */\n hasEmptyRulesets?: boolean;\n /** Registry URL if extends is configured */\n registryUrl?: string;\n /** Warnings about configuration */\n warnings?: string[];\n}\n"],"mappings":"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","names":["fs","path","chalk","chalk"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@standards-kit/conform",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "Standards conformance checking - in-repo enforcement CLI",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"main": "dist/index.js",
|
|
@@ -40,7 +40,7 @@
|
|
|
40
40
|
},
|
|
41
41
|
"homepage": "https://github.com/chrismlittle123/standards-kit/tree/main/packages/conform#readme",
|
|
42
42
|
"engines": {
|
|
43
|
-
"node": ">=
|
|
43
|
+
"node": ">=22"
|
|
44
44
|
},
|
|
45
45
|
"dependencies": {
|
|
46
46
|
"@aws-sdk/client-cloudwatch-logs": "^3.974.0",
|
|
@@ -52,7 +52,7 @@
|
|
|
52
52
|
"@aws-sdk/client-iam": "^3.974.0",
|
|
53
53
|
"@aws-sdk/client-lambda": "^3.974.0",
|
|
54
54
|
"@aws-sdk/client-rds": "^3.975.0",
|
|
55
|
-
"@aws-sdk/client-s3": "^3.
|
|
55
|
+
"@aws-sdk/client-s3": "^3.975.0",
|
|
56
56
|
"@aws-sdk/client-secrets-manager": "^3.974.0",
|
|
57
57
|
"@aws-sdk/client-sns": "^3.974.0",
|
|
58
58
|
"@aws-sdk/client-sqs": "^3.974.0",
|
|
@@ -62,22 +62,19 @@
|
|
|
62
62
|
"@iarna/toml": "^2.2.5",
|
|
63
63
|
"@modelcontextprotocol/sdk": "^1.25.3",
|
|
64
64
|
"chalk": "^5.6.2",
|
|
65
|
-
"commander": "^
|
|
65
|
+
"commander": "^14.0.0",
|
|
66
66
|
"execa": "^9.6.1",
|
|
67
67
|
"glob": "^13.0.0",
|
|
68
68
|
"google-auth-library": "^10.5.0",
|
|
69
69
|
"gray-matter": "^4.0.3",
|
|
70
70
|
"js-yaml": "^4.1.1",
|
|
71
71
|
"minimatch": "^10.1.1",
|
|
72
|
-
"zod": "^3.
|
|
73
|
-
"zod-to-json-schema": "^3.25.1"
|
|
72
|
+
"zod": "^4.3.5"
|
|
74
73
|
},
|
|
75
74
|
"devDependencies": {
|
|
76
75
|
"@types/js-yaml": "^4.0.9",
|
|
77
76
|
"@types/node": "^22.10.2",
|
|
78
77
|
"@vitest/coverage-v8": "^2.1.9",
|
|
79
|
-
"aws-sdk-client-mock": "^4.1.0",
|
|
80
|
-
"dts-bundle-generator": "^9.5.1",
|
|
81
78
|
"tsup": "^8.0.0",
|
|
82
79
|
"typescript": "^5.4.0",
|
|
83
80
|
"vitest": "^2.1.8"
|
|
@@ -86,13 +83,10 @@
|
|
|
86
83
|
"build": "tsup && tsc --emitDeclarationOnly",
|
|
87
84
|
"dev": "tsup --watch",
|
|
88
85
|
"start": "node dist/cli.js",
|
|
89
|
-
"
|
|
90
|
-
"test
|
|
91
|
-
"test:watch": "vitest
|
|
92
|
-
"test:coverage": "vitest run
|
|
93
|
-
"
|
|
94
|
-
"test:all": "vitest run",
|
|
95
|
-
"typecheck": "tsc --noEmit",
|
|
96
|
-
"lint": "eslint src"
|
|
86
|
+
"lint": "eslint src",
|
|
87
|
+
"test": "vitest run",
|
|
88
|
+
"test:watch": "vitest",
|
|
89
|
+
"test:coverage": "vitest run --coverage",
|
|
90
|
+
"typecheck": "tsc --noEmit"
|
|
97
91
|
}
|
|
98
92
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/core/registry.ts","../src/core/loader.ts","../src/core/schema.ts"],"sourcesContent":["/* eslint-disable max-lines -- registry config merging requires many type-safe merge functions */\nimport * as fs from \"node:fs\";\nimport * as os from \"node:os\";\nimport * as path from \"node:path\";\n\nimport * as toml from \"@iarna/toml\";\nimport { execa } from \"execa\";\n\nimport { ConfigError } from \"./loader.js\";\nimport { type Config, configSchema } from \"./schema.js\";\n\n/** Authentication method for private registries */\ntype AuthMethod = \"token\" | \"ssh\" | \"none\";\n\ninterface RegistryLocation {\n type: \"github\" | \"local\";\n owner?: string;\n repo?: string;\n ref?: string;\n path: string;\n auth?: AuthMethod;\n}\n\n/**\n * Detect authentication method based on environment variables.\n * Priority: CONFORM_REGISTRY_TOKEN > GITHUB_TOKEN > SSH key detection > none\n */\nfunction detectAuthMethod(): AuthMethod {\n if (process.env.CONFORM_REGISTRY_TOKEN || process.env.GITHUB_TOKEN) {\n return \"token\";\n }\n // Check for SSH key - if SSH_AUTH_SOCK is set, SSH agent is available\n if (process.env.SSH_AUTH_SOCK) {\n return \"ssh\";\n }\n return \"none\";\n}\n\n/**\n * Get the authentication token from environment variables.\n */\nfunction getAuthToken(): string | undefined {\n return process.env.CONFORM_REGISTRY_TOKEN ?? process.env.GITHUB_TOKEN;\n}\n\n/**\n * Build the git URL for a GitHub repository based on auth method.\n */\nfunction buildGitHubUrl(owner: string, repo: string, auth: AuthMethod): string {\n switch (auth) {\n case \"ssh\":\n return `git@github.com:${owner}/${repo}.git`;\n case \"token\": {\n const token = getAuthToken();\n if (token) {\n return `https://x-access-token:${token}@github.com/${owner}/${repo}.git`;\n }\n // Fall back to regular HTTPS if no token found\n return `https://github.com/${owner}/${repo}.git`;\n }\n case \"none\":\n default:\n return `https://github.com/${owner}/${repo}.git`;\n }\n}\n\n/**\n * Parse explicit auth method from URL prefix.\n * Supports: github+ssh:, github+token:, github: (auto-detect)\n */\nfunction parseAuthFromUrl(url: string): { auth: AuthMethod | \"auto\"; rest: string } {\n if (url.startsWith(\"github+ssh:\")) {\n return { auth: \"ssh\", rest: url.slice(11) };\n }\n if (url.startsWith(\"github+token:\")) {\n return { auth: \"token\", rest: url.slice(13) };\n }\n if (url.startsWith(\"github:\")) {\n return { auth: \"auto\", rest: url.slice(7) };\n }\n throw new ConfigError(`Invalid GitHub registry URL: ${url}`);\n}\n\nfunction parseGitHubUrl(url: string): RegistryLocation {\n const { auth: explicitAuth, rest } = parseAuthFromUrl(url);\n const [repoPath, ref] = rest.split(\"@\");\n const [owner, repo] = repoPath.split(\"/\");\n\n if (!owner || !repo) {\n throw new ConfigError(\n `Invalid GitHub registry URL: ${url}. Expected format: github:owner/repo or github+ssh:owner/repo`\n );\n }\n\n const auth = explicitAuth === \"auto\" ? detectAuthMethod() : explicitAuth;\n\n return {\n type: \"github\",\n owner,\n repo,\n ref: ref || undefined,\n path: buildGitHubUrl(owner, repo, auth),\n auth,\n };\n}\n\nexport function parseRegistryUrl(url: string, configDir?: string): RegistryLocation {\n if (url.startsWith(\"github:\") || url.startsWith(\"github+\")) {\n return parseGitHubUrl(url);\n }\n\n const localPath = !path.isAbsolute(url) && configDir ? path.resolve(configDir, url) : url;\n return { type: \"local\", path: localPath };\n}\n\nasync function updateExistingRepo(repoDir: string, ref?: string): Promise<boolean> {\n try {\n if (ref) {\n await execa(\"git\", [\"fetch\", \"--all\"], { cwd: repoDir });\n await execa(\"git\", [\"checkout\", ref], { cwd: repoDir });\n } else {\n await execa(\"git\", [\"pull\", \"--ff-only\"], { cwd: repoDir });\n }\n return true;\n } catch {\n fs.rmSync(repoDir, { recursive: true, force: true });\n return false;\n }\n}\n\nasync function cloneRepo(location: RegistryLocation, repoDir: string): Promise<void> {\n const cacheDir = path.dirname(repoDir);\n fs.mkdirSync(cacheDir, { recursive: true });\n\n const cloneArgs = [\"clone\", \"--depth\", \"1\"];\n if (location.ref) {\n cloneArgs.push(\"--branch\", location.ref);\n }\n cloneArgs.push(location.path, repoDir);\n\n try {\n await execa(\"git\", cloneArgs, { timeout: 30 * 1000 }); // 30 second timeout\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n if (message.includes(\"timed out\")) {\n throw new ConfigError(`Registry clone timed out after 30 seconds: ${location.path}`);\n }\n throw new ConfigError(`Failed to clone registry: ${message}`);\n }\n}\n\nexport async function fetchRegistry(location: RegistryLocation): Promise<string> {\n if (location.type === \"local\") {\n if (!fs.existsSync(location.path)) {\n throw new ConfigError(`Registry not found: ${location.path}`);\n }\n return location.path;\n }\n\n const cacheDir = path.join(os.tmpdir(), \"conform-registry-cache\");\n const repoDir = path.join(cacheDir, `${location.owner}-${location.repo}`);\n\n if (fs.existsSync(repoDir)) {\n await updateExistingRepo(repoDir, location.ref);\n }\n\n if (!fs.existsSync(repoDir)) {\n await cloneRepo(location, repoDir);\n }\n\n return repoDir;\n}\n\nexport function loadRuleset(registryDir: string, rulesetName: string): Config {\n const rulesetPath = path.join(registryDir, \"rulesets\", `${rulesetName}.toml`);\n\n if (!fs.existsSync(rulesetPath)) {\n throw new ConfigError(`Ruleset not found: ${rulesetName} (expected at ${rulesetPath})`);\n }\n\n const content = fs.readFileSync(rulesetPath, \"utf-8\");\n\n let parsed: unknown;\n try {\n parsed = toml.parse(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : String(error);\n throw new ConfigError(`Failed to parse ruleset ${rulesetName}: ${message}`);\n }\n\n const result = configSchema.safeParse(parsed);\n if (!result.success) {\n const errors = result.error.errors.map((e) => `${e.path.join(\".\")}: ${e.message}`).join(\", \");\n throw new ConfigError(`Invalid ruleset ${rulesetName}: ${errors}`);\n }\n\n return result.data;\n}\n\ntype CodeConfig = NonNullable<Config[\"code\"]>;\n\nfunction mergeToolConfig<T extends object>(base?: T, override?: T): T | undefined {\n if (!override) {\n return base;\n }\n return { ...base, ...override };\n}\n\nfunction mergeLinting(\n base: CodeConfig[\"linting\"],\n override: CodeConfig[\"linting\"]\n): CodeConfig[\"linting\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n eslint: mergeToolConfig(base?.eslint, override.eslint),\n ruff: mergeToolConfig(base?.ruff, override.ruff),\n };\n}\n\nfunction mergeTypes(base: CodeConfig[\"types\"], override: CodeConfig[\"types\"]): CodeConfig[\"types\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n tsc: mergeToolConfig(base?.tsc, override.tsc),\n ty: mergeToolConfig(base?.ty, override.ty),\n };\n}\n\nfunction mergeUnused(\n base: CodeConfig[\"unused\"],\n override: CodeConfig[\"unused\"]\n): CodeConfig[\"unused\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n knip: mergeToolConfig(base?.knip, override.knip),\n vulture: mergeToolConfig(base?.vulture, override.vulture),\n };\n}\n\nfunction mergeSecurity(\n base: CodeConfig[\"security\"],\n override: CodeConfig[\"security\"]\n): CodeConfig[\"security\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n secrets: mergeToolConfig(base?.secrets, override.secrets),\n pnpmaudit: mergeToolConfig(base?.pnpmaudit, override.pnpmaudit),\n pipaudit: mergeToolConfig(base?.pipaudit, override.pipaudit),\n };\n}\n\nfunction mergeNaming(\n base: CodeConfig[\"naming\"],\n override: CodeConfig[\"naming\"]\n): CodeConfig[\"naming\"] {\n if (!override) {\n return base;\n }\n // enabled has a default value from schema, so it's always defined after parsing\n return {\n enabled: override.enabled,\n rules: override.rules ?? base?.rules,\n };\n}\n\nfunction mergeQuality(\n base: CodeConfig[\"quality\"],\n override: CodeConfig[\"quality\"]\n): CodeConfig[\"quality\"] {\n if (!override) {\n return base;\n }\n return {\n ...base,\n \"disable-comments\": mergeToolConfig(base?.[\"disable-comments\"], override[\"disable-comments\"]),\n };\n}\n\nfunction mergeCodeSection(base: CodeConfig | undefined, override: CodeConfig): CodeConfig {\n return {\n linting: mergeLinting(base?.linting, override.linting),\n types: mergeTypes(base?.types, override.types),\n unused: mergeUnused(base?.unused, override.unused),\n coverage_run: mergeToolConfig(base?.coverage_run, override.coverage_run),\n security: mergeSecurity(base?.security, override.security),\n naming: mergeNaming(base?.naming, override.naming),\n quality: mergeQuality(base?.quality, override.quality),\n };\n}\n\ntype ProcessConfig = NonNullable<Config[\"process\"]>;\n\nfunction mergeHooksConfig(\n base: ProcessConfig[\"hooks\"],\n override: ProcessConfig[\"hooks\"]\n): ProcessConfig[\"hooks\"] {\n if (!override) {\n return base;\n }\n // enabled and require_husky have schema defaults, so they're always defined\n return {\n enabled: override.enabled,\n require_husky: override.require_husky,\n require_hooks: override.require_hooks ?? base?.require_hooks,\n commands: override.commands ?? base?.commands,\n };\n}\n\nfunction mergeCiConfig(\n base: ProcessConfig[\"ci\"],\n override: ProcessConfig[\"ci\"]\n): ProcessConfig[\"ci\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_workflows: override.require_workflows ?? base?.require_workflows,\n jobs: override.jobs ?? base?.jobs,\n actions: override.actions ?? base?.actions,\n };\n}\n\nfunction mergeBranchesConfig(\n base: ProcessConfig[\"branches\"],\n override: ProcessConfig[\"branches\"]\n): ProcessConfig[\"branches\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_issue: override.require_issue,\n pattern: override.pattern ?? base?.pattern,\n exclude: override.exclude ?? base?.exclude,\n issue_pattern: override.issue_pattern ?? base?.issue_pattern,\n };\n}\n\nfunction mergePrConfig(\n base: ProcessConfig[\"pr\"],\n override: ProcessConfig[\"pr\"]\n): ProcessConfig[\"pr\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n require_issue: override.require_issue,\n max_files: override.max_files ?? base?.max_files,\n max_lines: override.max_lines ?? base?.max_lines,\n issue_keywords: override.issue_keywords ?? base?.issue_keywords,\n };\n}\n\nfunction mergeTicketsConfig(\n base: ProcessConfig[\"tickets\"],\n override: ProcessConfig[\"tickets\"]\n): ProcessConfig[\"tickets\"] {\n if (!override) {\n return base;\n }\n // require_in_commits and require_in_branch have schema defaults, so they're always defined after parsing\n return {\n enabled: override.enabled,\n pattern: override.pattern ?? base?.pattern,\n require_in_commits: override.require_in_commits,\n require_in_branch: override.require_in_branch,\n };\n}\n\nfunction mergeCoverageConfig(\n base: ProcessConfig[\"coverage\"],\n override: ProcessConfig[\"coverage\"]\n): ProcessConfig[\"coverage\"] {\n if (!override) {\n return base;\n }\n // enforce_in has schema default, so it's always defined after parsing\n return {\n enabled: override.enabled,\n min_threshold: override.min_threshold ?? base?.min_threshold,\n enforce_in: override.enforce_in,\n ci_workflow: override.ci_workflow ?? base?.ci_workflow,\n ci_job: override.ci_job ?? base?.ci_job,\n };\n}\n\nfunction mergeCommitsConfig(\n base: ProcessConfig[\"commits\"],\n override: ProcessConfig[\"commits\"]\n): ProcessConfig[\"commits\"] {\n if (!override) {\n return base;\n }\n // require_scope has schema default, so it's always defined after parsing\n return {\n enabled: override.enabled,\n pattern: override.pattern ?? base?.pattern,\n types: override.types ?? base?.types,\n require_scope: override.require_scope,\n max_subject_length: override.max_subject_length ?? base?.max_subject_length,\n };\n}\n\nfunction mergeChangesetsConfig(\n base: ProcessConfig[\"changesets\"],\n override: ProcessConfig[\"changesets\"]\n): ProcessConfig[\"changesets\"] {\n if (!override) {\n return base;\n }\n // validate_format and require_description have schema defaults, so they're always defined after parsing\n return {\n enabled: override.enabled,\n require_for_paths: override.require_for_paths ?? base?.require_for_paths,\n exclude_paths: override.exclude_paths ?? base?.exclude_paths,\n validate_format: override.validate_format,\n allowed_bump_types: override.allowed_bump_types ?? base?.allowed_bump_types,\n require_description: override.require_description,\n min_description_length: override.min_description_length ?? base?.min_description_length,\n };\n}\n\nfunction mergeRepoConfig(\n base: ProcessConfig[\"repo\"],\n override: ProcessConfig[\"repo\"]\n): ProcessConfig[\"repo\"] {\n if (!override) {\n return base;\n }\n // require_branch_protection and require_codeowners have schema defaults\n return {\n enabled: override.enabled,\n require_branch_protection: override.require_branch_protection,\n require_codeowners: override.require_codeowners,\n ruleset: override.ruleset ?? base?.ruleset,\n tag_protection: override.tag_protection ?? base?.tag_protection,\n };\n}\n\nfunction mergeBackupsConfig(\n base: ProcessConfig[\"backups\"],\n override: ProcessConfig[\"backups\"]\n): ProcessConfig[\"backups\"] {\n if (!override) {\n return base;\n }\n // max_age_hours has schema default\n return {\n enabled: override.enabled,\n bucket: override.bucket ?? base?.bucket,\n prefix: override.prefix ?? base?.prefix,\n max_age_hours: override.max_age_hours,\n region: override.region ?? base?.region,\n };\n}\n\nfunction mergeCodeownersConfig(\n base: ProcessConfig[\"codeowners\"],\n override: ProcessConfig[\"codeowners\"]\n): ProcessConfig[\"codeowners\"] {\n if (!override) {\n return base;\n }\n return {\n enabled: override.enabled,\n rules: override.rules ?? base?.rules,\n };\n}\n\n// eslint-disable-next-line complexity -- docs config has many optional fields requiring individual merge\nfunction mergeDocsConfig(\n base: ProcessConfig[\"docs\"],\n override: ProcessConfig[\"docs\"]\n): ProcessConfig[\"docs\"] {\n if (!override) {\n return base;\n }\n // Fields with schema defaults: enabled, path, enforcement, staleness_days\n return {\n enabled: override.enabled,\n path: override.path,\n enforcement: override.enforcement,\n allowlist: override.allowlist ?? base?.allowlist,\n max_files: override.max_files ?? base?.max_files,\n max_file_lines: override.max_file_lines ?? base?.max_file_lines,\n max_total_kb: override.max_total_kb ?? base?.max_total_kb,\n staleness_days: override.staleness_days,\n stale_mappings: override.stale_mappings ?? base?.stale_mappings,\n min_coverage: override.min_coverage ?? base?.min_coverage,\n coverage_paths: override.coverage_paths ?? base?.coverage_paths,\n exclude_patterns: override.exclude_patterns ?? base?.exclude_patterns,\n types: override.types ?? base?.types,\n };\n}\n\n// eslint-disable-next-line complexity -- merging all process config sections requires multiple calls\nfunction mergeProcessSection(\n base: ProcessConfig | undefined,\n override: ProcessConfig\n): ProcessConfig {\n return {\n hooks: mergeHooksConfig(base?.hooks, override.hooks),\n ci: mergeCiConfig(base?.ci, override.ci),\n branches: mergeBranchesConfig(base?.branches, override.branches),\n commits: mergeCommitsConfig(base?.commits, override.commits),\n changesets: mergeChangesetsConfig(base?.changesets, override.changesets),\n pr: mergePrConfig(base?.pr, override.pr),\n tickets: mergeTicketsConfig(base?.tickets, override.tickets),\n coverage: mergeCoverageConfig(base?.coverage, override.coverage),\n repo: mergeRepoConfig(base?.repo, override.repo),\n backups: mergeBackupsConfig(base?.backups, override.backups),\n codeowners: mergeCodeownersConfig(base?.codeowners, override.codeowners),\n docs: mergeDocsConfig(base?.docs, override.docs),\n };\n}\n\nexport function mergeConfigs(base: Config, override: Config): Config {\n const merged: Config = { ...base };\n\n if (override.code) {\n merged.code = mergeCodeSection(base.code, override.code);\n }\n\n if (override.process) {\n merged.process = mergeProcessSection(base.process, override.process);\n }\n\n if (override.infra) {\n merged.infra = override.infra;\n }\n\n if (override.monorepo) {\n merged.monorepo = override.monorepo;\n }\n\n return merged;\n}\n\nexport async function resolveExtends(config: Config, configDir: string): Promise<Config> {\n if (!config.extends) {\n return config;\n }\n\n const { registry, rulesets } = config.extends;\n const location = parseRegistryUrl(registry, configDir);\n const registryDir = await fetchRegistry(location);\n\n let mergedConfig: Config = {};\n for (const rulesetName of rulesets) {\n const ruleset = loadRuleset(registryDir, rulesetName);\n mergedConfig = mergeConfigs(mergedConfig, ruleset);\n }\n\n // Local config overrides registry config (include all domains)\n const localConfig: Config = {\n code: config.code,\n process: config.process,\n infra: config.infra,\n monorepo: config.monorepo,\n };\n return mergeConfigs(mergedConfig, localConfig);\n}\n","import * as fs from \"node:fs\";\nimport * as path from \"node:path\";\n\nimport TOML from \"@iarna/toml\";\n\nimport { resolveExtends } from \"./registry.js\";\nimport { type Config, configSchema, defaultConfig } from \"./schema.js\";\n\n/** Config file name */\nexport const CONFIG_FILE_NAME = \"standards.toml\";\n\ninterface LoadConfigResult {\n config: Config;\n configPath: string;\n}\n\nexport class ConfigError extends Error {\n constructor(message: string) {\n super(message);\n this.name = \"ConfigError\";\n }\n}\n\n/**\n * Check if a path is a broken symlink\n */\nfunction isBrokenSymlink(filePath: string): boolean {\n try {\n const stats = fs.lstatSync(filePath);\n if (stats.isSymbolicLink()) {\n // It's a symlink - check if target exists\n try {\n fs.statSync(filePath);\n return false; // Target exists, not broken\n } catch {\n return true; // Target doesn't exist, broken symlink\n }\n }\n return false; // Not a symlink\n } catch {\n return false; // Path doesn't exist at all\n }\n}\n\n/**\n * Find standards.toml by walking up the directory tree\n */\nexport function findConfigFile(startDir: string = process.cwd()): string | null {\n let currentDir = path.resolve(startDir);\n const root = path.parse(currentDir).root;\n\n while (currentDir !== root) {\n const configPath = path.join(currentDir, CONFIG_FILE_NAME);\n if (isBrokenSymlink(configPath)) {\n throw new ConfigError(`${CONFIG_FILE_NAME} exists but is a broken symlink: ${configPath}`);\n }\n if (fs.existsSync(configPath)) {\n return configPath;\n }\n currentDir = path.dirname(currentDir);\n }\n\n // Check root directory too\n const rootConfig = path.join(root, CONFIG_FILE_NAME);\n if (isBrokenSymlink(rootConfig)) {\n throw new ConfigError(`${CONFIG_FILE_NAME} exists but is a broken symlink: ${rootConfig}`);\n }\n return fs.existsSync(rootConfig) ? rootConfig : null;\n}\n\n/**\n * Resolve and validate config file path\n * Always returns an absolute path to ensure consistent behavior\n */\nfunction resolveConfigPath(configPath?: string): string {\n const resolved = configPath ?? findConfigFile();\n if (!resolved) {\n throw new ConfigError(`No ${CONFIG_FILE_NAME} found. Create one or specify --config path.`);\n }\n // Convert to absolute path for consistent behavior across tools\n const absolutePath = path.resolve(resolved);\n if (!fs.existsSync(absolutePath)) {\n throw new ConfigError(`Config file not found: ${resolved}`);\n }\n return absolutePath;\n}\n\n/**\n * Parse TOML file content\n */\nfunction parseTomlFile(filePath: string): unknown {\n try {\n const content = fs.readFileSync(filePath, \"utf-8\");\n return TOML.parse(content);\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Unknown error\";\n throw new ConfigError(`Failed to parse ${CONFIG_FILE_NAME}: ${message}`);\n }\n}\n\n/**\n * Validate config against schema\n */\nfunction validateConfig(rawConfig: unknown): Config {\n const result = configSchema.safeParse(rawConfig);\n if (!result.success) {\n const errors = result.error.errors\n .map((e) => ` - ${e.path.join(\".\")}: ${e.message}`)\n .join(\"\\n\");\n throw new ConfigError(`Invalid ${CONFIG_FILE_NAME} configuration:\\n${errors}`);\n }\n return result.data;\n}\n\n/**\n * Load and parse standards.toml configuration (sync version without extends resolution)\n * Use loadConfigAsync for full extends support\n */\nexport function loadConfig(configPath?: string): LoadConfigResult {\n const resolvedPath = resolveConfigPath(configPath);\n const rawConfig = parseTomlFile(resolvedPath);\n const validatedConfig = validateConfig(rawConfig);\n const config = mergeWithDefaults(validatedConfig);\n return { config, configPath: resolvedPath };\n}\n\n/**\n * Load and parse standards.toml configuration with extends resolution\n */\nexport async function loadConfigAsync(configPath?: string): Promise<LoadConfigResult> {\n const resolvedPath = resolveConfigPath(configPath);\n const rawConfig = parseTomlFile(resolvedPath);\n const validatedConfig = validateConfig(rawConfig);\n\n // Resolve extends if present\n const configDir = path.dirname(resolvedPath);\n const resolvedConfig = await resolveExtends(validatedConfig, configDir);\n\n const config = mergeWithDefaults(resolvedConfig);\n return { config, configPath: resolvedPath };\n}\n\n/** Merge two optional objects, with right side taking precedence */\nfunction merge<T extends object>(a: T | undefined, b: T | undefined): T {\n return { ...a, ...b } as T;\n}\n\ntype CodeConfig = NonNullable<Config[\"code\"]>;\n\nfunction mergeLinting(c: Config, dc: Config): CodeConfig[\"linting\"] {\n const cl = c.code?.linting;\n const dl = dc.code?.linting;\n return { eslint: merge(dl?.eslint, cl?.eslint), ruff: merge(dl?.ruff, cl?.ruff) };\n}\n\nfunction mergeSecurity(c: Config, dc: Config): CodeConfig[\"security\"] {\n const cs = c.code?.security;\n const ds = dc.code?.security;\n return {\n secrets: merge(ds?.secrets, cs?.secrets),\n pnpmaudit: merge(ds?.pnpmaudit, cs?.pnpmaudit),\n pipaudit: merge(ds?.pipaudit, cs?.pipaudit),\n };\n}\n\nfunction mergeTypes(c: Config, dc: Config): CodeConfig[\"types\"] {\n return {\n tsc: merge(dc.code?.types?.tsc, c.code?.types?.tsc),\n ty: merge(dc.code?.types?.ty, c.code?.types?.ty),\n };\n}\n\nfunction mergeUnused(c: Config, dc: Config): CodeConfig[\"unused\"] {\n return {\n knip: merge(dc.code?.unused?.knip, c.code?.unused?.knip),\n vulture: merge(dc.code?.unused?.vulture, c.code?.unused?.vulture),\n };\n}\n\nfunction mergeCoverageRun(c: Config, dc: Config): CodeConfig[\"coverage_run\"] {\n return merge(dc.code?.coverage_run, c.code?.coverage_run);\n}\n\nfunction mergeNaming(c: Config, dc: Config): CodeConfig[\"naming\"] {\n const cn = c.code?.naming;\n const dn = dc.code?.naming;\n // For naming, we want to preserve the rules array from user config\n return {\n enabled: cn?.enabled ?? dn?.enabled ?? false,\n rules: cn?.rules ?? dn?.rules,\n };\n}\n\nfunction mergeQuality(c: Config, dc: Config): CodeConfig[\"quality\"] {\n const cq = c.code?.quality;\n const dq = dc.code?.quality;\n return {\n \"disable-comments\": merge(dq?.[\"disable-comments\"], cq?.[\"disable-comments\"]),\n };\n}\n\nfunction mergeCode(c: Config, dc: Config): CodeConfig {\n return {\n linting: mergeLinting(c, dc),\n types: mergeTypes(c, dc),\n unused: mergeUnused(c, dc),\n coverage_run: mergeCoverageRun(c, dc),\n security: mergeSecurity(c, dc),\n naming: mergeNaming(c, dc),\n quality: mergeQuality(c, dc),\n };\n}\n\ntype ProcessConfig = NonNullable<Config[\"process\"]>;\ntype HooksConfig = NonNullable<ProcessConfig[\"hooks\"]>;\ntype CiConfig = NonNullable<ProcessConfig[\"ci\"]>;\ntype BranchesConfig = NonNullable<ProcessConfig[\"branches\"]>;\ntype CommitsConfig = NonNullable<ProcessConfig[\"commits\"]>;\ntype ChangesetsConfig = NonNullable<ProcessConfig[\"changesets\"]>;\ntype PrConfig = NonNullable<ProcessConfig[\"pr\"]>;\ntype TicketsConfig = NonNullable<ProcessConfig[\"tickets\"]>;\ntype CoverageConfig = NonNullable<ProcessConfig[\"coverage\"]>;\ntype RepoConfig = NonNullable<ProcessConfig[\"repo\"]>;\ntype BackupsConfig = NonNullable<ProcessConfig[\"backups\"]>;\ntype CodeownersConfig = NonNullable<ProcessConfig[\"codeowners\"]>;\ntype DocsConfig = NonNullable<ProcessConfig[\"docs\"]>;\ntype ForbiddenFilesConfig = NonNullable<ProcessConfig[\"forbidden_files\"]>;\n\nconst defaultHooks: HooksConfig = { enabled: false, require_husky: true };\nconst defaultCi: CiConfig = { enabled: false };\nconst defaultBranches: BranchesConfig = { enabled: false, require_issue: false };\nconst defaultCommits: CommitsConfig = { enabled: false, require_scope: false };\nconst defaultChangesets: ChangesetsConfig = {\n enabled: false,\n validate_format: true,\n require_description: true,\n};\nconst defaultPr: PrConfig = { enabled: false, require_issue: false };\nconst defaultTickets: TicketsConfig = {\n enabled: false,\n require_in_commits: true,\n require_in_branch: false,\n};\nconst defaultCoverage: CoverageConfig = { enabled: false, enforce_in: \"config\" };\nconst defaultRepo: RepoConfig = {\n enabled: false,\n require_branch_protection: false,\n require_codeowners: false,\n};\nconst defaultBackups: BackupsConfig = { enabled: false, max_age_hours: 24 };\nconst defaultCodeowners: CodeownersConfig = { enabled: false };\nconst defaultDocs: DocsConfig = {\n enabled: false,\n path: \"docs/\",\n enforcement: \"warn\",\n staleness_days: 30,\n};\nconst defaultForbiddenFiles: ForbiddenFilesConfig = { enabled: false };\n\n/** Merge a single process config section with defaults */\nfunction mergeProcessSection<T>(defaultVal: T, dcVal: T | undefined, cVal: T | undefined): T {\n return { ...defaultVal, ...dcVal, ...cVal };\n}\n\nfunction mergeProcessHooks(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): HooksConfig {\n return mergeProcessSection(defaultHooks, dcp?.hooks, cp?.hooks);\n}\n\nfunction mergeProcessCi(cp: ProcessConfig | undefined, dcp: ProcessConfig | undefined): CiConfig {\n return mergeProcessSection(defaultCi, dcp?.ci, cp?.ci);\n}\n\nfunction mergeProcessBranches(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): BranchesConfig {\n return mergeProcessSection(defaultBranches, dcp?.branches, cp?.branches);\n}\n\nfunction mergeProcessCommits(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CommitsConfig {\n return mergeProcessSection(defaultCommits, dcp?.commits, cp?.commits);\n}\n\nfunction mergeProcessChangesets(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): ChangesetsConfig {\n return mergeProcessSection(defaultChangesets, dcp?.changesets, cp?.changesets);\n}\n\nfunction mergeProcessPr(cp: ProcessConfig | undefined, dcp: ProcessConfig | undefined): PrConfig {\n return mergeProcessSection(defaultPr, dcp?.pr, cp?.pr);\n}\n\nfunction mergeProcessTickets(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): TicketsConfig {\n return mergeProcessSection(defaultTickets, dcp?.tickets, cp?.tickets);\n}\n\nfunction mergeProcessCoverage(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CoverageConfig {\n return mergeProcessSection(defaultCoverage, dcp?.coverage, cp?.coverage);\n}\n\nfunction mergeProcessRepo(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): RepoConfig {\n return mergeProcessSection(defaultRepo, dcp?.repo, cp?.repo);\n}\n\nfunction mergeProcessBackups(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): BackupsConfig {\n return mergeProcessSection(defaultBackups, dcp?.backups, cp?.backups);\n}\n\nfunction mergeProcessCodeowners(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): CodeownersConfig {\n const cco = cp?.codeowners;\n const dco = dcp?.codeowners;\n // Merge rules arrays: registry rules + project rules (deduplicated by pattern)\n const registryRules = dco?.rules ?? [];\n const projectRules = cco?.rules ?? [];\n // Project rules can override registry rules for the same pattern\n const ruleMap = new Map<string, { pattern: string; owners: string[] }>();\n for (const rule of registryRules) {\n ruleMap.set(rule.pattern, rule);\n }\n for (const rule of projectRules) {\n ruleMap.set(rule.pattern, rule);\n }\n const mergedRules = Array.from(ruleMap.values());\n return {\n ...defaultCodeowners,\n ...dco,\n ...cco,\n rules: mergedRules.length > 0 ? mergedRules : undefined,\n };\n}\n\nfunction mergeProcessDocs(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): DocsConfig {\n return mergeProcessSection(defaultDocs, dcp?.docs, cp?.docs);\n}\n\nfunction mergeProcessForbiddenFiles(\n cp: ProcessConfig | undefined,\n dcp: ProcessConfig | undefined\n): ForbiddenFilesConfig {\n return mergeProcessSection(defaultForbiddenFiles, dcp?.forbidden_files, cp?.forbidden_files);\n}\n\nfunction mergeProcess(c: Config, dc: Config): ProcessConfig {\n return {\n hooks: mergeProcessHooks(c.process, dc.process),\n ci: mergeProcessCi(c.process, dc.process),\n branches: mergeProcessBranches(c.process, dc.process),\n commits: mergeProcessCommits(c.process, dc.process),\n changesets: mergeProcessChangesets(c.process, dc.process),\n pr: mergeProcessPr(c.process, dc.process),\n tickets: mergeProcessTickets(c.process, dc.process),\n coverage: mergeProcessCoverage(c.process, dc.process),\n repo: mergeProcessRepo(c.process, dc.process),\n backups: mergeProcessBackups(c.process, dc.process),\n codeowners: mergeProcessCodeowners(c.process, dc.process),\n docs: mergeProcessDocs(c.process, dc.process),\n forbidden_files: mergeProcessForbiddenFiles(c.process, dc.process),\n };\n}\n\n/**\n * Deep merge config with defaults\n */\nfunction mergeWithDefaults(config: Config): Config {\n return {\n code: mergeCode(config, defaultConfig),\n process: mergeProcess(config, defaultConfig),\n infra: {\n enabled: config.infra?.enabled ?? defaultConfig.infra?.enabled ?? false,\n manifest: config.infra?.manifest ?? defaultConfig.infra?.manifest ?? \"infra-manifest.json\",\n },\n monorepo: config.monorepo,\n };\n}\n\n/**\n * Get the project root directory (where standards.toml is located)\n */\nexport function getProjectRoot(configPath: string): string {\n return path.dirname(configPath);\n}\n\n/** Information about a config override */\nexport interface ConfigOverride {\n section: string;\n key: string;\n registryValue: string;\n projectValue: string;\n}\n\n/** Check if a project rule overrides a registry rule */\nfunction checkRuleOverride(\n projectRule: { pattern: string; owners: string[] },\n registryOwners: string[] | undefined\n): ConfigOverride | null {\n if (!registryOwners) {\n return null;\n }\n const registryStr = registryOwners.join(\" \");\n const projectStr = projectRule.owners.join(\" \");\n if (registryStr === projectStr) {\n return null;\n }\n return {\n section: \"process.codeowners.rules\",\n key: projectRule.pattern,\n registryValue: registryStr,\n projectValue: projectStr,\n };\n}\n\n/** Detect CODEOWNERS rule overrides between registry and project config */\nfunction detectCodeownersOverrides(\n registryConfig: Config | undefined,\n projectConfig: Config | undefined\n): ConfigOverride[] {\n const registryRules = registryConfig?.process?.codeowners?.rules ?? [];\n const projectRules = projectConfig?.process?.codeowners?.rules ?? [];\n const registryMap = new Map(registryRules.map((r) => [r.pattern, r.owners]));\n\n return projectRules\n .map((rule) => checkRuleOverride(rule, registryMap.get(rule.pattern)))\n .filter((o): o is ConfigOverride => o !== null);\n}\n\n/** Load registry config from extends */\nasync function loadRegistryConfig(\n extendsConfig: NonNullable<Config[\"extends\"]>,\n configDir: string\n): Promise<Config> {\n const registryModule = await import(\"./registry.js\");\n const loc = registryModule.parseRegistryUrl(extendsConfig.registry, configDir);\n const registryDir = await registryModule.fetchRegistry(loc);\n\n let config: Config = {};\n for (const name of extendsConfig.rulesets) {\n config = registryModule.mergeConfigs(config, registryModule.loadRuleset(registryDir, name));\n }\n return config;\n}\n\n/**\n * Load config and detect any overrides from registry\n * Returns both the merged config and information about overrides\n */\nexport async function loadConfigWithOverrides(\n configPath?: string\n): Promise<LoadConfigResult & { overrides: ConfigOverride[] }> {\n const resolvedPath = resolveConfigPath(configPath);\n const validatedConfig = validateConfig(parseTomlFile(resolvedPath));\n\n let overrides: ConfigOverride[] = [];\n if (validatedConfig.extends) {\n const registryConfig = await loadRegistryConfig(\n validatedConfig.extends,\n path.dirname(resolvedPath)\n );\n overrides = detectCodeownersOverrides(registryConfig, validatedConfig);\n }\n\n const { config, configPath: finalPath } = await loadConfigAsync(configPath);\n return { config, configPath: finalPath, overrides };\n}\n","/* eslint-disable max-lines -- schema file contains all domain schemas and grows with features */\nimport { minimatch } from \"minimatch\";\nimport { z } from \"zod\";\n\n/**\n * Count unclosed brackets and braces in a pattern, respecting escapes.\n */\nfunction countUnclosedDelimiters(pattern: string): { brackets: number; braces: number } {\n let brackets = 0;\n let braces = 0;\n for (let i = 0; i < pattern.length; i++) {\n if (pattern[i] === \"\\\\\" && i + 1 < pattern.length) {\n i++; // Skip escaped character\n continue;\n }\n switch (pattern[i]) {\n case \"[\":\n brackets++;\n break;\n case \"]\":\n if (brackets > 0) {\n brackets--;\n }\n break;\n case \"{\":\n braces++;\n break;\n case \"}\":\n if (braces > 0) {\n braces--;\n }\n break;\n }\n }\n return { brackets, braces };\n}\n\n/**\n * Validate that a string is a valid glob pattern.\n * Checks for balanced brackets/braces since minimatch is too lenient.\n */\nfunction isValidGlobPattern(pattern: string): { valid: boolean; error?: string } {\n if (pattern.length === 0) {\n return { valid: false, error: \"empty pattern\" };\n }\n\n const unclosed = countUnclosedDelimiters(pattern);\n if (unclosed.brackets > 0) {\n return { valid: false, error: \"unclosed bracket '['\" };\n }\n if (unclosed.braces > 0) {\n return { valid: false, error: \"unclosed brace '{'\" };\n }\n\n try {\n const result = minimatch.makeRe(pattern);\n return result === false ? { valid: false, error: \"invalid pattern syntax\" } : { valid: true };\n } catch (error) {\n const message = error instanceof Error ? error.message : \"Invalid glob pattern\";\n return { valid: false, error: message };\n }\n}\n\n/**\n * Zod schema for a valid glob pattern string\n */\nconst globPatternSchema = z.string().refine(\n (pattern) => isValidGlobPattern(pattern).valid,\n (pattern) => ({\n message: `Invalid glob pattern: \"${pattern}\" - ${isValidGlobPattern(pattern).error}`,\n })\n);\n\n/**\n * Zod schema for standards.toml configuration\n */\n\n// =============================================================================\n// ESLint Configuration\n// =============================================================================\n\n/** ESLint rule severity */\nconst eslintRuleSeverity = z.enum([\"off\", \"warn\", \"error\"]);\n\n/**\n * ESLint rule with options in TOML-friendly object format.\n * Example: { severity = \"error\", max = 10 }\n * The 'severity' key is required, all other keys are rule-specific options.\n */\nconst eslintRuleWithOptions = z\n .object({\n severity: eslintRuleSeverity,\n })\n .catchall(z.unknown()); // Allow any additional options (max, skipBlankLines, etc.)\n\n/**\n * ESLint rule value - can be:\n * - severity string: \"error\"\n * - object with severity and options: { severity: \"error\", max: 10 }\n */\nconst eslintRuleValue = z.union([eslintRuleSeverity, eslintRuleWithOptions]);\n\n/** ESLint rules configuration */\nconst eslintRulesSchema = z.record(z.string(), eslintRuleValue).optional();\n\n/** ESLint configuration */\nconst eslintConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(true),\n files: z.array(z.string()).optional(), // Glob patterns for files to lint\n ignore: z.array(z.string()).optional(), // Glob patterns to ignore\n \"max-warnings\": z.number().int().nonnegative().optional(), // Max warnings before failure\n rules: eslintRulesSchema, // Required rules for audit (verifies eslint.config.js)\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Ruff Configuration\n// =============================================================================\n\n/** Ruff lint configuration */\nconst ruffLintSchema = z\n .object({\n select: z.array(z.string()).optional(),\n ignore: z.array(z.string()).optional(),\n })\n .strict()\n .optional();\n\n/** Ruff configuration */\nconst ruffConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(true),\n \"line-length\": z.number().int().positive().optional(),\n lint: ruffLintSchema,\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// TypeScript Configuration\n// =============================================================================\n\n/** TypeScript compiler options that can be required via audit */\nconst tscCompilerOptionsSchema = z\n .object({\n strict: z.boolean().optional(),\n noImplicitAny: z.boolean().optional(),\n strictNullChecks: z.boolean().optional(),\n noUnusedLocals: z.boolean().optional(),\n noUnusedParameters: z.boolean().optional(),\n noImplicitReturns: z.boolean().optional(),\n noFallthroughCasesInSwitch: z.boolean().optional(),\n esModuleInterop: z.boolean().optional(),\n skipLibCheck: z.boolean().optional(),\n forceConsistentCasingInFileNames: z.boolean().optional(),\n })\n .strict()\n .optional();\n\n/** TypeScript compiler configuration */\nconst tscConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require: tscCompilerOptionsSchema, // Required compiler options for audit\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// ty Configuration (Python Type Checking)\n// =============================================================================\n\n/** ty Python type checker configuration */\nconst tyConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Knip Configuration (Unused Code Detection)\n// =============================================================================\n\n/** Knip configuration */\nconst knipConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Vulture Configuration (Python Dead Code Detection)\n// =============================================================================\n\n/** Vulture configuration */\nconst vultureConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Coverage Run Configuration\n// =============================================================================\n\n/** Coverage run test runner type */\nconst coverageRunnerSchema = z.enum([\"vitest\", \"jest\", \"pytest\", \"auto\"]);\n\n/** Coverage run configuration - runs tests and verifies coverage threshold */\nconst coverageRunConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n min_threshold: z.number().int().min(0).max(100).optional().default(80), // Minimum coverage percentage\n runner: coverageRunnerSchema.optional().default(\"auto\"), // Test runner to use\n command: z.string().optional(), // Custom command to run tests with coverage\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Security Configuration\n// =============================================================================\n\n/** Secrets (Gitleaks) configuration */\nconst secretsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n scan_mode: z\n .enum([\"branch\", \"files\", \"staged\", \"full\"])\n .optional()\n .default(\"branch\"), // branch: scan current branch commits, files: scan filesystem, staged: staged files only, full: entire git history\n base_branch: z.string().optional().default(\"main\"), // Branch to compare against for \"branch\" mode\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** pnpm audit configuration */\nconst pnpmauditConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n exclude_dev: z.boolean().optional().default(true),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** pip-audit configuration */\nconst pipauditConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n dependencies: z.array(z.string()).optional(), // Custom dependency files for drift tracking\n })\n .strict()\n .optional();\n\n/** Code security configuration */\nconst codeSecuritySchema = z\n .object({\n secrets: secretsConfigSchema,\n pnpmaudit: pnpmauditConfigSchema,\n pipaudit: pipauditConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Naming Conventions Configuration\n// =============================================================================\n\n/** Supported case types for naming conventions */\nconst caseTypeSchema = z.enum([\"kebab-case\", \"snake_case\", \"camelCase\", \"PascalCase\"]);\n\n/** Helper to validate no duplicate values in array */\nconst uniqueArraySchema = <T extends z.ZodTypeAny>(schema: T): z.ZodEffects<z.ZodArray<T>> =>\n z.array(schema).refine((arr) => new Set(arr).size === arr.length, {\n message: \"Duplicate values not allowed\",\n });\n\n/** Helper to validate no duplicate values in array with minimum length */\nconst uniqueArraySchemaMin1 = <T extends z.ZodTypeAny>(schema: T): z.ZodEffects<z.ZodArray<T>> =>\n z\n .array(schema)\n .min(1, \"At least one value is required\")\n .refine((arr) => new Set(arr).size === arr.length, {\n message: \"Duplicate values not allowed\",\n });\n\n/** Single naming rule */\nconst namingRuleSchema = z\n .object({\n extensions: uniqueArraySchemaMin1(z.string()), // e.g., [\"ts\", \"tsx\"] - no duplicates allowed, at least one required\n file_case: caseTypeSchema,\n folder_case: caseTypeSchema,\n exclude: z.array(z.string()).optional(), // Glob patterns to exclude, e.g., [\"tests/**\"]\n allow_dynamic_routes: z.boolean().optional(), // Allow Next.js/Remix dynamic route folders: [id], [...slug], (group)\n })\n .strict();\n\n/** Naming conventions configuration */\nconst namingConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n rules: z.array(namingRuleSchema).optional(),\n })\n .strict()\n .superRefine((data, ctx) => {\n if (!data.rules || data.rules.length <= 1) {\n return;\n }\n\n const extensionToRuleIndex = new Map<string, number>();\n for (let i = 0; i < data.rules.length; i++) {\n for (const ext of data.rules[i].extensions) {\n const existing = extensionToRuleIndex.get(ext);\n if (existing !== undefined) {\n ctx.addIssue({\n code: z.ZodIssueCode.custom,\n message: `Extension \"${ext}\" appears in multiple naming rules (rules ${existing + 1} and ${i + 1}). Each extension can only appear in one rule.`,\n path: [\"rules\", i, \"extensions\"],\n });\n } else {\n extensionToRuleIndex.set(ext, i);\n }\n }\n }\n })\n .optional();\n\n// =============================================================================\n// Quality Configuration (Disable Comments Detection)\n// =============================================================================\n\n/** Disable comments configuration */\nconst disableCommentsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n patterns: z.array(z.string()).optional(), // Override default patterns\n extensions: uniqueArraySchema(z.string()).optional(), // File extensions to scan - no duplicates allowed\n exclude: z.array(z.string()).optional(), // Glob patterns to exclude\n })\n .strict()\n .optional();\n\n/** Code quality configuration */\nconst codeQualitySchema = z\n .object({\n \"disable-comments\": disableCommentsConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Code Domain Configuration\n// =============================================================================\n\n/** Code linting configuration */\nconst codeLintingSchema = z\n .object({\n eslint: eslintConfigSchema,\n ruff: ruffConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code type checking configuration */\nconst codeTypesSchema = z\n .object({\n tsc: tscConfigSchema,\n ty: tyConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code unused detection configuration */\nconst codeUnusedSchema = z\n .object({\n knip: knipConfigSchema,\n vulture: vultureConfigSchema,\n })\n .strict()\n .optional();\n\n/** Code domain configuration */\nconst codeSchema = z\n .object({\n linting: codeLintingSchema,\n types: codeTypesSchema,\n unused: codeUnusedSchema,\n coverage_run: coverageRunConfigSchema,\n security: codeSecuritySchema,\n naming: namingConfigSchema,\n quality: codeQualitySchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Process Domain Configuration\n// =============================================================================\n\n/** Hook commands configuration - maps hook name to required commands */\nconst hookCommandsSchema = z.record(z.string(), z.array(z.string())).optional();\n\n/** Git hooks (husky) configuration */\nconst hooksConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_husky: z.boolean().optional().default(true), // Require .husky/ directory\n require_hooks: z.array(z.string()).optional(), // e.g., [\"pre-commit\", \"pre-push\"]\n commands: hookCommandsSchema, // e.g., { \"pre-commit\": [\"lint-staged\"] }\n protected_branches: z.array(z.string()).optional(), // e.g., [\"main\", \"master\"] - verify pre-push prevents direct pushes\n })\n .strict()\n .optional();\n\n/**\n * CI commands configuration value - can be:\n * - Array of strings: commands required anywhere in workflow\n * - Record mapping job names to arrays: commands required in specific jobs\n */\nconst ciCommandsValueSchema = z.union([\n z.array(z.string()), // Workflow-level: [\"cmd1\", \"cmd2\"]\n z.record(z.string(), z.array(z.string())), // Job-level: { jobName: [\"cmd1\"] }\n]);\n\n/** CI commands schema - maps workflow file to required commands */\nconst ciCommandsSchema = z.record(z.string(), ciCommandsValueSchema).optional();\n\n/** CI/CD workflows configuration */\nconst ciConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_workflows: z.array(z.string()).optional(), // e.g., [\"ci.yml\", \"release.yml\"]\n jobs: z.record(z.string(), z.array(z.string())).optional(), // e.g., { \"ci.yml\": [\"test\", \"lint\"] }\n actions: z.record(z.string(), z.array(z.string())).optional(), // e.g., { \"ci.yml\": [\"actions/checkout\"] }\n commands: ciCommandsSchema, // e.g., { \"ci.yml\": [\"conform code check\"] } or { \"ci.yml\": { \"test\": [\"npm test\"] } }\n })\n .strict()\n .optional();\n\n/** Branch naming configuration */\nconst branchesConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for branch names\n exclude: z.array(z.string()).optional(), // Branches to skip (e.g., [\"main\", \"master\"])\n require_issue: z.boolean().optional().default(false), // Require issue number in branch name\n issue_pattern: z.string().optional(), // Regex to extract issue number (default: captures number after type/)\n })\n .strict()\n .optional();\n\n/** Commit message format configuration */\nconst commitsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for commit messages (e.g., conventional commits)\n types: z.array(z.string()).optional(), // Allowed commit types (e.g., [\"feat\", \"fix\", \"chore\"])\n require_scope: z.boolean().optional().default(false), // Require scope like feat(api): ...\n max_subject_length: z.number().int().positive().optional(), // Max length of subject line\n })\n .strict()\n .optional();\n\n/** Changeset bump type */\nconst changesetBumpTypeSchema = z.enum([\"patch\", \"minor\", \"major\"]);\n\n/** Changeset validation configuration */\nconst changesetsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_for_paths: z.array(z.string()).optional(), // Glob patterns that require changesets (e.g., [\"src/**\"])\n exclude_paths: z.array(z.string()).optional(), // Paths that don't require changesets (e.g., [\"**/*.test.ts\"])\n validate_format: z.boolean().optional().default(true), // Validate changeset file format (frontmatter, description)\n allowed_bump_types: z.array(changesetBumpTypeSchema).optional(), // Restrict allowed bump types (e.g., [\"patch\", \"minor\"])\n require_description: z.boolean().optional().default(true), // Require non-empty description\n min_description_length: z.number().int().positive().optional(), // Minimum description length\n })\n .strict()\n .optional();\n\n/** PR configuration */\nconst prConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n max_files: z.number().int().positive().optional(), // Max files changed in PR\n max_lines: z.number().int().positive().optional(), // Max lines changed (additions + deletions)\n require_issue: z.boolean().optional().default(false), // Require issue reference in PR description\n issue_keywords: z.array(z.string()).optional(), // Keywords that link to issues (e.g., [\"Closes\", \"Fixes\", \"Resolves\"])\n exclude: z.array(globPatternSchema).optional(), // Glob patterns to exclude from size calculation (e.g., [\"*.lock\", \"**/*.snap\"])\n })\n .strict()\n .optional();\n\n/** Ticket reference validation configuration */\nconst ticketsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n pattern: z.string().optional(), // Regex pattern for ticket IDs (e.g., \"^(ABC|XYZ)-[0-9]+\")\n require_in_commits: z.boolean().optional().default(true), // Require ticket in commit messages\n require_in_branch: z.boolean().optional().default(false), // Require ticket in branch name\n })\n .strict()\n .optional();\n\n/** Coverage enforcement mode */\nconst coverageEnforceInSchema = z.enum([\"ci\", \"config\", \"both\"]);\n\n/** Coverage enforcement configuration */\nconst coverageConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n min_threshold: z.number().int().min(0).max(100).optional(), // Minimum coverage percentage\n enforce_in: coverageEnforceInSchema.optional().default(\"config\"), // Where to verify coverage\n ci_workflow: z.string().optional(), // Workflow file to check (e.g., \"ci.yml\")\n ci_job: z.string().optional(), // Job name to check (e.g., \"test\")\n })\n .strict()\n .optional();\n\n/** Bypass actor type for GitHub Rulesets */\nconst bypassActorTypeSchema = z.enum([\n \"Integration\", // GitHub App\n \"OrganizationAdmin\", // Org admin role\n \"RepositoryRole\", // Repository role (1=read, 2=triage, 3=write, 4=maintain, 5=admin)\n \"Team\", // GitHub team\n \"DeployKey\", // Deploy key\n]);\n\n/** Bypass mode - when the actor can bypass */\nconst bypassModeSchema = z.enum([\n \"always\", // Can always bypass\n \"pull_request\", // Can bypass only via pull request\n]);\n\n/** Single bypass actor configuration */\nconst bypassActorSchema = z\n .object({\n actor_type: bypassActorTypeSchema,\n actor_id: z.number().int().positive().optional(), // Actor ID (required except for DeployKey)\n bypass_mode: bypassModeSchema.optional().default(\"always\"),\n })\n .strict();\n\n/** Ruleset configuration (uses GitHub Rulesets API) */\nconst rulesetConfigSchema = z\n .object({\n name: z.string().optional().default(\"Branch Protection\"), // Ruleset name in GitHub\n branch: z.string().optional().default(\"main\"), // Branch to check (default: main)\n enforcement: z.enum([\"active\", \"evaluate\", \"disabled\"]).optional().default(\"active\"), // Ruleset enforcement\n required_reviews: z.number().int().min(0).optional(), // Minimum required reviews\n dismiss_stale_reviews: z.boolean().optional(), // Dismiss stale reviews on new commits\n require_code_owner_reviews: z.boolean().optional(), // Require CODEOWNER review\n require_status_checks: z.array(z.string()).optional(), // Required status checks\n require_branches_up_to_date: z.boolean().optional(), // Require branch to be up to date\n require_signed_commits: z.boolean().optional(), // Require signed commits\n enforce_admins: z.boolean().optional(), // Enforce rules for admins (no bypass actors when true)\n bypass_actors: z.array(bypassActorSchema).optional(), // Actors that can bypass rules\n })\n .strict()\n .optional();\n\n/** Tag protection ruleset configuration */\nconst tagProtectionConfigSchema = z\n .object({\n patterns: z.array(z.string()).optional(), // Tag patterns to protect (e.g., [\"v*\"])\n prevent_deletion: z.boolean().optional().default(true), // Prevent tag deletion\n prevent_update: z.boolean().optional().default(true), // Prevent tag updates (force-push)\n })\n .strict()\n .optional();\n\n/** Repository settings configuration */\nconst repoConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n require_branch_protection: z.boolean().optional().default(false), // Check branch protection exists\n require_codeowners: z.boolean().optional().default(false), // Check CODEOWNERS file exists\n ruleset: rulesetConfigSchema, // GitHub Ruleset configuration\n tag_protection: tagProtectionConfigSchema, // Tag protection via GitHub rulesets\n })\n .strict()\n .optional();\n\n/** S3 backup verification configuration */\nconst backupsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n bucket: z.string().optional(), // S3 bucket name\n prefix: z.string().optional(), // S3 key prefix\n max_age_hours: z.number().int().positive().optional().default(24), // Max age of most recent backup\n region: z.string().optional(), // AWS region (defaults to AWS_REGION env)\n })\n .strict()\n .optional();\n\n/** Single CODEOWNERS rule */\nconst codeownersRuleSchema = z\n .object({\n pattern: z.string(), // File pattern (e.g., \"/standards.toml\", \"*.js\", \"/src/api/*\")\n owners: z.array(z.string()), // Owner handles (e.g., [\"@user\", \"@org/team\"])\n })\n .strict();\n\n/** CODEOWNERS validation configuration */\nconst codeownersConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n rules: z.array(codeownersRuleSchema).optional(), // Required rules in CODEOWNERS\n })\n .strict()\n .optional();\n\n/** Doc type configuration - defines required sections and frontmatter per doc type */\nconst docsTypeConfigSchema = z\n .object({\n required_sections: z.array(z.string()).optional(), // e.g., [\"Overview\", \"Parameters\", \"Returns\", \"Examples\"]\n frontmatter: z.array(z.string()).optional(), // e.g., [\"title\", \"tracks\"]\n })\n .strict();\n\n/** Documentation enforcement mode */\nconst docsEnforcementSchema = z.enum([\"block\", \"warn\"]);\n\n/** Documentation governance configuration */\nconst docsConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n path: z.string().optional().default(\"docs/\"), // Documentation directory\n enforcement: docsEnforcementSchema.optional().default(\"warn\"), // \"block\" or \"warn\"\n allowlist: z.array(z.string()).optional(), // Markdown files allowed outside docs/, e.g., [\"README.md\", \"CLAUDE.md\"]\n max_files: z.number().int().positive().optional(), // Max markdown files in docs/\n max_file_lines: z.number().int().positive().optional(), // Max lines per markdown file\n max_total_kb: z.number().int().positive().optional(), // Max total size of docs/\n staleness_days: z.number().int().positive().optional().default(30), // Days before doc is considered stale\n stale_mappings: z.record(z.string(), z.string()).optional(), // Override doc-to-source mappings\n min_coverage: z.number().int().min(0).max(100).optional(), // Minimum API coverage percentage\n coverage_paths: z.array(z.string()).optional(), // Glob patterns for source files, e.g., [\"src/**/*.ts\"]\n exclude_patterns: z.array(z.string()).optional(), // Exclude from coverage, e.g., [\"**/*.test.ts\"]\n types: z.record(z.string(), docsTypeConfigSchema).optional(), // Per-type config, e.g., { api: {...}, guide: {...} }\n })\n .strict()\n .optional();\n\n// =============================================================================\n// MCP Configuration\n// =============================================================================\n\n/** MCP standards source configuration */\nconst mcpStandardsSchema = z\n .object({\n source: z\n .string()\n .optional()\n .describe(\n 'Standards repository source: \"github:owner/repo\", \"github:owner/repo@ref\", or local path'\n ),\n })\n .strict()\n .optional();\n\n/** MCP configuration */\nconst mcpSchema = z\n .object({\n standards: mcpStandardsSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Infra Domain Configuration\n// =============================================================================\n\n/** Infra domain configuration for AWS resource verification */\nconst infraSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n manifest: z.string().optional().default(\"infra-manifest.json\"), // Path to manifest file\n })\n .strict()\n .optional();\n\n/** Default ignore patterns for forbidden files scan */\nconst DEFAULT_FORBIDDEN_FILES_IGNORE = [\"**/node_modules/**\", \"**/.git/**\"];\n\n/** Forbidden files configuration - files that must NOT exist */\nconst forbiddenFilesConfigSchema = z\n .object({\n enabled: z.boolean().optional().default(false),\n files: z.array(globPatternSchema).optional(), // Glob patterns for files that must not exist (validated)\n ignore: z.array(globPatternSchema).optional(), // Glob patterns to ignore (validated, overrides defaults if provided)\n message: z.string().optional(), // Custom message explaining why these files are forbidden\n })\n .strict()\n .optional();\n\nexport { DEFAULT_FORBIDDEN_FILES_IGNORE };\n\n/** Process domain configuration */\nconst processSchema = z\n .object({\n hooks: hooksConfigSchema,\n ci: ciConfigSchema,\n branches: branchesConfigSchema,\n commits: commitsConfigSchema,\n changesets: changesetsConfigSchema,\n pr: prConfigSchema,\n tickets: ticketsConfigSchema,\n coverage: coverageConfigSchema,\n repo: repoConfigSchema,\n backups: backupsConfigSchema,\n codeowners: codeownersConfigSchema,\n docs: docsConfigSchema,\n forbidden_files: forbiddenFilesConfigSchema,\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Extends Configuration\n// =============================================================================\n\n/** Extends configuration for inheriting from registries */\nconst extendsSchema = z\n .object({\n registry: z.string(), // e.g., \"github:myorg/standards\" or local path\n rulesets: z.array(z.string()), // e.g., [\"base\", \"typescript\"]\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Monorepo Configuration\n// =============================================================================\n\n/** Monorepo project detection configuration */\nconst monorepoSchema = z\n .object({\n exclude: z.array(globPatternSchema).optional(), // Glob patterns to exclude from project detection\n })\n .strict()\n .optional();\n\n// =============================================================================\n// Full Configuration\n// =============================================================================\n\n/** Full standards.toml schema */\nexport const configSchema = z\n .object({\n extends: extendsSchema,\n code: codeSchema,\n process: processSchema,\n infra: infraSchema,\n mcp: mcpSchema,\n monorepo: monorepoSchema,\n })\n .strict();\n\n/** Inferred TypeScript type from schema */\nexport type Config = z.infer<typeof configSchema>;\n\n/** Default configuration */\nexport const defaultConfig: Config = {\n code: {\n linting: {\n eslint: { enabled: false },\n ruff: { enabled: false },\n },\n types: {\n tsc: { enabled: false },\n ty: { enabled: false },\n },\n unused: {\n knip: { enabled: false },\n vulture: { enabled: false },\n },\n coverage_run: {\n enabled: false,\n min_threshold: 80,\n runner: \"auto\",\n },\n security: {\n secrets: { enabled: false, scan_mode: \"branch\", base_branch: \"main\" },\n pnpmaudit: { enabled: false, exclude_dev: true },\n pipaudit: { enabled: false },\n },\n naming: {\n enabled: false,\n },\n quality: {\n \"disable-comments\": { enabled: false },\n },\n },\n monorepo: {},\n process: {\n hooks: {\n enabled: false,\n require_husky: true,\n },\n ci: {\n enabled: false,\n },\n branches: {\n enabled: false,\n require_issue: false,\n },\n commits: {\n enabled: false,\n require_scope: false,\n },\n changesets: {\n enabled: false,\n validate_format: true,\n require_description: true,\n },\n pr: {\n enabled: false,\n require_issue: false,\n },\n tickets: {\n enabled: false,\n require_in_commits: true,\n require_in_branch: false,\n },\n coverage: {\n enabled: false,\n enforce_in: \"config\",\n },\n repo: {\n enabled: false,\n require_branch_protection: false,\n require_codeowners: false,\n },\n backups: {\n enabled: false,\n max_age_hours: 24,\n },\n codeowners: {\n enabled: false,\n },\n docs: {\n enabled: false,\n path: \"docs/\",\n enforcement: \"warn\",\n staleness_days: 30,\n },\n forbidden_files: {\n enabled: false,\n },\n },\n infra: {\n enabled: false,\n manifest: \"infra-manifest.json\",\n },\n mcp: {\n standards: {\n source: undefined,\n },\n },\n};\n"],"mappings":"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","names":["fs","path","mergeLinting","mergeTypes","mergeUnused","mergeSecurity","mergeNaming","mergeQuality","mergeProcessSection"]}
|