From 2cece3c36259e664c2ffed1fa28ce7d56ea5c432 Mon Sep 17 00:00:00 2001 From: tnpfldyd Date: Mon, 11 Dec 2023 15:28:33 +0900 Subject: [PATCH] =?UTF-8?q?fix(#212):=20=ED=8C=8C=EC=9D=BC=20=EC=9D=BD?= =?UTF-8?q?=EA=B3=A0=20=EC=93=B0=EB=8A=94=20=EB=B0=A9=EC=8B=9D=20=EB=B3=80?= =?UTF-8?q?=EA=B2=BD?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../temporary-database.service.ts | 28 ++++++++++--------- 1 file changed, 15 insertions(+), 13 deletions(-) diff --git a/nestjs-BE/server/src/temporary-database/temporary-database.service.ts b/nestjs-BE/server/src/temporary-database/temporary-database.service.ts index 96463bc1..de993400 100644 --- a/nestjs-BE/server/src/temporary-database/temporary-database.service.ts +++ b/nestjs-BE/server/src/temporary-database/temporary-database.service.ts @@ -12,6 +12,8 @@ import { CreateProfileSpaceDto } from 'src/profile-space/dto/create-profile-spac import { UpdateProfileDto } from 'src/profiles/dto/update-profile.dto'; import { UpdateSpaceDto } from 'src/spaces/dto/update-space.dto'; import { UpdateUserDto } from 'src/users/dto/update-user.dto'; +import costomEnv from 'src/config/env'; +const { CSV_FOLDER } = costomEnv; type DeleteDataType = { field: string; @@ -42,15 +44,19 @@ interface OperationData { @Injectable() export class TemporaryDatabaseService { private database: Map>> = new Map(); - private readonly FOLDER_NAME = 'operations'; + private readonly FOLDER_NAME = CSV_FOLDER; constructor( private readonly prismaMysql: PrismaServiceMySQL, private readonly prismaMongoDB: PrismaServiceMongoDB, ) { + this.init(); + } + + async init() { this.initializeDatabase(); - this.readDataFromFiles(); - this.executeBulkOperations(); + await this.readDataFromFiles(); + await this.executeBulkOperations(); } private initializeDatabase() { @@ -76,11 +82,11 @@ export class TemporaryDatabaseService { private async readDataFromFiles() { const files = await fs.readdir(this.FOLDER_NAME); - files.forEach((file) => { - if (file.endsWith('.csv')) { - this.readDataFromFile(file); - } - }); + return Promise.all( + files + .filter((file) => file.endsWith('.csv')) + .map((file) => this.readDataFromFile(file)), + ); } private async readDataFromFile(file: string) { @@ -129,11 +135,7 @@ export class TemporaryDatabaseService { operation({ service, uniqueKey, command, data }: OperationData) { const filePath = join(this.FOLDER_NAME, `${service}-${command}.csv`); - fs.readFile(filePath, 'utf8').then((fileData) => { - fileData += `${uniqueKey},${JSON.stringify(data)}\n`; - fs.writeFile(filePath, fileData); - this.database.get(service).get(command).set(uniqueKey, data); - }); + fs.appendFile(filePath, `${uniqueKey},${JSON.stringify(data)}\n`, 'utf8'); } @Cron('0 */10 * * * *')