2022-08-31 06:33:37 +05:00
|
|
|
/*
|
|
|
|
|
This file is part of the Notesnook project (https://notesnook.com/)
|
|
|
|
|
|
2023-01-16 13:44:52 +05:00
|
|
|
Copyright (C) 2023 Streetwriters (Private) Limited
|
2022-08-31 06:33:37 +05:00
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
*/
|
2022-08-30 16:13:11 +05:00
|
|
|
|
2022-07-20 09:20:05 +05:00
|
|
|
import {
|
|
|
|
|
initalize,
|
|
|
|
|
logger as _logger,
|
2022-08-26 16:19:39 +05:00
|
|
|
logManager
|
2023-08-12 19:55:54 +05:00
|
|
|
} from "@notesnook/core/dist/logger";
|
2022-08-30 16:13:11 +05:00
|
|
|
import { LogMessage } from "@notesnook/logger";
|
2022-07-20 09:20:05 +05:00
|
|
|
import { DatabasePersistence, NNStorage } from "../interfaces/storage";
|
2024-01-05 22:05:04 +05:00
|
|
|
import { ZipFile, createZipStream } from "./streams/zip-stream";
|
|
|
|
|
import { createWriteStream } from "./stream-saver";
|
2022-07-20 09:20:05 +05:00
|
|
|
|
2022-08-30 16:13:11 +05:00
|
|
|
let logger: typeof _logger;
|
2023-08-05 11:16:01 +05:00
|
|
|
async function initalizeLogger(persistence: DatabasePersistence = "db") {
|
2024-01-05 22:05:04 +05:00
|
|
|
initalize(await NNStorage.createInstance("Logs", persistence), false);
|
2022-07-20 09:20:05 +05:00
|
|
|
logger = _logger.scope("notesnook-web");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function downloadLogs() {
|
|
|
|
|
if (!logManager) return;
|
|
|
|
|
const allLogs = await logManager.get();
|
2024-01-05 22:05:04 +05:00
|
|
|
const textEncoder = new TextEncoder();
|
|
|
|
|
await new ReadableStream<ZipFile>({
|
|
|
|
|
pull(controller) {
|
|
|
|
|
for (const log of allLogs) {
|
|
|
|
|
controller.enqueue({
|
|
|
|
|
path: log.key,
|
|
|
|
|
data: textEncoder.encode(
|
|
|
|
|
(log.logs as LogMessage[])
|
|
|
|
|
.map((line) => JSON.stringify(line))
|
|
|
|
|
.join("\n")
|
|
|
|
|
)
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.pipeThrough(createZipStream())
|
|
|
|
|
.pipeTo(await createWriteStream("notesnook-logs.zip"));
|
2022-07-20 09:20:05 +05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async function clearLogs() {
|
|
|
|
|
if (!logManager) return;
|
|
|
|
|
|
|
|
|
|
await logManager.clear();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
export { initalizeLogger, logger, downloadLogs, clearLogs };
|