import { Component } from "@angular/core"; import { LogService } from "@bitwarden/common/abstractions/log.service"; import { UserVerificationService } from "@bitwarden/common/abstractions/userVerification.service"; import { SecretVerificationRequest } from "@bitwarden/common/models/request/secretVerificationRequest"; import { ApiKeyResponse } from "@bitwarden/common/models/response/apiKeyResponse"; import { Verification } from "@bitwarden/common/types/verification"; @Component({ selector: "app-api-key", templateUrl: "api-key.component.html", }) export class ApiKeyComponent { keyType: string; isRotation: boolean; postKey: (entityId: string, request: SecretVerificationRequest) => Promise; entityId: string; scope: string; grantType: string; apiKeyTitle: string; apiKeyWarning: string; apiKeyDescription: string; masterPassword: Verification; formPromise: Promise; clientId: string; clientSecret: string; constructor( private userVerificationService: UserVerificationService, private logService: LogService ) {} async submit() { try { this.formPromise = this.userVerificationService .buildRequest(this.masterPassword) .then((request) => this.postKey(this.entityId, request)); const response = await this.formPromise; this.clientSecret = response.apiKey; this.clientId = `${this.keyType}.${this.entityId}`; } catch (e) { this.logService.error(e); } } }