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 {
|
2023-08-21 16:24:17 +05:00
|
|
|
initialize,
|
2022-07-20 09:20:05 +05:00
|
|
|
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";
|
2024-05-20 14:50:33 +05:00
|
|
|
import { LogMessage, NoopLogger, format } from "@notesnook/logger";
|
2024-01-05 22:05:04 +05:00
|
|
|
import { ZipFile, createZipStream } from "./streams/zip-stream";
|
|
|
|
|
import { createWriteStream } from "./stream-saver";
|
2024-02-12 12:44:34 +05:00
|
|
|
import { sanitizeFilename } from "@notesnook/common";
|
2024-05-20 13:21:35 +05:00
|
|
|
import { createDialect } from "../common/sqlite";
|
|
|
|
|
import { isFeatureSupported } from "./feature-check";
|
2022-07-20 09:20:05 +05:00
|
|
|
|
2024-05-20 14:50:33 +05:00
|
|
|
let logger: typeof _logger = new NoopLogger();
|
2024-05-20 13:21:35 +05:00
|
|
|
async function initializeLogger() {
|
|
|
|
|
await initialize(
|
|
|
|
|
{
|
|
|
|
|
dialect: (name, init) => createDialect(name, false, init),
|
|
|
|
|
...(IS_DESKTOP_APP || isFeatureSupported("opfs")
|
|
|
|
|
? { journalMode: "WAL", lockingMode: "exclusive" }
|
|
|
|
|
: {
|
|
|
|
|
journalMode: "MEMORY",
|
|
|
|
|
lockingMode: "exclusive"
|
|
|
|
|
}),
|
|
|
|
|
tempStore: "memory",
|
|
|
|
|
synchronous: "normal",
|
|
|
|
|
pageSize: 8192,
|
|
|
|
|
cacheSize: -32000,
|
2024-06-28 09:57:24 +05:00
|
|
|
skipInitialization: !IS_DESKTOP_APP && !!globalThis.SharedWorker
|
2024-05-20 13:21:35 +05:00
|
|
|
},
|
|
|
|
|
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-02-12 12:44:34 +05:00
|
|
|
let i = 0;
|
2024-01-05 22:05:04 +05:00
|
|
|
const textEncoder = new TextEncoder();
|
|
|
|
|
await new ReadableStream<ZipFile>({
|
|
|
|
|
pull(controller) {
|
2024-02-12 12:44:34 +05:00
|
|
|
const log = allLogs[i++];
|
|
|
|
|
if (!log) {
|
|
|
|
|
controller.close();
|
|
|
|
|
return;
|
2024-01-05 22:05:04 +05:00
|
|
|
}
|
2024-02-12 12:44:34 +05:00
|
|
|
controller.enqueue({
|
2024-05-20 13:21:35 +05:00
|
|
|
path: sanitizeFilename(log.key, { replacement: "-" }) + ".log",
|
2024-02-12 12:44:34 +05:00
|
|
|
data: textEncoder.encode(
|
2024-05-20 13:21:35 +05:00
|
|
|
(log.logs as LogMessage[]).map((line) => format(line)).join("\n")
|
2024-02-12 12:44:34 +05:00
|
|
|
)
|
|
|
|
|
});
|
2024-01-05 22:05:04 +05:00
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
.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();
|
|
|
|
|
}
|
|
|
|
|
|
2023-08-21 16:24:17 +05:00
|
|
|
export { initializeLogger, logger, downloadLogs, clearLogs };
|