mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-06 18:57:56 +01:00
changed breach report to allow username entry
This commit is contained in:
parent
dec6b17aa4
commit
15d6e4937f
2
jslib
2
jslib
@ -1 +1 @@
|
|||||||
Subproject commit 93edd272dde1d0d5739c29a57668849fb445eee3
|
Subproject commit e297f39bd53db6939bc888e5aa1c41ff8579b19d
|
@ -2,15 +2,27 @@
|
|||||||
<h1>{{'dataBreachReport' | i18n}}</h1>
|
<h1>{{'dataBreachReport' | i18n}}</h1>
|
||||||
</div>
|
</div>
|
||||||
<p>{{'breachDesc' | i18n}}</p>
|
<p>{{'breachDesc' | i18n}}</p>
|
||||||
<i class="fa fa-spinner fa-spin text-muted" *ngIf="loading"></i>
|
<form #form (ngSubmit)="submit()" [appApiAction]="formPromise" ngNativeValidate>
|
||||||
<ng-container *ngIf="!loading">
|
<div class="row">
|
||||||
|
<div class="form-group col-6">
|
||||||
|
<label for="username">{{'username' | i18n}}</label>
|
||||||
|
<input id="username" type="text" name="Username" class="form-control" [(ngModel)]="username" required>
|
||||||
|
<small class="form-text text-muted">{{'breachCheckUsernameEmail' | i18n}}</small>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<button appBlurClick type="submit" class="btn btn-primary btn-submit" [disabled]="form.loading">
|
||||||
|
<i class="fa fa-spinner fa-spin"></i>
|
||||||
|
<span>{{'checkBreaches' | i18n}}</span>
|
||||||
|
</button>
|
||||||
|
</form>
|
||||||
|
<div class="mt-4" *ngIf="!form.loading && checkedUsername">
|
||||||
<p *ngIf="error">{{'reportError' | i18n}}...</p>
|
<p *ngIf="error">{{'reportError' | i18n}}...</p>
|
||||||
<ng-container *ngIf="!error">
|
<ng-container *ngIf="!error">
|
||||||
<app-callout type="success" title="{{'goodNews' | i18n}}" *ngIf="!breachedAccounts.length">
|
<app-callout type="success" title="{{'goodNews' | i18n}}" *ngIf="!breachedAccounts.length">
|
||||||
{{'breachEmailNotFound' | i18n : email}}
|
{{'breachUsernameNotFound' | i18n : checkedUsername}}
|
||||||
</app-callout>
|
</app-callout>
|
||||||
<app-callout type="danger" title="{{'breachFound' | i18n}}" *ngIf="breachedAccounts.length">
|
<app-callout type="danger" title="{{'breachFound' | i18n}}" *ngIf="breachedAccounts.length">
|
||||||
{{'breachEmailFound' | i18n : email : breachedAccounts.length}}
|
{{'breachUsernameFound' | i18n : checkedUsername : breachedAccounts.length}}
|
||||||
</app-callout>
|
</app-callout>
|
||||||
<ul class="list-group list-group-breach" *ngIf="breachedAccounts.length">
|
<ul class="list-group list-group-breach" *ngIf="breachedAccounts.length">
|
||||||
<li *ngFor="let a of breachedAccounts" class="list-group-item d-flex align-items-center">
|
<li *ngFor="let a of breachedAccounts" class="list-group-item d-flex align-items-center">
|
||||||
@ -42,4 +54,4 @@
|
|||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</ng-container>
|
</ng-container>
|
||||||
</ng-container>
|
</div>
|
||||||
|
@ -12,21 +12,27 @@ import { BreachAccountResponse } from 'jslib/models/response/breachAccountRespon
|
|||||||
templateUrl: 'breach-report.component.html',
|
templateUrl: 'breach-report.component.html',
|
||||||
})
|
})
|
||||||
export class BreachReportComponent implements OnInit {
|
export class BreachReportComponent implements OnInit {
|
||||||
loading = true;
|
|
||||||
error = false;
|
error = false;
|
||||||
email: string;
|
username: string;
|
||||||
|
checkedUsername: string;
|
||||||
breachedAccounts: BreachAccountResponse[] = [];
|
breachedAccounts: BreachAccountResponse[] = [];
|
||||||
|
formPromise: Promise<BreachAccountResponse[]>;
|
||||||
|
|
||||||
constructor(private auditService: AuditService, private userService: UserService) { }
|
constructor(private auditService: AuditService, private userService: UserService) { }
|
||||||
|
|
||||||
async ngOnInit() {
|
async ngOnInit() {
|
||||||
this.loading = true;
|
this.username = await this.userService.getEmail();
|
||||||
|
}
|
||||||
|
|
||||||
|
async submit() {
|
||||||
|
this.error = false;
|
||||||
|
this.username = this.username.toLowerCase();
|
||||||
try {
|
try {
|
||||||
this.email = await this.userService.getEmail();
|
this.formPromise = this.auditService.breachedAccounts(this.username);
|
||||||
this.breachedAccounts = await this.auditService.breachedAccounts(this.email);
|
this.breachedAccounts = await this.formPromise;
|
||||||
} catch {
|
} catch {
|
||||||
this.error = true;
|
this.error = true;
|
||||||
}
|
}
|
||||||
this.loading = false;
|
this.checkedUsername = this.username;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1148,10 +1148,16 @@
|
|||||||
"breachDesc": {
|
"breachDesc": {
|
||||||
"message": "A \"breach\" is an incident where a site's data has been illegally accessed by hackers and then released publicly. Review the types of data that were compromised (email addresses, passwords, credit cards etc.) and take appropriate action, such as changing passwords."
|
"message": "A \"breach\" is an incident where a site's data has been illegally accessed by hackers and then released publicly. Review the types of data that were compromised (email addresses, passwords, credit cards etc.) and take appropriate action, such as changing passwords."
|
||||||
},
|
},
|
||||||
"breachEmailNotFound": {
|
"breachCheckUsernameEmail": {
|
||||||
"message": "Your email ($EMAIL$) was not found in any known data breaches.",
|
"message": "Check any usernames or email addresses that you use."
|
||||||
|
},
|
||||||
|
"checkBreaches": {
|
||||||
|
"message": "Check Breaches"
|
||||||
|
},
|
||||||
|
"breachUsernameNotFound": {
|
||||||
|
"message": "$USERNAME$ was not found in any known data breaches.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"email": {
|
"username": {
|
||||||
"content": "$1",
|
"content": "$1",
|
||||||
"example": "user@example.com"
|
"example": "user@example.com"
|
||||||
}
|
}
|
||||||
@ -1161,10 +1167,10 @@
|
|||||||
"message": "Good News",
|
"message": "Good News",
|
||||||
"description": "ex. Good News, No Breached Accounts Found!"
|
"description": "ex. Good News, No Breached Accounts Found!"
|
||||||
},
|
},
|
||||||
"breachEmailFound": {
|
"breachUsernameFound": {
|
||||||
"message": "Your email ($EMAIL$) was found in $COUNT$ different data breaches online.",
|
"message": "$USERNAME$ was found in $COUNT$ different data breaches online.",
|
||||||
"placeholders": {
|
"placeholders": {
|
||||||
"email": {
|
"username": {
|
||||||
"content": "$1",
|
"content": "$1",
|
||||||
"example": "user@example.com"
|
"example": "user@example.com"
|
||||||
},
|
},
|
||||||
|
Loading…
Reference in New Issue
Block a user