mirror of
https://github.com/bitwarden/browser.git
synced 2025-01-02 18:17:46 +01:00
added q promise library. moving cipher service functions out into application services and domain models.
This commit is contained in:
parent
2c44bd5cc8
commit
16a59f8d09
@ -96,6 +96,10 @@ gulp.task('lib', ['clean:lib'], function () {
|
|||||||
{
|
{
|
||||||
src: paths.npmDir + 'clipboard/dist/clipboard.js',
|
src: paths.npmDir + 'clipboard/dist/clipboard.js',
|
||||||
dest: paths.libDir + 'clipboard'
|
dest: paths.libDir + 'clipboard'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
src: paths.npmDir + 'q/q.js',
|
||||||
|
dest: paths.libDir + 'q'
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@
|
|||||||
"ngclipboard": "1.1.1",
|
"ngclipboard": "1.1.1",
|
||||||
"clipboard": "1.5.12",
|
"clipboard": "1.5.12",
|
||||||
"merge-stream": "1.0.0",
|
"merge-stream": "1.0.0",
|
||||||
"angular-toastr": "2.1.1"
|
"angular-toastr": "2.1.1",
|
||||||
|
"q": "1.4.1"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
"lib/sjcl/sjcl.js",
|
"lib/sjcl/sjcl.js",
|
||||||
"lib/sjcl/cbc.js",
|
"lib/sjcl/cbc.js",
|
||||||
"lib/sjcl/bitArray.js",
|
"lib/sjcl/bitArray.js",
|
||||||
|
"lib/q/q.js",
|
||||||
"scripts/tld.js",
|
"scripts/tld.js",
|
||||||
"models/api/requestModels.js",
|
"models/api/requestModels.js",
|
||||||
"models/api/responseModels.js",
|
"models/api/responseModels.js",
|
||||||
|
@ -8,21 +8,6 @@ var CipherString = function (encryptedString) {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
!function () {
|
|
||||||
CipherString.prototype.decrypt = function (callback) {
|
|
||||||
if (!this.decryptedValue) {
|
|
||||||
var cryptoService = chrome.extension.getBackgroundPage().cryptoService;
|
|
||||||
cryptoService.decrypt(this, function (decValue) {
|
|
||||||
this.decryptedValue = decValue;
|
|
||||||
callback(this.decryptedValue);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
callback(this.decryptedValue);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}();
|
|
||||||
|
|
||||||
var Site = function (obj, alreadyEncrypted) {
|
var Site = function (obj, alreadyEncrypted) {
|
||||||
this.id = obj.id ? obj.id : null;
|
this.id = obj.id ? obj.id : null;
|
||||||
this.folderId = obj.folderId ? obj.folderId : null;
|
this.folderId = obj.folderId ? obj.folderId : null;
|
||||||
@ -54,3 +39,75 @@ var Folder = function (obj, alreadyEncrypted) {
|
|||||||
this.name = obj.name ? new CipherString(obj.name) : null;
|
this.name = obj.name ? new CipherString(obj.name) : null;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
!function () {
|
||||||
|
CipherString.prototype.decrypt = function (callback) {
|
||||||
|
if (!this.decryptedValue) {
|
||||||
|
var cryptoService = chrome.extension.getBackgroundPage().cryptoService;
|
||||||
|
cryptoService.decrypt(this, function (decValue) {
|
||||||
|
this.decryptedValue = decValue;
|
||||||
|
callback(this.decryptedValue);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
callback(this.decryptedValue);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
CipherString.prototype.decryptWithPromise = function () {
|
||||||
|
var deferred = Q.defer();
|
||||||
|
|
||||||
|
if (!this) {
|
||||||
|
deferred.resolve(null);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.decrypt(function (decVal) {
|
||||||
|
deferred.resolve(decVal);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
return deferred.promise;
|
||||||
|
}
|
||||||
|
|
||||||
|
Site.prototype.decrypt = function () {
|
||||||
|
var self = this;
|
||||||
|
var model = {
|
||||||
|
id: self.id,
|
||||||
|
folderId: self.folderId,
|
||||||
|
favorite: self.favorite
|
||||||
|
};
|
||||||
|
|
||||||
|
var deferred = Q.defer();
|
||||||
|
|
||||||
|
self.name.decryptWithPromise().then(function (val) {
|
||||||
|
model.name = val;
|
||||||
|
if (self.uri) {
|
||||||
|
return self.uri.decryptWithPromise();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}).then(function (val) {
|
||||||
|
model.uri = val;
|
||||||
|
if (self.username) {
|
||||||
|
return self.username.decryptWithPromise();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}).then(function (val) {
|
||||||
|
model.username = val;
|
||||||
|
if (self.password) {
|
||||||
|
return self.password.decryptWithPromise();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}).then(function (val) {
|
||||||
|
model.password = val;
|
||||||
|
if (self.notes) {
|
||||||
|
return self.notes.decryptWithPromise();
|
||||||
|
}
|
||||||
|
return null;
|
||||||
|
}).then(function (val) {
|
||||||
|
model.notes = val;
|
||||||
|
deferred.resolve(model);
|
||||||
|
});
|
||||||
|
|
||||||
|
return deferred.promise;
|
||||||
|
};
|
||||||
|
}();
|
||||||
|
@ -1,61 +1,15 @@
|
|||||||
angular
|
angular
|
||||||
.module('bit.services')
|
.module('bit.services')
|
||||||
|
|
||||||
.factory('cipherService', function (cryptoService, $q) {
|
.factory('cipherService', function ($q, siteService) {
|
||||||
var _service = {};
|
var _service = {};
|
||||||
|
|
||||||
_service.encryptSite = function (site) {
|
_service.encryptSite = function (site) {
|
||||||
var model = {
|
return $q.when(siteService.encrypt(site));
|
||||||
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);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
_service.decryptSite = function (site) {
|
_service.decryptSite = function (site) {
|
||||||
var model = {
|
return $q.when(site.decrypt());
|
||||||
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);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
};
|
};
|
||||||
|
|
||||||
_service.decrypt = 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;
|
return _service;
|
||||||
});
|
});
|
||||||
|
@ -48,8 +48,6 @@
|
|||||||
$scope.save = function (model) {
|
$scope.save = function (model) {
|
||||||
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
||||||
var site = new Site(siteModel, true);
|
var site = new Site(siteModel, true);
|
||||||
return site;
|
|
||||||
}).then(function (site) {
|
|
||||||
return saveSite(site).then(function (site) {
|
return saveSite(site).then(function (site) {
|
||||||
toastr.success('Added site');
|
toastr.success('Added site');
|
||||||
$scope.close();
|
$scope.close();
|
||||||
|
@ -45,8 +45,6 @@ angular
|
|||||||
$scope.save = function (model) {
|
$scope.save = function (model) {
|
||||||
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
$scope.savePromise = cipherService.encryptSite(model).then(function (siteModel) {
|
||||||
var site = new Site(siteModel, true);
|
var site = new Site(siteModel, true);
|
||||||
return site;
|
|
||||||
}).then(function (site) {
|
|
||||||
return saveSite(site).then(function (site) {
|
return saveSite(site).then(function (site) {
|
||||||
toastr.success('Edited site');
|
toastr.success('Edited site');
|
||||||
$scope.close();
|
$scope.close();
|
||||||
|
@ -7,6 +7,45 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
function initSiteService() {
|
function initSiteService() {
|
||||||
|
SiteService.prototype.encrypt = function (site) {
|
||||||
|
var model = {
|
||||||
|
id: site.id,
|
||||||
|
folderId: site.folderId,
|
||||||
|
favorite: site.favorite
|
||||||
|
};
|
||||||
|
|
||||||
|
var deferred = Q.defer();
|
||||||
|
|
||||||
|
encryptWithPromise(site.name).then(function (cs) {
|
||||||
|
model.name = cs;
|
||||||
|
return encryptWithPromise(site.uri);
|
||||||
|
}).then(function (cs) {
|
||||||
|
model.uri = cs;
|
||||||
|
return encryptWithPromise(site.username);
|
||||||
|
}).then(function (cs) {
|
||||||
|
model.username = cs;
|
||||||
|
return encryptWithPromise(site.password);
|
||||||
|
}).then(function (cs) {
|
||||||
|
model.password = cs;
|
||||||
|
return encryptWithPromise(site.notes);
|
||||||
|
}).then(function (cs) {
|
||||||
|
model.notes = cs;
|
||||||
|
deferred.resolve(model);
|
||||||
|
});
|
||||||
|
|
||||||
|
return deferred.promise;
|
||||||
|
};
|
||||||
|
|
||||||
|
function encryptWithPromise(plaintextString) {
|
||||||
|
var deferred = Q.defer();
|
||||||
|
|
||||||
|
cryptoService.encrypt(plaintextString, function (cipherString) {
|
||||||
|
deferred.resolve(cipherString);
|
||||||
|
});
|
||||||
|
|
||||||
|
return deferred.promise;
|
||||||
|
}
|
||||||
|
|
||||||
SiteService.prototype.get = function (id, callback) {
|
SiteService.prototype.get = function (id, callback) {
|
||||||
if (!callback || typeof callback !== 'function') {
|
if (!callback || typeof callback !== 'function') {
|
||||||
throw 'callback function required';
|
throw 'callback function required';
|
||||||
|
Loading…
Reference in New Issue
Block a user