mail/src/js/controller/login/login-existing.js

66 lines
1.6 KiB
JavaScript
Raw Normal View History

2014-10-02 16:05:44 -04:00
'use strict';
2013-10-21 07:10:42 -04:00
2014-10-02 16:05:44 -04:00
var appController = require('../app-controller');
2013-10-21 07:10:42 -04:00
2014-10-02 16:05:44 -04:00
var LoginExistingCtrl = function($scope, $location, $routeParams) {
if (!appController._emailDao && !$routeParams.dev) {
$location.path('/'); // init app
return;
}
2014-10-02 16:05:44 -04:00
var emailDao = appController._emailDao;
2013-11-04 08:20:14 -05:00
2014-10-02 16:05:44 -04:00
$scope.confirmPassphrase = function() {
if ($scope.form.$invalid) {
$scope.errMsg = 'Please fill out all required fields!';
2014-10-02 16:05:44 -04:00
return;
}
$scope.busy = true;
$scope.errMsg = undefined;
2014-10-02 16:05:44 -04:00
$scope.incorrect = false;
2014-10-02 16:05:44 -04:00
unlockCrypto();
};
2014-10-02 16:05:44 -04:00
function unlockCrypto() {
var userId = emailDao._account.emailAddress;
emailDao._keychain.getUserKeyPair(userId, function(err, keypair) {
if (err) {
displayError(err);
2013-10-21 07:10:42 -04:00
return;
}
2014-10-02 16:05:44 -04:00
emailDao.unlock({
keypair: keypair,
passphrase: $scope.passphrase
}, onUnlock);
});
}
2014-10-02 16:05:44 -04:00
function onUnlock(err) {
if (err) {
displayError(err);
2014-10-02 16:05:44 -04:00
return;
2013-11-04 08:20:14 -05:00
}
2013-10-21 07:10:42 -04:00
2014-10-02 16:05:44 -04:00
appController._auth.storeCredentials(function(err) {
2013-11-04 08:20:14 -05:00
if (err) {
displayError(err);
return;
2013-10-21 07:10:42 -04:00
}
2013-11-04 08:20:14 -05:00
2014-10-02 16:05:44 -04:00
$location.path('/desktop');
$scope.$apply();
});
}
2013-10-21 07:10:42 -04:00
function displayError(err) {
$scope.busy = false;
2014-10-02 16:05:44 -04:00
$scope.incorrect = true;
$scope.errMsg = err.errMsg || err.message;
$scope.$apply();
2014-10-02 16:05:44 -04:00
}
};
2013-10-21 07:10:42 -04:00
2014-10-08 06:34:34 -04:00
module.exports = LoginExistingCtrl;