[d24f17c] | 1 | "use strict";
|
---|
| 2 |
|
---|
| 3 | var _interopRequireWildcard = require("@babel/runtime-corejs3/helpers/interopRequireWildcard").default;
|
---|
| 4 | var _interopRequireDefault = require("@babel/runtime-corejs3/helpers/interopRequireDefault").default;
|
---|
| 5 | exports.__esModule = true;
|
---|
| 6 | exports.dereferenceApiDOM = exports.default = void 0;
|
---|
| 7 | var _ramda = require("ramda");
|
---|
| 8 | var _apidomCore = require("@swagger-api/apidom-core");
|
---|
| 9 | var _File = _interopRequireDefault(require("../util/File.cjs"));
|
---|
| 10 | var plugins = _interopRequireWildcard(require("../util/plugins.cjs"));
|
---|
| 11 | var _UnmatchedDereferenceStrategyError = _interopRequireDefault(require("../errors/UnmatchedDereferenceStrategyError.cjs"));
|
---|
| 12 | var _DereferenceError = _interopRequireDefault(require("../errors/DereferenceError.cjs"));
|
---|
| 13 | var _index = _interopRequireDefault(require("../parse/index.cjs"));
|
---|
| 14 | var _util = require("../options/util.cjs");
|
---|
| 15 | var url = _interopRequireWildcard(require("../util/url.cjs"));
|
---|
| 16 | /**
|
---|
| 17 | * Dereferences ApiDOM with all its external references.
|
---|
| 18 | */
|
---|
| 19 | const dereferenceApiDOM = async (element, options) => {
|
---|
| 20 | // @ts-ignore
|
---|
| 21 | let parseResult = element;
|
---|
| 22 | let surrogateWrapping = false;
|
---|
| 23 |
|
---|
| 24 | // wrap element into parse result
|
---|
| 25 | if (!(0, _apidomCore.isParseResultElement)(element)) {
|
---|
| 26 | const elementClone = (0, _apidomCore.cloneShallow)(element);
|
---|
| 27 | elementClone.classes.push('result');
|
---|
| 28 | parseResult = new _apidomCore.ParseResultElement([elementClone]);
|
---|
| 29 | surrogateWrapping = true;
|
---|
| 30 | }
|
---|
| 31 | const file = (0, _File.default)({
|
---|
| 32 | uri: options.resolve.baseURI,
|
---|
| 33 | parseResult,
|
---|
| 34 | mediaType: options.parse.mediaType
|
---|
| 35 | });
|
---|
| 36 | const dereferenceStrategies = await plugins.filter('canDereference', file, options.dereference.strategies);
|
---|
| 37 |
|
---|
| 38 | // we couldn't find any dereference strategy for this File
|
---|
| 39 | if ((0, _ramda.isEmpty)(dereferenceStrategies)) {
|
---|
| 40 | throw new _UnmatchedDereferenceStrategyError.default(file.uri);
|
---|
| 41 | }
|
---|
| 42 | try {
|
---|
| 43 | const {
|
---|
| 44 | result
|
---|
| 45 | } = await plugins.run('dereference', [file, options], dereferenceStrategies);
|
---|
| 46 | // unwrap the element from ParseResult assuming first element is the actual result
|
---|
| 47 | return surrogateWrapping ? result.get(0) : result;
|
---|
| 48 | } catch (error) {
|
---|
| 49 | throw new _DereferenceError.default(`Error while dereferencing file "${file.uri}"`, {
|
---|
| 50 | cause: error
|
---|
| 51 | });
|
---|
| 52 | }
|
---|
| 53 | };
|
---|
| 54 |
|
---|
| 55 | /**
|
---|
| 56 | * Dereferences a file with all its external references.
|
---|
| 57 | */
|
---|
| 58 | exports.dereferenceApiDOM = dereferenceApiDOM;
|
---|
| 59 | const dereference = async (uri, options) => {
|
---|
| 60 | const {
|
---|
| 61 | refSet
|
---|
| 62 | } = options.dereference;
|
---|
| 63 | const sanitizedURI = url.sanitize(uri);
|
---|
| 64 | let parseResult;
|
---|
| 65 |
|
---|
| 66 | // if refSet was provided, use it to avoid unnecessary parsing
|
---|
| 67 | if (refSet !== null && refSet.has(sanitizedURI)) {
|
---|
| 68 | // @ts-ignore
|
---|
| 69 | ({
|
---|
| 70 | value: parseResult
|
---|
| 71 | } = refSet.find((0, _ramda.propEq)(sanitizedURI, 'uri')));
|
---|
| 72 | } else {
|
---|
| 73 | parseResult = await (0, _index.default)(uri, options);
|
---|
| 74 | }
|
---|
| 75 | const mergedOptions = (0, _util.merge)(options, {
|
---|
| 76 | resolve: {
|
---|
| 77 | baseURI: sanitizedURI
|
---|
| 78 | }
|
---|
| 79 | });
|
---|
| 80 | return dereferenceApiDOM(parseResult, mergedOptions);
|
---|
| 81 | };
|
---|
| 82 | var _default = exports.default = dereference; |
---|