
package.es.dereference.index.mjs Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of apidom-reference Show documentation
Show all versions of apidom-reference Show documentation
Advanced algorithms for semantic ApiDOM manipulations like dereferencing or resolution.
import { isEmpty, propEq } from 'ramda';
import { isParseResultElement, ParseResultElement, cloneShallow } from '@swagger-api/apidom-core';
import File from "../File.mjs";
import * as plugins from "../util/plugins.mjs";
import UnmatchedDereferenceStrategyError from "../errors/UnmatchedDereferenceStrategyError.mjs";
import DereferenceError from "../errors/DereferenceError.mjs";
import parse from "../parse/index.mjs";
import { merge as mergeOptions } from "../options/util.mjs";
import * as url from "../util/url.mjs";
/**
* Dereferences ApiDOM with all its external references.
*/
export const dereferenceApiDOM = async (element, options) => {
// @ts-ignore
let parseResult = element;
let surrogateWrapping = false;
// wrap element into parse result
if (!isParseResultElement(element)) {
const elementClone = cloneShallow(element);
elementClone.classes.push('result');
parseResult = new ParseResultElement([elementClone]);
surrogateWrapping = true;
}
const file = new File({
uri: options.resolve.baseURI,
parseResult,
mediaType: options.parse.mediaType
});
const dereferenceStrategies = await plugins.filter('canDereference', [file, options], options.dereference.strategies);
// we couldn't find any dereference strategy for this File
if (isEmpty(dereferenceStrategies)) {
throw new UnmatchedDereferenceStrategyError(file.uri);
}
try {
const {
result
} = await plugins.run('dereference', [file, options], dereferenceStrategies);
// unwrap the element from ParseResult assuming first element is the actual result
return surrogateWrapping ? result.get(0) : result;
} catch (error) {
throw new DereferenceError(`Error while dereferencing file "${file.uri}"`, {
cause: error
});
}
};
/**
* Dereferences a file with all its external references.
*/
const dereference = async (uri, options) => {
const {
refSet
} = options.dereference;
const sanitizedURI = url.sanitize(uri);
let parseResult;
// if refSet was provided, use it to avoid unnecessary parsing
if (refSet !== null && refSet.has(sanitizedURI)) {
// @ts-ignore
({
value: parseResult
} = refSet.find(propEq(sanitizedURI, 'uri')));
} else {
parseResult = await parse(uri, options);
}
const mergedOptions = mergeOptions(options, {
resolve: {
baseURI: sanitizedURI
},
dereference: {
// if refSet was not provided, then we can work in mutable mode
immutable: options.dereference.immutable && refSet !== null
}
});
return dereferenceApiDOM(parseResult, mergedOptions);
};
export default dereference;
© 2015 - 2025 Weber Informatics LLC | Privacy Policy