mirror of
https://github.com/bitwarden/browser
synced 2025-12-06 00:13:28 +00:00
* feat: scaffold desktop_objc * feat: rename fido2 to autofill * feat: scaffold electron autofill * feat: auto call hello world on init * feat: scaffold call to basic objc function * feat: simple log that checks if autofill is enabled * feat: adding some availability guards * feat: scaffold services and allow calls from inspector * feat: create custom type for returning strings across rust/objc boundary * chore: clean up comments * feat: enable ARC * feat: add util function `c_string_to_nsstring` * chore: refactor and rename to `run_command` * feat: add try-catch around command execution * feat: properly implement command calling Add static typing. Add proper error handling. * feat: add autoreleasepool to avoid memory leaks * chore: change objc names to camelCase * fix: error returning * feat: extract some helper functions into utils class * feat: scaffold status command * feat: implement status command * feat: implement password credential mapping * wip: implement sync command This crashes because we are not properly handling the fact that `saveCredentialIdentities` uses callbacks, resulting in a race condition where we try to access a variable (result) that has already gotten dealloc'd. * feat: first version of callback * feat: make run_command async * feat: functioning callback returns * chore: refactor to make objc code easier to read and use * feat: refactor everything to use new callback return method * feat: re-implement status command with callback * fix: warning about CommandContext not being FFI-safe * feat: implement sync command using callbacks * feat: implement manual password credential sync * feat: add auto syncing * docs: add todo * feat: add support for passkeys * chore: move desktop autofill service to init service * feat: auto-add all .m files to builder * fix: native build on unix and windows * fix: unused compiler warnings * fix: napi type exports * feat: add corresponding dist command * feat: comment signing profile until we fix signing * fix: build breaking on non-macOS platforms * chore: cargo lock update * chore: revert accidental version change * feat: put sync behind feature flag * chore: put files in autofill folder * fix: obj-c code not recompiling on changes * feat: add `namespace` to commands * fix: linting complaining about flag * feat: add autofill as owner of their objc code * chore: make autofill owner of run_command in core crate * fix: re-add napi annotation * fix: remove dev bypass
92 lines
5.0 KiB
TypeScript
92 lines
5.0 KiB
TypeScript
import { DOCUMENT } from "@angular/common";
|
|
import { Inject, Injectable } from "@angular/core";
|
|
import { firstValueFrom } from "rxjs";
|
|
|
|
import { AbstractThemingService } from "@bitwarden/angular/platform/services/theming/theming.service.abstraction";
|
|
import { WINDOW } from "@bitwarden/angular/services/injection-tokens";
|
|
import { EventUploadService as EventUploadServiceAbstraction } from "@bitwarden/common/abstractions/event/event-upload.service";
|
|
import { NotificationsService as NotificationsServiceAbstraction } from "@bitwarden/common/abstractions/notifications.service";
|
|
import { AccountService } from "@bitwarden/common/auth/abstractions/account.service";
|
|
import { TwoFactorService as TwoFactorServiceAbstraction } from "@bitwarden/common/auth/abstractions/two-factor.service";
|
|
import { EncryptService } from "@bitwarden/common/platform/abstractions/encrypt.service";
|
|
import { I18nService as I18nServiceAbstraction } from "@bitwarden/common/platform/abstractions/i18n.service";
|
|
import { PlatformUtilsService as PlatformUtilsServiceAbstraction } from "@bitwarden/common/platform/abstractions/platform-utils.service";
|
|
import { StateService as StateServiceAbstraction } from "@bitwarden/common/platform/abstractions/state.service";
|
|
import { ContainerService } from "@bitwarden/common/platform/services/container.service";
|
|
import { UserAutoUnlockKeyService } from "@bitwarden/common/platform/services/user-auto-unlock-key.service";
|
|
import { SyncService as SyncServiceAbstraction } from "@bitwarden/common/platform/sync";
|
|
import { EventUploadService } from "@bitwarden/common/services/event/event-upload.service";
|
|
import { VaultTimeoutService } from "@bitwarden/common/services/vault-timeout/vault-timeout.service";
|
|
import { UserId } from "@bitwarden/common/types/guid";
|
|
import { KeyService as KeyServiceAbstraction } from "@bitwarden/key-management";
|
|
|
|
import { DesktopAutofillService } from "../../autofill/services/desktop-autofill.service";
|
|
import { I18nRendererService } from "../../platform/services/i18n.renderer.service";
|
|
import { SshAgentService } from "../../platform/services/ssh-agent.service";
|
|
import { VersionService } from "../../platform/services/version.service";
|
|
import { NativeMessagingService } from "../../services/native-messaging.service";
|
|
|
|
@Injectable()
|
|
export class InitService {
|
|
constructor(
|
|
@Inject(WINDOW) private win: Window,
|
|
private syncService: SyncServiceAbstraction,
|
|
private vaultTimeoutService: VaultTimeoutService,
|
|
private i18nService: I18nServiceAbstraction,
|
|
private eventUploadService: EventUploadServiceAbstraction,
|
|
private twoFactorService: TwoFactorServiceAbstraction,
|
|
private notificationsService: NotificationsServiceAbstraction,
|
|
private platformUtilsService: PlatformUtilsServiceAbstraction,
|
|
private stateService: StateServiceAbstraction,
|
|
private keyService: KeyServiceAbstraction,
|
|
private nativeMessagingService: NativeMessagingService,
|
|
private themingService: AbstractThemingService,
|
|
private encryptService: EncryptService,
|
|
private userAutoUnlockKeyService: UserAutoUnlockKeyService,
|
|
private accountService: AccountService,
|
|
private versionService: VersionService,
|
|
private sshAgentService: SshAgentService,
|
|
private autofillService: DesktopAutofillService,
|
|
@Inject(DOCUMENT) private document: Document,
|
|
) {}
|
|
|
|
init() {
|
|
return async () => {
|
|
await this.sshAgentService.init();
|
|
this.nativeMessagingService.init();
|
|
await this.stateService.init({ runMigrations: false }); // Desktop will run them in main process
|
|
|
|
const accounts = await firstValueFrom(this.accountService.accounts$);
|
|
const setUserKeyInMemoryPromises = [];
|
|
for (const userId of Object.keys(accounts) as UserId[]) {
|
|
// For each acct, we must await the process of setting the user key in memory
|
|
// if the auto user key is set to avoid race conditions of any code trying to access
|
|
// the user key from mem.
|
|
setUserKeyInMemoryPromises.push(
|
|
this.userAutoUnlockKeyService.setUserKeyInMemoryIfAutoUserKeySet(userId),
|
|
);
|
|
}
|
|
await Promise.all(setUserKeyInMemoryPromises);
|
|
|
|
// FIXME: Verify that this floating promise is intentional. If it is, add an explanatory comment and ensure there is proper error handling.
|
|
// eslint-disable-next-line @typescript-eslint/no-floating-promises
|
|
this.syncService.fullSync(true);
|
|
await this.vaultTimeoutService.init(true);
|
|
await (this.i18nService as I18nRendererService).init();
|
|
(this.eventUploadService as EventUploadService).init(true);
|
|
this.twoFactorService.init();
|
|
setTimeout(() => this.notificationsService.init(), 3000);
|
|
const htmlEl = this.win.document.documentElement;
|
|
htmlEl.classList.add("os_" + this.platformUtilsService.getDeviceString());
|
|
this.themingService.applyThemeChangesTo(this.document);
|
|
|
|
this.versionService.init();
|
|
|
|
const containerService = new ContainerService(this.keyService, this.encryptService);
|
|
containerService.attachToGlobal(this.win);
|
|
|
|
await this.autofillService.init();
|
|
};
|
|
}
|
|
}
|