source: node_modules/swagger-client/lib/resolver/strategies/openapi-3-1-apidom/resolve.js@ 65b6638

main
Last change on this file since 65b6638 was d24f17c, checked in by Aleksandar Panovski <apano77@…>, 15 months ago

Initial commit

  • Property mode set to 100644
File size: 5.8 KB
Line 
1"use strict";
2
3var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard").default;
4var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault").default;
5exports.__esModule = true;
6exports.default = void 0;
7var _apidomCore = require("@swagger-api/apidom-core");
8var _apidomJsonPointer = require("@swagger-api/apidom-json-pointer");
9var _apidomNsOpenapi = require("@swagger-api/apidom-ns-openapi-3-1");
10var _empty = require("@swagger-api/apidom-reference/configuration/empty");
11var _binary = _interopRequireDefault(require("@swagger-api/apidom-reference/parse/parsers/binary"));
12var _openapi = _interopRequireDefault(require("@swagger-api/apidom-reference/resolve/strategies/openapi-3-1"));
13var _constants = require("../../../constants.js");
14var optionsUtil = _interopRequireWildcard(require("../../utils/options.js"));
15var _normalize = _interopRequireDefault(require("./normalize.js"));
16var _index = _interopRequireDefault(require("../../apidom/reference/resolve/resolvers/http-swagger-client/index.js"));
17var _index2 = _interopRequireDefault(require("../../apidom/reference/parse/parsers/json/index.js"));
18var _index3 = _interopRequireDefault(require("../../apidom/reference/parse/parsers/yaml-1-2/index.js"));
19var _index4 = _interopRequireDefault(require("../../apidom/reference/parse/parsers/openapi-json-3-1/index.js"));
20var _index5 = _interopRequireDefault(require("../../apidom/reference/parse/parsers/openapi-yaml-3-1/index.js"));
21var _index6 = _interopRequireDefault(require("../../apidom/reference/dereference/strategies/openapi-3-1-swagger-client/index.js"));
22/* eslint-disable camelcase */
23
24const resolveOpenAPI31Strategy = async options => {
25 const {
26 spec,
27 timeout,
28 redirects,
29 requestInterceptor,
30 responseInterceptor,
31 pathDiscriminator = [],
32 allowMetaPatches = false,
33 useCircularStructures = false,
34 skipNormalization = false,
35 parameterMacro = null,
36 modelPropertyMacro = null,
37 mode = 'non-strict'
38 } = options;
39 try {
40 const {
41 cache
42 } = resolveOpenAPI31Strategy;
43
44 // determining BaseURI
45 const cwd = _empty.url.isHttpUrl(_empty.url.cwd()) ? _empty.url.cwd() : _constants.DEFAULT_BASE_URL;
46 const retrievalURI = optionsUtil.retrievalURI(options);
47 const baseURI = _empty.url.resolve(cwd, retrievalURI);
48
49 // prepare spec for dereferencing
50 let openApiElement;
51 if (cache.has(spec)) {
52 openApiElement = cache.get(spec);
53 } else {
54 openApiElement = _apidomNsOpenapi.OpenApi3_1Element.refract(spec);
55 openApiElement.classes.push('result');
56 cache.set(spec, openApiElement);
57 }
58 const openApiParseResultElement = new _apidomCore.ParseResultElement([openApiElement]);
59
60 // prepare fragment for dereferencing
61 const jsonPointer = (0, _apidomJsonPointer.compile)(pathDiscriminator);
62 const jsonPointerURI = jsonPointer === '' ? '' : `#${jsonPointer}`;
63 const fragmentElement = (0, _apidomJsonPointer.evaluate)(jsonPointer, openApiElement);
64
65 // prepare reference set for dereferencing
66 const openApiElementReference = (0, _empty.Reference)({
67 uri: baseURI,
68 value: openApiParseResultElement
69 });
70 const refSet = (0, _empty.ReferenceSet)({
71 refs: [openApiElementReference]
72 });
73 if (jsonPointer !== '') refSet.rootRef = null; // reset root reference as we want fragment to become the root reference
74
75 // prepare ancestors; needed for cases where fragment is not OpenAPI element
76 const ancestors = [new Set([fragmentElement])];
77 const errors = [];
78 const dereferenced = await (0, _empty.dereferenceApiDOM)(fragmentElement, {
79 resolve: {
80 /**
81 * swagger-client only supports resolving HTTP(S) URLs or spec objects.
82 * If runtime env is detected as non-browser one,
83 * and baseURI was not provided as part of resolver options,
84 * then below baseURI check will make sure that constant HTTPS URL is used as baseURI.
85 */
86 baseURI: `${baseURI}${jsonPointerURI}`,
87 resolvers: [(0, _index.default)({
88 timeout: timeout || 10000,
89 redirects: redirects || 10
90 })],
91 resolverOpts: {
92 swaggerHTTPClientConfig: {
93 requestInterceptor,
94 responseInterceptor
95 }
96 },
97 strategies: [(0, _openapi.default)()]
98 },
99 parse: {
100 mediaType: _apidomNsOpenapi.mediaTypes.latest(),
101 parsers: [(0, _index4.default)({
102 allowEmpty: false,
103 sourceMap: false
104 }), (0, _index5.default)({
105 allowEmpty: false,
106 sourceMap: false
107 }), (0, _index2.default)({
108 allowEmpty: false,
109 sourceMap: false
110 }), (0, _index3.default)({
111 allowEmpty: false,
112 sourceMap: false
113 }), (0, _binary.default)({
114 allowEmpty: false,
115 sourceMap: false
116 })]
117 },
118 dereference: {
119 maxDepth: 100,
120 strategies: [(0, _index6.default)({
121 allowMetaPatches,
122 useCircularStructures,
123 parameterMacro,
124 modelPropertyMacro,
125 mode,
126 ancestors
127 })],
128 refSet,
129 dereferenceOpts: {
130 errors
131 }
132 }
133 });
134 const transcluded = (0, _apidomCore.transclude)(fragmentElement, dereferenced, openApiElement);
135 const normalized = skipNormalization ? transcluded : (0, _normalize.default)(transcluded);
136 return {
137 spec: (0, _apidomCore.toValue)(normalized),
138 errors
139 };
140 } catch (error) {
141 if (error instanceof _apidomJsonPointer.InvalidJsonPointerError || error instanceof _apidomJsonPointer.EvaluationJsonPointerError) {
142 return {
143 spec: null,
144 errors: []
145 };
146 }
147 throw error;
148 }
149};
150resolveOpenAPI31Strategy.cache = new WeakMap();
151var _default = exports.default = resolveOpenAPI31Strategy;
152/* eslint-enable camelcase */
Note: See TracBrowser for help on using the repository browser.