UNPKG

molstar

Version:

A comprehensive macromolecular library.

134 lines (133 loc) 5.45 kB
"use strict"; /** * Copyright (c) 2020 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.getSchema = getSchema; const version_1 = require("./version"); function getSchema(config) { function mapPath(path) { return `${config.api_prefix}/${path}`; } return { openapi: '3.0.0', info: { version: version_1.VERSION, title: 'PluginState Server', description: 'The PluginState Server is a simple service for storing and retreiving states of the Mol* Viewer app.', }, tags: [ { name: 'General', } ], paths: { [mapPath(`list/`)]: { get: { tags: ['General'], summary: 'Returns a JSON response with the list of currently stored states.', operationId: 'list', parameters: [], responses: { 200: { description: 'A list of stored states', content: { 'application/json': {} } } }, } }, [mapPath(`get/{id}`)]: { get: { tags: ['General'], summary: 'Returns the Mol* Viewer state with the given id.', operationId: 'get', parameters: [ { name: 'id', in: 'path', description: `Id of the state.`, required: true, schema: { type: 'string' }, style: 'simple' } ], responses: { 200: { description: 'A JSON object with the state.', content: { 'application/json': {} } } }, } }, [mapPath(`remove/{id}`)]: { get: { tags: ['General'], summary: 'Removes the Mol* Viewer state with the given id.', operationId: 'remove', parameters: [ { name: 'id', in: 'path', description: `Id of the state.`, required: true, schema: { type: 'string' }, style: 'simple' } ], responses: { 200: { description: 'Empty response.', content: { 'text/plain': {} } } }, } }, [mapPath(`set/`)]: { post: { tags: ['General'], summary: `Post Mol* Viewer state to the server. At most ${config.max_states} states can be stored. If the limit is reached, older states will be removed.`, operationId: 'set', requestBody: { content: { 'application/json': { schema: { type: 'object' } } } }, parameters: [ { name: 'name', in: 'query', description: `Name of the state. If none provided, current UTC date-time is used.`, required: false, schema: { type: 'string' }, style: 'simple' }, { name: 'description', in: 'query', description: `Description of the state.`, required: false, schema: { type: 'string' }, style: 'simple' } ], responses: { 200: { description: 'Empty response.', content: { 'text/plain': {} } } }, } }, } }; } exports.shortcutIconLink = `<link rel='shortcut icon' href='' />`;