@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.
Files changed (275) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/package.json +26 -27
  3. package/src/File.cjs +50 -0
  4. package/src/File.mjs +44 -0
  5. package/src/File.ts +63 -0
  6. package/src/Reference.cjs +31 -0
  7. package/src/Reference.mjs +27 -0
  8. package/src/Reference.ts +38 -0
  9. package/src/ReferenceSet.cjs +60 -0
  10. package/src/ReferenceSet.mjs +57 -0
  11. package/src/ReferenceSet.ts +73 -0
  12. package/src/bundle/index.cjs +61 -0
  13. package/src/bundle/index.mjs +55 -0
  14. package/src/bundle/index.ts +57 -0
  15. package/src/bundle/strategies/BundleStrategy.cjs +20 -0
  16. package/src/bundle/strategies/BundleStrategy.mjs +16 -0
  17. package/src/bundle/strategies/BundleStrategy.ts +27 -0
  18. package/src/bundle/strategies/openapi-3-1/index.cjs +35 -0
  19. package/src/bundle/strategies/openapi-3-1/index.mjs +29 -0
  20. package/src/bundle/strategies/openapi-3-1/index.ts +57 -0
  21. package/src/configuration/empty.cjs +9 -0
  22. package/src/configuration/empty.mjs +1 -0
  23. package/src/configuration/empty.ts +1 -0
  24. package/src/configuration/saturated.cjs +88 -0
  25. package/src/configuration/saturated.mjs +80 -0
  26. package/src/configuration/saturated.ts +72 -0
  27. package/src/dereference/index.cjs +90 -0
  28. package/src/dereference/index.mjs +83 -0
  29. package/src/dereference/index.ts +96 -0
  30. package/src/dereference/strategies/DereferenceStrategy.cjs +20 -0
  31. package/src/dereference/strategies/DereferenceStrategy.mjs +16 -0
  32. package/src/dereference/strategies/DereferenceStrategy.ts +27 -0
  33. package/src/dereference/strategies/apidom/index.cjs +89 -0
  34. package/src/dereference/strategies/apidom/index.mjs +83 -0
  35. package/src/dereference/strategies/apidom/index.ts +128 -0
  36. package/src/dereference/strategies/apidom/selectors/element-id.cjs +47 -0
  37. package/src/dereference/strategies/apidom/selectors/element-id.mjs +41 -0
  38. package/src/dereference/strategies/apidom/selectors/element-id.ts +48 -0
  39. package/src/dereference/strategies/apidom/visitor.cjs +266 -0
  40. package/src/dereference/strategies/apidom/visitor.mjs +259 -0
  41. package/src/dereference/strategies/apidom/visitor.ts +316 -0
  42. package/src/dereference/strategies/arazzo-1/index.cjs +109 -0
  43. package/src/dereference/strategies/arazzo-1/index.mjs +100 -0
  44. package/src/dereference/strategies/arazzo-1/index.ts +158 -0
  45. package/src/dereference/strategies/arazzo-1/selectors/$anchor.cjs +12 -0
  46. package/src/dereference/strategies/arazzo-1/selectors/$anchor.mjs +1 -0
  47. package/src/dereference/strategies/arazzo-1/selectors/$anchor.ts +9 -0
  48. package/src/dereference/strategies/arazzo-1/selectors/uri.cjs +8 -0
  49. package/src/dereference/strategies/arazzo-1/selectors/uri.mjs +1 -0
  50. package/src/dereference/strategies/arazzo-1/selectors/uri.ts +5 -0
  51. package/src/dereference/strategies/arazzo-1/source-descriptions.cjs +248 -0
  52. package/src/dereference/strategies/arazzo-1/source-descriptions.mjs +243 -0
  53. package/src/dereference/strategies/arazzo-1/source-descriptions.ts +317 -0
  54. package/src/dereference/strategies/arazzo-1/util.cjs +37 -0
  55. package/src/dereference/strategies/arazzo-1/util.mjs +29 -0
  56. package/src/dereference/strategies/arazzo-1/util.ts +33 -0
  57. package/src/dereference/strategies/arazzo-1/visitor.cjs +507 -0
  58. package/src/dereference/strategies/arazzo-1/visitor.mjs +500 -0
  59. package/src/dereference/strategies/arazzo-1/visitor.ts +574 -0
  60. package/src/dereference/strategies/asyncapi-2/index.cjs +94 -0
  61. package/src/dereference/strategies/asyncapi-2/index.mjs +88 -0
  62. package/src/dereference/strategies/asyncapi-2/index.ts +133 -0
  63. package/src/dereference/strategies/asyncapi-2/visitor.cjs +501 -0
  64. package/src/dereference/strategies/asyncapi-2/visitor.mjs +494 -0
  65. package/src/dereference/strategies/asyncapi-2/visitor.ts +589 -0
  66. package/src/dereference/strategies/openapi-2/index.cjs +96 -0
  67. package/src/dereference/strategies/openapi-2/index.mjs +90 -0
  68. package/src/dereference/strategies/openapi-2/index.ts +136 -0
  69. package/src/dereference/strategies/openapi-2/visitor.cjs +629 -0
  70. package/src/dereference/strategies/openapi-2/visitor.mjs +622 -0
  71. package/src/dereference/strategies/openapi-2/visitor.ts +745 -0
  72. package/src/dereference/strategies/openapi-3-0/index.cjs +96 -0
  73. package/src/dereference/strategies/openapi-3-0/index.mjs +90 -0
  74. package/src/dereference/strategies/openapi-3-0/index.ts +134 -0
  75. package/src/dereference/strategies/openapi-3-0/visitor.cjs +622 -0
  76. package/src/dereference/strategies/openapi-3-0/visitor.mjs +615 -0
  77. package/src/dereference/strategies/openapi-3-0/visitor.ts +760 -0
  78. package/src/dereference/strategies/openapi-3-1/index.cjs +99 -0
  79. package/src/dereference/strategies/openapi-3-1/index.mjs +90 -0
  80. package/src/dereference/strategies/openapi-3-1/index.ts +141 -0
  81. package/src/dereference/strategies/openapi-3-1/selectors/$anchor.cjs +65 -0
  82. package/src/dereference/strategies/openapi-3-1/selectors/$anchor.mjs +54 -0
  83. package/src/dereference/strategies/openapi-3-1/selectors/$anchor.ts +64 -0
  84. package/src/dereference/strategies/openapi-3-1/selectors/uri.cjs +50 -0
  85. package/src/dereference/strategies/openapi-3-1/selectors/uri.mjs +42 -0
  86. package/src/dereference/strategies/openapi-3-1/selectors/uri.ts +54 -0
  87. package/src/dereference/strategies/openapi-3-1/util.cjs +68 -0
  88. package/src/dereference/strategies/openapi-3-1/util.mjs +59 -0
  89. package/src/dereference/strategies/openapi-3-1/util.ts +83 -0
  90. package/src/dereference/strategies/openapi-3-1/visitor.cjs +874 -0
  91. package/src/dereference/strategies/openapi-3-1/visitor.mjs +867 -0
  92. package/src/dereference/strategies/openapi-3-1/visitor.ts +1053 -0
  93. package/src/dereference/util.cjs +31 -0
  94. package/src/dereference/util.mjs +27 -0
  95. package/src/dereference/util.ts +29 -0
  96. package/src/errors/BundleError.cjs +10 -0
  97. package/src/errors/BundleError.mjs +7 -0
  98. package/src/errors/BundleError.ts +8 -0
  99. package/src/errors/DereferenceError.cjs +10 -0
  100. package/src/errors/DereferenceError.mjs +7 -0
  101. package/src/errors/DereferenceError.ts +8 -0
  102. package/src/errors/EvaluationElementIdError.cjs +10 -0
  103. package/src/errors/EvaluationElementIdError.mjs +7 -0
  104. package/src/errors/EvaluationElementIdError.ts +8 -0
  105. package/src/errors/EvaluationJsonSchema$anchorError.cjs +11 -0
  106. package/src/errors/EvaluationJsonSchema$anchorError.mjs +6 -0
  107. package/src/errors/EvaluationJsonSchema$anchorError.ts +8 -0
  108. package/src/errors/EvaluationJsonSchemaUriError.cjs +11 -0
  109. package/src/errors/EvaluationJsonSchemaUriError.mjs +6 -0
  110. package/src/errors/EvaluationJsonSchemaUriError.ts +8 -0
  111. package/src/errors/InvalidJsonSchema$anchorError.cjs +15 -0
  112. package/src/errors/InvalidJsonSchema$anchorError.mjs +10 -0
  113. package/src/errors/InvalidJsonSchema$anchorError.ts +12 -0
  114. package/src/errors/JsonSchema$anchorError.cjs +10 -0
  115. package/src/errors/JsonSchema$anchorError.mjs +7 -0
  116. package/src/errors/JsonSchema$anchorError.ts +8 -0
  117. package/src/errors/JsonSchemaUriError.cjs +10 -0
  118. package/src/errors/JsonSchemaUriError.mjs +7 -0
  119. package/src/errors/JsonSchemaUriError.ts +8 -0
  120. package/src/errors/MaximumBundleDepthError.cjs +11 -0
  121. package/src/errors/MaximumBundleDepthError.mjs +6 -0
  122. package/src/errors/MaximumBundleDepthError.ts +8 -0
  123. package/src/errors/MaximumDereferenceDepthError.cjs +11 -0
  124. package/src/errors/MaximumDereferenceDepthError.mjs +6 -0
  125. package/src/errors/MaximumDereferenceDepthError.ts +8 -0
  126. package/src/errors/MaximumResolveDepthError.cjs +11 -0
  127. package/src/errors/MaximumResolveDepthError.mjs +6 -0
  128. package/src/errors/MaximumResolveDepthError.ts +8 -0
  129. package/src/errors/ParseError.cjs +10 -0
  130. package/src/errors/ParseError.mjs +7 -0
  131. package/src/errors/ParseError.ts +8 -0
  132. package/src/errors/ParserError.cjs +11 -0
  133. package/src/errors/ParserError.mjs +6 -0
  134. package/src/errors/ParserError.ts +8 -0
  135. package/src/errors/PluginError.cjs +18 -0
  136. package/src/errors/PluginError.mjs +15 -0
  137. package/src/errors/PluginError.ts +15 -0
  138. package/src/errors/ResolveError.cjs +10 -0
  139. package/src/errors/ResolveError.mjs +7 -0
  140. package/src/errors/ResolveError.ts +8 -0
  141. package/src/errors/ResolverError.cjs +11 -0
  142. package/src/errors/ResolverError.mjs +6 -0
  143. package/src/errors/ResolverError.ts +8 -0
  144. package/src/errors/UnmatchedBundleStrategyError.cjs +11 -0
  145. package/src/errors/UnmatchedBundleStrategyError.mjs +6 -0
  146. package/src/errors/UnmatchedBundleStrategyError.ts +8 -0
  147. package/src/errors/UnmatchedDereferenceStrategyError.cjs +11 -0
  148. package/src/errors/UnmatchedDereferenceStrategyError.mjs +6 -0
  149. package/src/errors/UnmatchedDereferenceStrategyError.ts +8 -0
  150. package/src/errors/UnmatchedParserError.cjs +11 -0
  151. package/src/errors/UnmatchedParserError.mjs +6 -0
  152. package/src/errors/UnmatchedParserError.ts +8 -0
  153. package/src/errors/UnmatchedResolveStrategyError.cjs +11 -0
  154. package/src/errors/UnmatchedResolveStrategyError.mjs +6 -0
  155. package/src/errors/UnmatchedResolveStrategyError.ts +8 -0
  156. package/src/errors/UnmatchedResolverError.cjs +11 -0
  157. package/src/errors/UnmatchedResolverError.mjs +6 -0
  158. package/src/errors/UnmatchedResolverError.ts +8 -0
  159. package/src/errors/UnresolvableReferenceError.cjs +11 -0
  160. package/src/errors/UnresolvableReferenceError.mjs +6 -0
  161. package/src/errors/UnresolvableReferenceError.ts +8 -0
  162. package/src/index.cjs +146 -0
  163. package/src/index.mjs +103 -0
  164. package/src/index.ts +135 -0
  165. package/src/options/index.cjs +194 -0
  166. package/src/options/index.mjs +191 -0
  167. package/src/options/index.ts +239 -0
  168. package/src/options/util.cjs +24 -0
  169. package/src/options/util.mjs +19 -0
  170. package/src/options/util.ts +22 -0
  171. package/src/parse/index.cjs +69 -0
  172. package/src/parse/index.mjs +63 -0
  173. package/src/parse/index.ts +67 -0
  174. package/src/parse/parsers/Parser.cjs +62 -0
  175. package/src/parse/parsers/Parser.mjs +58 -0
  176. package/src/parse/parsers/Parser.ts +80 -0
  177. package/src/parse/parsers/apidom-json/index.cjs +70 -0
  178. package/src/parse/parsers/apidom-json/index.mjs +64 -0
  179. package/src/parse/parsers/apidom-json/index.ts +78 -0
  180. package/src/parse/parsers/arazzo-json-1/index.cjs +62 -0
  181. package/src/parse/parsers/arazzo-json-1/index.mjs +56 -0
  182. package/src/parse/parsers/arazzo-json-1/index.ts +76 -0
  183. package/src/parse/parsers/arazzo-json-1/source-descriptions.cjs +221 -0
  184. package/src/parse/parsers/arazzo-json-1/source-descriptions.mjs +214 -0
  185. package/src/parse/parsers/arazzo-json-1/source-descriptions.ts +280 -0
  186. package/src/parse/parsers/arazzo-yaml-1/index.cjs +62 -0
  187. package/src/parse/parsers/arazzo-yaml-1/index.mjs +56 -0
  188. package/src/parse/parsers/arazzo-yaml-1/index.ts +77 -0
  189. package/src/parse/parsers/arazzo-yaml-1/source-descriptions.cjs +12 -0
  190. package/src/parse/parsers/arazzo-yaml-1/source-descriptions.mjs +7 -0
  191. package/src/parse/parsers/arazzo-yaml-1/source-descriptions.ts +16 -0
  192. package/src/parse/parsers/asyncapi-json-2/index.cjs +54 -0
  193. package/src/parse/parsers/asyncapi-json-2/index.mjs +48 -0
  194. package/src/parse/parsers/asyncapi-json-2/index.ts +58 -0
  195. package/src/parse/parsers/asyncapi-yaml-2/index.cjs +54 -0
  196. package/src/parse/parsers/asyncapi-yaml-2/index.mjs +48 -0
  197. package/src/parse/parsers/asyncapi-yaml-2/index.ts +58 -0
  198. package/src/parse/parsers/binary/index-browser.cjs +56 -0
  199. package/src/parse/parsers/binary/index-browser.mjs +50 -0
  200. package/src/parse/parsers/binary/index-browser.ts +60 -0
  201. package/src/parse/parsers/binary/index-node.cjs +51 -0
  202. package/src/parse/parsers/binary/index-node.mjs +45 -0
  203. package/src/parse/parsers/binary/index-node.ts +57 -0
  204. package/src/parse/parsers/json/index.cjs +53 -0
  205. package/src/parse/parsers/json/index.mjs +47 -0
  206. package/src/parse/parsers/json/index.ts +52 -0
  207. package/src/parse/parsers/openapi-json-2/index.cjs +54 -0
  208. package/src/parse/parsers/openapi-json-2/index.mjs +48 -0
  209. package/src/parse/parsers/openapi-json-2/index.ts +58 -0
  210. package/src/parse/parsers/openapi-json-3-0/index.cjs +54 -0
  211. package/src/parse/parsers/openapi-json-3-0/index.mjs +48 -0
  212. package/src/parse/parsers/openapi-json-3-0/index.ts +59 -0
  213. package/src/parse/parsers/openapi-json-3-1/index.cjs +54 -0
  214. package/src/parse/parsers/openapi-json-3-1/index.mjs +48 -0
  215. package/src/parse/parsers/openapi-json-3-1/index.ts +59 -0
  216. package/src/parse/parsers/openapi-yaml-2/index.cjs +54 -0
  217. package/src/parse/parsers/openapi-yaml-2/index.mjs +48 -0
  218. package/src/parse/parsers/openapi-yaml-2/index.ts +58 -0
  219. package/src/parse/parsers/openapi-yaml-3-0/index.cjs +54 -0
  220. package/src/parse/parsers/openapi-yaml-3-0/index.mjs +48 -0
  221. package/src/parse/parsers/openapi-yaml-3-0/index.ts +59 -0
  222. package/src/parse/parsers/openapi-yaml-3-1/index.cjs +54 -0
  223. package/src/parse/parsers/openapi-yaml-3-1/index.mjs +48 -0
  224. package/src/parse/parsers/openapi-yaml-3-1/index.ts +59 -0
  225. package/src/parse/parsers/yaml-1-2/index.cjs +56 -0
  226. package/src/parse/parsers/yaml-1-2/index.mjs +50 -0
  227. package/src/parse/parsers/yaml-1-2/index.ts +60 -0
  228. package/src/resolve/index.cjs +67 -0
  229. package/src/resolve/index.mjs +60 -0
  230. package/src/resolve/index.ts +75 -0
  231. package/src/resolve/resolvers/HTTPResolver.cjs +45 -0
  232. package/src/resolve/resolvers/HTTPResolver.mjs +37 -0
  233. package/src/resolve/resolvers/HTTPResolver.ts +58 -0
  234. package/src/resolve/resolvers/Resolver.cjs +20 -0
  235. package/src/resolve/resolvers/Resolver.mjs +16 -0
  236. package/src/resolve/resolvers/Resolver.ts +25 -0
  237. package/src/resolve/resolvers/file/index-browser.cjs +24 -0
  238. package/src/resolve/resolvers/file/index-browser.mjs +19 -0
  239. package/src/resolve/resolvers/file/index-browser.ts +24 -0
  240. package/src/resolve/resolvers/file/index-node.cjs +49 -0
  241. package/src/resolve/resolvers/file/index-node.mjs +42 -0
  242. package/src/resolve/resolvers/file/index-node.ts +55 -0
  243. package/src/resolve/resolvers/http-axios/cache/MemoryCache.cjs +41 -0
  244. package/src/resolve/resolvers/http-axios/cache/MemoryCache.mjs +37 -0
  245. package/src/resolve/resolvers/http-axios/cache/MemoryCache.ts +46 -0
  246. package/src/resolve/resolvers/http-axios/index.cjs +113 -0
  247. package/src/resolve/resolvers/http-axios/index.mjs +105 -0
  248. package/src/resolve/resolvers/http-axios/index.ts +130 -0
  249. package/src/resolve/strategies/ResolveStrategy.cjs +20 -0
  250. package/src/resolve/strategies/ResolveStrategy.mjs +16 -0
  251. package/src/resolve/strategies/ResolveStrategy.ts +26 -0
  252. package/src/resolve/strategies/apidom/index.cjs +49 -0
  253. package/src/resolve/strategies/apidom/index.mjs +43 -0
  254. package/src/resolve/strategies/apidom/index.ts +78 -0
  255. package/src/resolve/strategies/asyncapi-2/index.cjs +49 -0
  256. package/src/resolve/strategies/asyncapi-2/index.mjs +43 -0
  257. package/src/resolve/strategies/asyncapi-2/index.ts +78 -0
  258. package/src/resolve/strategies/openapi-2/index.cjs +49 -0
  259. package/src/resolve/strategies/openapi-2/index.mjs +43 -0
  260. package/src/resolve/strategies/openapi-2/index.ts +78 -0
  261. package/src/resolve/strategies/openapi-3-0/index.cjs +49 -0
  262. package/src/resolve/strategies/openapi-3-0/index.mjs +43 -0
  263. package/src/resolve/strategies/openapi-3-0/index.ts +78 -0
  264. package/src/resolve/strategies/openapi-3-1/index.cjs +49 -0
  265. package/src/resolve/strategies/openapi-3-1/index.mjs +43 -0
  266. package/src/resolve/strategies/openapi-3-1/index.ts +78 -0
  267. package/src/resolve/util.cjs +37 -0
  268. package/src/resolve/util.mjs +30 -0
  269. package/src/resolve/util.ts +39 -0
  270. package/src/util/plugins.cjs +39 -0
  271. package/src/util/plugins.mjs +34 -0
  272. package/src/util/plugins.ts +37 -0
  273. package/src/util/url.cjs +288 -0
  274. package/src/util/url.mjs +274 -0
  275. 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;