mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-04 18:37:45 +01:00
[PM-3687] Remove ipcRenderer from native-messaging (#6893)
This commit is contained in:
parent
f6c2e0b6c0
commit
1ecf019397
@ -1,8 +1,14 @@
|
|||||||
import { ipcRenderer } from "electron";
|
import { ipcRenderer } from "electron";
|
||||||
|
|
||||||
import { DeviceType, ThemeType, KeySuffixOptions } from "@bitwarden/common/enums";
|
import { DeviceType, ThemeType, KeySuffixOptions } from "@bitwarden/common/enums";
|
||||||
|
import { EncString } from "@bitwarden/common/platform/models/domain/enc-string";
|
||||||
|
|
||||||
import { EncryptedMessageResponse, UnencryptedMessageResponse } from "../models/native-messaging";
|
import {
|
||||||
|
EncryptedMessageResponse,
|
||||||
|
LegacyMessageWrapper,
|
||||||
|
Message,
|
||||||
|
UnencryptedMessageResponse,
|
||||||
|
} from "../models/native-messaging";
|
||||||
import { BiometricMessage, BiometricAction } from "../types/biometric-message";
|
import { BiometricMessage, BiometricAction } from "../types/biometric-message";
|
||||||
import { isDev, isWindowsStore } from "../utils";
|
import { isDev, isWindowsStore } from "../utils";
|
||||||
|
|
||||||
@ -56,6 +62,17 @@ const nativeMessaging = {
|
|||||||
sendReply: (message: EncryptedMessageResponse | UnencryptedMessageResponse) => {
|
sendReply: (message: EncryptedMessageResponse | UnencryptedMessageResponse) => {
|
||||||
ipcRenderer.send("nativeMessagingReply", message);
|
ipcRenderer.send("nativeMessagingReply", message);
|
||||||
},
|
},
|
||||||
|
sendMessage: (message: {
|
||||||
|
appId: string;
|
||||||
|
command?: string;
|
||||||
|
sharedSecret?: string;
|
||||||
|
message?: EncString;
|
||||||
|
}) => {
|
||||||
|
ipcRenderer.send("nativeMessagingReply", message);
|
||||||
|
},
|
||||||
|
onMessage: (callback: (message: LegacyMessageWrapper | Message) => void) => {
|
||||||
|
ipcRenderer.on("nativeMessaging", (_event, message) => callback(message));
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
|
@ -1,5 +1,4 @@
|
|||||||
import { Injectable, NgZone } from "@angular/core";
|
import { Injectable, NgZone } from "@angular/core";
|
||||||
import { ipcRenderer } from "electron";
|
|
||||||
import { firstValueFrom } from "rxjs";
|
import { firstValueFrom } from "rxjs";
|
||||||
|
|
||||||
import { KeySuffixOptions } from "@bitwarden/common/enums";
|
import { KeySuffixOptions } from "@bitwarden/common/enums";
|
||||||
@ -43,9 +42,7 @@ export class NativeMessagingService {
|
|||||||
) {}
|
) {}
|
||||||
|
|
||||||
init() {
|
init() {
|
||||||
ipcRenderer.on("nativeMessaging", async (_event: any, message: any) => {
|
ipc.platform.nativeMessaging.onMessage((message) => this.messageHandler(message));
|
||||||
this.messageHandler(message);
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private async messageHandler(msg: LegacyMessageWrapper | Message) {
|
private async messageHandler(msg: LegacyMessageWrapper | Message) {
|
||||||
@ -65,12 +62,18 @@ export class NativeMessagingService {
|
|||||||
const accounts = await firstValueFrom(this.stateService.accounts$);
|
const accounts = await firstValueFrom(this.stateService.accounts$);
|
||||||
const userIds = Object.keys(accounts);
|
const userIds = Object.keys(accounts);
|
||||||
if (!userIds.includes(rawMessage.userId)) {
|
if (!userIds.includes(rawMessage.userId)) {
|
||||||
ipcRenderer.send("nativeMessagingReply", { command: "wrongUserId", appId: appId });
|
ipc.platform.nativeMessaging.sendMessage({
|
||||||
|
command: "wrongUserId",
|
||||||
|
appId: appId,
|
||||||
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (await this.stateService.getEnableBrowserIntegrationFingerprint()) {
|
if (await this.stateService.getEnableBrowserIntegrationFingerprint()) {
|
||||||
ipcRenderer.send("nativeMessagingReply", { command: "verifyFingerprint", appId: appId });
|
ipc.platform.nativeMessaging.sendMessage({
|
||||||
|
command: "verifyFingerprint",
|
||||||
|
appId: appId,
|
||||||
|
});
|
||||||
|
|
||||||
const fingerprint = await this.cryptoService.getFingerprint(
|
const fingerprint = await this.cryptoService.getFingerprint(
|
||||||
await this.stateService.getUserId(),
|
await this.stateService.getUserId(),
|
||||||
@ -95,7 +98,10 @@ export class NativeMessagingService {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (this.sharedSecrets.get(appId) == null) {
|
if (this.sharedSecrets.get(appId) == null) {
|
||||||
ipcRenderer.send("nativeMessagingReply", { command: "invalidateEncryption", appId: appId });
|
ipc.platform.nativeMessaging.sendMessage({
|
||||||
|
command: "invalidateEncryption",
|
||||||
|
appId: appId,
|
||||||
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -105,7 +111,10 @@ export class NativeMessagingService {
|
|||||||
|
|
||||||
// Shared secret is invalidated, force re-authentication
|
// Shared secret is invalidated, force re-authentication
|
||||||
if (message == null) {
|
if (message == null) {
|
||||||
ipcRenderer.send("nativeMessagingReply", { command: "invalidateEncryption", appId: appId });
|
ipc.platform.nativeMessaging.sendMessage({
|
||||||
|
command: "invalidateEncryption",
|
||||||
|
appId: appId,
|
||||||
|
});
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -174,7 +183,7 @@ export class NativeMessagingService {
|
|||||||
this.sharedSecrets.get(appId)
|
this.sharedSecrets.get(appId)
|
||||||
);
|
);
|
||||||
|
|
||||||
ipcRenderer.send("nativeMessagingReply", { appId: appId, message: encrypted });
|
ipc.platform.nativeMessaging.sendMessage({ appId: appId, message: encrypted });
|
||||||
}
|
}
|
||||||
|
|
||||||
private async secureCommunication(remotePublicKey: Uint8Array, appId: string) {
|
private async secureCommunication(remotePublicKey: Uint8Array, appId: string) {
|
||||||
@ -186,7 +195,7 @@ export class NativeMessagingService {
|
|||||||
remotePublicKey,
|
remotePublicKey,
|
||||||
EncryptionAlgorithm
|
EncryptionAlgorithm
|
||||||
);
|
);
|
||||||
ipcRenderer.send("nativeMessagingReply", {
|
ipc.platform.nativeMessaging.sendMessage({
|
||||||
appId: appId,
|
appId: appId,
|
||||||
command: "setupEncryption",
|
command: "setupEncryption",
|
||||||
sharedSecret: Utils.fromBufferToB64(encryptedSecret),
|
sharedSecret: Utils.fromBufferToB64(encryptedSecret),
|
||||||
|
Loading…
Reference in New Issue
Block a user