mirror of
https://github.com/streetwriters/notesnook.git
synced 2025-12-23 23:19:40 +01:00
feat: add logger
This commit is contained in:
115
packages/core/logger.js
Normal file
115
packages/core/logger.js
Normal 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 };
|
||||
12
packages/core/package-lock.json
generated
12
packages/core/package-lock.json
generated
@@ -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",
|
||||
|
||||
@@ -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",
|
||||
|
||||
Reference in New Issue
Block a user