mirror of
https://github.com/bitwarden/browser
synced 2025-12-17 16:53:34 +00:00
added q promise library. moving cipher service functions out into application services and domain models.
This commit is contained in:
@@ -1,61 +1,15 @@
|
||||
angular
|
||||
.module('bit.services')
|
||||
|
||||
.factory('cipherService', function (cryptoService, $q) {
|
||||
.factory('cipherService', function ($q, siteService) {
|
||||
var _service = {};
|
||||
|
||||
_service.encryptSite = function (site) {
|
||||
var model = {
|
||||
id: site.id,
|
||||
folderId: site.folderId,
|
||||
favorite: site.favorite
|
||||
};
|
||||
|
||||
return $q(function (resolve, reject) {
|
||||
encrypt(site.name).then(function (cs) {
|
||||
model.name = cs;
|
||||
return encrypt(site.uri);
|
||||
}).then(function (cs) {
|
||||
model.uri = cs;
|
||||
return encrypt(site.username);
|
||||
}).then(function (cs) {
|
||||
model.username = cs;
|
||||
return encrypt(site.password);
|
||||
}).then(function (cs) {
|
||||
model.password = cs;
|
||||
return encrypt(site.notes);
|
||||
}).then(function (cs) {
|
||||
model.notes = cs;
|
||||
resolve(model);
|
||||
});
|
||||
});
|
||||
return $q.when(siteService.encrypt(site));
|
||||
};
|
||||
|
||||
_service.decryptSite = function (site) {
|
||||
var model = {
|
||||
id: site.id,
|
||||
folderId: site.folderId,
|
||||
favorite: site.favorite
|
||||
};
|
||||
|
||||
return $q(function (resolve, reject) {
|
||||
decrypt(site.name).then(function (obj) {
|
||||
model.name = obj.val;
|
||||
return decrypt(site.uri);
|
||||
}).then(function (obj) {
|
||||
model.uri = obj.val;
|
||||
return decrypt(site.username);
|
||||
}).then(function (obj) {
|
||||
model.username = obj.val;
|
||||
return decrypt(site.password);
|
||||
}).then(function (obj) {
|
||||
model.password = obj.val;
|
||||
return decrypt(site.notes);
|
||||
}).then(function (obj) {
|
||||
model.notes = obj.val;
|
||||
resolve(model);
|
||||
});
|
||||
});
|
||||
return $q.when(site.decrypt());
|
||||
};
|
||||
|
||||
_service.decrypt = decrypt;
|
||||
@@ -79,13 +33,5 @@
|
||||
});
|
||||
}
|
||||
|
||||
function encrypt(plaintextString) {
|
||||
return $q(function (resolve, reject) {
|
||||
cryptoService.encrypt(plaintextString, function (cipherString) {
|
||||
resolve(cipherString);
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
return _service;
|
||||
});
|
||||
|
||||
@@ -48,8 +48,6 @@
|
||||
$scope.save = function (model) {
|
||||
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
||||
var site = new Site(siteModel, true);
|
||||
return site;
|
||||
}).then(function (site) {
|
||||
return saveSite(site).then(function (site) {
|
||||
toastr.success('Added site');
|
||||
$scope.close();
|
||||
|
||||
@@ -45,8 +45,6 @@ angular
|
||||
$scope.save = function (model) {
|
||||
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
||||
var site = new Site(siteModel, true);
|
||||
return site;
|
||||
}).then(function (site) {
|
||||
return saveSite(site).then(function (site) {
|
||||
toastr.success('Edited site');
|
||||
$scope.close();
|
||||
|
||||
Reference in New Issue
Block a user