efb0ffc4ec
* Fix API Schema Error * Delete SimpleSchema/SimpleObj and Move schemas to dedicated files * Userのスキーマを分割してみる * define packMany type * add , * Ensure enum schema and Make "as const" put once * test? * Revert "test?" This reverts commit 97dc9bfa70851bfb7d1cf38e883f8df20fb78b79. * Revert "Fix API Schema Error" This reverts commit 21b6176d974ed8e3eb73723ad21a105c5d297323. * ✌️ * clean up * test? * wip * wip * better schema def * ✌️ * fix * add minLength property * wip * wip * wip * anyOf/oneOf/allOfに対応? ~ relation.ts * refactor! * Define MinimumSchema * wip * wip * anyOf/oneOf/allOfが動作するようにUnionSchemaTypeを修正 * anyOf/oneOf/allOfが動作するようにUnionSchemaTypeを修正 * Update packages/backend/src/misc/schema.ts Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com> * fix * array oneOfをより正確な型に * array oneOfをより正確な型に * wip * ✌️ * なんかもういろいろ * remove * very good schema * api schema * wip * refactor: awaitAllの型定義を変えてみる * fix * specify types in awaitAll * specify types in awaitAll * ✌️ * wip * ... * ✌️ * AllowDateはやめておく * 不必要なoptional: false, nullable: falseを廃止 * Packedが展開されないように * 続packed * wip * define note type * wip * UserDetailedをMeDetailedかUserDetailedNotMeかを区別できるように * wip * wip * wip specify user type of other schemas * ok * convertSchemaToOpenApiSchemaを改修 * convertSchemaToOpenApiSchemaを改修 * Fix * fix * ✌️ * wip * 分割代入ではなくallOfで定義するように Co-authored-by: Acid Chicken (硫酸鶏) <root@acid-chicken.com>
33 lines
933 B
TypeScript
33 lines
933 B
TypeScript
import { EntityRepository, Repository } from 'typeorm';
|
|
import { Users } from '../index';
|
|
import { Blocking } from '@/models/entities/blocking';
|
|
import { awaitAll } from '@/prelude/await-all';
|
|
import { Packed } from '@/misc/schema';
|
|
import { User } from '@/models/entities/user';
|
|
|
|
@EntityRepository(Blocking)
|
|
export class BlockingRepository extends Repository<Blocking> {
|
|
public async pack(
|
|
src: Blocking['id'] | Blocking,
|
|
me?: { id: User['id'] } | null | undefined
|
|
): Promise<Packed<'Blocking'>> {
|
|
const blocking = typeof src === 'object' ? src : await this.findOneOrFail(src);
|
|
|
|
return await awaitAll({
|
|
id: blocking.id,
|
|
createdAt: blocking.createdAt.toISOString(),
|
|
blockeeId: blocking.blockeeId,
|
|
blockee: Users.pack(blocking.blockeeId, me, {
|
|
detail: true,
|
|
}),
|
|
});
|
|
}
|
|
|
|
public packMany(
|
|
blockings: any[],
|
|
me: { id: User['id'] }
|
|
) {
|
|
return Promise.all(blockings.map(x => this.pack(x, me)));
|
|
}
|
|
}
|