molstar
Version:
A comprehensive macromolecular library.
135 lines • 5.68 kB
JavaScript
/**
* 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 = exports.getSchema = void 0;
var version_1 = require("./version");
function getSchema(config) {
var _a;
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: (_a = {},
_a[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': {}
}
}
},
}
},
_a[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': {}
}
}
},
}
},
_a[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': {} }
}
},
}
},
_a[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': {} }
}
},
}
},
_a)
};
}
exports.getSchema = getSchema;
exports.shortcutIconLink = "<link rel='shortcut icon' href='' />";
//# sourceMappingURL=api-schema.js.map
;