2019-04-23 16:35:26 +03:00
|
|
|
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';
|
|
|
|
|
|
|
|
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 !== true).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']
|
|
|
|
},
|
|
|
|
|
2019-04-23 16:35:26 +03:00
|
|
|
User: convertSchemaToOpenApiSchema(packedUserSchema),
|
|
|
|
UserList: convertSchemaToOpenApiSchema(packedUserListSchema),
|
|
|
|
App: convertSchemaToOpenApiSchema(packedAppSchema),
|
|
|
|
MessagingMessage: convertSchemaToOpenApiSchema(packedMessagingMessageSchema),
|
|
|
|
Note: convertSchemaToOpenApiSchema(packedNoteSchema),
|
|
|
|
Notification: convertSchemaToOpenApiSchema(packedNotificationSchema),
|
|
|
|
DriveFile: convertSchemaToOpenApiSchema(packedDriveFileSchema),
|
|
|
|
DriveFolder: convertSchemaToOpenApiSchema(packedDriveFolderSchema),
|
|
|
|
Following: convertSchemaToOpenApiSchema(packedFollowingSchema),
|
|
|
|
Muting: convertSchemaToOpenApiSchema(packedMutingSchema),
|
|
|
|
Blocking: convertSchemaToOpenApiSchema(packedBlockingSchema),
|
|
|
|
NoteReaction: convertSchemaToOpenApiSchema(packedNoteReactionSchema),
|
2019-02-26 22:08:42 +02:00
|
|
|
|
2019-02-26 22:02:36 +02:00
|
|
|
Hashtag: {
|
|
|
|
type: 'object',
|
|
|
|
properties: {
|
|
|
|
tag: {
|
|
|
|
type: 'string',
|
|
|
|
description: 'The hashtag name. No # prefixed.',
|
|
|
|
example: 'misskey',
|
|
|
|
},
|
|
|
|
mentionedUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of all users using this hashtag.'
|
|
|
|
},
|
|
|
|
mentionedLocalUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of local users using this hashtag.'
|
|
|
|
},
|
|
|
|
mentionedRemoteUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of remote users using this hashtag.'
|
|
|
|
},
|
|
|
|
attachedUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of all users who attached this hashtag to profile.'
|
|
|
|
},
|
|
|
|
attachedLocalUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of local users who attached this hashtag to profile.'
|
|
|
|
},
|
|
|
|
attachedRemoteUsersCount: {
|
|
|
|
type: 'number',
|
|
|
|
description: 'Number of remote users who attached this hashtag to profile.'
|
|
|
|
},
|
|
|
|
},
|
|
|
|
required: [
|
|
|
|
'tag',
|
|
|
|
'mentionedUsersCount',
|
|
|
|
'mentionedLocalUsersCount',
|
|
|
|
'mentionedRemoteUsersCount',
|
|
|
|
'attachedUsersCount',
|
|
|
|
'attachedLocalUsersCount',
|
|
|
|
'attachedRemoteUsersCount',
|
|
|
|
]
|
|
|
|
},
|
2019-02-23 21:08:08 +02:00
|
|
|
};
|