1
0
forked from noxious/server

Moved funcs to basEvent

This commit is contained in:
2024-12-28 23:15:00 +01:00
parent 8781bf43a1
commit ff01e41c8f
4 changed files with 14 additions and 127 deletions

View File

@ -13,7 +13,7 @@ export default class CharacterConnectEvent extends BaseEvent {
this.socket.on('character:connect', this.handleEvent.bind(this))
}
private async handleEvent({ characterId, characterHairId }: CharacterConnectPayload): Promise<void> {
private async handleEvent(data: CharacterConnectPayload, callback: (response: boolean) => void): Promise<void> {
if (!this.socket.userId) {
this.emitError('User not authenticated')
return
@ -25,7 +25,7 @@ export default class CharacterConnectEvent extends BaseEvent {
return
}
const character = await CharacterRepository.getByUserAndId(this.socket.userId, characterId)
const character = await CharacterRepository.getByUserAndId(this.socket.userId, data.characterId)
if (!character) {
this.emitError('Character not found or does not belong to this user')
@ -36,7 +36,7 @@ export default class CharacterConnectEvent extends BaseEvent {
this.socket.characterId = character.id
// Set character hair
const characterHair = await CharacterHairRepository.getById(characterHairId ?? 0)
const characterHair = await CharacterHairRepository.getById(data.characterHairId ?? 0)
await character.setCharacterHair(characterHair).update()
// Emit character connect event
@ -50,15 +50,4 @@ export default class CharacterConnectEvent extends BaseEvent {
const characters = await CharacterRepository.getByUserId(this.socket.userId!)
return characters?.some((char) => ZoneManager.getCharacterById(char.id)) ?? false
}
private emitError(message: string): void {
this.socket.emit('notification', { title: 'Server message', message })
this.logger.error('character:connect error', `Player ${this.socket.userId}: ${message}`)
}
private handleError(context: string, error: unknown): void {
const errorMessage = error instanceof Error ? error.message : String(error)
this.emitError(`${context}: ${errorMessage}`)
this.logger.error('character:connect error', errorMessage)
}
}