More event progress

This commit is contained in:
2025-01-02 02:24:09 +01:00
parent ab89d0cbb0
commit f7dbf09bf5
18 changed files with 194 additions and 464 deletions

View File

@ -1,60 +1,36 @@
import fs from 'fs/promises'
import { Server } from 'socket.io'
import { gameMasterLogger } from '#application/logger'
import prisma from '#application/prisma'
import { BaseEvent } from '#application/base/baseEvent'
import Storage from '#application/storage'
import { TSocket } from '#application/types'
import characterRepository from '#repositories/characterRepository'
import { UUID } from '#application/types'
import TileRepository from '#repositories/tileRepository'
type Payload = {
id: string
id: UUID
}
export default class GMTileDeleteEvent {
private readonly public_folder: string
constructor(
private readonly io: Server,
private readonly socket: TSocket
) {
this.public_folder = Storage.getPublicPath('tiles')
}
export default class GMTileDeleteEvent extends BaseEvent {
public listen(): void {
this.socket.on('gm:tile:delete', this.handleEvent.bind(this))
}
private async handleEvent(data: Payload, callback: (response: boolean) => void): Promise<void> {
const character = await characterRepository.getById(this.socket.characterId as number)
if (!character) return callback(false)
if (character.role !== 'gm') {
return
}
if (!(await this.isCharacterGM())) return
try {
gameMasterLogger.info(`Deleting tile ${data.id}`)
await this.deleteTileFromDatabase(data.id)
this.logger.info(`Deleting tile ${data.id}`)
await this.deleteTileFile(data.id)
await (await TileRepository.getById(data.id))?.delete()
gameMasterLogger.info(`Tile ${data.id} deleted successfully.`)
callback(true)
} catch (error: any) {
gameMasterLogger.error('gm:tile:delete error', error.message)
callback(false)
this.logger.info(`Tile ${data.id} deleted successfully.`)
return callback(true)
} catch (error: unknown) {
this.logger.error('gm:tile:delete error', error)
return callback(false)
}
}
private async deleteTileFromDatabase(tileId: string): Promise<void> {
await prisma.tile.delete({
where: {
id: tileId
}
})
}
private async deleteTileFile(tileId: string): Promise<void> {
const finalFilePath = Storage.getPublicPath('tiles', `${tileId}.png`)
try {
@ -63,7 +39,7 @@ export default class GMTileDeleteEvent {
if (error.code !== 'ENOENT') {
throw error
}
gameMasterLogger.warn(`File ${finalFilePath} does not exist.`)
this.logger.warn(`File ${finalFilePath} does not exist.`)
}
}
}