mirror of
https://github.com/bitwarden/browser
synced 2026-01-04 09:33:27 +00:00
* Disable node integration and enable context isolation * Review comments * Log in renderer through IPC * Missed imports * Mock electron API * resourcesPath is undefined in the preload, but process.windowsStore works correctly * Replace fromBufferToUtf8 conditional implementation for the `buffer` package The current non-node implementation is different than the node implementation, as the non-node would break when the contents can't be parsed as a URI component. Replacing the impl by the `buffer` package makes the result match in both environments. * Fix lint * Add some more tests * Remove buffer from devDependencies
56 lines
1.3 KiB
TypeScript
56 lines
1.3 KiB
TypeScript
import * as path from "path";
|
|
|
|
import { ipcMain } from "electron";
|
|
import log from "electron-log/main";
|
|
|
|
import { LogLevelType } from "@bitwarden/common/platform/enums/log-level-type.enum";
|
|
import { ConsoleLogService as BaseLogService } from "@bitwarden/common/platform/services/console-log.service";
|
|
|
|
import { isDev } from "../../utils";
|
|
|
|
export class ElectronLogMainService extends BaseLogService {
|
|
constructor(
|
|
protected filter: (level: LogLevelType) => boolean = null,
|
|
private logDir: string = null,
|
|
) {
|
|
super(isDev(), filter);
|
|
|
|
if (log.transports == null) {
|
|
return;
|
|
}
|
|
|
|
log.transports.file.level = "info";
|
|
if (this.logDir != null) {
|
|
log.transports.file.resolvePathFn = () => path.join(this.logDir, "app.log");
|
|
}
|
|
log.initialize();
|
|
|
|
ipcMain.handle("ipc.log", (_event, { level, message }) => {
|
|
this.write(level, message);
|
|
});
|
|
}
|
|
|
|
write(level: LogLevelType, message: string) {
|
|
if (this.filter != null && this.filter(level)) {
|
|
return;
|
|
}
|
|
|
|
switch (level) {
|
|
case LogLevelType.Debug:
|
|
log.debug(message);
|
|
break;
|
|
case LogLevelType.Info:
|
|
log.info(message);
|
|
break;
|
|
case LogLevelType.Warning:
|
|
log.warn(message);
|
|
break;
|
|
case LogLevelType.Error:
|
|
log.error(message);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
}
|