UNPKG

molstar

Version:

A comprehensive macromolecular library.

184 lines (183 loc) 6.38 kB
"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.shortcutIconLink = void 0; exports.getApiSchema = getApiSchema; const version_1 = require("../version"); const api_1 = require("./api"); const 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' }, } } }; } function getPaths() { const ret = {}; for (const { name, definition } of api_1.QueryList) { ret[`${config_1.ModelServerConfig.apiPrefix}/v1/{id}/${name}`] = getQueryInfo(definition); } const queryManySummary = 'Executes multiple queries at the same time and writes them as separate data blocks.'; const 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) { const jsonExample = {}; def.jsonParams.forEach(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: [ { $ref: '#/components/parameters/id' }, ...def.restParams.map(getParamInfo), ...api_1.CommonQueryParamsInfo.map(getParamInfo) ], responses: { 200: { description: def.description, content: { 'text/plain': {}, 'application/octet-stream': {}, } } } }, post: { tags: ['General'], summary: def.description, operationId: def.name + '-post', parameters: [ { $ref: '#/components/parameters/id' }, ...api_1.CommonQueryParamsInfo.map(getParamInfo) ], 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' }; }