Merge branch 'sharing_no_groups' of github.com:nextcloud/passman into sharing_no_groups

This commit is contained in:
Marcos Zuriaga 2016-10-03 20:40:27 +02:00
commit de0b08f91a
No known key found for this signature in database
GPG key ID: 7D15585354D072FF
5 changed files with 50 additions and 26 deletions

View file

@ -93,7 +93,7 @@ class CredentialController extends ApiController {
$credential_id, $custom_fields, $delete_time, $credential_id, $custom_fields, $delete_time,
$description, $email, $expire_time, $favicon, $files, $guid, $description, $email, $expire_time, $favicon, $files, $guid,
$hidden, $label, $otp, $password, $renew_interval, $hidden, $label, $otp, $password, $renew_interval,
$tags, $url, $username, $vault_id, $revision_created, $shared_key) { $tags, $url, $username, $vault_id, $revision_created, $shared_key, $acl) {
$credential = array( $credential = array(
'credential_id' => $credential_id, 'credential_id' => $credential_id,
'guid' => $guid, 'guid' => $guid,

View file

@ -9,8 +9,8 @@
*/ */
angular.module('passmanApp') angular.module('passmanApp')
.controller('CredentialCtrl', ['$scope', 'VaultService', 'SettingsService', '$location', 'CredentialService', .controller('CredentialCtrl', ['$scope', 'VaultService', 'SettingsService', '$location', 'CredentialService',
'$rootScope', 'FileService', 'EncryptService', 'TagService', '$timeout', 'NotificationService', 'CacheService', 'ShareService', '$rootScope', 'FileService', 'EncryptService', 'TagService', '$timeout', 'NotificationService', 'CacheService', 'ShareService', 'SharingACL',
function ($scope, VaultService, SettingsService, $location, CredentialService, $rootScope, FileService, EncryptService, TagService, $timeout, NotificationService, CacheService, ShareService) { function ($scope, VaultService, SettingsService, $location, CredentialService, $rootScope, FileService, EncryptService, TagService, $timeout, NotificationService, CacheService, ShareService, SharingACL) {
$scope.active_vault = VaultService.getActiveVault(); $scope.active_vault = VaultService.getActiveVault();
if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) { if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) {
if (!$scope.active_vault) { if (!$scope.active_vault) {
@ -32,6 +32,7 @@ angular.module('passmanApp')
var getSharedCredentials = function() { var getSharedCredentials = function() {
ShareService.getCredendialsSharedWithUs($scope.active_vault.guid).then(function (shared_credentials) { ShareService.getCredendialsSharedWithUs($scope.active_vault.guid).then(function (shared_credentials) {
console.log('Shared credentials', shared_credentials);
for (var c = 0; c < shared_credentials.length; c++) { for (var c = 0; c < shared_credentials.length; c++) {
var _shared_credential = shared_credentials[c]; var _shared_credential = shared_credentials[c];
var decrypted_key = EncryptService.decryptString(_shared_credential.shared_key); var decrypted_key = EncryptService.decryptString(_shared_credential.shared_key);
@ -43,6 +44,7 @@ angular.module('passmanApp')
if(_shared_credential_data){ if(_shared_credential_data){
delete _shared_credential.credential_data; delete _shared_credential.credential_data;
_shared_credential_data.acl = _shared_credential; _shared_credential_data.acl = _shared_credential;
_shared_credential_data.acl.permissions = new SharingACL(_shared_credential_data.acl.permissions);
_shared_credential_data.tags_raw = _shared_credential_data.tags; _shared_credential_data.tags_raw = _shared_credential_data.tags;
console.log(_shared_credential_data) console.log(_shared_credential_data)
$scope.active_vault.credentials.push(_shared_credential_data); $scope.active_vault.credentials.push(_shared_credential_data);
@ -99,6 +101,17 @@ angular.module('passmanApp')
}); });
} }
}); });
$scope.permissions = new SharingACL(0);
$scope.hasPermission = function(acl, permission){
if(acl) {
return acl.hasPermission(permission);
} else {
return true;
}
};
$scope.acceptShareRequest = function(share_request){ $scope.acceptShareRequest = function(share_request){
console.log('Accepted share request', share_request); console.log('Accepted share request', share_request);

View file

@ -8,8 +8,8 @@
* Controller of the passmanApp * Controller of the passmanApp
*/ */
angular.module('passmanApp') angular.module('passmanApp')
.controller('CredentialEditCtrl', ['$scope', 'VaultService', 'CredentialService', 'SettingsService', '$location', '$routeParams', 'FileService', 'EncryptService', 'TagService', 'NotificationService', .controller('CredentialEditCtrl', ['$scope', 'VaultService', 'CredentialService', 'SettingsService', '$location', '$routeParams', 'FileService', 'EncryptService', 'TagService', 'NotificationService', 'ShareService',
function ($scope, VaultService, CredentialService, SettingsService, $location, $routeParams, FileService, EncryptService, TagService, NotificationService) { function ($scope, VaultService, CredentialService, SettingsService, $location, $routeParams, FileService, EncryptService, TagService, NotificationService, ShareService) {
$scope.active_vault = VaultService.getActiveVault(); $scope.active_vault = VaultService.getActiveVault();
if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) { if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) {
if (!$scope.active_vault) { if (!$scope.active_vault) {
@ -62,7 +62,6 @@ angular.module('passmanApp')
}]; }];
if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) { if (!SettingsService.getSetting('defaultVault') || !SettingsService.getSetting('defaultVaultPass')) {
if (!$scope.active_vault) { if (!$scope.active_vault) {
$location.path('/') $location.path('/')
@ -82,7 +81,7 @@ angular.module('passmanApp')
var storedCredential = SettingsService.getSetting('edit_credential'); var storedCredential = SettingsService.getSetting('edit_credential');
if (!storedCredential) { if (!storedCredential) {
CredentialService.getCredential($routeParams.credential_id).then(function(result){ CredentialService.getCredential($routeParams.credential_id).then(function (result) {
$scope.storedCredential = CredentialService.decryptCredential(angular.copy(result)); $scope.storedCredential = CredentialService.decryptCredential(angular.copy(result));
}); });
} else { } else {
@ -188,10 +187,10 @@ angular.module('passmanApp')
$scope.renewIntervalValue = 0; $scope.renewIntervalValue = 0;
$scope.renewIntervalModifier = '0'; $scope.renewIntervalModifier = '0';
$scope.updateInterval = function(renewIntervalValue, renewIntervalModifier){ $scope.updateInterval = function (renewIntervalValue, renewIntervalModifier) {
var value = parseInt(renewIntervalValue); var value = parseInt(renewIntervalValue);
var modifier = parseInt(renewIntervalModifier); var modifier = parseInt(renewIntervalModifier);
if( value && modifier) { if (value && modifier) {
$scope.storedCredential.renew_interval = value * modifier; $scope.storedCredential.renew_interval = value * modifier;
} }
}; };
@ -214,21 +213,34 @@ angular.module('passmanApp')
$scope.saveCredential = function () { $scope.saveCredential = function () {
//@TODO validation //@TODO validation
//@TODO When credential is expired and has renew interval set, calc new expire time. //@TODO When credential is expired and has renew interval set, calc new expire time.
console.log(JSON.stringify($scope.storedCredential));
delete $scope.storedCredential.password_repeat; delete $scope.storedCredential.password_repeat;
if (!$scope.storedCredential.credential_id) {
$scope.storedCredential.vault_id = $scope.active_vault.vault_id; if ($scope.storedCredential.hasOwnProperty('acl')) {
CredentialService.createCredential($scope.storedCredential).then(function (result) { var enc_key = EncryptService.decryptString(angular.copy($scope.storedCredential.acl.shared_key));
$location.path('/vault/' + $routeParams.vault_id); console.log(enc_key)
NotificationService.showNotification('Credential created!', 5000) var _credential = ShareService.encryptSharedCredential($scope.storedCredential, enc_key);
}) console.log(_credential);
} else { CredentialService.updateCredential(_credential).then(function (result) {
CredentialService.updateCredential($scope.storedCredential).then(function (result) {
SettingsService.setSetting('edit_credential', null); SettingsService.setSetting('edit_credential', null);
$location.path('/vault/' + $routeParams.vault_id); $location.path('/vault/' + $routeParams.vault_id);
NotificationService.showNotification('Credential updated!', 5000) NotificationService.showNotification('Credential updated!', 5000)
}) })
} else {
if (!$scope.storedCredential.credential_id) {
$scope.storedCredential.vault_id = $scope.active_vault.vault_id;
CredentialService.createCredential($scope.storedCredential).then(function (result) {
$location.path('/vault/' + $routeParams.vault_id);
NotificationService.showNotification('Credential created!', 5000)
})
} else {
CredentialService.updateCredential($scope.storedCredential).then(function (result) {
SettingsService.setSetting('edit_credential', null);
$location.path('/vault/' + $routeParams.vault_id);
NotificationService.showNotification('Credential updated!', 5000)
})
}
} }
}; };
$scope.cancel = function () { $scope.cancel = function () {

File diff suppressed because one or more lines are too long

View file

@ -213,32 +213,32 @@
</div> </div>
<div ng-show="selectedCredential"> <div ng-show="selectedCredential">
<div ng-if="!selectedCredential.acl || selectedCredential.acl.permissions == 2"> <div>
<button class="button" <button class="button"
ng-click="editCredential(selectedCredential)" ng-click="editCredential(selectedCredential)"
ng-if="selectedCredential.delete_time == 0"> ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
<span class="fa fa-edit"></span> Edit <span class="fa fa-edit"></span> Edit
</button> </button>
<button class="button" <button class="button"
ng-click="deleteCredential(selectedCredential)" ng-click="deleteCredential(selectedCredential)"
ng-if="selectedCredential.delete_time == 0"> ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
<span class="fa fa-trash"></span> Delete <span class="fa fa-trash"></span> Delete
</button> </button>
<button class="button" <button class="button"
ng-click="shareCredential(selectedCredential)" ng-click="shareCredential(selectedCredential)"
ng-if="selectedCredential.delete_time == 0"> ng-if="selectedCredential.delete_time == 0 && selectedCredential.acl === undefined">
<span class="fa fa-share"></span> Share <span class="fa fa-share"></span> Share
</button> </button>
<button class="button" <button class="button"
ng-click="getRevisions(selectedCredential)" ng-click="getRevisions(selectedCredential)"
ng-if="selectedCredential.delete_time == 0"> ng-if="selectedCredential.delete_time == 0 && hasPermission(selectedCredential.acl.permissions, permissions.permissions.HISTORY)">
<span class="fa fa-undo"></span> Revisions <span class="fa fa-undo"></span> Revisions
</button> </button>
<button class="button" <button class="button"
ng-if="selectedCredential.delete_time > 0" ng-if="selectedCredential.delete_time > 0"
ng-click="recoverCredential(selectedCredential)"> ng-click="recoverCredential(selectedCredential) && hasPermission(selectedCredential.acl.permissions, permissions.permissions.WRITE)">
<span class="fa fa-recycle"></span> Recover <span class="fa fa-recycle"></span> Recover
</button> </button>
<button class="button" <button class="button"
@ -247,7 +247,6 @@
<span class="fa fa-bomb"></span> Destroy <span class="fa fa-bomb"></span> Destroy
</button> </button>
</div> </div>
</div> </div>
</div> </div>
</div> </div>