forked from noxious/server
Converted socketEvents to new format
Still need to rework 'any' type Promises
This commit is contained in:
@ -7,18 +7,27 @@ type SocketResponseT = {
|
||||
character_id: number
|
||||
}
|
||||
|
||||
export default function (io: Server, socket: TSocket) {
|
||||
socket.on('character:connect', async (data: SocketResponseT) => {
|
||||
export default class CharacterConnectEvent {
|
||||
constructor(
|
||||
private readonly io: Server,
|
||||
private readonly socket: TSocket
|
||||
) {}
|
||||
|
||||
public listen(): void {
|
||||
this.socket.on('character:connect', this.handleCharacterConnect.bind(this))
|
||||
}
|
||||
|
||||
private async handleCharacterConnect(data: SocketResponseT): Promise<void> {
|
||||
console.log('character:connect requested', data)
|
||||
try {
|
||||
const character = await CharacterRepository.getByUserAndId(socket?.user?.id as number, data.character_id)
|
||||
const character = await CharacterRepository.getByUserAndId(this.socket?.user?.id as number, data.character_id)
|
||||
if (!character) return
|
||||
socket.characterId = character.id
|
||||
this.socket.characterId = character.id
|
||||
|
||||
CharacterManager.initCharacter(character as ExtendedCharacter)
|
||||
socket.emit('character:connect', character)
|
||||
this.socket.emit('character:connect', character)
|
||||
} catch (error: any) {
|
||||
console.log('character:connect error', error)
|
||||
}
|
||||
})
|
||||
}
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user