mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-26 03:20:54 +09:00
wip
This commit is contained in:
parent
768d0bdc00
commit
a78013d0e5
@ -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;
|
||||||
}
|
}
|
||||||
|
@ -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,
|
||||||
);
|
);
|
||||||
|
Loading…
Reference in New Issue
Block a user