2016-09-11 05:30:17 +08:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @ngdoc service
|
|
|
|
* @name passmanApp.CredentialService
|
|
|
|
* @description
|
|
|
|
* # CredentialService
|
|
|
|
* Service in the passmanApp.
|
|
|
|
*/
|
|
|
|
angular.module('passmanApp')
|
2016-09-12 01:45:20 +08:00
|
|
|
.service('CredentialService', ['$http', 'EncryptService', function ($http, EncryptService) {
|
|
|
|
var credential = {
|
|
|
|
'credential_id': null,
|
|
|
|
'guid': null,
|
|
|
|
'vault_id': null,
|
|
|
|
'label': null,
|
|
|
|
'description': null,
|
|
|
|
'created': null,
|
|
|
|
'changed': null,
|
2016-09-16 03:43:23 +08:00
|
|
|
'tags': [],
|
2016-09-12 01:45:20 +08:00
|
|
|
'email': null,
|
|
|
|
'username': null,
|
|
|
|
'password': null,
|
|
|
|
'url': null,
|
|
|
|
'favicon': null,
|
|
|
|
'renew_interval': null,
|
2016-09-15 03:12:10 +08:00
|
|
|
'expire_time': 0,
|
2016-09-13 22:31:07 +08:00
|
|
|
'delete_time': 0,
|
|
|
|
'files': [],
|
|
|
|
'custom_fields': [],
|
2016-09-14 05:03:12 +08:00
|
|
|
'otp': {},
|
2016-09-12 01:45:20 +08:00
|
|
|
'hidden': false
|
|
|
|
};
|
2016-09-15 03:12:10 +08:00
|
|
|
var _encryptedFields = ['description', 'username', 'password', 'files', 'custom_fields', 'otp', 'email', 'tags', 'url'];
|
|
|
|
|
|
|
|
|
2016-09-12 01:45:20 +08:00
|
|
|
return {
|
|
|
|
newCredential: function () {
|
2016-09-13 06:10:24 +08:00
|
|
|
return angular.copy(credential);
|
2016-09-12 01:45:20 +08:00
|
|
|
},
|
|
|
|
createCredential: function (credential) {
|
2016-09-15 03:12:10 +08:00
|
|
|
var _credential = angular.copy(credential);
|
|
|
|
for (var i = 0; i < _encryptedFields.length; i++) {
|
2016-09-12 01:45:20 +08:00
|
|
|
var field = _encryptedFields[i];
|
|
|
|
var fieldValue = angular.copy(credential[field]);
|
2016-09-15 03:12:10 +08:00
|
|
|
_credential[field] = EncryptService.encryptString(JSON.stringify(fieldValue));
|
2016-09-12 01:45:20 +08:00
|
|
|
}
|
|
|
|
|
2016-09-23 21:05:27 +08:00
|
|
|
_credential.expire_time = new Date( angular.copy(credential.expire_time) ).getTime() / 1000;
|
|
|
|
|
2016-09-12 01:45:20 +08:00
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials');
|
2016-09-15 03:12:10 +08:00
|
|
|
return $http.post(queryUrl, _credential).then(function (response) {
|
|
|
|
if (response.data) {
|
2016-09-12 01:45:20 +08:00
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2016-10-02 18:35:27 +08:00
|
|
|
getEncryptedFields: function () {
|
|
|
|
return _encryptedFields;
|
|
|
|
},
|
2016-10-03 03:17:17 +08:00
|
|
|
updateCredential: function (credential, skipEncyption) {
|
2016-09-15 03:12:10 +08:00
|
|
|
var _credential = angular.copy(credential);
|
2016-10-03 03:17:17 +08:00
|
|
|
if(!skipEncyption){
|
|
|
|
for (var i = 0; i < _encryptedFields.length; i++) {
|
|
|
|
var field = _encryptedFields[i];
|
|
|
|
var fieldValue = angular.copy(credential[field]);
|
|
|
|
_credential[field] = EncryptService.encryptString(JSON.stringify(fieldValue));
|
|
|
|
}
|
2016-10-03 21:47:00 +08:00
|
|
|
} else {
|
|
|
|
console.log('Skipping encryption')
|
2016-09-12 01:45:20 +08:00
|
|
|
}
|
2016-10-03 21:47:00 +08:00
|
|
|
|
2016-09-23 21:05:27 +08:00
|
|
|
_credential.expire_time = new Date( angular.copy(credential.expire_time) ).getTime() / 1000;
|
2016-09-12 01:45:20 +08:00
|
|
|
|
2016-09-15 03:12:10 +08:00
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials/' + credential.credential_id);
|
|
|
|
return $http.patch(queryUrl, _credential).then(function (response) {
|
|
|
|
if (response.data) {
|
2016-09-12 01:45:20 +08:00
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
2016-09-12 02:47:29 +08:00
|
|
|
},
|
2016-09-23 23:22:47 +08:00
|
|
|
getCredential: function(id){
|
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials/' + id);
|
|
|
|
return $http.get(queryUrl).then(function (response) {
|
|
|
|
if (response.data) {
|
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2016-09-24 03:30:07 +08:00
|
|
|
destroyCredential: function(id){
|
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials/' + id);
|
|
|
|
return $http.delete(queryUrl).then(function (response) {
|
|
|
|
if (response.data) {
|
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2016-09-14 05:03:12 +08:00
|
|
|
encryptCredential: function (credential) {
|
2016-09-15 03:12:10 +08:00
|
|
|
for (var i = 0; i < _encryptedFields.length; i++) {
|
2016-09-14 05:03:12 +08:00
|
|
|
var field = _encryptedFields[i];
|
|
|
|
var fieldValue = angular.copy(credential[field]);
|
|
|
|
credential[field] = EncryptService.encryptString(JSON.stringify(fieldValue));
|
|
|
|
}
|
|
|
|
return credential;
|
|
|
|
},
|
2016-09-12 02:47:29 +08:00
|
|
|
decryptCredential: function (credential) {
|
2016-09-15 03:12:10 +08:00
|
|
|
for (var i = 0; i < _encryptedFields.length; i++) {
|
2016-09-12 02:47:29 +08:00
|
|
|
var field = _encryptedFields[i];
|
|
|
|
var fieldValue = angular.copy(credential[field]);
|
2016-09-28 04:02:04 +08:00
|
|
|
try {
|
|
|
|
var field_decrypted_value = EncryptService.decryptString(fieldValue)
|
|
|
|
} catch (e){
|
|
|
|
console.log(e)
|
|
|
|
throw e
|
|
|
|
}
|
2016-09-16 03:43:23 +08:00
|
|
|
try{
|
2016-09-28 04:02:04 +08:00
|
|
|
credential[field] = JSON.parse(field_decrypted_value);
|
2016-09-16 03:43:23 +08:00
|
|
|
} catch (e){
|
|
|
|
console.log('Field' + field + ' in '+ credential.label +' could not be parsed! Value:'+ fieldValue)
|
2016-09-28 03:12:12 +08:00
|
|
|
throw e
|
2016-09-16 03:43:23 +08:00
|
|
|
}
|
|
|
|
|
2016-09-12 02:47:29 +08:00
|
|
|
}
|
|
|
|
return credential;
|
2016-09-24 17:40:15 +08:00
|
|
|
},
|
|
|
|
getRevisions: function(id){
|
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials/' + id + '/revision');
|
|
|
|
return $http.get(queryUrl).then(function (response) {
|
|
|
|
if (response.data) {
|
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
2016-09-24 18:59:19 +08:00
|
|
|
},
|
|
|
|
deleteRevision: function(credential_id, revision_id){
|
|
|
|
var queryUrl = OC.generateUrl('apps/passman/api/v2/credentials/' + credential_id + '/revision/' + revision_id);
|
|
|
|
return $http.delete(queryUrl).then(function (response) {
|
|
|
|
if (response.data) {
|
|
|
|
return response.data;
|
|
|
|
} else {
|
|
|
|
return response;
|
|
|
|
}
|
|
|
|
});
|
2016-09-12 01:45:20 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}]);
|