1
0
mirror of https://github.com/bitwarden/browser.git synced 2024-10-09 05:57:40 +02:00
bitwarden-browser/src/app/settings/deauthorize-sessions.component.ts

39 lines
1.5 KiB
TypeScript
Raw Normal View History

import { Component } from '@angular/core';
2018-06-21 23:14:36 +02:00
import { ToasterService } from 'angular2-toaster';
import { ApiService } from 'jslib-common/abstractions/api.service';
import { I18nService } from 'jslib-common/abstractions/i18n.service';
import { LogService } from 'jslib-common/abstractions/log.service';
import { MessagingService } from 'jslib-common/abstractions/messaging.service';
import { UserVerificationService } from 'jslib-common/abstractions/userVerification.service';
2018-06-21 23:14:36 +02:00
import { Verification } from 'jslib-common/types/verification';
2018-06-21 23:14:36 +02:00
@Component({
selector: 'app-deauthorize-sessions',
templateUrl: 'deauthorize-sessions.component.html',
})
export class DeauthorizeSessionsComponent {
masterPassword: Verification;
2018-06-21 23:14:36 +02:00
formPromise: Promise<any>;
constructor(private apiService: ApiService, private i18nService: I18nService,
private toasterService: ToasterService, private userVerificationService: UserVerificationService,
private messagingService: MessagingService, private logService: LogService) { }
2018-06-21 23:14:36 +02:00
async submit() {
const request = await this.userVerificationService.buildRequest(this.masterPassword);
2018-06-21 23:14:36 +02:00
try {
this.formPromise = this.apiService.postSecurityStamp(request);
await this.formPromise;
this.toasterService.popAsync('success', this.i18nService.t('sessionsDeauthorized'),
this.i18nService.t('logBackIn'));
this.messagingService.send('logout');
} catch (e) {
this.logService.error(e);
}
2018-06-21 23:14:36 +02:00
}
}