@loopback/openapi-v3
Version:
Decorators that annotate LoopBack artifacts with OpenAPI v3 metadata and utilities that transform LoopBack metadata to OpenAPI v3 specifications
122 lines • 4.98 kB
JavaScript
// Copyright IBM Corp. and LoopBack contributors 2018,2020. All Rights Reserved.
// Node module: @loopback/openapi-v3
// This file is licensed under the MIT License.
// License text available at https://opensource.org/licenses/MIT
Object.defineProperty(exports, "__esModule", { value: true });
exports.jsonOrBooleanToJSON = exports.jsonToSchemaObject = void 0;
const tslib_1 = require("tslib");
const lodash_1 = tslib_1.__importDefault(require("lodash"));
const types_1 = require("./types");
/**
* Converts JSON Schemas into a SchemaObject
* @param json - JSON Schema to convert from
* @param visited - A map to keep track of mapped json schemas to handle
* circular references
*/
function jsonToSchemaObject(json, visited = new Map()) {
var _a, _b;
// A flag to check if a schema object is fully converted
const converted = 'x-loopback-converted';
const schema = visited.get(json);
if (schema != null && (0, types_1.isSchemaObject)(schema) && schema[converted] === false) {
return { $ref: `#/components/schemas/${json.title}` };
}
if (schema != null)
return schema;
const result = {
[converted]: false,
};
visited.set(json, result);
const propsToIgnore = ['additionalItems', 'defaultProperties', 'typeof'];
for (const property in json) {
if (propsToIgnore.includes(property)) {
continue;
}
switch (property) {
case 'type': {
if (json.type === 'array' && !json.items) {
throw new Error('"items" property must be present if "type" is an array');
}
result.type = Array.isArray(json.type) ? json.type[0] : json.type;
break;
}
case 'allOf': {
result.allOf = lodash_1.default.map(json.allOf, item => jsonToSchemaObject(item, visited));
break;
}
case 'anyOf': {
result.anyOf = lodash_1.default.map(json.anyOf, item => jsonToSchemaObject(item, visited));
break;
}
case 'oneOf': {
result.oneOf = lodash_1.default.map(json.oneOf, item => jsonToSchemaObject(item, visited));
break;
}
case 'definitions': {
result.definitions = lodash_1.default.mapValues(json.definitions, def => jsonToSchemaObject(jsonOrBooleanToJSON(def), visited));
break;
}
case 'properties': {
result.properties = lodash_1.default.mapValues(json.properties, item => jsonToSchemaObject(jsonOrBooleanToJSON(item), visited));
break;
}
case 'additionalProperties': {
if (typeof json.additionalProperties === 'boolean') {
result.additionalProperties = json.additionalProperties;
}
else {
result.additionalProperties = jsonToSchemaObject(json.additionalProperties, visited);
}
break;
}
case 'items': {
const items = Array.isArray(json.items) ? json.items[0] : json.items;
result.items = jsonToSchemaObject(jsonOrBooleanToJSON(items), visited);
break;
}
case '$ref': {
result.$ref = json.$ref.replace('#/definitions', '#/components/schemas');
break;
}
case 'examples': {
if (Array.isArray(json.examples)) {
result.example = json.examples[0];
}
break;
}
default: {
result[property] = json[property];
break;
}
}
}
delete result[converted];
// Check if the description contains information about TypeScript type
const matched = (_a = result.description) === null || _a === void 0 ? void 0 : _a.match(/^\(tsType: (.+), schemaOptions:/);
if (matched) {
result['x-typescript-type'] = matched[1];
}
const indexInfoMatched = (_b = result.description) === null || _b === void 0 ? void 0 : _b.match(/\{"indexInfo".*$/s);
if (indexInfoMatched) {
result['x-index-info'] = indexInfoMatched[1];
}
return result;
}
exports.jsonToSchemaObject = jsonToSchemaObject;
/**
* Helper function used to interpret boolean values as JSON Schemas.
* See http://json-schema.org/draft-06/json-schema-release-notes.html
* @param jsonOrBool - converts boolean values into their representative JSON Schemas
* @returns A JSON Schema document representing the input value.
*/
function jsonOrBooleanToJSON(jsonOrBool) {
if (typeof jsonOrBool === 'object') {
return jsonOrBool;
}
else {
return jsonOrBool ? {} : { not: {} };
}
}
exports.jsonOrBooleanToJSON = jsonOrBooleanToJSON;
//# sourceMappingURL=json-to-schema.js.map
;