mirror of
https://git.joinsharkey.org/Sharkey/Sharkey.git
synced 2024-11-14 10:03:09 +02:00
510de87607
* wip * wip * Update abuse-user-reports.ts * Update files.ts * Update list-remote.ts * Update list.ts * Update show-users.ts * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * wip * Update update.ts * Update search.ts * Update reactions.ts * Update search.ts * wip * wip * wip * wip * Update update.ts * Update relation.ts * Update available.ts * wip * wip * wip * Update packages/backend/src/server/api/define.ts Co-authored-by: Johann150 <johann.galle@protonmail.com> * Update define.ts * Update define.ts * typo * wip * wip * wip * wip * wip * wip * wip * wip * Update update.ts * wip * Update signup.ts * Update call.ts * minimum for limit * type * remove needless annotation * wip * Update signup.ts * wip * wip * fix * Update create.ts Co-authored-by: Johann150 <johann.galle@protonmail.com>
70 lines
2.3 KiB
TypeScript
70 lines
2.3 KiB
TypeScript
import * as fs from 'fs';
|
|
import * as Ajv from 'ajv';
|
|
import { ILocalUser } from '@/models/entities/user';
|
|
import { IEndpointMeta } from './endpoints';
|
|
import { ApiError } from './error';
|
|
import { Schema, SchemaType } from '@/misc/schema';
|
|
import { AccessToken } from '@/models/entities/access-token';
|
|
|
|
type SimpleUserInfo = {
|
|
id: ILocalUser['id'];
|
|
createdAt: ILocalUser['createdAt'];
|
|
host: ILocalUser['host'];
|
|
username: ILocalUser['username'];
|
|
uri: ILocalUser['uri'];
|
|
inbox: ILocalUser['inbox'];
|
|
sharedInbox: ILocalUser['sharedInbox'];
|
|
isAdmin: ILocalUser['isAdmin'];
|
|
isModerator: ILocalUser['isModerator'];
|
|
isSilenced: ILocalUser['isSilenced'];
|
|
showTimelineReplies: ILocalUser['showTimelineReplies'];
|
|
};
|
|
|
|
export type Response = Record<string, any> | void;
|
|
|
|
// TODO: paramsの型をT['params']のスキーマ定義から推論する
|
|
type executor<T extends IEndpointMeta, Ps extends Schema> =
|
|
(params: SchemaType<Ps>, user: T['requireCredential'] extends true ? SimpleUserInfo : SimpleUserInfo | null, token: AccessToken | null, file?: any, cleanup?: () => any) =>
|
|
Promise<T['res'] extends undefined ? Response : SchemaType<NonNullable<T['res']>>>;
|
|
|
|
const ajv = new Ajv({
|
|
useDefaults: true,
|
|
});
|
|
|
|
ajv.addFormat('misskey:id', /^[a-z0-9]+$/);
|
|
|
|
export default function <T extends IEndpointMeta, Ps extends Schema>(meta: T, paramDef: Ps, cb: executor<T, Ps>)
|
|
: (params: any, user: T['requireCredential'] extends true ? SimpleUserInfo : SimpleUserInfo | null, token: AccessToken | null, file?: any) => Promise<any> {
|
|
|
|
const validate = ajv.compile(paramDef);
|
|
|
|
return (params: any, user: T['requireCredential'] extends true ? SimpleUserInfo : SimpleUserInfo | null, token: AccessToken | null, file?: any) => {
|
|
function cleanup() {
|
|
fs.unlink(file.path, () => {});
|
|
}
|
|
|
|
if (meta.requireFile && file == null) return Promise.reject(new ApiError({
|
|
message: 'File required.',
|
|
code: 'FILE_REQUIRED',
|
|
id: '4267801e-70d1-416a-b011-4ee502885d8b',
|
|
}));
|
|
|
|
const valid = validate(params);
|
|
if (!valid) {
|
|
if (file) cleanup();
|
|
|
|
const errors = validate.errors!;
|
|
const err = new ApiError({
|
|
message: 'Invalid param.',
|
|
code: 'INVALID_PARAM',
|
|
id: '3d81ceae-475f-4600-b2a8-2bc116157532',
|
|
}, {
|
|
param: errors[0].schemaPath,
|
|
reason: errors[0].message,
|
|
});
|
|
return Promise.reject(err);
|
|
}
|
|
|
|
return cb(params, user, token, file, cleanup);
|
|
};
|
|
}
|