Sharkey/src/server/api/openapi/schemas.ts

88 lines
3.5 KiB
TypeScript
Raw Normal View History

import { packedUserSchema } from '../../../models/repositories/user';
import { Schema } from '../../../misc/schema';
import { packedNoteSchema } from '../../../models/repositories/note';
import { packedUserListSchema } from '../../../models/repositories/user-list';
import { packedAppSchema } from '../../../models/repositories/app';
import { packedMessagingMessageSchema } from '../../../models/repositories/messaging-message';
import { packedNotificationSchema } from '../../../models/repositories/notification';
import { packedDriveFileSchema } from '../../../models/repositories/drive-file';
import { packedDriveFolderSchema } from '../../../models/repositories/drive-folder';
import { packedFollowingSchema } from '../../../models/repositories/following';
import { packedMutingSchema } from '../../../models/repositories/muting';
import { packedBlockingSchema } from '../../../models/repositories/blocking';
import { packedNoteReactionSchema } from '../../../models/repositories/note-reaction';
2019-04-25 07:25:10 +03:00
import { packedHashtagSchema } from '../../../models/repositories/hashtag';
2019-04-30 22:44:46 +03:00
import { packedPageSchema } from '../../../models/repositories/page';
2019-05-18 14:36:33 +03:00
import { packedUserGroupSchema } from '../../../models/repositories/user-group';
2019-05-20 16:01:32 +03:00
import { packedNoteFavoriteSchema } from '../../../models/repositories/note-favorite';
2020-08-21 22:25:47 +03:00
import { packedChannelSchema } from '../../../models/repositories/channel';
export function convertSchemaToOpenApiSchema(schema: Schema) {
const res: any = schema;
if (schema.type === 'object' && schema.properties) {
res.required = Object.entries(schema.properties).filter(([k, v]) => !v.optional).map(([k]) => k);
for (const k of Object.keys(schema.properties)) {
res.properties[k] = convertSchemaToOpenApiSchema(schema.properties[k]);
}
}
if (schema.type === 'array' && schema.items) {
res.items = convertSchemaToOpenApiSchema(schema.items);
}
if (schema.ref) {
res.$ref = `#/components/schemas/${schema.ref}`;
}
return res;
}
2019-02-23 21:08:08 +02:00
export const schemas = {
Error: {
type: 'object',
properties: {
error: {
type: 'object',
description: 'An error object.',
properties: {
code: {
type: 'string',
2019-02-23 21:27:09 +02:00
description: 'An error code. Unique within the endpoint.',
2019-02-23 21:08:08 +02:00
},
message: {
type: 'string',
description: 'An error message.',
},
id: {
type: 'string',
format: 'uuid',
description: 'An error ID. This ID is static.',
}
},
required: ['code', 'id', 'message']
},
},
required: ['error']
},
User: convertSchemaToOpenApiSchema(packedUserSchema),
UserList: convertSchemaToOpenApiSchema(packedUserListSchema),
2019-05-18 14:36:33 +03:00
UserGroup: convertSchemaToOpenApiSchema(packedUserGroupSchema),
App: convertSchemaToOpenApiSchema(packedAppSchema),
MessagingMessage: convertSchemaToOpenApiSchema(packedMessagingMessageSchema),
Note: convertSchemaToOpenApiSchema(packedNoteSchema),
2019-05-20 16:01:32 +03:00
NoteReaction: convertSchemaToOpenApiSchema(packedNoteReactionSchema),
NoteFavorite: convertSchemaToOpenApiSchema(packedNoteFavoriteSchema),
Notification: convertSchemaToOpenApiSchema(packedNotificationSchema),
DriveFile: convertSchemaToOpenApiSchema(packedDriveFileSchema),
DriveFolder: convertSchemaToOpenApiSchema(packedDriveFolderSchema),
Following: convertSchemaToOpenApiSchema(packedFollowingSchema),
Muting: convertSchemaToOpenApiSchema(packedMutingSchema),
Blocking: convertSchemaToOpenApiSchema(packedBlockingSchema),
2019-04-25 07:25:10 +03:00
Hashtag: convertSchemaToOpenApiSchema(packedHashtagSchema),
2019-04-30 22:44:46 +03:00
Page: convertSchemaToOpenApiSchema(packedPageSchema),
2020-08-21 22:25:47 +03:00
Channel: convertSchemaToOpenApiSchema(packedChannelSchema),
2019-02-23 21:08:08 +02:00
};