1
0
mirror of https://github.com/bitwarden/browser.git synced 2025-01-04 18:37:45 +01:00

changed breach report to allow username entry

This commit is contained in:
Kyle Spearrin 2018-06-29 08:21:08 -04:00
parent dec6b17aa4
commit 15d6e4937f
4 changed files with 42 additions and 18 deletions

2
jslib

@ -1 +1 @@
Subproject commit 93edd272dde1d0d5739c29a57668849fb445eee3 Subproject commit e297f39bd53db6939bc888e5aa1c41ff8579b19d

View File

@ -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>

View File

@ -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;
} }
} }

View File

@ -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"
}, },