feat: add logger

This commit is contained in:
thecodrr
2022-07-19 09:41:29 +05:00
parent 20d4a08b37
commit fa30984849
3 changed files with 128 additions and 0 deletions

115
packages/core/logger.js Normal file
View File

@@ -0,0 +1,115 @@
import {
Logger,
combineReporters,
consoleReporter,
format,
LogLevel,
} from "@streetwriters/logger";
// Database logger reporter:
// 1. Log to new key on every instance
// 2. Each key contains logs of a session
// 3. Keep 14 days of logs
// 4. Implement functions for log retrieval & filtering
const MAX_RETENTION_LENGTH = 14;
class DatabaseLogReporter {
/**
*
* @param {import("./database/storage").default} storage
*/
constructor(storage) {
this.writer = new DatabaseLogWriter(storage);
}
/**
*
* @param {import("@streetwriters/logger").LogMessage} log
*/
write(log) {
this.writer.push(log);
}
}
class DatabaseLogWriter {
/**
*
* @param {import("./database/storage").default} storage
*/
constructor(storage) {
this.storage = storage;
this.key = new Date().toLocaleDateString();
}
async push(message) {
const logs = await this.read();
if (!logs) {
await this.rotate();
return this.push(message);
}
logs.push(message);
await this.storage.write(this.key, logs);
}
async read() {
return await this.storage.read(this.key, true);
}
async rotate() {
await this.storage.write(this.key, []);
const logKeys = (await this.storage.getAllKeys()).sort();
if (logKeys.length > MAX_RETENTION_LENGTH) {
for (const key of logKeys.slice(
0,
logKeys.length - MAX_RETENTION_LENGTH
)) {
await this.storage.remove(key);
}
}
}
}
class DatabaseLogger extends Logger {
/**
*
* @param {import("./database/storage").default} storage
*/
constructor(storage) {
super({
reporter: combineReporters([
new DatabaseLogReporter(storage),
consoleReporter,
]),
lastTime: Date.now(),
});
this.storage = storage;
}
async get() {
const logKeys = await this.storage.getAllKeys();
const logs = [];
for (const key of logKeys) {
const log = await this.storage.read(key, true);
logs.push({ key, logs: log });
}
return logs;
}
}
/**
*
* @param {import("./database/storage").default} storage
*/
function initalize(storage) {
logger = new DatabaseLogger(storage);
}
/**
* @type {DatabaseLogger}
*/
var logger;
export { logger, initalize, format, LogLevel };

View File

@@ -11,6 +11,7 @@
"dependencies": {
"@microsoft/signalr": "^6.0.3",
"@microsoft/signalr-protocol-msgpack": "^6.0.3",
"@streetwriters/logger": "^1.0.0",
"async-mutex": "^0.3.2",
"base64-arraybuffer": "^1.0.1",
"dayjs": "^1.10.6",
@@ -1757,6 +1758,12 @@
"libsodium-wrappers": "^0.7.9"
}
},
"node_modules/@streetwriters/logger": {
"version": "1.0.0",
"resolved": "https://npm.pkg.github.com/download/@streetwriters/logger/1.0.0/5fd9facea043ed8216cf28aa368c02e446220c1d0071ff78ba02785d2268483e",
"integrity": "sha512-+8gARDAKxg2ube2o/T7xaqQ6HAGDnijZ44/VGdRYuEOg+qfQPPrWkhGfyqhcyyPTFH4J1fu04rGH3MH7nm6pCg==",
"license": "MIT"
},
"node_modules/@types/babel__core": {
"version": "7.1.7",
"resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.7.tgz",
@@ -11158,6 +11165,11 @@
"libsodium-wrappers": "^0.7.9"
}
},
"@streetwriters/logger": {
"version": "1.0.0",
"resolved": "https://npm.pkg.github.com/download/@streetwriters/logger/1.0.0/5fd9facea043ed8216cf28aa368c02e446220c1d0071ff78ba02785d2268483e",
"integrity": "sha512-+8gARDAKxg2ube2o/T7xaqQ6HAGDnijZ44/VGdRYuEOg+qfQPPrWkhGfyqhcyyPTFH4J1fu04rGH3MH7nm6pCg=="
},
"@types/babel__core": {
"version": "7.1.7",
"resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.7.tgz",

View File

@@ -34,6 +34,7 @@
"dependencies": {
"@microsoft/signalr": "^6.0.3",
"@microsoft/signalr-protocol-msgpack": "^6.0.3",
"@streetwriters/logger": "^1.0.0",
"async-mutex": "^0.3.2",
"base64-arraybuffer": "^1.0.1",
"dayjs": "^1.10.6",