bitwarden-estensione-browser/src/popup/app/services/loginService.js

90 lines
3.6 KiB
JavaScript
Raw Normal View History

2016-09-03 06:03:13 +02:00
angular
.module('bit.services')
.factory('loginService', function (cryptoService, apiService, userService, tokenService, $q, $rootScope, siteService,
folderService) {
2016-09-03 06:03:13 +02:00
var _service = {};
_service.logIn = function (email, masterPassword) {
2016-09-21 05:30:16 +02:00
email = email.toLowerCase();
2016-09-03 06:03:13 +02:00
var key = cryptoService.makeKey(masterPassword, email);
var deferred = $q.defer();
2016-09-05 06:03:49 +02:00
cryptoService.hashPassword(masterPassword, key, function (hashedPassword) {
var request = new TokenRequest(email, hashedPassword);
2016-09-03 06:03:13 +02:00
2016-09-05 06:03:49 +02:00
apiService.postToken(request, function (response) {
if (!response || !response.token) {
return;
}
2016-09-03 06:03:13 +02:00
2016-09-05 06:03:49 +02:00
tokenService.setToken(response.token, function () {
cryptoService.setKey(key, function () {
2016-09-21 05:30:16 +02:00
if (response.profile) {
userService.setUserId(response.profile.id, function () {
userService.setEmail(response.profile.email, function () {
chrome.runtime.sendMessage({ command: 'loggedIn' });
2016-09-21 05:30:16 +02:00
deferred.resolve(response);
});
});
}
else {
2016-09-05 06:03:49 +02:00
deferred.resolve(response);
2016-09-21 05:30:16 +02:00
}
2016-09-03 06:03:13 +02:00
});
});
2016-09-05 06:03:49 +02:00
}, function (error) {
deferred.reject(error);
2016-09-03 06:03:13 +02:00
});
2016-09-05 06:03:49 +02:00
});
return deferred.promise;
2016-09-03 06:03:13 +02:00
};
2016-09-21 05:30:16 +02:00
_service.logInTwoFactor = function (code) {
var request = new TokenTwoFactorRequest(code);
2016-09-03 06:03:13 +02:00
var deferred = $q.defer();
2016-09-21 17:35:24 +02:00
apiService.postTokenTwoFactor(request, function (response) {
2016-09-21 05:30:16 +02:00
if (!response || !response.token) {
deferred.reject();
2016-09-03 06:03:13 +02:00
return;
}
2016-09-21 05:30:16 +02:00
tokenService.setToken(response.token, function () {
userService.setUserId(response.profile.id, function () {
userService.setEmail(response.profile.email, function () {
chrome.runtime.sendMessage({ command: 'loggedIn' });
2016-09-21 05:30:16 +02:00
deferred.resolve(response);
});
2016-09-03 06:03:13 +02:00
});
});
}, function (error) {
deferred.reject(error);
});
return deferred.promise;
};
_service.logOut = function (callback) {
userService.getUserId(function (userId) {
tokenService.clearToken(function () {
cryptoService.clearKey(function () {
userService.clearUserId(function () {
userService.clearEmail(function () {
siteService.clear(userId, function () {
folderService.clear(userId, function () {
$rootScope.vaultSites = null;
$rootScope.vaultFolders = null;
chrome.runtime.sendMessage({ command: 'loggedOut' });
callback();
});
});
});
2016-09-21 05:30:16 +02:00
});
});
2016-09-03 06:03:13 +02:00
});
});
};
return _service;
});