1
0
forked from noxious/server

Updated upload object event to new format and set img width and height

This commit is contained in:
Dennis Postma 2024-09-15 20:43:26 +02:00
parent d93044d9d7
commit 26660aadf0

View File

@ -4,20 +4,26 @@ import { writeFile } from 'node:fs/promises'
import path from 'path'
import fs from 'fs/promises'
import prisma from '../../../../utilities/prisma'
import sharp from 'sharp'
import logger from '../../../../utilities/logger'
interface IObjectData {
[key: string]: Buffer
}
/**
* Handle game master upload object event
* @param socket
* @param io
*/
export default function (socket: TSocket, io: Server) {
socket.on('gm:object:upload', async (data: IObjectData, callback: (response: boolean) => void) => {
export default class ObjectUploadEvent {
constructor(
private readonly io: Server,
private readonly socket: TSocket
) {}
public listen(): void {
this.socket.on('gm:object:upload', this.handleObjectUpload.bind(this))
}
private async handleObjectUpload(data: IObjectData, callback: (response: boolean) => void): Promise<void> {
try {
if (socket.character?.role !== 'gm') {
if (this.socket.character?.role !== 'gm') {
callback(false)
return
}
@ -28,12 +34,19 @@ export default function (socket: TSocket, io: Server) {
await fs.mkdir(public_folder, { recursive: true })
const uploadPromises = Object.entries(data).map(async ([key, objectData]) => {
// Get image dimensions
const metadata = await sharp(objectData).metadata()
const width = metadata.width || 0
const height = metadata.height || 0
const object = await prisma.object.create({
data: {
name: key,
tags: [],
originX: 0,
originY: 0
originY: 0,
frameWidth: width,
frameHeight: height,
}
})
@ -41,14 +54,16 @@ export default function (socket: TSocket, io: Server) {
const filename = `${uuid}.png`
const finalFilePath = path.join(public_folder, filename)
await writeFile(finalFilePath, objectData)
logger.info('gm:object:upload', `Object ${key} uploaded with id ${uuid}`)
})
await Promise.all(uploadPromises)
callback(true)
} catch (error) {
console.error('Error uploading tile:', error)
} catch (error: any) {
logger.error('gm:object:upload error', error.message)
callback(false)
}
})
}
}
}