@speclynx/apidom-reference 4.0.1 → 4.0.3
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 +10 -0
- package/package.json +26 -27
- package/src/File.cjs +50 -0
- package/src/File.mjs +44 -0
- package/src/File.ts +63 -0
- package/src/Reference.cjs +31 -0
- package/src/Reference.mjs +27 -0
- package/src/Reference.ts +38 -0
- package/src/ReferenceSet.cjs +60 -0
- package/src/ReferenceSet.mjs +57 -0
- package/src/ReferenceSet.ts +73 -0
- package/src/bundle/index.cjs +61 -0
- package/src/bundle/index.mjs +55 -0
- package/src/bundle/index.ts +57 -0
- package/src/bundle/strategies/BundleStrategy.cjs +20 -0
- package/src/bundle/strategies/BundleStrategy.mjs +16 -0
- package/src/bundle/strategies/BundleStrategy.ts +27 -0
- package/src/bundle/strategies/openapi-3-1/index.cjs +35 -0
- package/src/bundle/strategies/openapi-3-1/index.mjs +29 -0
- package/src/bundle/strategies/openapi-3-1/index.ts +57 -0
- package/src/configuration/empty.cjs +9 -0
- package/src/configuration/empty.mjs +1 -0
- package/src/configuration/empty.ts +1 -0
- package/src/configuration/saturated.cjs +88 -0
- package/src/configuration/saturated.mjs +80 -0
- package/src/configuration/saturated.ts +72 -0
- package/src/dereference/index.cjs +90 -0
- package/src/dereference/index.mjs +83 -0
- package/src/dereference/index.ts +96 -0
- package/src/dereference/strategies/DereferenceStrategy.cjs +20 -0
- package/src/dereference/strategies/DereferenceStrategy.mjs +16 -0
- package/src/dereference/strategies/DereferenceStrategy.ts +27 -0
- package/src/dereference/strategies/apidom/index.cjs +89 -0
- package/src/dereference/strategies/apidom/index.mjs +83 -0
- package/src/dereference/strategies/apidom/index.ts +128 -0
- package/src/dereference/strategies/apidom/selectors/element-id.cjs +47 -0
- package/src/dereference/strategies/apidom/selectors/element-id.mjs +41 -0
- package/src/dereference/strategies/apidom/selectors/element-id.ts +48 -0
- package/src/dereference/strategies/apidom/visitor.cjs +266 -0
- package/src/dereference/strategies/apidom/visitor.mjs +259 -0
- package/src/dereference/strategies/apidom/visitor.ts +316 -0
- package/src/dereference/strategies/arazzo-1/index.cjs +109 -0
- package/src/dereference/strategies/arazzo-1/index.mjs +100 -0
- package/src/dereference/strategies/arazzo-1/index.ts +158 -0
- package/src/dereference/strategies/arazzo-1/selectors/$anchor.cjs +12 -0
- package/src/dereference/strategies/arazzo-1/selectors/$anchor.mjs +1 -0
- package/src/dereference/strategies/arazzo-1/selectors/$anchor.ts +9 -0
- package/src/dereference/strategies/arazzo-1/selectors/uri.cjs +8 -0
- package/src/dereference/strategies/arazzo-1/selectors/uri.mjs +1 -0
- package/src/dereference/strategies/arazzo-1/selectors/uri.ts +5 -0
- package/src/dereference/strategies/arazzo-1/source-descriptions.cjs +248 -0
- package/src/dereference/strategies/arazzo-1/source-descriptions.mjs +243 -0
- package/src/dereference/strategies/arazzo-1/source-descriptions.ts +317 -0
- package/src/dereference/strategies/arazzo-1/util.cjs +37 -0
- package/src/dereference/strategies/arazzo-1/util.mjs +29 -0
- package/src/dereference/strategies/arazzo-1/util.ts +33 -0
- package/src/dereference/strategies/arazzo-1/visitor.cjs +507 -0
- package/src/dereference/strategies/arazzo-1/visitor.mjs +500 -0
- package/src/dereference/strategies/arazzo-1/visitor.ts +574 -0
- package/src/dereference/strategies/asyncapi-2/index.cjs +94 -0
- package/src/dereference/strategies/asyncapi-2/index.mjs +88 -0
- package/src/dereference/strategies/asyncapi-2/index.ts +133 -0
- package/src/dereference/strategies/asyncapi-2/visitor.cjs +501 -0
- package/src/dereference/strategies/asyncapi-2/visitor.mjs +494 -0
- package/src/dereference/strategies/asyncapi-2/visitor.ts +589 -0
- package/src/dereference/strategies/openapi-2/index.cjs +96 -0
- package/src/dereference/strategies/openapi-2/index.mjs +90 -0
- package/src/dereference/strategies/openapi-2/index.ts +136 -0
- package/src/dereference/strategies/openapi-2/visitor.cjs +629 -0
- package/src/dereference/strategies/openapi-2/visitor.mjs +622 -0
- package/src/dereference/strategies/openapi-2/visitor.ts +745 -0
- package/src/dereference/strategies/openapi-3-0/index.cjs +96 -0
- package/src/dereference/strategies/openapi-3-0/index.mjs +90 -0
- package/src/dereference/strategies/openapi-3-0/index.ts +134 -0
- package/src/dereference/strategies/openapi-3-0/visitor.cjs +622 -0
- package/src/dereference/strategies/openapi-3-0/visitor.mjs +615 -0
- package/src/dereference/strategies/openapi-3-0/visitor.ts +760 -0
- package/src/dereference/strategies/openapi-3-1/index.cjs +99 -0
- package/src/dereference/strategies/openapi-3-1/index.mjs +90 -0
- package/src/dereference/strategies/openapi-3-1/index.ts +141 -0
- package/src/dereference/strategies/openapi-3-1/selectors/$anchor.cjs +65 -0
- package/src/dereference/strategies/openapi-3-1/selectors/$anchor.mjs +54 -0
- package/src/dereference/strategies/openapi-3-1/selectors/$anchor.ts +64 -0
- package/src/dereference/strategies/openapi-3-1/selectors/uri.cjs +50 -0
- package/src/dereference/strategies/openapi-3-1/selectors/uri.mjs +42 -0
- package/src/dereference/strategies/openapi-3-1/selectors/uri.ts +54 -0
- package/src/dereference/strategies/openapi-3-1/util.cjs +68 -0
- package/src/dereference/strategies/openapi-3-1/util.mjs +59 -0
- package/src/dereference/strategies/openapi-3-1/util.ts +83 -0
- package/src/dereference/strategies/openapi-3-1/visitor.cjs +874 -0
- package/src/dereference/strategies/openapi-3-1/visitor.mjs +867 -0
- package/src/dereference/strategies/openapi-3-1/visitor.ts +1053 -0
- package/src/dereference/util.cjs +31 -0
- package/src/dereference/util.mjs +27 -0
- package/src/dereference/util.ts +29 -0
- package/src/errors/BundleError.cjs +10 -0
- package/src/errors/BundleError.mjs +7 -0
- package/src/errors/BundleError.ts +8 -0
- package/src/errors/DereferenceError.cjs +10 -0
- package/src/errors/DereferenceError.mjs +7 -0
- package/src/errors/DereferenceError.ts +8 -0
- package/src/errors/EvaluationElementIdError.cjs +10 -0
- package/src/errors/EvaluationElementIdError.mjs +7 -0
- package/src/errors/EvaluationElementIdError.ts +8 -0
- package/src/errors/EvaluationJsonSchema$anchorError.cjs +11 -0
- package/src/errors/EvaluationJsonSchema$anchorError.mjs +6 -0
- package/src/errors/EvaluationJsonSchema$anchorError.ts +8 -0
- package/src/errors/EvaluationJsonSchemaUriError.cjs +11 -0
- package/src/errors/EvaluationJsonSchemaUriError.mjs +6 -0
- package/src/errors/EvaluationJsonSchemaUriError.ts +8 -0
- package/src/errors/InvalidJsonSchema$anchorError.cjs +15 -0
- package/src/errors/InvalidJsonSchema$anchorError.mjs +10 -0
- package/src/errors/InvalidJsonSchema$anchorError.ts +12 -0
- package/src/errors/JsonSchema$anchorError.cjs +10 -0
- package/src/errors/JsonSchema$anchorError.mjs +7 -0
- package/src/errors/JsonSchema$anchorError.ts +8 -0
- package/src/errors/JsonSchemaUriError.cjs +10 -0
- package/src/errors/JsonSchemaUriError.mjs +7 -0
- package/src/errors/JsonSchemaUriError.ts +8 -0
- package/src/errors/MaximumBundleDepthError.cjs +11 -0
- package/src/errors/MaximumBundleDepthError.mjs +6 -0
- package/src/errors/MaximumBundleDepthError.ts +8 -0
- package/src/errors/MaximumDereferenceDepthError.cjs +11 -0
- package/src/errors/MaximumDereferenceDepthError.mjs +6 -0
- package/src/errors/MaximumDereferenceDepthError.ts +8 -0
- package/src/errors/MaximumResolveDepthError.cjs +11 -0
- package/src/errors/MaximumResolveDepthError.mjs +6 -0
- package/src/errors/MaximumResolveDepthError.ts +8 -0
- package/src/errors/ParseError.cjs +10 -0
- package/src/errors/ParseError.mjs +7 -0
- package/src/errors/ParseError.ts +8 -0
- package/src/errors/ParserError.cjs +11 -0
- package/src/errors/ParserError.mjs +6 -0
- package/src/errors/ParserError.ts +8 -0
- package/src/errors/PluginError.cjs +18 -0
- package/src/errors/PluginError.mjs +15 -0
- package/src/errors/PluginError.ts +15 -0
- package/src/errors/ResolveError.cjs +10 -0
- package/src/errors/ResolveError.mjs +7 -0
- package/src/errors/ResolveError.ts +8 -0
- package/src/errors/ResolverError.cjs +11 -0
- package/src/errors/ResolverError.mjs +6 -0
- package/src/errors/ResolverError.ts +8 -0
- package/src/errors/UnmatchedBundleStrategyError.cjs +11 -0
- package/src/errors/UnmatchedBundleStrategyError.mjs +6 -0
- package/src/errors/UnmatchedBundleStrategyError.ts +8 -0
- package/src/errors/UnmatchedDereferenceStrategyError.cjs +11 -0
- package/src/errors/UnmatchedDereferenceStrategyError.mjs +6 -0
- package/src/errors/UnmatchedDereferenceStrategyError.ts +8 -0
- package/src/errors/UnmatchedParserError.cjs +11 -0
- package/src/errors/UnmatchedParserError.mjs +6 -0
- package/src/errors/UnmatchedParserError.ts +8 -0
- package/src/errors/UnmatchedResolveStrategyError.cjs +11 -0
- package/src/errors/UnmatchedResolveStrategyError.mjs +6 -0
- package/src/errors/UnmatchedResolveStrategyError.ts +8 -0
- package/src/errors/UnmatchedResolverError.cjs +11 -0
- package/src/errors/UnmatchedResolverError.mjs +6 -0
- package/src/errors/UnmatchedResolverError.ts +8 -0
- package/src/errors/UnresolvableReferenceError.cjs +11 -0
- package/src/errors/UnresolvableReferenceError.mjs +6 -0
- package/src/errors/UnresolvableReferenceError.ts +8 -0
- package/src/index.cjs +146 -0
- package/src/index.mjs +103 -0
- package/src/index.ts +135 -0
- package/src/options/index.cjs +194 -0
- package/src/options/index.mjs +191 -0
- package/src/options/index.ts +239 -0
- package/src/options/util.cjs +24 -0
- package/src/options/util.mjs +19 -0
- package/src/options/util.ts +22 -0
- package/src/parse/index.cjs +69 -0
- package/src/parse/index.mjs +63 -0
- package/src/parse/index.ts +67 -0
- package/src/parse/parsers/Parser.cjs +62 -0
- package/src/parse/parsers/Parser.mjs +58 -0
- package/src/parse/parsers/Parser.ts +80 -0
- package/src/parse/parsers/apidom-json/index.cjs +70 -0
- package/src/parse/parsers/apidom-json/index.mjs +64 -0
- package/src/parse/parsers/apidom-json/index.ts +78 -0
- package/src/parse/parsers/arazzo-json-1/index.cjs +62 -0
- package/src/parse/parsers/arazzo-json-1/index.mjs +56 -0
- package/src/parse/parsers/arazzo-json-1/index.ts +76 -0
- package/src/parse/parsers/arazzo-json-1/source-descriptions.cjs +221 -0
- package/src/parse/parsers/arazzo-json-1/source-descriptions.mjs +214 -0
- package/src/parse/parsers/arazzo-json-1/source-descriptions.ts +280 -0
- package/src/parse/parsers/arazzo-yaml-1/index.cjs +62 -0
- package/src/parse/parsers/arazzo-yaml-1/index.mjs +56 -0
- package/src/parse/parsers/arazzo-yaml-1/index.ts +77 -0
- package/src/parse/parsers/arazzo-yaml-1/source-descriptions.cjs +12 -0
- package/src/parse/parsers/arazzo-yaml-1/source-descriptions.mjs +7 -0
- package/src/parse/parsers/arazzo-yaml-1/source-descriptions.ts +16 -0
- package/src/parse/parsers/asyncapi-json-2/index.cjs +54 -0
- package/src/parse/parsers/asyncapi-json-2/index.mjs +48 -0
- package/src/parse/parsers/asyncapi-json-2/index.ts +58 -0
- package/src/parse/parsers/asyncapi-yaml-2/index.cjs +54 -0
- package/src/parse/parsers/asyncapi-yaml-2/index.mjs +48 -0
- package/src/parse/parsers/asyncapi-yaml-2/index.ts +58 -0
- package/src/parse/parsers/binary/index-browser.cjs +56 -0
- package/src/parse/parsers/binary/index-browser.mjs +50 -0
- package/src/parse/parsers/binary/index-browser.ts +60 -0
- package/src/parse/parsers/binary/index-node.cjs +51 -0
- package/src/parse/parsers/binary/index-node.mjs +45 -0
- package/src/parse/parsers/binary/index-node.ts +57 -0
- package/src/parse/parsers/json/index.cjs +53 -0
- package/src/parse/parsers/json/index.mjs +47 -0
- package/src/parse/parsers/json/index.ts +52 -0
- package/src/parse/parsers/openapi-json-2/index.cjs +54 -0
- package/src/parse/parsers/openapi-json-2/index.mjs +48 -0
- package/src/parse/parsers/openapi-json-2/index.ts +58 -0
- package/src/parse/parsers/openapi-json-3-0/index.cjs +54 -0
- package/src/parse/parsers/openapi-json-3-0/index.mjs +48 -0
- package/src/parse/parsers/openapi-json-3-0/index.ts +59 -0
- package/src/parse/parsers/openapi-json-3-1/index.cjs +54 -0
- package/src/parse/parsers/openapi-json-3-1/index.mjs +48 -0
- package/src/parse/parsers/openapi-json-3-1/index.ts +59 -0
- package/src/parse/parsers/openapi-yaml-2/index.cjs +54 -0
- package/src/parse/parsers/openapi-yaml-2/index.mjs +48 -0
- package/src/parse/parsers/openapi-yaml-2/index.ts +58 -0
- package/src/parse/parsers/openapi-yaml-3-0/index.cjs +54 -0
- package/src/parse/parsers/openapi-yaml-3-0/index.mjs +48 -0
- package/src/parse/parsers/openapi-yaml-3-0/index.ts +59 -0
- package/src/parse/parsers/openapi-yaml-3-1/index.cjs +54 -0
- package/src/parse/parsers/openapi-yaml-3-1/index.mjs +48 -0
- package/src/parse/parsers/openapi-yaml-3-1/index.ts +59 -0
- package/src/parse/parsers/yaml-1-2/index.cjs +56 -0
- package/src/parse/parsers/yaml-1-2/index.mjs +50 -0
- package/src/parse/parsers/yaml-1-2/index.ts +60 -0
- package/src/resolve/index.cjs +67 -0
- package/src/resolve/index.mjs +60 -0
- package/src/resolve/index.ts +75 -0
- package/src/resolve/resolvers/HTTPResolver.cjs +45 -0
- package/src/resolve/resolvers/HTTPResolver.mjs +37 -0
- package/src/resolve/resolvers/HTTPResolver.ts +58 -0
- package/src/resolve/resolvers/Resolver.cjs +20 -0
- package/src/resolve/resolvers/Resolver.mjs +16 -0
- package/src/resolve/resolvers/Resolver.ts +25 -0
- package/src/resolve/resolvers/file/index-browser.cjs +24 -0
- package/src/resolve/resolvers/file/index-browser.mjs +19 -0
- package/src/resolve/resolvers/file/index-browser.ts +24 -0
- package/src/resolve/resolvers/file/index-node.cjs +49 -0
- package/src/resolve/resolvers/file/index-node.mjs +42 -0
- package/src/resolve/resolvers/file/index-node.ts +55 -0
- package/src/resolve/resolvers/http-axios/cache/MemoryCache.cjs +41 -0
- package/src/resolve/resolvers/http-axios/cache/MemoryCache.mjs +37 -0
- package/src/resolve/resolvers/http-axios/cache/MemoryCache.ts +46 -0
- package/src/resolve/resolvers/http-axios/index.cjs +113 -0
- package/src/resolve/resolvers/http-axios/index.mjs +105 -0
- package/src/resolve/resolvers/http-axios/index.ts +130 -0
- package/src/resolve/strategies/ResolveStrategy.cjs +20 -0
- package/src/resolve/strategies/ResolveStrategy.mjs +16 -0
- package/src/resolve/strategies/ResolveStrategy.ts +26 -0
- package/src/resolve/strategies/apidom/index.cjs +49 -0
- package/src/resolve/strategies/apidom/index.mjs +43 -0
- package/src/resolve/strategies/apidom/index.ts +78 -0
- package/src/resolve/strategies/asyncapi-2/index.cjs +49 -0
- package/src/resolve/strategies/asyncapi-2/index.mjs +43 -0
- package/src/resolve/strategies/asyncapi-2/index.ts +78 -0
- package/src/resolve/strategies/openapi-2/index.cjs +49 -0
- package/src/resolve/strategies/openapi-2/index.mjs +43 -0
- package/src/resolve/strategies/openapi-2/index.ts +78 -0
- package/src/resolve/strategies/openapi-3-0/index.cjs +49 -0
- package/src/resolve/strategies/openapi-3-0/index.mjs +43 -0
- package/src/resolve/strategies/openapi-3-0/index.ts +78 -0
- package/src/resolve/strategies/openapi-3-1/index.cjs +49 -0
- package/src/resolve/strategies/openapi-3-1/index.mjs +43 -0
- package/src/resolve/strategies/openapi-3-1/index.ts +78 -0
- package/src/resolve/util.cjs +37 -0
- package/src/resolve/util.mjs +30 -0
- package/src/resolve/util.ts +39 -0
- package/src/util/plugins.cjs +39 -0
- package/src/util/plugins.mjs +34 -0
- package/src/util/plugins.ts +37 -0
- package/src/util/url.cjs +288 -0
- package/src/util/url.mjs +274 -0
- package/src/util/url.ts +285 -0
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault").default;
|
|
4
|
+
exports.__esModule = true;
|
|
5
|
+
exports.default = void 0;
|
|
6
|
+
var _apidomDatamodel = require("@speclynx/apidom-datamodel");
|
|
7
|
+
var _apidomTraverse = require("@speclynx/apidom-traverse");
|
|
8
|
+
var _apidomNsOpenapi = require("@speclynx/apidom-ns-openapi-3-0");
|
|
9
|
+
var _DereferenceStrategy = _interopRequireDefault(require("../DereferenceStrategy.cjs"));
|
|
10
|
+
var _Reference = _interopRequireDefault(require("../../../Reference.cjs"));
|
|
11
|
+
var _ReferenceSet = _interopRequireDefault(require("../../../ReferenceSet.cjs"));
|
|
12
|
+
var _visitor = _interopRequireDefault(require("./visitor.cjs"));
|
|
13
|
+
exports.OpenAPI3_0DereferenceVisitor = _visitor.default;
|
|
14
|
+
/**
|
|
15
|
+
* @public
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* @public
|
|
20
|
+
*/
|
|
21
|
+
class OpenAPI3_0DereferenceStrategy extends _DereferenceStrategy.default {
|
|
22
|
+
constructor(options) {
|
|
23
|
+
super({
|
|
24
|
+
...(options ?? {}),
|
|
25
|
+
name: 'openapi-3-0'
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
canDereference(file) {
|
|
29
|
+
// assert by media type
|
|
30
|
+
if (file.mediaType !== 'text/plain') {
|
|
31
|
+
return _apidomNsOpenapi.mediaTypes.includes(file.mediaType);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
// assert by inspecting ApiDOM
|
|
35
|
+
return (0, _apidomNsOpenapi.isOpenApi3_0Element)(file.parseResult?.result);
|
|
36
|
+
}
|
|
37
|
+
async dereference(file, options) {
|
|
38
|
+
const immutableRefSet = options.dereference.refSet ?? new _ReferenceSet.default();
|
|
39
|
+
const mutableRefSet = new _ReferenceSet.default();
|
|
40
|
+
let refSet = immutableRefSet;
|
|
41
|
+
let reference;
|
|
42
|
+
|
|
43
|
+
// determine the initial reference
|
|
44
|
+
if (!immutableRefSet.has(file.uri)) {
|
|
45
|
+
reference = new _Reference.default({
|
|
46
|
+
uri: file.uri,
|
|
47
|
+
value: file.parseResult
|
|
48
|
+
});
|
|
49
|
+
immutableRefSet.add(reference);
|
|
50
|
+
} else {
|
|
51
|
+
// pre-computed refSet was provided as configuration option
|
|
52
|
+
reference = immutableRefSet.find(ref => ref.uri === file.uri);
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* Clone refSet due the dereferencing process being mutable.
|
|
57
|
+
* We don't want to mutate the original refSet and the references.
|
|
58
|
+
*/
|
|
59
|
+
if (options.dereference.immutable) {
|
|
60
|
+
immutableRefSet.refs.map(ref => new _Reference.default({
|
|
61
|
+
...ref,
|
|
62
|
+
value: (0, _apidomDatamodel.cloneDeep)(ref.value)
|
|
63
|
+
})).forEach(ref => mutableRefSet.add(ref));
|
|
64
|
+
reference = mutableRefSet.find(ref => ref.uri === file.uri);
|
|
65
|
+
refSet = mutableRefSet;
|
|
66
|
+
}
|
|
67
|
+
const visitor = new _visitor.default({
|
|
68
|
+
reference: reference,
|
|
69
|
+
options
|
|
70
|
+
});
|
|
71
|
+
const dereferencedElement = await (0, _apidomTraverse.traverseAsync)(refSet.rootRef.value, visitor, {
|
|
72
|
+
mutable: true
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* If immutable option is set, replay refs from the refSet.
|
|
77
|
+
*/
|
|
78
|
+
if (options.dereference.immutable) {
|
|
79
|
+
mutableRefSet.refs.filter(ref => ref.uri.startsWith('immutable://')).map(ref => new _Reference.default({
|
|
80
|
+
...ref,
|
|
81
|
+
uri: ref.uri.replace(/^immutable:\/\//, '')
|
|
82
|
+
})).forEach(ref => immutableRefSet.add(ref));
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
/**
|
|
86
|
+
* Release all memory if this refSet was not provided as a configuration option.
|
|
87
|
+
* If provided as configuration option, then provider is responsible for cleanup.
|
|
88
|
+
*/
|
|
89
|
+
if (options.dereference.refSet === null) {
|
|
90
|
+
immutableRefSet.clean();
|
|
91
|
+
}
|
|
92
|
+
mutableRefSet.clean();
|
|
93
|
+
return dereferencedElement;
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
var _default = exports.default = OpenAPI3_0DereferenceStrategy;
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
import { cloneDeep } from '@speclynx/apidom-datamodel';
|
|
2
|
+
import { traverseAsync } from '@speclynx/apidom-traverse';
|
|
3
|
+
import { isOpenApi3_0Element, mediaTypes } from '@speclynx/apidom-ns-openapi-3-0';
|
|
4
|
+
import DereferenceStrategy from "../DereferenceStrategy.mjs";
|
|
5
|
+
import Reference from "../../../Reference.mjs";
|
|
6
|
+
import ReferenceSet from "../../../ReferenceSet.mjs";
|
|
7
|
+
import OpenAPI3_0DereferenceVisitor from "./visitor.mjs";
|
|
8
|
+
/**
|
|
9
|
+
* @public
|
|
10
|
+
*/
|
|
11
|
+
/**
|
|
12
|
+
* @public
|
|
13
|
+
*/
|
|
14
|
+
class OpenAPI3_0DereferenceStrategy extends DereferenceStrategy {
|
|
15
|
+
constructor(options) {
|
|
16
|
+
super({
|
|
17
|
+
...(options ?? {}),
|
|
18
|
+
name: 'openapi-3-0'
|
|
19
|
+
});
|
|
20
|
+
}
|
|
21
|
+
canDereference(file) {
|
|
22
|
+
// assert by media type
|
|
23
|
+
if (file.mediaType !== 'text/plain') {
|
|
24
|
+
return mediaTypes.includes(file.mediaType);
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
// assert by inspecting ApiDOM
|
|
28
|
+
return isOpenApi3_0Element(file.parseResult?.result);
|
|
29
|
+
}
|
|
30
|
+
async dereference(file, options) {
|
|
31
|
+
const immutableRefSet = options.dereference.refSet ?? new ReferenceSet();
|
|
32
|
+
const mutableRefSet = new ReferenceSet();
|
|
33
|
+
let refSet = immutableRefSet;
|
|
34
|
+
let reference;
|
|
35
|
+
|
|
36
|
+
// determine the initial reference
|
|
37
|
+
if (!immutableRefSet.has(file.uri)) {
|
|
38
|
+
reference = new Reference({
|
|
39
|
+
uri: file.uri,
|
|
40
|
+
value: file.parseResult
|
|
41
|
+
});
|
|
42
|
+
immutableRefSet.add(reference);
|
|
43
|
+
} else {
|
|
44
|
+
// pre-computed refSet was provided as configuration option
|
|
45
|
+
reference = immutableRefSet.find(ref => ref.uri === file.uri);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* Clone refSet due the dereferencing process being mutable.
|
|
50
|
+
* We don't want to mutate the original refSet and the references.
|
|
51
|
+
*/
|
|
52
|
+
if (options.dereference.immutable) {
|
|
53
|
+
immutableRefSet.refs.map(ref => new Reference({
|
|
54
|
+
...ref,
|
|
55
|
+
value: cloneDeep(ref.value)
|
|
56
|
+
})).forEach(ref => mutableRefSet.add(ref));
|
|
57
|
+
reference = mutableRefSet.find(ref => ref.uri === file.uri);
|
|
58
|
+
refSet = mutableRefSet;
|
|
59
|
+
}
|
|
60
|
+
const visitor = new OpenAPI3_0DereferenceVisitor({
|
|
61
|
+
reference: reference,
|
|
62
|
+
options
|
|
63
|
+
});
|
|
64
|
+
const dereferencedElement = await traverseAsync(refSet.rootRef.value, visitor, {
|
|
65
|
+
mutable: true
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
/**
|
|
69
|
+
* If immutable option is set, replay refs from the refSet.
|
|
70
|
+
*/
|
|
71
|
+
if (options.dereference.immutable) {
|
|
72
|
+
mutableRefSet.refs.filter(ref => ref.uri.startsWith('immutable://')).map(ref => new Reference({
|
|
73
|
+
...ref,
|
|
74
|
+
uri: ref.uri.replace(/^immutable:\/\//, '')
|
|
75
|
+
})).forEach(ref => immutableRefSet.add(ref));
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
/**
|
|
79
|
+
* Release all memory if this refSet was not provided as a configuration option.
|
|
80
|
+
* If provided as configuration option, then provider is responsible for cleanup.
|
|
81
|
+
*/
|
|
82
|
+
if (options.dereference.refSet === null) {
|
|
83
|
+
immutableRefSet.clean();
|
|
84
|
+
}
|
|
85
|
+
mutableRefSet.clean();
|
|
86
|
+
return dereferencedElement;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
export { OpenAPI3_0DereferenceVisitor };
|
|
90
|
+
export default OpenAPI3_0DereferenceStrategy;
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { Element, cloneDeep } from '@speclynx/apidom-datamodel';
|
|
2
|
+
import { traverseAsync } from '@speclynx/apidom-traverse';
|
|
3
|
+
import { isOpenApi3_0Element, mediaTypes } from '@speclynx/apidom-ns-openapi-3-0';
|
|
4
|
+
|
|
5
|
+
import DereferenceStrategy, { DereferenceStrategyOptions } from '../DereferenceStrategy.ts';
|
|
6
|
+
import File from '../../../File.ts';
|
|
7
|
+
import Reference from '../../../Reference.ts';
|
|
8
|
+
import ReferenceSet from '../../../ReferenceSet.ts';
|
|
9
|
+
import OpenAPI3_0DereferenceVisitor from './visitor.ts';
|
|
10
|
+
import type { ReferenceOptions } from '../../../options/index.ts';
|
|
11
|
+
|
|
12
|
+
export type {
|
|
13
|
+
default as DereferenceStrategy,
|
|
14
|
+
DereferenceStrategyOptions,
|
|
15
|
+
} from '../DereferenceStrategy.ts';
|
|
16
|
+
export type { default as File, FileOptions } from '../../../File.ts';
|
|
17
|
+
export type { default as Reference, ReferenceOptions } from '../../../Reference.ts';
|
|
18
|
+
export type { default as ReferenceSet, ReferenceSetOptions } from '../../../ReferenceSet.ts';
|
|
19
|
+
export type { OpenAPI3_0DereferenceVisitorOptions } from './visitor.ts';
|
|
20
|
+
export type {
|
|
21
|
+
ReferenceOptions as ApiDOMReferenceOptions,
|
|
22
|
+
ReferenceBundleOptions as ApiDOMReferenceBundleOptions,
|
|
23
|
+
ReferenceDereferenceOptions as ApiDOMReferenceDereferenceOptions,
|
|
24
|
+
ReferenceParseOptions as ApiDOMReferenceParseOptions,
|
|
25
|
+
ReferenceResolveOptions as ApiDOMReferenceResolveOptions,
|
|
26
|
+
} from '../../../options/index.ts';
|
|
27
|
+
export type { default as Parser, ParserOptions } from '../../../parse/parsers/Parser.ts';
|
|
28
|
+
export type { default as Resolver, ResolverOptions } from '../../../resolve/resolvers/Resolver.ts';
|
|
29
|
+
export type {
|
|
30
|
+
default as ResolveStrategy,
|
|
31
|
+
ResolveStrategyOptions,
|
|
32
|
+
} from '../../../resolve/strategies/ResolveStrategy.ts';
|
|
33
|
+
export type {
|
|
34
|
+
default as BundleStrategy,
|
|
35
|
+
BundleStrategyOptions,
|
|
36
|
+
} from '../../../bundle/strategies/BundleStrategy.ts';
|
|
37
|
+
export type { AncestorLineage } from '../../util.ts';
|
|
38
|
+
|
|
39
|
+
/**
|
|
40
|
+
* @public
|
|
41
|
+
*/
|
|
42
|
+
export interface OpenAPI3_0DereferenceStrategyOptions extends Omit<
|
|
43
|
+
DereferenceStrategyOptions,
|
|
44
|
+
'name'
|
|
45
|
+
> {}
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* @public
|
|
49
|
+
*/
|
|
50
|
+
class OpenAPI3_0DereferenceStrategy extends DereferenceStrategy {
|
|
51
|
+
constructor(options?: OpenAPI3_0DereferenceStrategyOptions) {
|
|
52
|
+
super({ ...(options ?? {}), name: 'openapi-3-0' });
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
canDereference(file: File): boolean {
|
|
56
|
+
// assert by media type
|
|
57
|
+
if (file.mediaType !== 'text/plain') {
|
|
58
|
+
return mediaTypes.includes(file.mediaType);
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
// assert by inspecting ApiDOM
|
|
62
|
+
return isOpenApi3_0Element(file.parseResult?.result);
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
async dereference(file: File, options: ReferenceOptions): Promise<Element> {
|
|
66
|
+
const immutableRefSet = options.dereference.refSet ?? new ReferenceSet();
|
|
67
|
+
const mutableRefSet = new ReferenceSet();
|
|
68
|
+
let refSet = immutableRefSet;
|
|
69
|
+
let reference;
|
|
70
|
+
|
|
71
|
+
// determine the initial reference
|
|
72
|
+
if (!immutableRefSet.has(file.uri)) {
|
|
73
|
+
reference = new Reference({ uri: file.uri, value: file.parseResult! });
|
|
74
|
+
immutableRefSet.add(reference);
|
|
75
|
+
} else {
|
|
76
|
+
// pre-computed refSet was provided as configuration option
|
|
77
|
+
reference = immutableRefSet.find((ref) => ref.uri === file.uri);
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Clone refSet due the dereferencing process being mutable.
|
|
82
|
+
* We don't want to mutate the original refSet and the references.
|
|
83
|
+
*/
|
|
84
|
+
if (options.dereference.immutable) {
|
|
85
|
+
immutableRefSet.refs
|
|
86
|
+
.map(
|
|
87
|
+
(ref) =>
|
|
88
|
+
new Reference({
|
|
89
|
+
...ref,
|
|
90
|
+
value: cloneDeep(ref.value),
|
|
91
|
+
}),
|
|
92
|
+
)
|
|
93
|
+
.forEach((ref) => mutableRefSet.add(ref));
|
|
94
|
+
reference = mutableRefSet.find((ref) => ref.uri === file.uri);
|
|
95
|
+
refSet = mutableRefSet;
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
const visitor = new OpenAPI3_0DereferenceVisitor({ reference: reference!, options });
|
|
99
|
+
const dereferencedElement = await traverseAsync(refSet.rootRef!.value, visitor, {
|
|
100
|
+
mutable: true,
|
|
101
|
+
});
|
|
102
|
+
|
|
103
|
+
/**
|
|
104
|
+
* If immutable option is set, replay refs from the refSet.
|
|
105
|
+
*/
|
|
106
|
+
if (options.dereference.immutable) {
|
|
107
|
+
mutableRefSet.refs
|
|
108
|
+
.filter((ref) => ref.uri.startsWith('immutable://'))
|
|
109
|
+
.map(
|
|
110
|
+
(ref) =>
|
|
111
|
+
new Reference({
|
|
112
|
+
...ref,
|
|
113
|
+
uri: ref.uri.replace(/^immutable:\/\//, ''),
|
|
114
|
+
}),
|
|
115
|
+
)
|
|
116
|
+
.forEach((ref) => immutableRefSet.add(ref));
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
/**
|
|
120
|
+
* Release all memory if this refSet was not provided as a configuration option.
|
|
121
|
+
* If provided as configuration option, then provider is responsible for cleanup.
|
|
122
|
+
*/
|
|
123
|
+
if (options.dereference.refSet === null) {
|
|
124
|
+
immutableRefSet.clean();
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
mutableRefSet.clean();
|
|
128
|
+
|
|
129
|
+
return dereferencedElement;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
export { OpenAPI3_0DereferenceVisitor };
|
|
134
|
+
export default OpenAPI3_0DereferenceStrategy;
|