1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889 |
- /**
- * Copyright (c) 2019 mol* contributors, licensed under MIT, See LICENSE file for more info.
- *
- * @author David Sehnal <david.sehnal@gmail.com>
- */
- import VERSION from '../version'
- import { QueryParamInfo, QueryParamType, QueryDefinition, CommonQueryParamsInfo, QueryList } from './api';
- import ServerConfig from '../config';
- export const shortcutIconLink = `<link rel='shortcut icon' href='' />`
- export function getApiSchema() {
- return {
- openapi: '3.0.0',
- info: {
- version: 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: any = {};
- for (const { name, definition } of QueryList) {
- ret[`${ServerConfig.appPrefix}/v1/{id}/${name}`] = getQueryInfo(definition);
- }
- return ret;
- }
- function getQueryInfo(def: QueryDefinition) {
- return {
- get: {
- tags: ['General'],
- summary: def.description,
- operationId: def.name,
- parameters: [
- { $ref: '#/components/parameters/id' },
- ...def.restParams.map(getParamInfo),
- ...CommonQueryParamsInfo.map(getParamInfo)
- ],
- responses: {
- 200: {
- description: def.description,
- content: {
- 'text/plain': {},
- 'application/octet-stream': {},
- }
- }
- }
- }
- };
- }
- function getParamInfo(info: QueryParamInfo) {
- return {
- name: info.name,
- in: 'query',
- description: info.description,
- required: !!info.required,
- schema: {
- type: info.type === QueryParamType.String ? 'string' : info.type === QueryParamType.Integer ? 'integer' : 'number',
- enum: info.supportedValues ? info.supportedValues : void 0,
- default: info.defaultValue
- },
- style: 'simple'
- };
- }
|