1
0
mirror of https://github.com/bitwarden/browser.git synced 2024-10-10 06:08:34 +02:00
bitwarden-browser/src/app/settings/settingsTwoFactorController.js

89 lines
3.5 KiB
JavaScript
Raw Normal View History

2015-12-09 04:35:05 +01:00
angular
.module('bit.settings')
.controller('settingsTwoFactorController', function ($scope, apiService, $uibModalInstance, cryptoService, authService, $q, toastr, $analytics) {
$analytics.eventTrack('settingsTwoFactorController', { category: 'Modal' });
2015-12-09 04:35:05 +01:00
var _issuer = 'bitwarden',
_profile = authService.getUserProfile(),
_masterPasswordHash;
$scope.account = _profile.email;
$scope.enabled = function () {
return _profile.extended && _profile.extended.twoFactorEnabled;
};
2015-12-09 04:35:05 +01:00
$scope.auth = function (model) {
_masterPasswordHash = cryptoService.hashPassword(model.masterPassword);
$scope.authPromise = apiService.accounts.getTwoFactor({
masterPasswordHash: _masterPasswordHash,
provider: 0 /* Only authenticator provider for now. */
}, function (response) {
2016-12-01 05:22:25 +01:00
processResponse(response);
2015-12-09 04:35:05 +01:00
}).$promise;
};
function formatString(s) {
2016-11-15 04:45:01 +01:00
if (!s) {
return null;
}
return s.replace(/(.{4})/g, '$1 ').trim().toUpperCase();
}
2016-12-01 05:22:25 +01:00
function processResponse(response) {
var key = response.AuthenticatorKey;
$scope.twoFactorModel = {
enabled: response.TwoFactorEnabled,
key: formatString(key),
recovery: formatString(response.TwoFactorRecoveryCode),
qr: 'https://chart.googleapis.com/chart?chs=120x120&chld=L|0&cht=qr&chl=otpauth://totp/' +
_issuer + ':' + encodeURIComponent(_profile.email) +
'%3Fsecret=' + encodeURIComponent(key) +
'%26issuer=' + _issuer
};
}
2015-12-09 04:35:05 +01:00
$scope.update = function (model) {
var currentlyEnabled = $scope.twoFactorModel.enabled;
if (currentlyEnabled && !confirm('Are you sure you want to disable two-step login?')) {
return;
}
var request = {
enabled: !currentlyEnabled,
2016-12-01 05:22:25 +01:00
token: model.token.replace(' ', ''),
masterPasswordHash: _masterPasswordHash
2015-12-09 04:35:05 +01:00
};
$scope.updatePromise = apiService.accounts.putTwoFactor({}, request, function (response) {
if (response.TwoFactorEnabled) {
$analytics.eventTrack('Enabled Two-step Login');
2015-12-09 04:35:05 +01:00
toastr.success('Two-step login has been enabled.');
if (_profile.extended) _profile.extended.twoFactorEnabled = true;
2016-12-01 05:22:25 +01:00
processResponse(response);
$('#token').blur();
model.token = null;
2015-12-09 04:35:05 +01:00
}
else {
$analytics.eventTrack('Disabled Two-step Login');
2015-12-09 04:35:05 +01:00
toastr.success('Two-step login has been disabled.');
if (_profile.extended) _profile.extended.twoFactorEnabled = false;
2016-12-01 05:22:25 +01:00
$scope.close();
2015-12-09 04:35:05 +01:00
}
}).$promise;
};
$scope.print = function (printContent) {
var w = window.open();
w.document.write('<div style="font-size: 18px; text-align: center;"><p>bitwarden two-step login recovery code:</p>' +
'<pre>' + printContent + '</pre>');
w.print();
w.close();
2017-02-12 00:22:13 +01:00
};
2015-12-09 04:35:05 +01:00
$scope.close = function () {
2017-02-11 23:08:06 +01:00
$uibModalInstance.close(!_profile.extended ? null : _profile.extended.twoFactorEnabled);
2015-12-09 04:35:05 +01:00
};
});