mirror of
https://github.com/bitwarden/browser
synced 2025-12-16 16:23:44 +00:00
* [PM-2135] feat: create new user-verification module
* [PM-2136] feat: add ability to remove form field bottom margin
(cherry picked from commit 05925ff77ed47f3865c2aecade8271390d9e2fa6)
* [PM-2135] feat: refactor user-verification component
* [PM-2135] feat: refactor user-verification-prompt
* [PM-2135] feat: use form validation in prompt
* [PM-2135] feat: change autofocus target
* [PM-2135] chore: clean up old code
* [PM-2135] feat: allow user verification to show invalid password error
* [PM-2135] feat: hack mark as touched to get error to display
* [PM-2135] chore: move to auth
* [PM-2135] fix: hardcoded dialog buttons
* [PM-2135] feat: add onDestroy handler
* [PM-2135] fix: remove unecessary directive input
* [PM-2135] feat: add password toggle
* [PM-2135] chore: add hack comment
* [PM-2135] chore: move services to auth folder and rename
* [PM-2135] fix: show correct error messages
* [PM-2135] fix: re-add non-existant files to whitelist
I honestly don't know why the linter is complaining about this
* Fix capital letters whitelist
* [PM-2135] chore: remove rows that were mistakenly added during merge from master
* [PM-2135] chore: remove rows that were mistakenly added during merge from master
* [PM-2135] feat: disable built-in browser validations
* Revert "[PM-2135] feat: disable built-in browser validations"
This reverts commit 969f75822a.
---------
Co-authored-by: Thomas Rittson <trittson@bitwarden.com>
47 lines
1.5 KiB
TypeScript
47 lines
1.5 KiB
TypeScript
import { Component } from "@angular/core";
|
|
|
|
import { UserVerificationService } from "@bitwarden/common/auth/abstractions/user-verification/user-verification.service.abstraction";
|
|
import { SecretVerificationRequest } from "@bitwarden/common/auth/models/request/secret-verification.request";
|
|
import { ApiKeyResponse } from "@bitwarden/common/auth/models/response/api-key.response";
|
|
import { LogService } from "@bitwarden/common/platform/abstractions/log.service";
|
|
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<ApiKeyResponse>;
|
|
entityId: string;
|
|
scope: string;
|
|
grantType: string;
|
|
apiKeyTitle: string;
|
|
apiKeyWarning: string;
|
|
apiKeyDescription: string;
|
|
|
|
masterPassword: Verification;
|
|
formPromise: Promise<ApiKeyResponse>;
|
|
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);
|
|
}
|
|
}
|
|
}
|