This commit is contained in:
syuilo 2024-01-18 17:38:24 +09:00
parent 768d0bdc00
commit a78013d0e5
2 changed files with 3 additions and 38 deletions

View File

@ -93,10 +93,6 @@ export class ReversiService implements OnApplicationShutdown, OnModuleInit {
childId: me.id, childId: me.id,
}); });
if (other === 0) {
publishMainStream(me.id, 'reversiNoInvites');
}
return game; return game;
} else { } else {
const child = targetUser; const child = targetUser;
@ -113,7 +109,6 @@ export class ReversiService implements OnApplicationShutdown, OnModuleInit {
const packed = await this.reversiMatchingsEntityService.pack(matching, child); const packed = await this.reversiMatchingsEntityService.pack(matching, child);
this.globalEventService.publishReversiStream(child.id, 'invited', { game: packed }); this.globalEventService.publishReversiStream(child.id, 'invited', { game: packed });
publishMainStream(child.id, 'reversiInvited', packed);
return null; return null;
} }

View File

@ -3,13 +3,8 @@
* SPDX-License-Identifier: AGPL-3.0-only * SPDX-License-Identifier: AGPL-3.0-only
*/ */
import { Inject, Injectable } from '@nestjs/common'; import { Injectable } from '@nestjs/common';
import * as CRC32 from 'crc-32';
import type { MiReversiGame, MiUser, ReversiGamesRepository } from '@/models/_.js';
import type { Packed } from '@/misc/json-schema.js';
import { DI } from '@/di-symbols.js';
import { bindThis } from '@/decorators.js'; import { bindThis } from '@/decorators.js';
import { ReversiService } from '@/core/ReversiService.js';
import Channel, { type MiChannelService } from '../channel.js'; import Channel, { type MiChannelService } from '../channel.js';
class ReversiChannel extends Channel { class ReversiChannel extends Channel {
@ -19,9 +14,6 @@ class ReversiChannel extends Channel {
public static kind = 'read:account'; public static kind = 'read:account';
constructor( constructor(
private reversiService: ReversiService,
private reversiGamesRepository: ReversiGamesRepository,
id: string, id: string,
connection: Channel['connection'], connection: Channel['connection'],
) { ) {
@ -30,29 +22,13 @@ class ReversiChannel extends Channel {
@bindThis @bindThis
public async init(params: any) { public async init(params: any) {
this.subscriber.on(`reversiStream:${this.user.id}`, this.send); this.subscriber.on(`reversiStream:${this.user!.id}`, this.send);
}
@bindThis
public async async onMessage(type: string, body: any) {
switch (type) {
case 'ping': {
if (body.id == null) return;
const matching = await ReversiMatchings.findOne({
parentId: this.user!.id,
childId: body.id,
});
if (matching == null) return;
publishMainStream(matching.childId, 'reversiInvited', await ReversiMatchings.pack(matching, { id: matching.childId }));
break;
}
}
} }
@bindThis @bindThis
public dispose() { public dispose() {
// Unsubscribe events // Unsubscribe events
this.subscriber.off(`reversiStream:${this.user.id}`, this.send); this.subscriber.off(`reversiStream:${this.user!.id}`, this.send);
} }
} }
@ -63,18 +39,12 @@ export class ReversiChannelService implements MiChannelService<true> {
public readonly kind = ReversiChannel.kind; public readonly kind = ReversiChannel.kind;
constructor( constructor(
@Inject(DI.reversiGamesRepository)
private reversiGamesRepository: ReversiGamesRepository,
private reversiService: ReversiService,
) { ) {
} }
@bindThis @bindThis
public create(id: string, connection: Channel['connection']): ReversiChannel { public create(id: string, connection: Channel['connection']): ReversiChannel {
return new ReversiChannel( return new ReversiChannel(
this.reversiService,
this.reversiGamesRepository,
id, id,
connection, connection,
); );