2016-09-23 18:03:37 +08:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngdoc service
|
|
|
|
* @name passmanApp.ShareService
|
|
|
|
* @description
|
|
|
|
* # ShareService
|
|
|
|
* Service in the passmanApp.
|
|
|
|
*/
|
|
|
|
angular.module('passmanApp')
|
2016-09-26 04:02:58 +08:00
|
|
|
.service('ShareService', ['$http', 'VaultService', 'EncryptService', function ($http, VaultService, EncryptService) {
|
2016-09-26 20:23:31 +08:00
|
|
|
// Setup sjcl random engine to max paranoia level and start collecting data
|
|
|
|
var paranoia_level = 10
|
|
|
|
sjcl.random.setDefaultParanoia(paranoia_level);
|
|
|
|
sjcl.random.startCollectors();
|
|
|
|
|
2016-09-23 18:03:37 +08:00
|
|
|
return {
|
|
|
|
search: function (string) {
|
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/sharing/search');
|
|
|
|
return $http.post(queryUrl, {search: string}).then(function (response) {
|
|
|
|
if (response.data) {
|
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
2016-09-25 23:46:55 +08:00
|
|
|
},
|
2016-09-26 00:42:41 +08:00
|
|
|
generateRSAKeys: function(key_length, progress, callback){
|
2016-09-26 23:05:47 +08:00
|
|
|
var p = new C_Promise(function(){
|
2016-09-26 20:23:31 +08:00
|
|
|
var state = forge.pki.rsa.createKeyPairGenerationState(key_length, 0x10001);
|
|
|
|
var step = function() {
|
|
|
|
// run for 100 ms
|
|
|
|
if(!forge.pki.rsa.stepKeyPairGenerationState(state, 100)) {
|
|
|
|
// console.log(state);
|
|
|
|
if (state.p !== null) {
|
|
|
|
// progress(50);
|
2016-09-26 23:05:47 +08:00
|
|
|
this.call_progress(50);
|
2016-09-26 20:23:31 +08:00
|
|
|
}
|
|
|
|
else {
|
|
|
|
// progress(0);
|
2016-09-26 23:05:47 +08:00
|
|
|
this.call_progress(0);
|
2016-09-26 20:23:31 +08:00
|
|
|
}
|
2016-09-26 23:05:47 +08:00
|
|
|
setTimeout(step.bind(this), 1);
|
2016-09-26 02:19:58 +08:00
|
|
|
}
|
|
|
|
else {
|
2016-09-26 20:23:31 +08:00
|
|
|
// callback(state.keys);
|
2016-09-26 23:05:47 +08:00
|
|
|
this.call_then(state.keys);
|
2016-09-26 02:19:58 +08:00
|
|
|
}
|
2016-09-26 20:23:31 +08:00
|
|
|
};
|
2016-09-26 23:05:47 +08:00
|
|
|
setTimeout(step.bind(this), 100);
|
2016-09-26 20:23:31 +08:00
|
|
|
});
|
|
|
|
return p;
|
|
|
|
},
|
|
|
|
generateSharedKey: function(size){
|
|
|
|
size = size || 20;
|
2016-09-26 23:05:47 +08:00
|
|
|
return new C_Promise(function(){
|
2016-09-26 20:23:31 +08:00
|
|
|
CRYPTO.PASSWORD.generate(size,
|
|
|
|
function(pass) {
|
2016-09-26 23:05:47 +08:00
|
|
|
this.call_then(pass);
|
2016-09-26 20:23:31 +08:00
|
|
|
},
|
|
|
|
function(progress) {
|
2016-09-26 23:05:47 +08:00
|
|
|
this.call_progress(progress);
|
2016-09-26 20:23:31 +08:00
|
|
|
}
|
|
|
|
);
|
|
|
|
})
|
2016-09-25 23:46:55 +08:00
|
|
|
},
|
|
|
|
rsaKeyPairToPEM: function(keypair){
|
|
|
|
return {
|
|
|
|
'publicKey' : forge.pki.publicKeyToPem(keypair.publicKey),
|
|
|
|
'privateKey' : forge.pki.privateKeyToPem(keypair.privateKey)
|
|
|
|
};
|
2016-09-26 00:42:41 +08:00
|
|
|
},
|
2016-09-26 04:02:58 +08:00
|
|
|
getSharingKeys: function(){
|
|
|
|
var vault = VaultService.getActiveVault();
|
|
|
|
return{
|
|
|
|
'private_sharing_key': EncryptService.decryptString(angular.copy(vault.private_sharing_key)),
|
|
|
|
'public_sharing_key': vault.public_sharing_key
|
|
|
|
};
|
|
|
|
},
|
2016-09-26 00:42:41 +08:00
|
|
|
rsaPrivateKeyFromPEM: function(private_pem) {
|
|
|
|
return forge.pki.privateKeyFromPem(private_pem);
|
|
|
|
},
|
|
|
|
rsaPublicKeyFromPEM: function(public_pem){
|
|
|
|
return forge.pki.publicKeyFromPem(public_pem);
|
2016-09-23 18:03:37 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}]);
|