molstar
Version:
A comprehensive macromolecular library.
183 lines • 6.81 kB
JavaScript
"use strict";
/**
* Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
*
* @author David Sehnal <david.sehnal@gmail.com>
*/
Object.defineProperty(exports, "__esModule", { value: true });
exports.getApiSchema = exports.shortcutIconLink = void 0;
var tslib_1 = require("tslib");
var version_1 = require("../version");
var api_1 = require("./api");
var config_1 = require("../config");
exports.shortcutIconLink = "<link rel='shortcut icon' href='' />";
function getApiSchema() {
return {
openapi: '3.0.0',
info: {
version: version_1.VERSION,
title: 'ModelServer',
description: 'The ModelServer is a service for accessing subsets of macromolecular model data.',
},
tags: [
{
name: 'General',
}
],
paths: getPaths(),
components: {
parameters: {
id: {
name: 'id',
in: 'path',
description: 'Id of the entry (i.e. 1tqn).',
required: true,
schema: {
type: 'string',
},
style: 'simple'
},
}
}
};
}
exports.getApiSchema = getApiSchema;
function getPaths() {
var ret = {};
for (var _i = 0, QueryList_1 = api_1.QueryList; _i < QueryList_1.length; _i++) {
var _a = QueryList_1[_i], name_1 = _a.name, definition = _a.definition;
ret[config_1.ModelServerConfig.apiPrefix + "/v1/{id}/" + name_1] = getQueryInfo(definition);
}
var queryManySummary = 'Executes multiple queries at the same time and writes them as separate data blocks.';
var queryManyExample = {
queries: [
{ entryId: '1cbs', query: 'residueInteraction', params: { atom_site: [{ label_comp_id: 'REA' }], radius: 5 } },
{ entryId: '1tqn', query: 'full', copy_all_categories: true }
],
encoding: 'cif',
asTarGz: false
};
ret[config_1.ModelServerConfig.apiPrefix + "/v1/query-many"] = {
get: {
tags: ['General'],
summary: queryManySummary,
operationId: 'query-many',
parameters: [{
name: 'query',
in: 'query',
description: 'URI encoded JSON object with the query definiton.',
required: true,
schema: {
type: 'string',
},
example: JSON.stringify(queryManyExample),
style: 'simple'
}],
responses: {
200: {
description: 'Separate CIF data blocks with the result',
content: {
'text/plain': {},
'application/octet-stream': {},
}
}
}
},
post: {
tags: ['General'],
summary: queryManySummary,
operationId: 'query-many-post',
parameters: [],
requestBody: {
content: {
'application/json': {
schema: { type: 'object' },
example: queryManyExample
}
}
},
responses: {
200: {
description: 'Separate CIF data blocks with the result',
content: {
'text/plain': {},
'application/octet-stream': {},
}
}
}
}
};
return ret;
}
function getQueryInfo(def) {
var jsonExample = {};
def.jsonParams.forEach(function (p) {
if (!p.exampleValues || !p.exampleValues.length)
return;
jsonExample[p.name] = p.exampleValues[0];
});
return {
get: {
tags: ['General'],
summary: def.description,
operationId: def.name,
parameters: (0, tslib_1.__spreadArray)((0, tslib_1.__spreadArray)([
{ $ref: '#/components/parameters/id' }
], def.restParams.map(getParamInfo), true), api_1.CommonQueryParamsInfo.map(getParamInfo), true),
responses: {
200: {
description: def.description,
content: {
'text/plain': {},
'application/octet-stream': {},
}
}
}
},
post: {
tags: ['General'],
summary: def.description,
operationId: def.name + '-post',
parameters: (0, tslib_1.__spreadArray)([
{ $ref: '#/components/parameters/id' }
], api_1.CommonQueryParamsInfo.map(getParamInfo), true),
requestBody: {
content: {
'application/json': {
schema: { type: 'object' },
example: jsonExample
}
}
},
responses: {
200: {
description: def.description,
content: {
'text/plain': {},
'application/octet-stream': {},
}
}
}
}
};
}
function getParamInfo(info) {
return {
name: info.name,
in: 'query',
description: info.description,
required: !!info.required,
schema: {
type: info.type === api_1.QueryParamType.String
? 'string' : info.type === api_1.QueryParamType.Integer
? 'integer'
: info.type === api_1.QueryParamType.Boolean
? 'boolean'
: 'number',
enum: info.supportedValues ? info.supportedValues : void 0,
default: info.defaultValue
},
style: 'simple'
};
}
//# sourceMappingURL=api-schema.js.map