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>
42 lines
1.4 KiB
TypeScript
42 lines
1.4 KiB
TypeScript
import { EntityRepository, Repository } from 'typeorm';
|
|
import { Channel } from '@/models/entities/channel';
|
|
import { Packed } from '@/misc/schema';
|
|
import { DriveFiles, ChannelFollowings, NoteUnreads } from '../index';
|
|
import { User } from '@/models/entities/user';
|
|
|
|
@EntityRepository(Channel)
|
|
export class ChannelRepository extends Repository<Channel> {
|
|
public async pack(
|
|
src: Channel['id'] | Channel,
|
|
me?: { id: User['id'] } | null | undefined,
|
|
): Promise<Packed<'Channel'>> {
|
|
const channel = typeof src === 'object' ? src : await this.findOneOrFail(src);
|
|
const meId = me ? me.id : null;
|
|
|
|
const banner = channel.bannerId ? await DriveFiles.findOne(channel.bannerId) : null;
|
|
|
|
const hasUnreadNote = meId ? (await NoteUnreads.findOne({ noteChannelId: channel.id, userId: meId })) != null : undefined;
|
|
|
|
const following = meId ? await ChannelFollowings.findOne({
|
|
followerId: meId,
|
|
followeeId: channel.id,
|
|
}) : null;
|
|
|
|
return {
|
|
id: channel.id,
|
|
createdAt: channel.createdAt.toISOString(),
|
|
lastNotedAt: channel.lastNotedAt ? channel.lastNotedAt.toISOString() : null,
|
|
name: channel.name,
|
|
description: channel.description,
|
|
userId: channel.userId,
|
|
bannerUrl: banner ? DriveFiles.getPublicUrl(banner, false) : null,
|
|
usersCount: channel.usersCount,
|
|
notesCount: channel.notesCount,
|
|
|
|
...(me ? {
|
|
isFollowing: following != null,
|
|
hasUnreadNote,
|
|
} : {}),
|
|
};
|
|
}
|
|
}
|