@opsydyn/elysia-spectral 0.2.4 → 0.2.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +7 -0
- package/README.md +1 -1
- package/dist/core/index.mjs +1 -1
- package/dist/{core-Czin3kvK.mjs → core-CTQQBA_q.mjs} +13 -4
- package/dist/index.mjs +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,12 @@
|
|
|
1
1
|
# Changelog
|
|
2
2
|
|
|
3
|
+
## [0.2.5](https://github.com/opsydyn/elysia-spectral/compare/v0.2.4...v0.2.5) (2026-04-14)
|
|
4
|
+
|
|
5
|
+
|
|
6
|
+
### Bug Fixes
|
|
7
|
+
|
|
8
|
+
* deep-merge partial rule overrides in mergeRulesets ([4308196](https://github.com/opsydyn/elysia-spectral/commit/4308196ad4b017d94ac015239c51815c26cafb20))
|
|
9
|
+
|
|
3
10
|
## [0.2.4](https://github.com/opsydyn/elysia-spectral/compare/v0.2.3...v0.2.4) (2026-04-14)
|
|
4
11
|
|
|
5
12
|
|
package/README.md
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<p align="center">
|
|
2
|
-
<img src="https://raw.githubusercontent.com/opsydyn/elysia-spectral/main/
|
|
2
|
+
<img src="https://raw.githubusercontent.com/opsydyn/elysia-spectral/main/repo_header_graphic.png" alt="@opsydyn/elysia-spectral" width="480" />
|
|
3
3
|
</p>
|
|
4
4
|
|
|
5
5
|
# @opsydyn/elysia-spectral
|
package/dist/core/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
import { a as OpenApiLintThresholdError, c as shouldFail, d as defaultRulesetResolvers, f as loadResolvedRuleset, h as normalizeFindings, i as resolveStartupMode, m as lintOpenApi, n as createOpenApiLintRuntime, o as enforceThreshold, p as loadRuleset, r as isEnabled, s as exceedsThreshold, t as OpenApiLintArtifactWriteError, u as RulesetLoadError } from "../core-
|
|
1
|
+
import { a as OpenApiLintThresholdError, c as shouldFail, d as defaultRulesetResolvers, f as loadResolvedRuleset, h as normalizeFindings, i as resolveStartupMode, m as lintOpenApi, n as createOpenApiLintRuntime, o as enforceThreshold, p as loadRuleset, r as isEnabled, s as exceedsThreshold, t as OpenApiLintArtifactWriteError, u as RulesetLoadError } from "../core-CTQQBA_q.mjs";
|
|
2
2
|
export { OpenApiLintArtifactWriteError, OpenApiLintThresholdError, RulesetLoadError, createOpenApiLintRuntime, defaultRulesetResolvers, enforceThreshold, exceedsThreshold, isEnabled, lintOpenApi, loadResolvedRuleset, loadRuleset, normalizeFindings, resolveStartupMode, shouldFail };
|
|
@@ -344,15 +344,24 @@ const normalizeRulesetDefinition = (input, availableFunctions = functionMap) =>
|
|
|
344
344
|
if ("rules" in normalized) normalized.rules = normalizeRules(normalized.rules, availableFunctions);
|
|
345
345
|
return normalized;
|
|
346
346
|
};
|
|
347
|
+
const mergeRuleEntry = (base, override) => {
|
|
348
|
+
if (!isRecord(override)) return override;
|
|
349
|
+
if ("given" in override || "then" in override) return override;
|
|
350
|
+
if (isRecord(base) && ("given" in base || "then" in base)) return {
|
|
351
|
+
...base,
|
|
352
|
+
...override
|
|
353
|
+
};
|
|
354
|
+
const keys = Object.keys(override);
|
|
355
|
+
if (keys.length === 1 && keys[0] === "severity") return override.severity;
|
|
356
|
+
return override;
|
|
357
|
+
};
|
|
347
358
|
const mergeRulesets = (baseRuleset, overrideRuleset) => {
|
|
348
359
|
const mergedBase = baseRuleset;
|
|
349
360
|
const mergedOverride = overrideRuleset;
|
|
350
361
|
const baseRules = isRecord(mergedBase.rules) ? mergedBase.rules : {};
|
|
351
362
|
const overrideRules = isRecord(mergedOverride.rules) ? mergedOverride.rules : {};
|
|
352
|
-
const mergedRules = {
|
|
353
|
-
|
|
354
|
-
...overrideRules
|
|
355
|
-
};
|
|
363
|
+
const mergedRules = { ...baseRules };
|
|
364
|
+
for (const [name, overrideRule] of Object.entries(overrideRules)) mergedRules[name] = mergeRuleEntry(baseRules[name], overrideRule);
|
|
356
365
|
const baseExtends = toExtendsArray(mergedBase.extends);
|
|
357
366
|
const overrideExtends = toExtendsArray(mergedOverride.extends);
|
|
358
367
|
const mergedExtends = [...baseExtends, ...overrideExtends];
|
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { a as OpenApiLintThresholdError, c as shouldFail, d as defaultRulesetResolvers, f as loadResolvedRuleset, h as normalizeFindings, i as resolveStartupMode, l as resolveReporter, m as lintOpenApi, n as createOpenApiLintRuntime, o as enforceThreshold, p as loadRuleset, r as isEnabled, s as exceedsThreshold, t as OpenApiLintArtifactWriteError, u as RulesetLoadError } from "./core-
|
|
1
|
+
import { a as OpenApiLintThresholdError, c as shouldFail, d as defaultRulesetResolvers, f as loadResolvedRuleset, h as normalizeFindings, i as resolveStartupMode, l as resolveReporter, m as lintOpenApi, n as createOpenApiLintRuntime, o as enforceThreshold, p as loadRuleset, r as isEnabled, s as exceedsThreshold, t as OpenApiLintArtifactWriteError, u as RulesetLoadError } from "./core-CTQQBA_q.mjs";
|
|
2
2
|
import { Elysia } from "elysia";
|
|
3
3
|
//#region src/plugin.ts
|
|
4
4
|
const spectralPlugin = (options = {}) => {
|