1 | import stampit from 'stampit';
|
---|
2 | import { defaultTo, propEq } from 'ramda';
|
---|
3 | import { createNamespace, visit } from '@swagger-api/apidom-core';
|
---|
4 | import openApi3_1Namespace, { getNodeType, isOpenApi3_1Element, keyMap, mediaTypes } from '@swagger-api/apidom-ns-openapi-3-1';
|
---|
5 | import DereferenceStrategy from "../DereferenceStrategy.mjs";
|
---|
6 | import Reference from "../../../Reference.mjs";
|
---|
7 | import ReferenceSet from "../../../ReferenceSet.mjs";
|
---|
8 | import OpenApi3_1DereferenceVisitor from "./visitor.mjs"; // @ts-ignore
|
---|
9 | const visitAsync = visit[Symbol.for('nodejs.util.promisify.custom')];
|
---|
10 |
|
---|
11 | // eslint-disable-next-line @typescript-eslint/naming-convention
|
---|
12 | const OpenApi3_1DereferenceStrategy = stampit(DereferenceStrategy, {
|
---|
13 | init() {
|
---|
14 | this.name = 'openapi-3-1';
|
---|
15 | },
|
---|
16 | methods: {
|
---|
17 | canDereference(file) {
|
---|
18 | var _file$parseResult;
|
---|
19 | // assert by media type
|
---|
20 | if (file.mediaType !== 'text/plain') {
|
---|
21 | return mediaTypes.includes(file.mediaType);
|
---|
22 | }
|
---|
23 |
|
---|
24 | // assert by inspecting ApiDOM
|
---|
25 | return isOpenApi3_1Element((_file$parseResult = file.parseResult) === null || _file$parseResult === void 0 ? void 0 : _file$parseResult.result);
|
---|
26 | },
|
---|
27 | async dereference(file, options) {
|
---|
28 | const namespace = createNamespace(openApi3_1Namespace);
|
---|
29 | const refSet = defaultTo(ReferenceSet(), options.dereference.refSet);
|
---|
30 | let reference;
|
---|
31 | if (!refSet.has(file.uri)) {
|
---|
32 | reference = Reference({
|
---|
33 | uri: file.uri,
|
---|
34 | value: file.parseResult
|
---|
35 | });
|
---|
36 | refSet.add(reference);
|
---|
37 | } else {
|
---|
38 | // pre-computed refSet was provided as configuration option
|
---|
39 | reference = refSet.find(propEq(file.uri, 'uri'));
|
---|
40 | }
|
---|
41 | const visitor = OpenApi3_1DereferenceVisitor({
|
---|
42 | reference,
|
---|
43 | namespace,
|
---|
44 | options
|
---|
45 | });
|
---|
46 | const dereferencedElement = await visitAsync(refSet.rootRef.value, visitor, {
|
---|
47 | keyMap,
|
---|
48 | nodeTypeGetter: getNodeType
|
---|
49 | });
|
---|
50 |
|
---|
51 | /**
|
---|
52 | * Release all memory if this refSet was not provided as an configuration option.
|
---|
53 | * If provided as configuration option, then provider is responsible for cleanup.
|
---|
54 | */
|
---|
55 | if (options.dereference.refSet === null) {
|
---|
56 | refSet.clean();
|
---|
57 | }
|
---|
58 | return dereferencedElement;
|
---|
59 | }
|
---|
60 | }
|
---|
61 | });
|
---|
62 | export { OpenApi3_1DereferenceVisitor };
|
---|
63 | export { resolveSchema$refField, maybeRefractToSchemaElement } from "../../../resolve/strategies/openapi-3-1/util.mjs";
|
---|
64 | export default OpenApi3_1DereferenceStrategy; |
---|