From c918acb25f6cf4ff84fc92596ae7b97516635bc0 Mon Sep 17 00:00:00 2001 From: M1000fr Date: Sat, 7 Sep 2024 02:04:37 +0200 Subject: [PATCH] chore: optimisation for deleted messages storage --- .gitignore | 3 +- src/index.ts | 44 ++++++++------------------- src/interfaces/messageData.d.ts | 1 + src/interfaces/messageDeleteData.d.ts | 4 --- 4 files changed, 15 insertions(+), 37 deletions(-) delete mode 100644 src/interfaces/messageDeleteData.d.ts diff --git a/.gitignore b/.gitignore index c1966fc..c24445c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,4 +1,3 @@ node_modules/ build/ -messages/ -messagesDeleted.json +messages/ \ No newline at end of file diff --git a/src/index.ts b/src/index.ts index 297ac33..81ed38f 100644 --- a/src/index.ts +++ b/src/index.ts @@ -2,7 +2,6 @@ import axios from "axios"; import fs from "node:fs/promises"; import { ChannelData } from "./interfaces/channelData"; import { MessageData } from "./interfaces/messageData"; -import { MessageDeleteData } from "./interfaces/messageDeleteData"; import moment from "moment"; import "json-bigint-patch"; @@ -51,18 +50,6 @@ async function main() { const channelsFolder = await fs.readdir("./messages"); - // get messagesDeleted.json, if not exists, create it - var messagesDeletedFile: MessageDeleteData[] = await fs - .readFile("./messagesDeleted.json") - .catch(() => null) - .then((data) => data && JSON.parse(data.toString())); - if (!messagesDeletedFile) { - await fs.writeFile("./messagesDeleted.json", "[]"); - messagesDeletedFile = []; - } - - totalDeleted += messagesDeletedFile.length; - // Loop through all the folders in the messages directory to calculate the total number of messages for (const channelFolder of channelsFolder) { const channelDataFile = await fs @@ -90,6 +77,10 @@ async function main() { CHANNELS_DATA.push(channelData); MESSAGES_DATA[channelData.id] = JSON.parse(messagesData.toString()); + + totalDeleted += messages.filter( + (message) => message?.Deleted == true + ).length; } // Loop through all the folders in the messages directory to delete the messages @@ -103,12 +94,7 @@ async function main() { // get messagesDeleted.json and filter to get only messages not deleted const messages: MessageData[] = MESSAGES_DATA[channelData.id], messagesNotDeleted = messages.filter((message) => { - const messageDeleted = messagesDeletedFile.find( - (messageDeleted) => - messageDeleted.channel_id === channelData.id && - messageDeleted.message_id === message.ID - ); - return !messageDeleted; + return !message.Deleted; }); for (const message of messagesNotDeleted) { @@ -130,13 +116,11 @@ async function main() { // Delete the message await deleteMessage(channelData.id, message.ID) .then(async () => { - messagesDeletedFile.push({ - channel_id: channelData.id, - message_id: message.ID, - }); + // Update the message data + message.Deleted = true; await fs.writeFile( - "./messagesDeleted.json", - JSON.stringify(messagesDeletedFile, null, 2) + `./messages/c${channelData.id}/messages.json`, + JSON.stringify(messages, null, 2) ); }) .catch(async (error) => { @@ -151,13 +135,11 @@ async function main() { errorMessage?.includes(msg) ) ) { - messagesDeletedFile.push({ - channel_id: channelData.id, - message_id: message.ID, - }); + // Update the message data + message.Deleted = true; await fs.writeFile( - "./messagesDeleted.json", - JSON.stringify(messagesDeletedFile, null, 2) + `./messages/c${channelData.id}/messages.json`, + JSON.stringify(messages, null, 1) ); } }); diff --git a/src/interfaces/messageData.d.ts b/src/interfaces/messageData.d.ts index 8950a42..cca6d8d 100644 --- a/src/interfaces/messageData.d.ts +++ b/src/interfaces/messageData.d.ts @@ -3,4 +3,5 @@ export interface MessageData { Timestamp: string; Contents: string; Attachments: string; + Deleted?: boolean; } diff --git a/src/interfaces/messageDeleteData.d.ts b/src/interfaces/messageDeleteData.d.ts deleted file mode 100644 index a7a287e..0000000 --- a/src/interfaces/messageDeleteData.d.ts +++ /dev/null @@ -1,4 +0,0 @@ -export interface MessageDeleteData { - channel_id: string; - message_id: bigint; -}