1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-19 20:51:35 +01:00

feat: somewhat complete web <-> browser link

This commit is contained in:
Andreas Coroiu 2024-12-17 14:33:34 +01:00
parent f04027489a
commit 45a1ff7f04
No known key found for this signature in database
GPG Key ID: E70B5FFC81DFEC1A
6 changed files with 74 additions and 16 deletions

View File

@ -1251,7 +1251,7 @@ export default class MainBackground {
this.inlineMenuFieldQualificationService = new InlineMenuFieldQualificationService(); this.inlineMenuFieldQualificationService = new InlineMenuFieldQualificationService();
this.ipcService = new IpcBackgroundService(); this.ipcService = new IpcBackgroundService(this.sdkService);
} }
async bootstrap() { async bootstrap() {

View File

@ -1,17 +1,45 @@
import { IpcService, isIpcMessage } from "@bitwarden/common/platform/ipc"; import { Observable } from "rxjs";
import { IpcLink, IpcMessage, IpcService, isIpcMessage } from "@bitwarden/common/platform/ipc";
import { BrowserApi } from "../browser/browser-api"; import { BrowserApi } from "../browser/browser-api";
export class IpcBackgroundService extends IpcService { export class IpcBackgroundService extends IpcService {
private links = new Map<string, IpcLink>();
override async init() { override async init() {
await super.init(); await super.init();
BrowserApi.messageListener("platform.ipc", (message) => { BrowserApi.messageListener("platform.ipc", (message, sender) => {
if (!isIpcMessage(message)) { if (!isIpcMessage(message)) {
return; return;
} }
console.log("Received IPC message", message); if (!this.links.has(sender.documentId)) {
this.links.set(
sender.documentId,
new IpcLink(
async (data) =>
BrowserApi.sendMessage("platform.ipc", {
type: "bitwarden-ipc-message",
payload: data,
} satisfies IpcMessage),
new Observable((subscriber) => {
const handler = (message: unknown) => {
if (!isIpcMessage(message)) {
return;
}
subscriber.next(message.payload);
};
BrowserApi.addListener(chrome.runtime.onMessage, handler);
return () => BrowserApi.removeListener(chrome.runtime.onMessage, handler);
}),
[{ Web: sender.documentId }],
),
);
}
}); });
} }
} }

View File

@ -67,8 +67,10 @@ import { LogService } from "@bitwarden/common/platform/abstractions/log.service"
import { MessagingService } from "@bitwarden/common/platform/abstractions/messaging.service"; import { MessagingService } from "@bitwarden/common/platform/abstractions/messaging.service";
import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service"; import { PlatformUtilsService } from "@bitwarden/common/platform/abstractions/platform-utils.service";
import { SdkClientFactory } from "@bitwarden/common/platform/abstractions/sdk/sdk-client-factory"; import { SdkClientFactory } from "@bitwarden/common/platform/abstractions/sdk/sdk-client-factory";
import { SdkService } from "@bitwarden/common/platform/abstractions/sdk/sdk.service";
import { AbstractStorageService } from "@bitwarden/common/platform/abstractions/storage.service"; import { AbstractStorageService } from "@bitwarden/common/platform/abstractions/storage.service";
import { ThemeType } from "@bitwarden/common/platform/enums"; import { ThemeType } from "@bitwarden/common/platform/enums";
import { IpcService } from "@bitwarden/common/platform/ipc";
import { AppIdService as DefaultAppIdService } from "@bitwarden/common/platform/services/app-id.service"; import { AppIdService as DefaultAppIdService } from "@bitwarden/common/platform/services/app-id.service";
import { MemoryStorageService } from "@bitwarden/common/platform/services/memory-storage.service"; import { MemoryStorageService } from "@bitwarden/common/platform/services/memory-storage.service";
// eslint-disable-next-line import/no-restricted-paths -- Implementation for memory storage // eslint-disable-next-line import/no-restricted-paths -- Implementation for memory storage
@ -108,6 +110,7 @@ import { HtmlStorageService } from "../core/html-storage.service";
import { I18nService } from "../core/i18n.service"; import { I18nService } from "../core/i18n.service";
import { WebProcessReloadService } from "../key-management/services/web-process-reload.service"; import { WebProcessReloadService } from "../key-management/services/web-process-reload.service";
import { WebBiometricsService } from "../key-management/web-biometric.service"; import { WebBiometricsService } from "../key-management/web-biometric.service";
import { WebIpcService } from "../platform/ipc/web-ipc.service";
import { WebEnvironmentService } from "../platform/web-environment.service"; import { WebEnvironmentService } from "../platform/web-environment.service";
import { WebMigrationRunner } from "../platform/web-migration-runner"; import { WebMigrationRunner } from "../platform/web-migration-runner";
import { WebSdkClientFactory } from "../platform/web-sdk-client-factory"; import { WebSdkClientFactory } from "../platform/web-sdk-client-factory";
@ -313,6 +316,11 @@ const safeProviders: SafeProvider[] = [
useClass: WebLoginDecryptionOptionsService, useClass: WebLoginDecryptionOptionsService,
deps: [MessagingService, RouterService, AcceptOrganizationInviteService], deps: [MessagingService, RouterService, AcceptOrganizationInviteService],
}), }),
safeProvider({
provide: IpcService,
useClass: WebIpcService,
deps: [SdkService],
}),
]; ];
@NgModule({ @NgModule({

View File

@ -15,6 +15,7 @@ import { ContainerService } from "@bitwarden/common/platform/services/container.
import { UserAutoUnlockKeyService } from "@bitwarden/common/platform/services/user-auto-unlock-key.service"; import { UserAutoUnlockKeyService } from "@bitwarden/common/platform/services/user-auto-unlock-key.service";
import { EventUploadService } from "@bitwarden/common/services/event/event-upload.service"; import { EventUploadService } from "@bitwarden/common/services/event/event-upload.service";
import { VaultTimeoutService } from "@bitwarden/common/services/vault-timeout/vault-timeout.service"; import { VaultTimeoutService } from "@bitwarden/common/services/vault-timeout/vault-timeout.service";
import { IpcService } from "@bitwarden/common/src/platform/ipc";
import { KeyService as KeyServiceAbstraction } from "@bitwarden/key-management"; import { KeyService as KeyServiceAbstraction } from "@bitwarden/key-management";
import { VersionService } from "../platform/version.service"; import { VersionService } from "../platform/version.service";
@ -35,6 +36,7 @@ export class InitService {
private userAutoUnlockKeyService: UserAutoUnlockKeyService, private userAutoUnlockKeyService: UserAutoUnlockKeyService,
private accountService: AccountService, private accountService: AccountService,
private versionService: VersionService, private versionService: VersionService,
private ipcService: IpcService,
@Inject(DOCUMENT) private document: Document, @Inject(DOCUMENT) private document: Document,
) {} ) {}
@ -58,6 +60,7 @@ export class InitService {
htmlEl.classList.add("locale_" + this.i18nService.translationLocale); htmlEl.classList.add("locale_" + this.i18nService.translationLocale);
this.themingService.applyThemeChangesTo(this.document); this.themingService.applyThemeChangesTo(this.document);
this.versionService.applyVersionToWindow(); this.versionService.applyVersionToWindow();
void this.ipcService.init();
const containerService = new ContainerService(this.keyService, this.encryptService); const containerService = new ContainerService(this.keyService, this.encryptService);
containerService.attachToGlobal(this.win); containerService.attachToGlobal(this.win);

View File

@ -1,16 +1,29 @@
import { IpcService, isIpcMessage } from "@bitwarden/common/platform/ipc"; import { Observable } from "rxjs";
import { IpcLink, IpcService, isIpcMessage } from "@bitwarden/common/platform/ipc";
export class WebIpcService extends IpcService { export class WebIpcService extends IpcService {
private static LinkToExtensionBackground = new IpcLink(
async (data) => window.postMessage(data, window.location.origin),
new Observable((subscriber) => {
const listener = (event: MessageEvent<unknown>) => {
const message = event.data;
if (!isIpcMessage(message)) {
return;
}
subscriber.next(message.payload);
};
window.addEventListener("message", listener);
return () => window.removeEventListener("message", listener);
}),
["BrowserBackground"],
);
override async init() { override async init() {
await super.init(); await super.init();
window.addEventListener("message", (event) => { this.manager.register_link(WebIpcService.LinkToExtensionBackground);
const message = event.data;
if (!isIpcMessage(message)) {
return;
}
console.log("WEB Received IPC message", message);
});
} }
} }

View File

@ -1,11 +1,17 @@
// import { Manager } from "@bitwarden/sdk-internal"; import { firstValueFrom, map } from "rxjs";
import { Manager } from "@bitwarden/sdk-internal";
import { SdkService } from "../abstractions/sdk/sdk.service"; import { SdkService } from "../abstractions/sdk/sdk.service";
export abstract class IpcService { export abstract class IpcService {
// protected manager = new Manager(); protected manager: Manager;
constructor(private sdkService: SdkService) {} constructor(private sdkService: SdkService) {}
async init() {} async init() {
await firstValueFrom(
this.sdkService.client$.pipe(map((client) => client.ipc().create_manager())),
);
}
} }