@api-client/core 0.11.0 → 0.11.2

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.
@@ -1,16 +1,3 @@
1
- /**
2
- @license
3
- Copyright 2018 The Advanced REST client authors <arc@mulesoft.com>
4
- Licensed under the Apache License, Version 2.0 (the "License"); you may not
5
- use this file except in compliance with the License. You may obtain a copy of
6
- the License at
7
- http://www.apache.org/licenses/LICENSE-2.0
8
- Unless required by applicable law or agreed to in writing, software
9
- distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
10
- WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
11
- License for the specific language governing permissions and limitations under
12
- the License.
13
- */
14
1
  import { IAmfDocument, IAmfDomainElement, IAmfEndPoint, IAmfSecurityScheme, IAmfShape, IAmfWebApi, IAmfOperation, IAmfAsyncApi, IAmfServer, IAmfRequest } from './definitions/Amf.js';
15
2
  export declare const findAmfType: unique symbol;
16
3
  export declare const findReferenceObject: unique symbol;
@@ -54,7 +41,7 @@ export declare class AmfMixinInterface {
54
41
  /**
55
42
  * Expands flattened AMF model
56
43
  */
57
- _expand(amf: any): any;
44
+ _expand(amf: unknown): IAmfDocument;
58
45
  /**
59
46
  * Returns compact model key for given value.
60
47
  * @param property AMF original property
@@ -68,7 +55,7 @@ export declare class AmfMixinInterface {
68
55
  * @param amf AMF json/ld model
69
56
  * @returns The API spec
70
57
  */
71
- _ensureAmfModel(amf: any): IAmfDocument | undefined;
58
+ _ensureAmfModel(amf: unknown): IAmfDocument | undefined;
72
59
  /**
73
60
  * Ensures that the value is an array.
74
61
  * It returns undefined when there's no value.
@@ -1 +1 @@
1
- {"version":3,"file":"AmfMixin.d.ts","sourceRoot":"","sources":["../../../src/amf/AmfMixin.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"AmfMixin.d.ts","sourceRoot":"","sources":["../../../src/amf/AmfMixin.ts"],"names":[],"mappings":"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"}
@@ -13,8 +13,7 @@ WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
13
13
  License for the specific language governing permissions and limitations under
14
14
  the License.
15
15
  */
16
- // @ts-expect-error This library has no proper types defined.
17
- import { AmfModelExpander, JsonLdOptions, JsonLd } from 'amf-json-ld-lib';
16
+ import { AmfModelExpander } from 'amf-json-ld-lib';
18
17
  import { AmfNamespace as ns } from './definitions/Namespace.js';
19
18
  export const findAmfType = Symbol('findAmfType');
20
19
  export const findReferenceObject = Symbol('findReferenceObject');
@@ -26,30 +25,18 @@ export const computeReferenceSecurity = Symbol('computeReferenceSecurity');
26
25
  export const AmfMixin = (superClass) => {
27
26
  class AmfMixin extends superClass {
28
27
  _amf;
29
- _flattenedAmf;
30
28
  __cachedKeys;
29
+ __lastSetValue;
31
30
  get amf() {
32
31
  return this._amf;
33
32
  }
34
33
  set amf(value) {
35
- const old = this._amf;
36
- if (old === value) {
34
+ if (this._amf === value || this.__lastSetValue === value) {
37
35
  return;
38
36
  }
39
- let expanded;
40
- if (!value || AmfModelExpander.isInExpandedForm(value)) {
41
- this._flattenedAmf = undefined;
42
- expanded = value;
43
- }
44
- else {
45
- const oldFlattened = this._flattenedAmf;
46
- if (oldFlattened === value) {
47
- return;
48
- }
49
- this._flattenedAmf = value;
50
- expanded = this._expand(value);
51
- }
52
- // Cached keys cannot be static as this element can be using in the sane
37
+ this.__lastSetValue = value;
38
+ const expanded = value ? this._expand(value) : undefined;
39
+ // Cached keys cannot be static as this element can be used in the sane
53
40
  // document with different AMF models
54
41
  this.__cachedKeys = {};
55
42
  this._amf = expanded;
@@ -68,15 +55,7 @@ export const AmfMixin = (superClass) => {
68
55
  * Expands flattened AMF model
69
56
  */
70
57
  _expand(amf) {
71
- AmfModelExpander.preprocessLegacyRootNodeId(amf);
72
- const linkEmbeddingFilter = (key) => !key.endsWith('fixPoint');
73
- const rootNode = amf['@context'] ? '' : 'amf://id';
74
- const options = JsonLdOptions.apply()
75
- .withEmbeddedLinks(linkEmbeddingFilter)
76
- .withCompactedIris()
77
- .withExpandedStructure()
78
- .withRootNode(rootNode);
79
- return JsonLd.process(amf, options);
58
+ return AmfModelExpander.expand(amf);
80
59
  }
81
60
  /**
82
61
  * Returns compact model key for given value.
@@ -1 +1 @@
1
- {"version":3,"file":"AmfMixin.js","sourceRoot":"","sources":["../../../src/amf/AmfMixin.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-unused-vars */\n/**\n@license\nCopyright 2018 The Advanced REST client authors <arc@mulesoft.com>\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not\nuse this file except in compliance with the License. You may obtain a copy of\nthe License at\nhttp://www.apache.org/licenses/LICENSE-2.0\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\nWARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the\nLicense for the specific language governing permissions and limitations under\nthe License.\n*/\n\n// @ts-expect-error This library has no proper types defined.\nimport { AmfModelExpander, JsonLdOptions, JsonLd } from 'amf-json-ld-lib'\nimport {\n IAmfDocument,\n IAmfDomainElement,\n IAmfEndPoint,\n IAmfLdValue,\n IAmfSecurityScheme,\n IAmfShape,\n IAmfWebApi,\n IAmfOperation,\n IAmfAsyncApi,\n IAmfServer,\n IAmfRequest,\n} from './definitions/Amf.js'\nimport { AmfNamespace as ns } from './definitions/Namespace.js'\n\nexport const findAmfType = Symbol('findAmfType')\nexport const findReferenceObject = Symbol('findReferenceObject')\nexport const getArrayItems = Symbol('getArrayItems')\nexport const computeReferenceSecurity = Symbol('computeReferenceSecurity')\n\nexport interface ServersQueryOptions {\n /**\n * An EndPoint to look for the servers in\n */\n endpointId?: string\n /**\n * An Operation to look for the servers in\n */\n methodId?: string\n}\n\nexport interface ServerQueryOptions {\n /**\n * An EndPoint to look for the servers in. Required if Operation is provided\n */\n endpointId?: string\n /**\n * An Operation to look for the servers in\n */\n methodId?: string\n /**\n * Optional selected server id\n */\n id?: string\n}\n\ntype Constructor<T = object> = new (...args: any[]) => T\n\nexport declare class AmfMixinInterface {\n amf?: IAmfDocument\n _amf?: IAmfDocument\n /**\n * This is an abstract method to be implemented by the components.\n * If, instead, the component uses `amf` setter you must use `super.amf` to\n * set the value.\n * @param amf Current AMF model. Can be undefined.\n */\n _amfChanged(amf?: IAmfDocument): void\n\n /**\n * Expands flattened AMF model\n */\n _expand(amf: any): any\n\n /**\n * Returns compact model key for given value.\n * @param property AMF original property\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Compact model property name or the same value if value not found in the context.\n */\n _getAmfKey(property?: string, context?: Record<string, string>): string\n\n /**\n * Ensures that the model is AMF object.\n *\n * @param amf AMF json/ld model\n * @returns The API spec\n */\n _ensureAmfModel(amf: any): IAmfDocument | undefined\n\n /**\n * Ensures that the value is an array.\n * It returns undefined when there's no value.\n * It returns the same array if the value is already an array.\n * It returns new array of the item is not an array.\n *\n * @param value An item to test\n */\n _ensureArray(value?: any): unknown[] | undefined\n\n /**\n * Gets a single scalar value from a model.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for key\n */\n _getValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | number | boolean | undefined | null\n\n /**\n * Gets values from a model as an array of `@value` properties.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The value for key\n */\n _getValueArray(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): (string | number | boolean | null)[] | undefined\n\n /**\n * Reads an array from the model.\n *\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for the key\n */\n [getArrayItems](\n model?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): IAmfDomainElement[] | undefined\n\n /**\n * Reads the value of the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValue(model: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): string | undefined\n\n /**\n * Reads the list of value for the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValues(model: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): string[] | undefined\n\n /**\n * Checks if a model has a type.\n * @param model Model to test\n * @param type Type name\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns True if model has a type.\n */\n _hasType(model?: IAmfDomainElement, type?: string, context?: Record<string, string>): boolean\n\n /**\n * Checks if a shape has a property.\n * @param shape The shape to test\n * @param untrustedKey Property name to test\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _hasProperty(shape: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): boolean\n\n /**\n * Computes array value of a property in a model (shape).\n *\n * @param shape AMF shape object\n * @param untrustedKey Property name\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computePropertyArray(\n shape?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): (string | number | boolean | null | object)[] | undefined\n\n /**\n * Computes API version from the AMF model.\n *\n * @param amf\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeApiVersion(amf?: IAmfDocument, context?: Record<string, string>): string | undefined\n\n /**\n * Computes model's `encodes` property.\n *\n * @param model AMF data model\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of encodes\n */\n _computeEncodes(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Computes list of declarations in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeDeclares(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined\n\n /**\n * Computes list of references in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeReferences(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined\n\n /**\n * Computes AMF's `http://schema.org/WebAPI` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Web API declaration.\n */\n _computeWebApi(model?: IAmfDocument, context?: Record<string, string>): IAmfWebApi | undefined\n\n /**\n * Computes AMF's `http://schema.org/API` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns API declaration.\n */\n _computeApi(model?: IAmfDocument, context?: Record<string, string>): IAmfAsyncApi | IAmfWebApi | undefined\n\n /**\n * Returns whether an AMF node is a WebAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isWebAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Returns whether an AMF node is an AsyncAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAsyncAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Returns whether an AMF node is an API node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Determines whether a partial model is valid for reading servers from\n * Current valid values:\n * - Operation\n * - Endpoint\n * @param model The partial model to evaluate\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Whether the model's type is part of the array of valid node types from which\n * to read servers\n * @private\n */\n _isValidServerPartial(model: IAmfDomainElement | IAmfDomainElement[], context?: Record<string, string>): boolean\n\n /**\n * @param options Server query options\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of servers for method, if defined, or endpoint, if defined, or root level\n */\n _getServers(options?: ServersQueryOptions, context?: Record<string, string>): IAmfServer[] | undefined\n\n /**\n * Computes value for the `expects` property.\n *\n * @param method AMF `supportedOperation` model\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeExpects(method?: IAmfOperation, context?: Record<string, string>): IAmfRequest | undefined\n\n /**\n * Computes list of endpoints from a WebApi model.\n * @param webApi\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An array of endpoints.\n */\n _computeEndpoints(webApi?: IAmfWebApi, context?: Record<string, string>): IAmfEndPoint[] | undefined\n /**\n * Computes model for an endpoint documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param id Selected shape ID\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint definition\n */\n _computeEndpointModel(webApi?: IAmfWebApi, id?: string, context?: Record<string, string>): IAmfEndPoint | undefined\n\n /**\n * Computes method for the method documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A method definition\n */\n _computeMethodModel(\n webApi?: IAmfWebApi,\n selected?: string,\n context?: Record<string, string>\n ): IAmfOperation | undefined\n\n /**\n * Computes an endpoint for a method.\n * @param webApi The WebApi AMF model\n * @param methodId Method id\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint model of undefined.\n */\n _computeMethodEndpoint(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined\n\n /**\n * Computes a list of methods for an endpoint that contains a method with\n * given id.\n *\n * @param webApi WebApi model\n * @param methodId Method id.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A list of sibling methods or undefined.\n */\n __computeMethodsListForMethod(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfOperation[] | undefined\n\n /**\n * Computes a type documentation model.\n *\n * @param declares Current value of `declares` property\n * @param references Current value of `references` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A type definition\n */\n _computeType(\n declares?: IAmfDomainElement[],\n references?: IAmfDomainElement[],\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined\n\n /**\n * Finds a type in the model declares and references.\n * @param domainId The domain id of the type (AMF's shape).\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The AMF shape or undefined when not found.\n */\n [findAmfType](domainId?: string, context?: Record<string, string>): IAmfShape | undefined\n\n /**\n * Searches for an object in model's references list.\n * It does not resolve the object (useful for handling links correctly).\n *\n * @param domainId The domain of the object to find in the references.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The domain object or undefined.\n */\n [findReferenceObject](domainId: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Computes a type model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n _computeReferenceType(\n reference?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined\n\n /**\n * Computes a documentation model.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeDocument(\n webApi?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined\n\n /**\n * Resolves a reference to an external fragment.\n *\n * @param shape A shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape.\n */\n _resolve(shape: any, context?: Record<string, string>): any\n\n /**\n * @param amf References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _getLinkTarget(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Resolves the shape of a given reference.\n *\n * @param references References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _obtainShapeFromReferences(\n references?: IAmfDomainElement[],\n id?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined\n\n /**\n * Searches a node with a given ID in an array\n *\n * @param array Array to search for a given ID\n * @param id Id to search for\n * @returns Node with the given ID when found, undefined otherwise\n */\n _findById(array?: IAmfDomainElement[], id?: string): IAmfDomainElement | undefined\n\n _getReferenceId(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n _resolveRecursive(shape: any, context?: Record<string, string>): void\n\n /**\n * Merge two shapes together. If the resulting shape has one of the \"special merge\" keys,\n * then the special merge function for that key will be used to match that property\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Merged AMF node\n */\n _mergeShapes(shapeA: any, shapeB: any, context?: Record<string, string>): any\n\n /**\n * Obtains source map sources value from two shapes and returns the merged result\n * If neither shape has a sources node, then an empty object will be returned.\n * Result is wrapped in an array as per AMF model standard\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Empty object or resulting merge, wrapped in an array\n * @private\n */\n _mergeSourceMapsSources(shapeA: any, shapeB: any, context?: Record<string, string>): (any | object)[]\n\n /**\n * Expands the key property from compacted mode to full mode.\n * @param value The value to process\n * @returns The expanded value.\n */\n _expandKey(value: string, context?: Record<string, string>): string\n\n /**\n * Computes a security model from a reference (library for example).\n * @param domainId Domain id of the security requirement to find.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n findSecurityScheme(domainId: string, context?: Record<string, string>): IAmfSecurityScheme | undefined\n\n /**\n * Computes a security model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n [computeReferenceSecurity](\n reference: IAmfDomainElement,\n selected: string,\n context?: Record<string, string>\n ): IAmfSecurityScheme | undefined\n\n /**\n * Collects domain objects by a domain type.\n * @param source The element to search for declare/encoded objects.\n * @param type The domain type\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n getByType(source: IAmfDomainElement, type: string, context?: Record<string, string>): IAmfDomainElement[]\n}\n\n/**\n * Common functions used by AMF components to compute AMF values.\n */\nexport const AmfMixin = <T extends Constructor<any>>(superClass: T): Constructor<AmfMixinInterface> & T => {\n class AmfMixin extends superClass {\n _amf?: IAmfDocument\n _flattenedAmf?: any\n __cachedKeys?: any\n\n get amf(): IAmfDocument | undefined {\n return this._amf\n }\n\n set amf(value: IAmfDocument | undefined) {\n const old = this._amf\n if (old === value) {\n return\n }\n let expanded\n if (!value || AmfModelExpander.isInExpandedForm(value)) {\n this._flattenedAmf = undefined\n expanded = value\n } else {\n const oldFlattened = this._flattenedAmf\n if (oldFlattened === value) {\n return\n }\n this._flattenedAmf = value\n expanded = this._expand(value)\n }\n // Cached keys cannot be static as this element can be using in the sane\n // document with different AMF models\n this.__cachedKeys = {}\n this._amf = expanded\n this._amfChanged(expanded)\n }\n\n /**\n * This is an abstract method to be implemented by the components.\n * If, instead, the component uses `amf` setter you must use `super.amf` to\n * set the value.\n * @param amf Current AMF model. Can be undefined.\n */\n _amfChanged(amf?: IAmfDocument): void {\n // ...\n }\n\n /**\n * Expands flattened AMF model\n */\n _expand(amf: any): any {\n AmfModelExpander.preprocessLegacyRootNodeId(amf)\n const linkEmbeddingFilter = (key: string): boolean => !key.endsWith('fixPoint')\n const rootNode = amf['@context'] ? '' : 'amf://id'\n const options = JsonLdOptions.apply()\n .withEmbeddedLinks(linkEmbeddingFilter)\n .withCompactedIris()\n .withExpandedStructure()\n .withRootNode(rootNode)\n return JsonLd.process(amf, options)\n }\n\n /**\n * Returns compact model key for given value.\n * @param property AMF original property\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Compact model property name or the same value if value not found in the context.\n */\n _getAmfKey(property?: string, context?: Record<string, string>): string {\n if (!property) {\n return ''\n }\n let { amf } = this\n if (!amf && !context) {\n return property\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (!this.__cachedKeys) {\n this.__cachedKeys = {}\n }\n const ctx = (context || (amf && amf['@context'])) as Record<string, string> | undefined\n if (!ctx || !property) {\n return property\n }\n const cache = this.__cachedKeys\n if (property in cache) {\n return cache[property]\n }\n property = String(property)\n const hashIndex = property.indexOf('#')\n const hashProperty = property.substring(0, hashIndex + 1)\n const keys = Object.keys(ctx)\n for (let i = 0, len = keys.length; i < len; i++) {\n const k = keys[i]\n if (ctx[k] === property) {\n cache[property] = k\n return k\n }\n if (hashIndex === -1 && property.indexOf(ctx[k]) === 0) {\n const result = property.replace(ctx[k], `${k}:`)\n cache[property] = result\n return result\n }\n if (ctx[k] === hashProperty) {\n const result = `${k}:${property.substring(hashIndex + 1)}`\n cache[property] = result\n return result\n }\n }\n return property\n }\n\n /**\n * Ensures that the model is AMF object.\n *\n * @param amf AMF json/ld model\n * @returns The API spec\n */\n _ensureAmfModel(amf: any): IAmfDocument | undefined {\n if (!amf) {\n return undefined\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (this._hasType(amf, ns.aml.vocabularies.document.Document)) {\n return amf\n }\n return undefined\n }\n\n /**\n * Ensures that the value is an array.\n * It returns undefined when there's no value.\n * It returns the same array if the value is already an array.\n * It returns new array of the item is not an array.\n *\n * @param value An item to test\n */\n _ensureArray(value?: any): unknown[] | undefined {\n if (!value) {\n return undefined\n }\n if (value instanceof Array) {\n return value\n }\n return [value]\n }\n\n /**\n * Gets a single scalar value from a model.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for key\n */\n _getValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | number | boolean | undefined | null {\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n let data = model && (model[key as keyof IAmfDomainElement] as string | number | boolean | undefined | null)\n if (!data) {\n // This includes \"undefined\", \"false\", \"null\" and \"0\"\n return data\n }\n if (Array.isArray(data)) {\n ;[data] = data\n }\n if (!data) {\n return undefined\n }\n const type = typeof data\n if (['string', 'number', 'boolean', 'undefined'].includes(type)) {\n return data\n }\n return (data as unknown as IAmfLdValue<any>)['@value']\n }\n\n /**\n * Gets values from a model as an array of `@value` properties.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The value for key\n */\n _getValueArray(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): (string | number | boolean | null)[] | undefined {\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n const data = model && (this._ensureArray((model as any)[key]) as any[])\n if (!Array.isArray(data)) {\n return undefined\n }\n return data.map((item) => item['@value'] || item)\n }\n\n /**\n * Reads an array from the model.\n *\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for the key\n */\n [getArrayItems](\n model?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): IAmfDomainElement[] | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n const data = model && (this._ensureArray((model as any)[k]) as IAmfDomainElement[])\n if (!Array.isArray(data)) {\n return undefined\n }\n return data\n }\n\n /**\n * Reads the value of the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n let data = model && (model as any)[k]\n if (!data) {\n return undefined\n }\n if (Array.isArray(data)) {\n ;[data] = data\n }\n if (!data) {\n return undefined\n }\n return data['@id']\n }\n\n /**\n * Reads the list of value for the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValues(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string[] | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n let data = (model && (model as any)[k]) as IAmfDomainElement[] | undefined\n if (!data) {\n return undefined\n }\n if (!Array.isArray(data)) {\n data = [data]\n }\n return data.map((i) => i['@id'])\n }\n\n /**\n * Checks if a model has a type.\n * @param model Model to test\n * @param type Type name\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns True if model has a type.\n */\n _hasType(model?: IAmfDomainElement, type?: string, context?: Record<string, string>): boolean {\n const types = this._ensureArray(model && model['@type'])\n if (!types || !types.length) {\n return false\n }\n const key = this._getAmfKey(type, context)\n for (const type of types) {\n if (type === key) {\n return true\n }\n }\n return false\n }\n\n /**\n * Checks if a shape has a property.\n * @param shape The shape to test\n * @param untrustedKey Property name to test\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _hasProperty(shape: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): boolean {\n const key = this._getAmfKey(untrustedKey, context) as string\n return !!(shape && key && key in shape)\n }\n\n /**\n * Computes array value of a property in a model (shape).\n *\n * @param shape AMF shape object\n * @param untrustedKey Property name\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computePropertyArray(\n shape?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): (string | number | boolean | null | object)[] | undefined {\n if (!shape) {\n return undefined\n }\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray(shape && (shape as any)[key])\n if (!data || !Array.isArray(data)) {\n return undefined\n }\n return data as (string | number | boolean | null | object)[]\n }\n\n /**\n * Computes API version from the AMF model.\n *\n * @param amf\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeApiVersion(amf?: IAmfDocument, context?: Record<string, string>): string | undefined {\n const api = this._computeApi(amf)\n if (!api) {\n return undefined\n }\n return this._getValue(api, ns.aml.vocabularies.core.version, context) as string\n }\n\n /**\n * Computes model's `encodes` property.\n *\n * @param model AMF data model\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of encodes\n */\n _computeEncodes(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.encodes, context)\n if (!key) {\n return undefined\n }\n const data = (model as any)[key]\n if (data) {\n return Array.isArray(data) ? data[0] : data\n }\n return undefined\n }\n\n /**\n * Computes list of declarations in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeDeclares(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.declares, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray((model as any)[key]) as IAmfDomainElement[]\n return Array.isArray(data) ? data : undefined\n }\n\n /**\n * Computes list of references in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeReferences(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.references, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray((model as any)[key]) as IAmfDomainElement[]\n return data instanceof Array ? data : undefined\n }\n\n /**\n * Computes AMF's `http://schema.org/WebAPI` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Web API declaration.\n */\n _computeWebApi(model?: IAmfDocument, context?: Record<string, string>): IAmfWebApi | undefined {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return undefined\n }\n if (this._hasType(enc, ns.aml.vocabularies.apiContract.WebAPI, context)) {\n return enc\n }\n return undefined\n }\n\n /**\n * Computes AMF's `http://schema.org/API` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns API declaration.\n */\n _computeApi(model?: IAmfDocument, context?: Record<string, string>): IAmfAsyncApi | IAmfWebApi | undefined {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return undefined\n }\n if (this._isAPI(model, context) || this._isWebAPI(model, context) || this._isAsyncAPI(model, context)) {\n return enc\n }\n return undefined\n }\n\n /**\n * Returns whether an AMF node is a WebAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isWebAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.WebAPI, context)\n }\n\n /**\n * Returns whether an AMF node is an AsyncAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAsyncAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.AsyncAPI, context)\n }\n\n /**\n * Returns whether an AMF node is an API node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.API, context)\n }\n\n /**\n * Determines whether a partial model is valid for reading servers from\n * Current valid values:\n * - Operation\n * - Endpoint\n * @param model The partial model to evaluate\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Whether the model's type is part of the array of valid node types from which\n * to read servers\n * @private\n */\n _isValidServerPartial(model: IAmfDomainElement | IAmfDomainElement[], context?: Record<string, string>): boolean {\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return false\n }\n const oKey = ns.aml.vocabularies.apiContract.Operation\n const eKey = ns.aml.vocabularies.apiContract.EndPoint\n const allowedPartialModelTypes = [this._getAmfKey(oKey, context), this._getAmfKey(eKey, context)]\n const types = model['@type']\n for (const type of types) {\n if (allowedPartialModelTypes.indexOf(type) !== -1) {\n return true\n }\n }\n return false\n }\n\n /**\n * @param options Server query options\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of servers for method, if defined, or endpoint, if defined, or root level\n */\n _getServers(options: ServersQueryOptions = {}, context?: Record<string, string>): IAmfServer[] | undefined {\n const { endpointId, methodId } = options\n const { amf } = this\n if (!amf) {\n return undefined\n }\n let api = this._computeApi(amf, context)\n if (Array.isArray(api)) {\n ;[api] = api\n }\n if (!api) {\n if (this._isValidServerPartial(amf, context)) {\n api = amf\n } else {\n return undefined\n }\n }\n\n const serverKey = this._getAmfKey(ns.aml.vocabularies.apiContract.server, context)\n\n const getRootServers = (): IAmfServer[] | undefined =>\n this[getArrayItems](api, serverKey, context) as IAmfServer[]\n const getEndpointServers = (): IAmfServer[] | undefined => {\n const endpoint = this._computeEndpointModel(api, endpointId, context)\n const servers = this[getArrayItems](endpoint, serverKey, context) as IAmfServer[]\n if (servers) {\n return servers\n }\n return getRootServers()\n }\n const getMethodServers = (): IAmfServer[] | undefined => {\n const method = this._computeMethodModel(api, methodId, context)\n const servers = this[getArrayItems](method, serverKey, context) as IAmfServer[]\n if (servers) {\n return servers\n }\n return getEndpointServers()\n }\n\n if (methodId) {\n return getMethodServers()\n }\n if (endpointId) {\n return getEndpointServers()\n }\n return getRootServers()\n }\n\n /**\n * Computes value for the `expects` property.\n *\n * @param method AMF `supportedOperation` model\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeExpects(method?: IAmfOperation, context?: Record<string, string>): IAmfRequest | undefined {\n const operationKey = ns.aml.vocabularies.apiContract.Operation\n const expectsKey = ns.aml.vocabularies.apiContract.expects\n if (this._hasType(method, operationKey, context)) {\n const key = this._getAmfKey(expectsKey, context) as string\n const expects = this._ensureArray((method as any)[key])\n if (expects) {\n return Array.isArray(expects) ? (expects[0] as IAmfRequest) : (expects as IAmfRequest)\n }\n }\n return undefined\n }\n\n /**\n * Computes list of endpoints from a WebApi model.\n * @param webApi\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An array of endpoints.\n */\n _computeEndpoints(webApi?: IAmfWebApi, context?: Record<string, string>): IAmfEndPoint[] | undefined {\n if (!webApi) {\n return []\n }\n const endpointKey = ns.aml.vocabularies.apiContract.endpoint\n const key = this._getAmfKey(endpointKey, context) as string\n return this._ensureArray((webApi as any)[key]) as IAmfEndPoint[]\n }\n\n /**\n * Computes model for an endpoint documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param id Selected shape ID\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint definition\n */\n _computeEndpointModel(\n webApi?: IAmfWebApi,\n id?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined {\n if (this._hasType(webApi, ns.aml.vocabularies.apiContract.EndPoint, context)) {\n return webApi\n }\n const endpoints = this._computeEndpoints(webApi, context)\n if (!endpoints) {\n return undefined\n }\n return endpoints.find((item) => item['@id'] === id)\n }\n\n /**\n * Computes method for the method documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A method definition\n */\n _computeMethodModel(\n webApi?: IAmfWebApi,\n selected?: string,\n context?: Record<string, string>\n ): IAmfOperation | undefined {\n const methods = this.__computeMethodsListForMethod(webApi, selected, context)\n if (!methods) {\n return undefined\n }\n return methods.find((item) => item['@id'] === selected)\n }\n\n /**\n * Computes an endpoint for a method.\n * @param webApi The WebApi AMF model\n * @param methodId Method id\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint model of undefined.\n */\n _computeMethodEndpoint(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined {\n if (!webApi || !methodId) {\n return undefined\n }\n if (this._hasType(webApi, ns.aml.vocabularies.apiContract.EndPoint, context)) {\n return webApi\n }\n const endpoints = this._computeEndpoints(webApi, context)\n if (!endpoints) {\n return undefined\n }\n const opKey = this._getAmfKey(ns.aml.vocabularies.apiContract.supportedOperation, context)\n for (let i = 0, len = endpoints.length; i < len; i++) {\n const endpoint = endpoints[i]\n let methods = (endpoint as any)[opKey] as IAmfOperation[]\n if (!methods) {\n continue\n }\n if (!Array.isArray(methods)) {\n methods = [methods]\n }\n for (let j = 0, jLen = methods.length; j < jLen; j++) {\n if (methods[j]['@id'] === methodId) {\n return endpoint\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a list of methods for an endpoint that contains a method with\n * given id.\n *\n * @param webApi WebApi model\n * @param methodId Method id.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A list of sibling methods or undefined.\n */\n __computeMethodsListForMethod(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfOperation[] | undefined {\n const endpoint = this._computeMethodEndpoint(webApi, methodId, context)\n if (!endpoint) {\n return undefined\n }\n const opKey = this._getAmfKey(ns.aml.vocabularies.apiContract.supportedOperation, context)\n return this._ensureArray((endpoint as any)[opKey]) as IAmfOperation[] | undefined\n }\n\n /**\n * Computes a type documentation model.\n *\n * @param declares Current value of `declares` property\n * @param references Current value of `references` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A type definition\n */\n _computeType(\n declares?: IAmfDomainElement[],\n references?: IAmfDomainElement[],\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined {\n if ((!declares && !references) || !selected) {\n return undefined\n }\n // In compact model some IDs are presented in long version (in source maps for examples)\n // This must test for this case as well.\n const compactId = selected.replace('amf://id', '')\n let type = declares && declares.find((item) => item['@id'] === selected || item['@id'] === compactId)\n if (!type && references && references.length) {\n for (let i = 0, len = references.length; i < len; i++) {\n if (!this._hasType(references[i], ns.aml.vocabularies.document.Module)) {\n continue\n }\n type = this._computeReferenceType(references[i], selected, context)\n if (type) {\n break\n }\n }\n }\n return type\n }\n\n /**\n * Finds a type in the model declares and references.\n * @param domainId The domain id of the type (AMF's shape).\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The AMF shape or undefined when not found.\n */\n [findAmfType](domainId?: string, context?: Record<string, string>): IAmfShape | undefined {\n let { amf } = this\n if (!amf || !domainId) {\n return undefined\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n const declares = this._computeDeclares(amf, context)\n const compactId = domainId.replace('amf://id', '')\n if (Array.isArray(declares)) {\n const result = declares.find((item) => item['@id'] === domainId || item['@id'] === compactId)\n if (result) {\n return result\n }\n }\n return this[findReferenceObject](domainId)\n }\n\n /**\n * Searches for an object in model's references list.\n * It does not resolve the object (useful for handling links correctly).\n *\n * @param domainId The domain of the object to find in the references.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The domain object or undefined.\n */\n [findReferenceObject](domainId: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n let { amf } = this\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (!amf) {\n return undefined\n }\n const references = this._computeReferences(amf, context)\n if (!Array.isArray(references) || !references.length) {\n return undefined\n }\n const compactId = domainId.replace('amf://id', '')\n for (let i = 0, len = references.length; i < len; i++) {\n const ref = /** @type IAmfDocument */ references[i]\n const declares = this._computeDeclares(ref, context)\n if (!Array.isArray(declares)) {\n continue\n }\n for (let j = 0, lenDecl = declares.length; j < lenDecl; j++) {\n let declared = declares[j]\n if (Array.isArray(declared)) {\n ;[declared] = declared\n }\n if (declared['@id'] === domainId || declared['@id'] === compactId) {\n return declared\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a type model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n _computeReferenceType(\n reference?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined {\n const declare = this._computeDeclares(reference, context)\n if (!declare || !selected) {\n return undefined\n }\n // In compact model some IDs are presented in long version (in source maps for examples)\n // This must test for this case as well.\n const compactId = selected.replace('amf://id', '')\n let result = declare.find((item) => {\n if (Array.isArray(item)) {\n ;[item] = item\n }\n return item['@id'] === selected || item['@id'] === compactId\n })\n if (Array.isArray(result)) {\n ;[result] = result\n }\n return this._resolve(result)\n }\n\n /**\n * Computes a documentation model.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeDocument(\n webApi?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined {\n if (!webApi || !selected) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.core.documentation, context)\n const docs = this._ensureArray((webApi as any)[key]) as IAmfDomainElement[]\n return docs && docs.find((item) => ((item as any)['@id'] as string) === selected)\n }\n\n /**\n * Resolves a reference to an external fragment.\n *\n * @param shape A shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape.\n */\n _resolve(shape: any, context?: Record<string, string>): any {\n const { amf } = this\n if (typeof shape !== 'object' || Array.isArray(shape) || !amf || shape.__apicResolved) {\n return shape\n }\n let refKey = this._getAmfKey(ns.aml.vocabularies.document.linkTarget, context)\n let refValue = this._ensureArray(shape[refKey]) as IAmfDomainElement[]\n let refData\n if (refValue) {\n const rk = refValue[0]['@id']\n if (rk === shape['@id']) {\n // recursive shape.\n shape.__apicResolved = true\n return shape\n }\n refData = this._getLinkTarget(amf, rk, context)\n } else {\n refKey = this._getAmfKey(ns.aml.vocabularies.document.referenceId, context)\n refValue = this._ensureArray(shape[refKey]) as IAmfDomainElement[]\n if (refValue) {\n const rk = refValue[0]['@id']\n if (rk === shape['@id']) {\n // recursive shape.\n shape.__apicResolved = true\n return shape\n }\n refData = this._getReferenceId(amf, rk, context)\n }\n }\n if (!refData) {\n this._resolveRecursive(shape)\n shape.__apicResolved = true\n return shape\n }\n const copy = { ...refData } as any\n delete copy['@id']\n const types = copy['@type']\n if (types) {\n if (shape['@type']) {\n shape['@type'] = shape['@type'].concat(types)\n } else {\n shape['@type'] = types\n }\n delete copy['@type']\n }\n this._mergeShapes(shape, copy, context)\n shape.__apicResolved = true\n this._resolveRecursive(shape)\n return shape\n }\n\n /**\n * @param amf References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _getLinkTarget(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!amf || !id) {\n return undefined\n }\n let target\n const declares = this._computeDeclares(amf, context)\n if (declares) {\n target = this._findById(declares, id)\n }\n if (!target) {\n const references = this._computeReferences(amf, context)\n target = this._obtainShapeFromReferences(references, id, context)\n }\n if (!target) {\n return undefined\n }\n // Declaration may contain references\n target = this._resolve(target)\n return target\n }\n\n /**\n * Resolves the shape of a given reference.\n *\n * @param references References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _obtainShapeFromReferences(\n references?: IAmfDomainElement[],\n id?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined {\n if (!Array.isArray(references) || !references.length) {\n return undefined\n }\n let target\n for (const _ref of references) {\n // case of fragment that encodes the shape\n const encoded = this._computeEncodes(_ref, context)\n if (encoded && encoded['@id'] === id) {\n target = encoded\n break\n }\n // case of a library which declares types\n if (!encoded) {\n target = this._findById(this._computeDeclares(_ref, context), id)\n if (target) break\n }\n }\n return target\n }\n\n /**\n * Searches a node with a given ID in an array\n *\n * @param array Array to search for a given ID\n * @param id Id to search for\n * @returns Node with the given ID when found, undefined otherwise\n */\n _findById(array?: IAmfDomainElement[], id?: string): IAmfDomainElement | undefined {\n if (!array) return undefined\n let target\n for (const _current of array) {\n if (_current && _current['@id'] === id) {\n target = _current\n break\n }\n }\n return target\n }\n\n _getReferenceId(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!amf || !id) {\n return undefined\n }\n const refs = this._computeReferences(amf, context)\n if (!refs) {\n return undefined\n }\n for (const _ref of refs) {\n const enc = this._computeEncodes(_ref, context)\n if (enc) {\n if (enc['@id'] === id) {\n return enc\n }\n }\n }\n return undefined\n }\n\n _resolveRecursive(shape: any, context?: Record<string, string>): void {\n Object.keys(shape).forEach((key) => {\n const currentShape = shape[key]\n if (Array.isArray(currentShape)) {\n for (let i = 0, len = currentShape.length; i < len; i++) {\n currentShape[i] = this._resolve(currentShape[i])\n }\n } else if (typeof currentShape === 'object') {\n shape[key] = this._resolve(currentShape, context)\n }\n })\n }\n\n /**\n * Merge two shapes together. If the resulting shape has one of the \"special merge\" keys,\n * then the special merge function for that key will be used to match that property\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Merged AMF node\n */\n _mergeShapes(shapeA: any, shapeB: any, context?: Record<string, string>): any {\n const merged = { ...shapeA, ...shapeB }\n const specialMerges = [\n {\n key: this._getAmfKey(ns.aml.vocabularies.docSourceMaps.sources, context),\n merger: this._mergeSourceMapsSources.bind(this),\n },\n ]\n specialMerges.forEach(({ key, merger }) => {\n if (this._hasProperty(merged, key, context)) {\n merged[key] = merger(shapeA, shapeB, context)\n }\n })\n return Object.assign(shapeA, merged)\n }\n\n /**\n * Obtains source map sources value from two shapes and returns the merged result\n * If neither shape has a sources node, then an empty object will be returned.\n * Result is wrapped in an array as per AMF model standard\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Empty object or resulting merge, wrapped in an array\n * @private\n */\n _mergeSourceMapsSources(shapeA: any, shapeB: any, context?: Record<string, string>): (any | object)[] {\n const sourcesKey = this._getAmfKey(ns.aml.vocabularies.docSourceMaps.sources, context)\n let aSources = shapeA[sourcesKey] || {}\n if (Array.isArray(aSources)) {\n aSources = aSources[0]\n }\n let bSources = shapeB[sourcesKey] || {}\n if (Array.isArray(bSources)) {\n bSources = bSources[0]\n }\n return [Object.assign(aSources, bSources)]\n }\n\n /**\n * Expands the key property from compacted mode to full mode.\n * @param value The value to process\n * @returns The expanded value.\n */\n _expandKey(value: string, context?: Record<string, string>): string {\n let { amf } = this\n if (!value || typeof value !== 'string' || (!amf && !context)) {\n return value\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n const ctx = context || (amf && amf['@context'])\n if (!ctx) {\n return value\n }\n const [root, key] = value.split(':')\n if (!root || !key) {\n return value\n }\n const prefix = ctx[root]\n if (!prefix) {\n return value\n }\n return `${prefix}${key}`\n }\n\n /**\n * Computes a security model from a reference (library for example).\n * @param domainId Domain id of the security requirement to find.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n findSecurityScheme(domainId: string, context?: Record<string, string>): IAmfSecurityScheme | undefined {\n const { amf } = this\n const declares = this._computeDeclares(amf, context)\n let result\n if (declares) {\n result = declares.find((item) => item['@id'] === domainId)\n }\n if (result) {\n result = this._resolve(result)\n return result\n }\n const references = this._computeReferences(amf, context)\n if (Array.isArray(references) && references.length) {\n for (const ref of references) {\n if (this._hasType(ref, ns.aml.vocabularies.document.Module, context)) {\n result = this[computeReferenceSecurity](ref, domainId, context)\n if (result) {\n result = this._resolve(result)\n return result\n }\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a security model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n [computeReferenceSecurity](\n reference: IAmfDomainElement,\n selected: string,\n context?: Record<string, string>\n ): IAmfSecurityScheme | undefined {\n const declare = this._computeDeclares(reference, context)\n if (!declare) {\n return undefined\n }\n let result = declare.find((item) => {\n let declared = item\n if (Array.isArray(declared)) {\n ;[declared] = declared\n }\n return declared['@id'] === selected\n })\n if (Array.isArray(result)) {\n ;[result] = result\n }\n return this._resolve(result)\n }\n\n /**\n * Collects domain objects by a domain type.\n * @param source The element to search for declare/encoded objects.\n * @param type The domain type\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n getByType(source: IAmfDomainElement, type: string, context?: Record<string, string>): IAmfDomainElement[] {\n if (!source) {\n return []\n }\n let result: IAmfDomainElement[] = []\n const declares = this._computeDeclares(source)\n const key = this._getAmfKey(type, context)\n if (declares && declares.length) {\n declares.forEach((declared) => {\n if (this._hasType(declared, key)) {\n result.push(declared as IAmfDomainElement)\n }\n })\n }\n const references = this._computeReferences(source)\n if (Array.isArray(references) && references.length) {\n for (const ref of references) {\n if (this._hasType(ref, ns.aml.vocabularies.document.Module)) {\n const items = this.getByType(ref as IAmfDomainElement, type, context)\n if (items.length) {\n result = result.concat(items)\n }\n }\n }\n }\n return result\n }\n }\n return AmfMixin as Constructor<AmfMixinInterface> & T\n}\n"]}
1
+ {"version":3,"file":"AmfMixin.js","sourceRoot":"","sources":["../../../src/amf/AmfMixin.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\n/* eslint-disable @typescript-eslint/no-unused-vars */\n/**\n@license\nCopyright 2018 The Advanced REST client authors <arc@mulesoft.com>\nLicensed under the Apache License, Version 2.0 (the \"License\"); you may not\nuse this file except in compliance with the License. You may obtain a copy of\nthe License at\nhttp://www.apache.org/licenses/LICENSE-2.0\nUnless required by applicable law or agreed to in writing, software\ndistributed under the License is distributed on an \"AS IS\" BASIS, WITHOUT\nWARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the\nLicense for the specific language governing permissions and limitations under\nthe License.\n*/\nimport { AmfModelExpander } from 'amf-json-ld-lib'\nimport {\n IAmfDocument,\n IAmfDomainElement,\n IAmfEndPoint,\n IAmfLdValue,\n IAmfSecurityScheme,\n IAmfShape,\n IAmfWebApi,\n IAmfOperation,\n IAmfAsyncApi,\n IAmfServer,\n IAmfRequest,\n} from './definitions/Amf.js'\nimport { AmfNamespace as ns } from './definitions/Namespace.js'\n\nexport const findAmfType = Symbol('findAmfType')\nexport const findReferenceObject = Symbol('findReferenceObject')\nexport const getArrayItems = Symbol('getArrayItems')\nexport const computeReferenceSecurity = Symbol('computeReferenceSecurity')\n\nexport interface ServersQueryOptions {\n /**\n * An EndPoint to look for the servers in\n */\n endpointId?: string\n /**\n * An Operation to look for the servers in\n */\n methodId?: string\n}\n\nexport interface ServerQueryOptions {\n /**\n * An EndPoint to look for the servers in. Required if Operation is provided\n */\n endpointId?: string\n /**\n * An Operation to look for the servers in\n */\n methodId?: string\n /**\n * Optional selected server id\n */\n id?: string\n}\n\ntype Constructor<T = object> = new (...args: any[]) => T\n\nexport declare class AmfMixinInterface {\n amf?: IAmfDocument\n _amf?: IAmfDocument\n /**\n * This is an abstract method to be implemented by the components.\n * If, instead, the component uses `amf` setter you must use `super.amf` to\n * set the value.\n * @param amf Current AMF model. Can be undefined.\n */\n _amfChanged(amf?: IAmfDocument): void\n\n /**\n * Expands flattened AMF model\n */\n _expand(amf: unknown): IAmfDocument\n\n /**\n * Returns compact model key for given value.\n * @param property AMF original property\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Compact model property name or the same value if value not found in the context.\n */\n _getAmfKey(property?: string, context?: Record<string, string>): string\n\n /**\n * Ensures that the model is AMF object.\n *\n * @param amf AMF json/ld model\n * @returns The API spec\n */\n _ensureAmfModel(amf: unknown): IAmfDocument | undefined\n\n /**\n * Ensures that the value is an array.\n * It returns undefined when there's no value.\n * It returns the same array if the value is already an array.\n * It returns new array of the item is not an array.\n *\n * @param value An item to test\n */\n _ensureArray(value?: any): unknown[] | undefined\n\n /**\n * Gets a single scalar value from a model.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for key\n */\n _getValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | number | boolean | undefined | null\n\n /**\n * Gets values from a model as an array of `@value` properties.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The value for key\n */\n _getValueArray(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): (string | number | boolean | null)[] | undefined\n\n /**\n * Reads an array from the model.\n *\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for the key\n */\n [getArrayItems](\n model?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): IAmfDomainElement[] | undefined\n\n /**\n * Reads the value of the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValue(model: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): string | undefined\n\n /**\n * Reads the list of value for the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValues(model: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): string[] | undefined\n\n /**\n * Checks if a model has a type.\n * @param model Model to test\n * @param type Type name\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns True if model has a type.\n */\n _hasType(model?: IAmfDomainElement, type?: string, context?: Record<string, string>): boolean\n\n /**\n * Checks if a shape has a property.\n * @param shape The shape to test\n * @param untrustedKey Property name to test\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _hasProperty(shape: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): boolean\n\n /**\n * Computes array value of a property in a model (shape).\n *\n * @param shape AMF shape object\n * @param untrustedKey Property name\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computePropertyArray(\n shape?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): (string | number | boolean | null | object)[] | undefined\n\n /**\n * Computes API version from the AMF model.\n *\n * @param amf\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeApiVersion(amf?: IAmfDocument, context?: Record<string, string>): string | undefined\n\n /**\n * Computes model's `encodes` property.\n *\n * @param model AMF data model\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of encodes\n */\n _computeEncodes(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Computes list of declarations in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeDeclares(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined\n\n /**\n * Computes list of references in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeReferences(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined\n\n /**\n * Computes AMF's `http://schema.org/WebAPI` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Web API declaration.\n */\n _computeWebApi(model?: IAmfDocument, context?: Record<string, string>): IAmfWebApi | undefined\n\n /**\n * Computes AMF's `http://schema.org/API` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns API declaration.\n */\n _computeApi(model?: IAmfDocument, context?: Record<string, string>): IAmfAsyncApi | IAmfWebApi | undefined\n\n /**\n * Returns whether an AMF node is a WebAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isWebAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Returns whether an AMF node is an AsyncAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAsyncAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Returns whether an AMF node is an API node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAPI(model?: IAmfDocument, context?: Record<string, string>): boolean\n\n /**\n * Determines whether a partial model is valid for reading servers from\n * Current valid values:\n * - Operation\n * - Endpoint\n * @param model The partial model to evaluate\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Whether the model's type is part of the array of valid node types from which\n * to read servers\n * @private\n */\n _isValidServerPartial(model: IAmfDomainElement | IAmfDomainElement[], context?: Record<string, string>): boolean\n\n /**\n * @param options Server query options\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of servers for method, if defined, or endpoint, if defined, or root level\n */\n _getServers(options?: ServersQueryOptions, context?: Record<string, string>): IAmfServer[] | undefined\n\n /**\n * Computes value for the `expects` property.\n *\n * @param method AMF `supportedOperation` model\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeExpects(method?: IAmfOperation, context?: Record<string, string>): IAmfRequest | undefined\n\n /**\n * Computes list of endpoints from a WebApi model.\n * @param webApi\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An array of endpoints.\n */\n _computeEndpoints(webApi?: IAmfWebApi, context?: Record<string, string>): IAmfEndPoint[] | undefined\n /**\n * Computes model for an endpoint documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param id Selected shape ID\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint definition\n */\n _computeEndpointModel(webApi?: IAmfWebApi, id?: string, context?: Record<string, string>): IAmfEndPoint | undefined\n\n /**\n * Computes method for the method documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A method definition\n */\n _computeMethodModel(\n webApi?: IAmfWebApi,\n selected?: string,\n context?: Record<string, string>\n ): IAmfOperation | undefined\n\n /**\n * Computes an endpoint for a method.\n * @param webApi The WebApi AMF model\n * @param methodId Method id\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint model of undefined.\n */\n _computeMethodEndpoint(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined\n\n /**\n * Computes a list of methods for an endpoint that contains a method with\n * given id.\n *\n * @param webApi WebApi model\n * @param methodId Method id.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A list of sibling methods or undefined.\n */\n __computeMethodsListForMethod(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfOperation[] | undefined\n\n /**\n * Computes a type documentation model.\n *\n * @param declares Current value of `declares` property\n * @param references Current value of `references` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A type definition\n */\n _computeType(\n declares?: IAmfDomainElement[],\n references?: IAmfDomainElement[],\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined\n\n /**\n * Finds a type in the model declares and references.\n * @param domainId The domain id of the type (AMF's shape).\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The AMF shape or undefined when not found.\n */\n [findAmfType](domainId?: string, context?: Record<string, string>): IAmfShape | undefined\n\n /**\n * Searches for an object in model's references list.\n * It does not resolve the object (useful for handling links correctly).\n *\n * @param domainId The domain of the object to find in the references.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The domain object or undefined.\n */\n [findReferenceObject](domainId: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Computes a type model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n _computeReferenceType(\n reference?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined\n\n /**\n * Computes a documentation model.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeDocument(\n webApi?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined\n\n /**\n * Resolves a reference to an external fragment.\n *\n * @param shape A shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape.\n */\n _resolve(shape: any, context?: Record<string, string>): any\n\n /**\n * @param amf References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _getLinkTarget(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n /**\n * Resolves the shape of a given reference.\n *\n * @param references References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _obtainShapeFromReferences(\n references?: IAmfDomainElement[],\n id?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined\n\n /**\n * Searches a node with a given ID in an array\n *\n * @param array Array to search for a given ID\n * @param id Id to search for\n * @returns Node with the given ID when found, undefined otherwise\n */\n _findById(array?: IAmfDomainElement[], id?: string): IAmfDomainElement | undefined\n\n _getReferenceId(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined\n\n _resolveRecursive(shape: any, context?: Record<string, string>): void\n\n /**\n * Merge two shapes together. If the resulting shape has one of the \"special merge\" keys,\n * then the special merge function for that key will be used to match that property\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Merged AMF node\n */\n _mergeShapes(shapeA: any, shapeB: any, context?: Record<string, string>): any\n\n /**\n * Obtains source map sources value from two shapes and returns the merged result\n * If neither shape has a sources node, then an empty object will be returned.\n * Result is wrapped in an array as per AMF model standard\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Empty object or resulting merge, wrapped in an array\n * @private\n */\n _mergeSourceMapsSources(shapeA: any, shapeB: any, context?: Record<string, string>): (any | object)[]\n\n /**\n * Expands the key property from compacted mode to full mode.\n * @param value The value to process\n * @returns The expanded value.\n */\n _expandKey(value: string, context?: Record<string, string>): string\n\n /**\n * Computes a security model from a reference (library for example).\n * @param domainId Domain id of the security requirement to find.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n findSecurityScheme(domainId: string, context?: Record<string, string>): IAmfSecurityScheme | undefined\n\n /**\n * Computes a security model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n [computeReferenceSecurity](\n reference: IAmfDomainElement,\n selected: string,\n context?: Record<string, string>\n ): IAmfSecurityScheme | undefined\n\n /**\n * Collects domain objects by a domain type.\n * @param source The element to search for declare/encoded objects.\n * @param type The domain type\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n getByType(source: IAmfDomainElement, type: string, context?: Record<string, string>): IAmfDomainElement[]\n}\n\n/**\n * Common functions used by AMF components to compute AMF values.\n */\nexport const AmfMixin = <T extends Constructor<any>>(superClass: T): Constructor<AmfMixinInterface> & T => {\n class AmfMixin extends superClass {\n _amf?: IAmfDocument\n __cachedKeys?: any\n __lastSetValue?: unknown\n\n get amf(): IAmfDocument | undefined {\n return this._amf\n }\n\n set amf(value: IAmfDocument | undefined) {\n if (this._amf === value || this.__lastSetValue === value) {\n return\n }\n this.__lastSetValue = value\n const expanded = value ? this._expand(value) : undefined\n // Cached keys cannot be static as this element can be used in the sane\n // document with different AMF models\n this.__cachedKeys = {}\n this._amf = expanded\n this._amfChanged(expanded)\n }\n\n /**\n * This is an abstract method to be implemented by the components.\n * If, instead, the component uses `amf` setter you must use `super.amf` to\n * set the value.\n * @param amf Current AMF model. Can be undefined.\n */\n _amfChanged(amf?: IAmfDocument): void {\n // ...\n }\n\n /**\n * Expands flattened AMF model\n */\n _expand(amf: any): IAmfDocument {\n return AmfModelExpander.expand(amf) as IAmfDocument\n }\n\n /**\n * Returns compact model key for given value.\n * @param property AMF original property\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Compact model property name or the same value if value not found in the context.\n */\n _getAmfKey(property?: string, context?: Record<string, string>): string {\n if (!property) {\n return ''\n }\n let { amf } = this\n if (!amf && !context) {\n return property\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (!this.__cachedKeys) {\n this.__cachedKeys = {}\n }\n const ctx = (context || (amf && amf['@context'])) as Record<string, string> | undefined\n if (!ctx || !property) {\n return property\n }\n const cache = this.__cachedKeys\n if (property in cache) {\n return cache[property]\n }\n property = String(property)\n const hashIndex = property.indexOf('#')\n const hashProperty = property.substring(0, hashIndex + 1)\n const keys = Object.keys(ctx)\n for (let i = 0, len = keys.length; i < len; i++) {\n const k = keys[i]\n if (ctx[k] === property) {\n cache[property] = k\n return k\n }\n if (hashIndex === -1 && property.indexOf(ctx[k]) === 0) {\n const result = property.replace(ctx[k], `${k}:`)\n cache[property] = result\n return result\n }\n if (ctx[k] === hashProperty) {\n const result = `${k}:${property.substring(hashIndex + 1)}`\n cache[property] = result\n return result\n }\n }\n return property\n }\n\n /**\n * Ensures that the model is AMF object.\n *\n * @param amf AMF json/ld model\n * @returns The API spec\n */\n _ensureAmfModel(amf: any): IAmfDocument | undefined {\n if (!amf) {\n return undefined\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (this._hasType(amf, ns.aml.vocabularies.document.Document)) {\n return amf\n }\n return undefined\n }\n\n /**\n * Ensures that the value is an array.\n * It returns undefined when there's no value.\n * It returns the same array if the value is already an array.\n * It returns new array of the item is not an array.\n *\n * @param value An item to test\n */\n _ensureArray(value?: any): unknown[] | undefined {\n if (!value) {\n return undefined\n }\n if (value instanceof Array) {\n return value\n }\n return [value]\n }\n\n /**\n * Gets a single scalar value from a model.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for key\n */\n _getValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | number | boolean | undefined | null {\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n let data = model && (model[key as keyof IAmfDomainElement] as string | number | boolean | undefined | null)\n if (!data) {\n // This includes \"undefined\", \"false\", \"null\" and \"0\"\n return data\n }\n if (Array.isArray(data)) {\n ;[data] = data\n }\n if (!data) {\n return undefined\n }\n const type = typeof data\n if (['string', 'number', 'boolean', 'undefined'].includes(type)) {\n return data\n }\n return (data as unknown as IAmfLdValue<any>)['@value']\n }\n\n /**\n * Gets values from a model as an array of `@value` properties.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The value for key\n */\n _getValueArray(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): (string | number | boolean | null)[] | undefined {\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n const data = model && (this._ensureArray((model as any)[key]) as any[])\n if (!Array.isArray(data)) {\n return undefined\n }\n return data.map((item) => item['@value'] || item)\n }\n\n /**\n * Reads an array from the model.\n *\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the value\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Value for the key\n */\n [getArrayItems](\n model?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): IAmfDomainElement[] | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n const data = model && (this._ensureArray((model as any)[k]) as IAmfDomainElement[])\n if (!Array.isArray(data)) {\n return undefined\n }\n return data\n }\n\n /**\n * Reads the value of the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValue(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n let data = model && (model as any)[k]\n if (!data) {\n return undefined\n }\n if (Array.isArray(data)) {\n ;[data] = data\n }\n if (!data) {\n return undefined\n }\n return data['@id']\n }\n\n /**\n * Reads the list of value for the `@id` property.\n * @param model Amf model to extract the value from.\n * @param untrustedKey Model key to search for the @id\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _getLinkValues(\n model: IAmfDomainElement,\n untrustedKey: string,\n context?: Record<string, string>\n ): string[] | undefined {\n const k = this._getAmfKey(untrustedKey, context)\n if (!k) {\n return undefined\n }\n let data = (model && (model as any)[k]) as IAmfDomainElement[] | undefined\n if (!data) {\n return undefined\n }\n if (!Array.isArray(data)) {\n data = [data]\n }\n return data.map((i) => i['@id'])\n }\n\n /**\n * Checks if a model has a type.\n * @param model Model to test\n * @param type Type name\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns True if model has a type.\n */\n _hasType(model?: IAmfDomainElement, type?: string, context?: Record<string, string>): boolean {\n const types = this._ensureArray(model && model['@type'])\n if (!types || !types.length) {\n return false\n }\n const key = this._getAmfKey(type, context)\n for (const type of types) {\n if (type === key) {\n return true\n }\n }\n return false\n }\n\n /**\n * Checks if a shape has a property.\n * @param shape The shape to test\n * @param untrustedKey Property name to test\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _hasProperty(shape: IAmfDomainElement, untrustedKey: string, context?: Record<string, string>): boolean {\n const key = this._getAmfKey(untrustedKey, context) as string\n return !!(shape && key && key in shape)\n }\n\n /**\n * Computes array value of a property in a model (shape).\n *\n * @param shape AMF shape object\n * @param untrustedKey Property name\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computePropertyArray(\n shape?: IAmfDomainElement,\n untrustedKey?: string,\n context?: Record<string, string>\n ): (string | number | boolean | null | object)[] | undefined {\n if (!shape) {\n return undefined\n }\n const key = this._getAmfKey(untrustedKey, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray(shape && (shape as any)[key])\n if (!data || !Array.isArray(data)) {\n return undefined\n }\n return data as (string | number | boolean | null | object)[]\n }\n\n /**\n * Computes API version from the AMF model.\n *\n * @param amf\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeApiVersion(amf?: IAmfDocument, context?: Record<string, string>): string | undefined {\n const api = this._computeApi(amf)\n if (!api) {\n return undefined\n }\n return this._getValue(api, ns.aml.vocabularies.core.version, context) as string\n }\n\n /**\n * Computes model's `encodes` property.\n *\n * @param model AMF data model\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of encodes\n */\n _computeEncodes(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.encodes, context)\n if (!key) {\n return undefined\n }\n const data = (model as any)[key]\n if (data) {\n return Array.isArray(data) ? data[0] : data\n }\n return undefined\n }\n\n /**\n * Computes list of declarations in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeDeclares(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.declares, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray((model as any)[key]) as IAmfDomainElement[]\n return Array.isArray(data) ? data : undefined\n }\n\n /**\n * Computes list of references in the AMF api model.\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of declarations\n */\n _computeReferences(model?: IAmfDocument, context?: Record<string, string>): IAmfDomainElement[] | undefined {\n if (!model) {\n return undefined\n }\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.document.references, context)\n if (!key) {\n return undefined\n }\n const data = this._ensureArray((model as any)[key]) as IAmfDomainElement[]\n return data instanceof Array ? data : undefined\n }\n\n /**\n * Computes AMF's `http://schema.org/WebAPI` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Web API declaration.\n */\n _computeWebApi(model?: IAmfDocument, context?: Record<string, string>): IAmfWebApi | undefined {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return undefined\n }\n if (this._hasType(enc, ns.aml.vocabularies.apiContract.WebAPI, context)) {\n return enc\n }\n return undefined\n }\n\n /**\n * Computes AMF's `http://schema.org/API` model\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns API declaration.\n */\n _computeApi(model?: IAmfDocument, context?: Record<string, string>): IAmfAsyncApi | IAmfWebApi | undefined {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return undefined\n }\n if (this._isAPI(model, context) || this._isWebAPI(model, context) || this._isAsyncAPI(model, context)) {\n return enc\n }\n return undefined\n }\n\n /**\n * Returns whether an AMF node is a WebAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isWebAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.WebAPI, context)\n }\n\n /**\n * Returns whether an AMF node is an AsyncAPI node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAsyncAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.AsyncAPI, context)\n }\n\n /**\n * Returns whether an AMF node is an API node\n *\n * @param model AMF json/ld model for an API\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _isAPI(model?: IAmfDocument, context?: Record<string, string>): boolean {\n const enc = this._computeEncodes(model, context)\n if (!enc) {\n return false\n }\n return this._hasType(enc, ns.aml.vocabularies.apiContract.API, context)\n }\n\n /**\n * Determines whether a partial model is valid for reading servers from\n * Current valid values:\n * - Operation\n * - Endpoint\n * @param model The partial model to evaluate\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Whether the model's type is part of the array of valid node types from which\n * to read servers\n * @private\n */\n _isValidServerPartial(model: IAmfDomainElement | IAmfDomainElement[], context?: Record<string, string>): boolean {\n if (Array.isArray(model)) {\n ;[model] = model\n }\n if (!model) {\n return false\n }\n const oKey = ns.aml.vocabularies.apiContract.Operation\n const eKey = ns.aml.vocabularies.apiContract.EndPoint\n const allowedPartialModelTypes = [this._getAmfKey(oKey, context), this._getAmfKey(eKey, context)]\n const types = model['@type']\n for (const type of types) {\n if (allowedPartialModelTypes.indexOf(type) !== -1) {\n return true\n }\n }\n return false\n }\n\n /**\n * @param options Server query options\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns List of servers for method, if defined, or endpoint, if defined, or root level\n */\n _getServers(options: ServersQueryOptions = {}, context?: Record<string, string>): IAmfServer[] | undefined {\n const { endpointId, methodId } = options\n const { amf } = this\n if (!amf) {\n return undefined\n }\n let api = this._computeApi(amf, context)\n if (Array.isArray(api)) {\n ;[api] = api\n }\n if (!api) {\n if (this._isValidServerPartial(amf, context)) {\n api = amf\n } else {\n return undefined\n }\n }\n\n const serverKey = this._getAmfKey(ns.aml.vocabularies.apiContract.server, context)\n\n const getRootServers = (): IAmfServer[] | undefined =>\n this[getArrayItems](api, serverKey, context) as IAmfServer[]\n const getEndpointServers = (): IAmfServer[] | undefined => {\n const endpoint = this._computeEndpointModel(api, endpointId, context)\n const servers = this[getArrayItems](endpoint, serverKey, context) as IAmfServer[]\n if (servers) {\n return servers\n }\n return getRootServers()\n }\n const getMethodServers = (): IAmfServer[] | undefined => {\n const method = this._computeMethodModel(api, methodId, context)\n const servers = this[getArrayItems](method, serverKey, context) as IAmfServer[]\n if (servers) {\n return servers\n }\n return getEndpointServers()\n }\n\n if (methodId) {\n return getMethodServers()\n }\n if (endpointId) {\n return getEndpointServers()\n }\n return getRootServers()\n }\n\n /**\n * Computes value for the `expects` property.\n *\n * @param method AMF `supportedOperation` model\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeExpects(method?: IAmfOperation, context?: Record<string, string>): IAmfRequest | undefined {\n const operationKey = ns.aml.vocabularies.apiContract.Operation\n const expectsKey = ns.aml.vocabularies.apiContract.expects\n if (this._hasType(method, operationKey, context)) {\n const key = this._getAmfKey(expectsKey, context) as string\n const expects = this._ensureArray((method as any)[key])\n if (expects) {\n return Array.isArray(expects) ? (expects[0] as IAmfRequest) : (expects as IAmfRequest)\n }\n }\n return undefined\n }\n\n /**\n * Computes list of endpoints from a WebApi model.\n * @param webApi\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An array of endpoints.\n */\n _computeEndpoints(webApi?: IAmfWebApi, context?: Record<string, string>): IAmfEndPoint[] | undefined {\n if (!webApi) {\n return []\n }\n const endpointKey = ns.aml.vocabularies.apiContract.endpoint\n const key = this._getAmfKey(endpointKey, context) as string\n return this._ensureArray((webApi as any)[key]) as IAmfEndPoint[]\n }\n\n /**\n * Computes model for an endpoint documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param id Selected shape ID\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint definition\n */\n _computeEndpointModel(\n webApi?: IAmfWebApi,\n id?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined {\n if (this._hasType(webApi, ns.aml.vocabularies.apiContract.EndPoint, context)) {\n return webApi\n }\n const endpoints = this._computeEndpoints(webApi, context)\n if (!endpoints) {\n return undefined\n }\n return endpoints.find((item) => item['@id'] === id)\n }\n\n /**\n * Computes method for the method documentation.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A method definition\n */\n _computeMethodModel(\n webApi?: IAmfWebApi,\n selected?: string,\n context?: Record<string, string>\n ): IAmfOperation | undefined {\n const methods = this.__computeMethodsListForMethod(webApi, selected, context)\n if (!methods) {\n return undefined\n }\n return methods.find((item) => item['@id'] === selected)\n }\n\n /**\n * Computes an endpoint for a method.\n * @param webApi The WebApi AMF model\n * @param methodId Method id\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns An endpoint model of undefined.\n */\n _computeMethodEndpoint(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfEndPoint | undefined {\n if (!webApi || !methodId) {\n return undefined\n }\n if (this._hasType(webApi, ns.aml.vocabularies.apiContract.EndPoint, context)) {\n return webApi\n }\n const endpoints = this._computeEndpoints(webApi, context)\n if (!endpoints) {\n return undefined\n }\n const opKey = this._getAmfKey(ns.aml.vocabularies.apiContract.supportedOperation, context)\n for (let i = 0, len = endpoints.length; i < len; i++) {\n const endpoint = endpoints[i]\n let methods = (endpoint as any)[opKey] as IAmfOperation[]\n if (!methods) {\n continue\n }\n if (!Array.isArray(methods)) {\n methods = [methods]\n }\n for (let j = 0, jLen = methods.length; j < jLen; j++) {\n if (methods[j]['@id'] === methodId) {\n return endpoint\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a list of methods for an endpoint that contains a method with\n * given id.\n *\n * @param webApi WebApi model\n * @param methodId Method id.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A list of sibling methods or undefined.\n */\n __computeMethodsListForMethod(\n webApi?: IAmfWebApi,\n methodId?: string,\n context?: Record<string, string>\n ): IAmfOperation[] | undefined {\n const endpoint = this._computeMethodEndpoint(webApi, methodId, context)\n if (!endpoint) {\n return undefined\n }\n const opKey = this._getAmfKey(ns.aml.vocabularies.apiContract.supportedOperation, context)\n return this._ensureArray((endpoint as any)[opKey]) as IAmfOperation[] | undefined\n }\n\n /**\n * Computes a type documentation model.\n *\n * @param declares Current value of `declares` property\n * @param references Current value of `references` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns A type definition\n */\n _computeType(\n declares?: IAmfDomainElement[],\n references?: IAmfDomainElement[],\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined {\n if ((!declares && !references) || !selected) {\n return undefined\n }\n // In compact model some IDs are presented in long version (in source maps for examples)\n // This must test for this case as well.\n const compactId = selected.replace('amf://id', '')\n let type = declares && declares.find((item) => item['@id'] === selected || item['@id'] === compactId)\n if (!type && references && references.length) {\n for (let i = 0, len = references.length; i < len; i++) {\n if (!this._hasType(references[i], ns.aml.vocabularies.document.Module)) {\n continue\n }\n type = this._computeReferenceType(references[i], selected, context)\n if (type) {\n break\n }\n }\n }\n return type\n }\n\n /**\n * Finds a type in the model declares and references.\n * @param domainId The domain id of the type (AMF's shape).\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The AMF shape or undefined when not found.\n */\n [findAmfType](domainId?: string, context?: Record<string, string>): IAmfShape | undefined {\n let { amf } = this\n if (!amf || !domainId) {\n return undefined\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n const declares = this._computeDeclares(amf, context)\n const compactId = domainId.replace('amf://id', '')\n if (Array.isArray(declares)) {\n const result = declares.find((item) => item['@id'] === domainId || item['@id'] === compactId)\n if (result) {\n return result\n }\n }\n return this[findReferenceObject](domainId)\n }\n\n /**\n * Searches for an object in model's references list.\n * It does not resolve the object (useful for handling links correctly).\n *\n * @param domainId The domain of the object to find in the references.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns The domain object or undefined.\n */\n [findReferenceObject](domainId: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n let { amf } = this\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n if (!amf) {\n return undefined\n }\n const references = this._computeReferences(amf, context)\n if (!Array.isArray(references) || !references.length) {\n return undefined\n }\n const compactId = domainId.replace('amf://id', '')\n for (let i = 0, len = references.length; i < len; i++) {\n const ref = /** @type IAmfDocument */ references[i]\n const declares = this._computeDeclares(ref, context)\n if (!Array.isArray(declares)) {\n continue\n }\n for (let j = 0, lenDecl = declares.length; j < lenDecl; j++) {\n let declared = declares[j]\n if (Array.isArray(declared)) {\n ;[declared] = declared\n }\n if (declared['@id'] === domainId || declared['@id'] === compactId) {\n return declared\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a type model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n _computeReferenceType(\n reference?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfShape | undefined {\n const declare = this._computeDeclares(reference, context)\n if (!declare || !selected) {\n return undefined\n }\n // In compact model some IDs are presented in long version (in source maps for examples)\n // This must test for this case as well.\n const compactId = selected.replace('amf://id', '')\n let result = declare.find((item) => {\n if (Array.isArray(item)) {\n ;[item] = item\n }\n return item['@id'] === selected || item['@id'] === compactId\n })\n if (Array.isArray(result)) {\n ;[result] = result\n }\n return this._resolve(result)\n }\n\n /**\n * Computes a documentation model.\n *\n * @param webApi Current value of `webApi` property\n * @param selected Selected shape\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n _computeDocument(\n webApi?: IAmfDomainElement,\n selected?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined {\n if (!webApi || !selected) {\n return undefined\n }\n const key = this._getAmfKey(ns.aml.vocabularies.core.documentation, context)\n const docs = this._ensureArray((webApi as any)[key]) as IAmfDomainElement[]\n return docs && docs.find((item) => ((item as any)['@id'] as string) === selected)\n }\n\n /**\n * Resolves a reference to an external fragment.\n *\n * @param shape A shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape.\n */\n _resolve(shape: any, context?: Record<string, string>): any {\n const { amf } = this\n if (typeof shape !== 'object' || Array.isArray(shape) || !amf || shape.__apicResolved) {\n return shape\n }\n let refKey = this._getAmfKey(ns.aml.vocabularies.document.linkTarget, context)\n let refValue = this._ensureArray(shape[refKey]) as IAmfDomainElement[]\n let refData\n if (refValue) {\n const rk = refValue[0]['@id']\n if (rk === shape['@id']) {\n // recursive shape.\n shape.__apicResolved = true\n return shape\n }\n refData = this._getLinkTarget(amf, rk, context)\n } else {\n refKey = this._getAmfKey(ns.aml.vocabularies.document.referenceId, context)\n refValue = this._ensureArray(shape[refKey]) as IAmfDomainElement[]\n if (refValue) {\n const rk = refValue[0]['@id']\n if (rk === shape['@id']) {\n // recursive shape.\n shape.__apicResolved = true\n return shape\n }\n refData = this._getReferenceId(amf, rk, context)\n }\n }\n if (!refData) {\n this._resolveRecursive(shape)\n shape.__apicResolved = true\n return shape\n }\n const copy = { ...refData } as any\n delete copy['@id']\n const types = copy['@type']\n if (types) {\n if (shape['@type']) {\n shape['@type'] = shape['@type'].concat(types)\n } else {\n shape['@type'] = types\n }\n delete copy['@type']\n }\n this._mergeShapes(shape, copy, context)\n shape.__apicResolved = true\n this._resolveRecursive(shape)\n return shape\n }\n\n /**\n * @param amf References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _getLinkTarget(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!amf || !id) {\n return undefined\n }\n let target\n const declares = this._computeDeclares(amf, context)\n if (declares) {\n target = this._findById(declares, id)\n }\n if (!target) {\n const references = this._computeReferences(amf, context)\n target = this._obtainShapeFromReferences(references, id, context)\n }\n if (!target) {\n return undefined\n }\n // Declaration may contain references\n target = this._resolve(target)\n return target\n }\n\n /**\n * Resolves the shape of a given reference.\n *\n * @param references References object to search in\n * @param id Id of the shape to resolve\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Resolved shape for given reference, undefined otherwise\n */\n _obtainShapeFromReferences(\n references?: IAmfDomainElement[],\n id?: string,\n context?: Record<string, string>\n ): IAmfDomainElement | undefined {\n if (!Array.isArray(references) || !references.length) {\n return undefined\n }\n let target\n for (const _ref of references) {\n // case of fragment that encodes the shape\n const encoded = this._computeEncodes(_ref, context)\n if (encoded && encoded['@id'] === id) {\n target = encoded\n break\n }\n // case of a library which declares types\n if (!encoded) {\n target = this._findById(this._computeDeclares(_ref, context), id)\n if (target) break\n }\n }\n return target\n }\n\n /**\n * Searches a node with a given ID in an array\n *\n * @param array Array to search for a given ID\n * @param id Id to search for\n * @returns Node with the given ID when found, undefined otherwise\n */\n _findById(array?: IAmfDomainElement[], id?: string): IAmfDomainElement | undefined {\n if (!array) return undefined\n let target\n for (const _current of array) {\n if (_current && _current['@id'] === id) {\n target = _current\n break\n }\n }\n return target\n }\n\n _getReferenceId(amf?: IAmfDocument, id?: string, context?: Record<string, string>): IAmfDomainElement | undefined {\n if (!amf || !id) {\n return undefined\n }\n const refs = this._computeReferences(amf, context)\n if (!refs) {\n return undefined\n }\n for (const _ref of refs) {\n const enc = this._computeEncodes(_ref, context)\n if (enc) {\n if (enc['@id'] === id) {\n return enc\n }\n }\n }\n return undefined\n }\n\n _resolveRecursive(shape: any, context?: Record<string, string>): void {\n Object.keys(shape).forEach((key) => {\n const currentShape = shape[key]\n if (Array.isArray(currentShape)) {\n for (let i = 0, len = currentShape.length; i < len; i++) {\n currentShape[i] = this._resolve(currentShape[i])\n }\n } else if (typeof currentShape === 'object') {\n shape[key] = this._resolve(currentShape, context)\n }\n })\n }\n\n /**\n * Merge two shapes together. If the resulting shape has one of the \"special merge\" keys,\n * then the special merge function for that key will be used to match that property\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Merged AMF node\n */\n _mergeShapes(shapeA: any, shapeB: any, context?: Record<string, string>): any {\n const merged = { ...shapeA, ...shapeB }\n const specialMerges = [\n {\n key: this._getAmfKey(ns.aml.vocabularies.docSourceMaps.sources, context),\n merger: this._mergeSourceMapsSources.bind(this),\n },\n ]\n specialMerges.forEach(({ key, merger }) => {\n if (this._hasProperty(merged, key, context)) {\n merged[key] = merger(shapeA, shapeB, context)\n }\n })\n return Object.assign(shapeA, merged)\n }\n\n /**\n * Obtains source map sources value from two shapes and returns the merged result\n * If neither shape has a sources node, then an empty object will be returned.\n * Result is wrapped in an array as per AMF model standard\n * @param shapeA AMF node\n * @param shapeB AMF node\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Empty object or resulting merge, wrapped in an array\n * @private\n */\n _mergeSourceMapsSources(shapeA: any, shapeB: any, context?: Record<string, string>): (any | object)[] {\n const sourcesKey = this._getAmfKey(ns.aml.vocabularies.docSourceMaps.sources, context)\n let aSources = shapeA[sourcesKey] || {}\n if (Array.isArray(aSources)) {\n aSources = aSources[0]\n }\n let bSources = shapeB[sourcesKey] || {}\n if (Array.isArray(bSources)) {\n bSources = bSources[0]\n }\n return [Object.assign(aSources, bSources)]\n }\n\n /**\n * Expands the key property from compacted mode to full mode.\n * @param value The value to process\n * @returns The expanded value.\n */\n _expandKey(value: string, context?: Record<string, string>): string {\n let { amf } = this\n if (!value || typeof value !== 'string' || (!amf && !context)) {\n return value\n }\n if (Array.isArray(amf)) {\n ;[amf] = amf\n }\n const ctx = context || (amf && amf['@context'])\n if (!ctx) {\n return value\n }\n const [root, key] = value.split(':')\n if (!root || !key) {\n return value\n }\n const prefix = ctx[root]\n if (!prefix) {\n return value\n }\n return `${prefix}${key}`\n }\n\n /**\n * Computes a security model from a reference (library for example).\n * @param domainId Domain id of the security requirement to find.\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n findSecurityScheme(domainId: string, context?: Record<string, string>): IAmfSecurityScheme | undefined {\n const { amf } = this\n const declares = this._computeDeclares(amf, context)\n let result\n if (declares) {\n result = declares.find((item) => item['@id'] === domainId)\n }\n if (result) {\n result = this._resolve(result)\n return result\n }\n const references = this._computeReferences(amf, context)\n if (Array.isArray(references) && references.length) {\n for (const ref of references) {\n if (this._hasType(ref, ns.aml.vocabularies.document.Module, context)) {\n result = this[computeReferenceSecurity](ref, domainId, context)\n if (result) {\n result = this._resolve(result)\n return result\n }\n }\n }\n }\n return undefined\n }\n\n /**\n * Computes a security model from a reference (library for example).\n * @param reference AMF model for a reference to extract the data from\n * @param selected Node ID to look for\n * @param context A context to use. If not set, it looks for the context of the passed model\n * @returns Type definition or undefined if not found.\n */\n [computeReferenceSecurity](\n reference: IAmfDomainElement,\n selected: string,\n context?: Record<string, string>\n ): IAmfSecurityScheme | undefined {\n const declare = this._computeDeclares(reference, context)\n if (!declare) {\n return undefined\n }\n let result = declare.find((item) => {\n let declared = item\n if (Array.isArray(declared)) {\n ;[declared] = declared\n }\n return declared['@id'] === selected\n })\n if (Array.isArray(result)) {\n ;[result] = result\n }\n return this._resolve(result)\n }\n\n /**\n * Collects domain objects by a domain type.\n * @param source The element to search for declare/encoded objects.\n * @param type The domain type\n * @param context A context to use. If not set, it looks for the context of the passed model\n */\n getByType(source: IAmfDomainElement, type: string, context?: Record<string, string>): IAmfDomainElement[] {\n if (!source) {\n return []\n }\n let result: IAmfDomainElement[] = []\n const declares = this._computeDeclares(source)\n const key = this._getAmfKey(type, context)\n if (declares && declares.length) {\n declares.forEach((declared) => {\n if (this._hasType(declared, key)) {\n result.push(declared as IAmfDomainElement)\n }\n })\n }\n const references = this._computeReferences(source)\n if (Array.isArray(references) && references.length) {\n for (const ref of references) {\n if (this._hasType(ref, ns.aml.vocabularies.document.Module)) {\n const items = this.getByType(ref as IAmfDomainElement, type, context)\n if (items.length) {\n result = result.concat(items)\n }\n }\n }\n }\n return result\n }\n }\n return AmfMixin as Constructor<AmfMixinInterface> & T\n}\n"]}
@@ -4,6 +4,7 @@ import { DataEntity, IDataEntity } from './DataEntity.js';
4
4
  import { DataNamespace } from './DataNamespace.js';
5
5
  import { DataAssociationKind } from '../models/kinds.js';
6
6
  import type { AssociationBinding, AssociationBindings, AssociationWebBindings } from './Bindings.js';
7
+ import { type DataAttributeAttribute } from './DataFormat.js';
7
8
  /**
8
9
  * Describes association target of an entity
9
10
  */
@@ -251,6 +252,12 @@ export declare class DataAssociation {
251
252
  * @returns The schema object.
252
253
  */
253
254
  ensureSchema(): IApiAssociationShape;
255
+ /**
256
+ * Checks whether the passed value is one of the supported data proprty attributes.
257
+ * @param value The value to test
258
+ * @returns True when the passed value is one of the supported data proprty attributes.
259
+ */
260
+ static isValidAttribute(value: unknown): value is DataAttributeAttribute;
254
261
  /**
255
262
  * Creates if not existing and returns web bindings definition.
256
263
  * @returns The web binding definition