1
0
mirror of https://github.com/bitwarden/browser synced 2025-12-12 06:13:38 +00:00

[PM-26318] Limit data.json to current user read/write (#16647)

* Limit data.json to current user read/write

* Keep existing permissions for portable
This commit is contained in:
Matt Gibson
2025-10-02 19:58:24 +00:00
committed by GitHub
parent bbbc10f233
commit 8315c68567

View File

@@ -3,6 +3,7 @@
import * as fs from "fs"; import * as fs from "fs";
import { ipcMain } from "electron"; import { ipcMain } from "electron";
import ElectronStore from "electron-store";
import { Subject } from "rxjs"; import { Subject } from "rxjs";
import { import {
@@ -11,22 +12,7 @@ import {
} from "@bitwarden/common/platform/abstractions/storage.service"; } from "@bitwarden/common/platform/abstractions/storage.service";
import { NodeUtils } from "@bitwarden/node/node-utils"; import { NodeUtils } from "@bitwarden/node/node-utils";
// See: https://github.com/sindresorhus/electron-store/blob/main/index.d.ts import { isWindowsPortable } from "../../utils";
interface ElectronStoreOptions {
defaults: unknown;
name: string;
}
type ElectronStoreConstructor = new (options: ElectronStoreOptions) => ElectronStore;
// eslint-disable-next-line
const Store: ElectronStoreConstructor = require("electron-store");
interface ElectronStore {
get: (key: string) => unknown;
set: (key: string, obj: unknown) => void;
delete: (key: string) => void;
}
interface BaseOptions<T extends string> { interface BaseOptions<T extends string> {
action: T; action: T;
@@ -48,11 +34,13 @@ export class ElectronStorageService implements AbstractStorageService {
if (!fs.existsSync(dir)) { if (!fs.existsSync(dir)) {
NodeUtils.mkdirpSync(dir, "700"); NodeUtils.mkdirpSync(dir, "700");
} }
const storeConfig: ElectronStoreOptions = { const fileMode = isWindowsPortable() ? 0o666 : 0o600;
const storeConfig: ElectronStore.Options<Record<string, unknown>> = {
defaults: defaults, defaults: defaults,
name: "data", name: "data",
configFileMode: fileMode,
}; };
this.store = new Store(storeConfig); this.store = new ElectronStore(storeConfig);
this.updates$ = this.updatesSubject.asObservable(); this.updates$ = this.updatesSubject.asObservable();
ipcMain.handle("storageService", (event, options: Options) => { ipcMain.handle("storageService", (event, options: Options) => {