a07d753da8
* Update api document in admin/announcements * Update api document in announcements * Update api document in i/read-announcements * Update api document in username/available * Update api document & Fix typo in API 403 error * Update api document * Update api document * Update api document * Fix API permission definition * Update api document * Update api document * Update api document * Update api document * Update api document * Update api document * Update api document * Update api document * Fix bug in users (api) * Apply reviews #6757 * Apply reviews #6757 Co-authored-by: syuilo <Syuilotan@yahoo.co.jp>
80 lines
1.9 KiB
TypeScript
80 lines
1.9 KiB
TypeScript
import { EntityRepository, Repository } from 'typeorm';
|
|
import { App } from '../entities/app';
|
|
import { AccessTokens } from '..';
|
|
import { SchemaType } from '../../misc/schema';
|
|
|
|
export type PackedApp = SchemaType<typeof packedAppSchema>;
|
|
|
|
@EntityRepository(App)
|
|
export class AppRepository extends Repository<App> {
|
|
public async pack(
|
|
src: App['id'] | App,
|
|
me?: any,
|
|
options?: {
|
|
detail?: boolean,
|
|
includeSecret?: boolean,
|
|
includeProfileImageIds?: boolean
|
|
}
|
|
): Promise<PackedApp> {
|
|
const opts = Object.assign({
|
|
detail: false,
|
|
includeSecret: false,
|
|
includeProfileImageIds: false
|
|
}, options);
|
|
|
|
const app = typeof src === 'object' ? src : await this.findOneOrFail(src);
|
|
|
|
return {
|
|
id: app.id,
|
|
name: app.name,
|
|
callbackUrl: app.callbackUrl,
|
|
permission: app.permission,
|
|
...(opts.includeSecret ? { secret: app.secret } : {}),
|
|
...(me ? {
|
|
isAuthorized: await AccessTokens.count({
|
|
appId: app.id,
|
|
userId: me,
|
|
}).then(count => count > 0)
|
|
} : {})
|
|
};
|
|
}
|
|
}
|
|
|
|
export const packedAppSchema = {
|
|
type: 'object' as const,
|
|
optional: false as const, nullable: false as const,
|
|
properties: {
|
|
id: {
|
|
type: 'string' as const,
|
|
optional: false as const, nullable: false as const
|
|
},
|
|
name: {
|
|
type: 'string' as const,
|
|
optional: false as const, nullable: false as const
|
|
},
|
|
createdAt: {
|
|
type: 'string' as const,
|
|
optional: false as const, nullable: false as const
|
|
},
|
|
lastUsedAt: {
|
|
type: 'string' as const,
|
|
optional: false as const, nullable: false as const
|
|
},
|
|
permission: {
|
|
type: 'array' as const,
|
|
optional: false as const, nullable: false as const,
|
|
items: {
|
|
type: 'string' as const,
|
|
optional: false as const, nullable: false as const
|
|
}
|
|
},
|
|
secret: {
|
|
type: 'string' as const,
|
|
optional: true as const, nullable: false as const
|
|
},
|
|
isAuthorized: {
|
|
type: 'boolean' as const,
|
|
optional: true as const, nullable: false as const
|
|
}
|
|
}
|
|
};
|