misskey/packages/backend/src/core/entities/ReversiGameEntityService.ts

124 lines
3.9 KiB
TypeScript

/*
* SPDX-FileCopyrightText: syuilo and other misskey contributors
* SPDX-License-Identifier: AGPL-3.0-only
*/
import { Inject, Injectable } from '@nestjs/common';
import { DI } from '@/di-symbols.js';
import type { MiUser, ReversiGamesRepository } from '@/models/_.js';
import { awaitAll } from '@/misc/prelude/await-all.js';
import type { Packed } from '@/misc/json-schema.js';
import type { } from '@/models/Blocking.js';
import type { MiReversiGame } from '@/models/ReversiGame.js';
import { bindThis } from '@/decorators.js';
import { UserEntityService } from './UserEntityService.js';
@Injectable()
export class ReversiGameEntityService {
constructor(
@Inject(DI.reversiGamesRepository)
private reversiGamesRepository: ReversiGamesRepository,
private userEntityService: UserEntityService,
) {
}
@bindThis
public async packDetail(
src: MiReversiGame['id'] | MiReversiGame,
me: { id: MiUser['id'] } | null | undefined,
): Promise<Packed<'ReversiGameDetailed'>> {
const game = typeof src === 'object' ? src : await this.reversiGamesRepository.findOneByOrFail({ id: src });
const users = await this.userEntityService.packMany([
game.user1 ?? game.user1Id,
game.user2 ?? game.user2Id
], me);
return await awaitAll({
id: game.id,
createdAt: game.createdAt.toISOString(),
startedAt: game.startedAt?.toISOString() ?? null,
endedAt: game.endedAt?.toISOString() ?? null,
isStarted: game.isStarted,
isEnded: game.isEnded,
form1: game.form1,
form2: game.form2,
user1Ready: game.user1Ready,
user2Ready: game.user2Ready,
user1Id: game.user1Id,
user2Id: game.user2Id,
user1: users[0],
user2: users[1],
winnerId: game.winnerId,
winner: game.winnerId ? users.find(u => u.id === game.winnerId)! : null,
surrenderedUserId: game.surrenderedUserId,
timeoutUserId: game.timeoutUserId,
black: game.black,
bw: game.bw,
isLlotheo: game.isLlotheo,
canPutEverywhere: game.canPutEverywhere,
loopedBoard: game.loopedBoard,
timeLimitForEachTurn: game.timeLimitForEachTurn,
logs: game.logs,
map: game.map,
});
}
@bindThis
public async packDetailMany(
xs: (MiReversiGame['id'] | MiReversiGame)[],
me: { id: MiUser['id'] } | null | undefined,
) : Promise<Packed<'ReversiGameDetailed'>[]> {
return (await Promise.allSettled(xs.map(x => this.packDetail(x, me))))
.filter(result => result.status === 'fulfilled')
.map(result => (result as PromiseFulfilledResult<Packed<'ReversiGameDetailed'>>).value);
}
@bindThis
public async packLite(
src: MiReversiGame['id'] | MiReversiGame,
me: { id: MiUser['id'] } | null | undefined,
): Promise<Packed<'ReversiGameLite'>> {
const game = typeof src === 'object' ? src : await this.reversiGamesRepository.findOneByOrFail({ id: src });
const users = await this.userEntityService.packMany([
game.user1 ?? game.user1Id,
game.user2 ?? game.user2Id
], me);
return await awaitAll({
id: game.id,
createdAt: game.createdAt.toISOString(),
startedAt: game.startedAt?.toISOString() ?? null,
endedAt: game.endedAt?.toISOString() ?? null,
isStarted: game.isStarted,
isEnded: game.isEnded,
user1Id: game.user1Id,
user2Id: game.user2Id,
user1: users[0],
user2: users[1],
winnerId: game.winnerId,
winner: game.winnerId ? users.find(u => u.id === game.winnerId)! : null,
surrenderedUserId: game.surrenderedUserId,
timeoutUserId: game.timeoutUserId,
black: game.black,
bw: game.bw,
isLlotheo: game.isLlotheo,
canPutEverywhere: game.canPutEverywhere,
loopedBoard: game.loopedBoard,
timeLimitForEachTurn: game.timeLimitForEachTurn,
});
}
@bindThis
public async packLiteMany(
xs: (MiReversiGame['id'] | MiReversiGame)[],
me: { id: MiUser['id'] } | null | undefined,
) : Promise<Packed<'ReversiGameLite'>[]> {
return (await Promise.allSettled(xs.map(x => this.packLite(x, me))))
.filter(result => result.status === 'fulfilled')
.map(result => (result as PromiseFulfilledResult<Packed<'ReversiGameLite'>>).value);
}
}