mirror of
https://github.com/bitwarden/browser.git
synced 2025-04-04 18:27:12 +02:00
[SG-997] Add warning for low kdf iterations (#4570)
* Created low kdf component * added low kdf transalation message * Registered commponent * Referenced low kdf child compoenent to vault * Added showLowKdf variable to determine if card should be shown * Removed test flag * Updated renamed enum * Capitalized kdf text
This commit is contained in:
parent
c6c81c3a60
commit
f274540896
17
apps/web/src/app/settings/low-kdf.component.html
Normal file
17
apps/web/src/app/settings/low-kdf.component.html
Normal file
@ -0,0 +1,17 @@
|
|||||||
|
<div class="tw-rounded tw-border tw-border-solid tw-border-warning-500 tw-bg-background">
|
||||||
|
<div class="tw-bg-warning-500 tw-px-5 tw-py-2.5 tw-font-bold tw-uppercase tw-text-contrast">
|
||||||
|
<i class="bwi bwi-exclamation-triangle bwi-fw" aria-hidden="true"></i>
|
||||||
|
{{ "lowKdfIterations" | i18n }}
|
||||||
|
</div>
|
||||||
|
<div class="tw-p-5">
|
||||||
|
<p>{{ "lowKdfIterationsDesc" | i18n }}</p>
|
||||||
|
<a
|
||||||
|
bitButton
|
||||||
|
buttonType="secondary"
|
||||||
|
[block]="true"
|
||||||
|
routerLink="/settings/security/security-keys"
|
||||||
|
>
|
||||||
|
{{ "changeKdfSettings" | i18n }}
|
||||||
|
</a>
|
||||||
|
</div>
|
||||||
|
</div>
|
7
apps/web/src/app/settings/low-kdf.component.ts
Normal file
7
apps/web/src/app/settings/low-kdf.component.ts
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
import { Component } from "@angular/core";
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: "app-low-kdf",
|
||||||
|
templateUrl: "low-kdf.component.html",
|
||||||
|
})
|
||||||
|
export class LowKdfComponent {}
|
@ -74,6 +74,7 @@ import { EmergencyAccessTakeoverComponent } from "../settings/emergency-access-t
|
|||||||
import { EmergencyAccessViewComponent } from "../settings/emergency-access-view.component";
|
import { EmergencyAccessViewComponent } from "../settings/emergency-access-view.component";
|
||||||
import { EmergencyAccessComponent } from "../settings/emergency-access.component";
|
import { EmergencyAccessComponent } from "../settings/emergency-access.component";
|
||||||
import { EmergencyAddEditComponent } from "../settings/emergency-add-edit.component";
|
import { EmergencyAddEditComponent } from "../settings/emergency-add-edit.component";
|
||||||
|
import { LowKdfComponent } from "../settings/low-kdf.component";
|
||||||
import { OrganizationPlansComponent } from "../settings/organization-plans.component";
|
import { OrganizationPlansComponent } from "../settings/organization-plans.component";
|
||||||
import { PaymentMethodComponent } from "../settings/payment-method.component";
|
import { PaymentMethodComponent } from "../settings/payment-method.component";
|
||||||
import { PaymentComponent } from "../settings/payment.component";
|
import { PaymentComponent } from "../settings/payment.component";
|
||||||
@ -227,6 +228,7 @@ import { SharedModule } from "./shared.module";
|
|||||||
VerifyEmailComponent,
|
VerifyEmailComponent,
|
||||||
VerifyEmailTokenComponent,
|
VerifyEmailTokenComponent,
|
||||||
VerifyRecoverDeleteComponent,
|
VerifyRecoverDeleteComponent,
|
||||||
|
LowKdfComponent,
|
||||||
],
|
],
|
||||||
exports: [
|
exports: [
|
||||||
PremiumBadgeComponent,
|
PremiumBadgeComponent,
|
||||||
@ -335,6 +337,7 @@ import { SharedModule } from "./shared.module";
|
|||||||
VerifyEmailComponent,
|
VerifyEmailComponent,
|
||||||
VerifyEmailTokenComponent,
|
VerifyEmailTokenComponent,
|
||||||
VerifyRecoverDeleteComponent,
|
VerifyRecoverDeleteComponent,
|
||||||
|
LowKdfComponent,
|
||||||
],
|
],
|
||||||
})
|
})
|
||||||
export class LooseComponentsModule {}
|
export class LooseComponentsModule {}
|
||||||
|
@ -83,6 +83,7 @@
|
|||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
<app-low-kdf *ngIf="showLowKdf"></app-low-kdf>
|
||||||
<app-verify-email
|
<app-verify-email
|
||||||
*ngIf="showVerifyEmail"
|
*ngIf="showVerifyEmail"
|
||||||
class="d-block mb-4"
|
class="d-block mb-4"
|
||||||
|
@ -23,6 +23,7 @@ import { PlatformUtilsService } from "@bitwarden/common/abstractions/platformUti
|
|||||||
import { StateService } from "@bitwarden/common/abstractions/state.service";
|
import { StateService } from "@bitwarden/common/abstractions/state.service";
|
||||||
import { SyncService } from "@bitwarden/common/abstractions/sync/sync.service.abstraction";
|
import { SyncService } from "@bitwarden/common/abstractions/sync/sync.service.abstraction";
|
||||||
import { TokenService } from "@bitwarden/common/abstractions/token.service";
|
import { TokenService } from "@bitwarden/common/abstractions/token.service";
|
||||||
|
import { DEFAULT_PBKDF2_ITERATIONS } from "@bitwarden/common/enums/kdfType";
|
||||||
import { ServiceUtils } from "@bitwarden/common/misc/serviceUtils";
|
import { ServiceUtils } from "@bitwarden/common/misc/serviceUtils";
|
||||||
import { TreeNode } from "@bitwarden/common/models/domain/tree-node";
|
import { TreeNode } from "@bitwarden/common/models/domain/tree-node";
|
||||||
import { CipherView } from "@bitwarden/common/models/view/cipher.view";
|
import { CipherView } from "@bitwarden/common/models/view/cipher.view";
|
||||||
@ -69,7 +70,9 @@ export class VaultComponent implements OnInit, OnDestroy {
|
|||||||
showBrowserOutdated = false;
|
showBrowserOutdated = false;
|
||||||
showUpdateKey = false;
|
showUpdateKey = false;
|
||||||
showPremiumCallout = false;
|
showPremiumCallout = false;
|
||||||
|
showLowKdf = false;
|
||||||
trashCleanupWarning: string = null;
|
trashCleanupWarning: string = null;
|
||||||
|
kdfIterations: number;
|
||||||
activeFilter: VaultFilter = new VaultFilter();
|
activeFilter: VaultFilter = new VaultFilter();
|
||||||
private destroy$ = new Subject<void>();
|
private destroy$ = new Subject<void>();
|
||||||
|
|
||||||
@ -96,6 +99,7 @@ export class VaultComponent implements OnInit, OnDestroy {
|
|||||||
async ngOnInit() {
|
async ngOnInit() {
|
||||||
this.showVerifyEmail = !(await this.tokenService.getEmailVerified());
|
this.showVerifyEmail = !(await this.tokenService.getEmailVerified());
|
||||||
this.showBrowserOutdated = window.navigator.userAgent.indexOf("MSIE") !== -1;
|
this.showBrowserOutdated = window.navigator.userAgent.indexOf("MSIE") !== -1;
|
||||||
|
this.showLowKdf = await this.isLowKdfIteration();
|
||||||
this.trashCleanupWarning = this.i18nService.t(
|
this.trashCleanupWarning = this.i18nService.t(
|
||||||
this.platformUtilsService.isSelfHost()
|
this.platformUtilsService.isSelfHost()
|
||||||
? "trashCleanupWarningSelfHosted"
|
? "trashCleanupWarningSelfHosted"
|
||||||
@ -388,6 +392,12 @@ export class VaultComponent implements OnInit, OnDestroy {
|
|||||||
await this.modalService.openViewRef(UpdateKeyComponent, this.updateKeyModalRef);
|
await this.modalService.openViewRef(UpdateKeyComponent, this.updateKeyModalRef);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async isLowKdfIteration() {
|
||||||
|
const kdfIterations = await this.stateService.getKdfIterations();
|
||||||
|
|
||||||
|
return kdfIterations < DEFAULT_PBKDF2_ITERATIONS;
|
||||||
|
}
|
||||||
|
|
||||||
get breadcrumbs(): TreeNode<CollectionFilter>[] {
|
get breadcrumbs(): TreeNode<CollectionFilter>[] {
|
||||||
if (!this.activeFilter.selectedCollectionNode) {
|
if (!this.activeFilter.selectedCollectionNode) {
|
||||||
return [];
|
return [];
|
||||||
|
@ -6082,5 +6082,14 @@
|
|||||||
"example": "2"
|
"example": "2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
},
|
||||||
|
"lowKdfIterations": {
|
||||||
|
"message": "Low KDF Iterations"
|
||||||
|
},
|
||||||
|
"lowKdfIterationsDesc": {
|
||||||
|
"message": "Increase your KDF encryption settings to improve the security of your account."
|
||||||
|
},
|
||||||
|
"changeKdfSettings": {
|
||||||
|
"message": "Change KDF settings"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user