230 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			230 lines
		
	
	
	
		
			6.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| /**
 | |
|  * An element which displays a panel for managing users.
 | |
|  */
 | |
| angular.module('quay').directive('manageUserTab', function () {
 | |
|   var directiveDefinitionObject = {
 | |
|     priority: 0,
 | |
|     templateUrl: '/static/directives/manage-users-tab.html',
 | |
|     replace: false,
 | |
|     transclude: true,
 | |
|     restrict: 'C',
 | |
|     scope: {
 | |
|       'isEnabled': '=isEnabled'
 | |
|     },
 | |
|     controller: function ($scope, $timeout, $location, $element, ApiService, UserService) {
 | |
| 
 | |
|       $scope.newUser = {};
 | |
|       $scope.createdUser = null;
 | |
|       $scope.takeOwnershipInfo = null;
 | |
| 
 | |
| 
 | |
|       $scope.showCreateUser = function () {
 | |
|         $scope.createdUser = null;
 | |
|         $('#createUserModal').modal('show');
 | |
|       };
 | |
| 
 | |
|       var loadUsersInternal = function () {
 | |
|         ApiService.listAllUsers().then(function (resp) {
 | |
|           $scope.users = resp['users'];
 | |
|           $scope.showInterface = true;
 | |
|         }, function (resp) {
 | |
|           $scope.users = [];
 | |
|           $scope.usersError = ApiService.getErrorMessage(resp);
 | |
|         });
 | |
|       };
 | |
| 
 | |
|       $scope.createUser = function () {
 | |
|         $scope.creatingUser = true;
 | |
|         $scope.createdUser = null;
 | |
| 
 | |
|         var errorHandler = ApiService.errorDisplay('Cannot create user', function () {
 | |
|           $scope.creatingUser = false;
 | |
|           $('#createUserModal').modal('hide');
 | |
|         });
 | |
| 
 | |
|         ApiService.createInstallUser($scope.newUser, null).then(function (resp) {
 | |
|           $scope.creatingUser = false;
 | |
|           $scope.newUser = {};
 | |
|           $scope.createdUser = resp;
 | |
|           loadUsersInternal();
 | |
|         }, errorHandler)
 | |
|       };
 | |
| 
 | |
| 
 | |
|       $scope.setSuperuser = function (user, status) {
 | |
|         var setSuperuser = function () {
 | |
|           var params = {
 | |
|             'username': user.username
 | |
|           };
 | |
| 
 | |
|           var data = {
 | |
|             'superuser': status
 | |
|           };
 | |
| 
 | |
|           ApiService.changeInstallUser(data, params).then(function (resp) {
 | |
|             $scope.requiresRestart = true;
 | |
|           }, ApiService.errorDisplay('Could not change user'));
 | |
|         };
 | |
| 
 | |
|         var msg = 'Note: This change, once applied, will require your installation ' +
 | |
|           'to be restarted to take effect';
 | |
| 
 | |
|         bootbox.confirm(msg, function (status) {
 | |
|           if (status) {
 | |
|             setSuperuser();
 | |
|           }
 | |
|         });
 | |
|       };
 | |
| 
 | |
|       $scope.showChangeEmail = function (user) {
 | |
|         $scope.userToChange = user;
 | |
|         $('#changeEmailModal').modal({});
 | |
|       };
 | |
| 
 | |
|       $scope.changeUserEmail = function (user) {
 | |
|         $('#changeEmailModal').modal('hide');
 | |
| 
 | |
|         var params = {
 | |
|           'username': user.username
 | |
|         };
 | |
| 
 | |
|         var data = {
 | |
|           'email': user.newemail
 | |
|         };
 | |
| 
 | |
|         ApiService.changeInstallUser(data, params).then(function (resp) {
 | |
|           loadUsersInternal();
 | |
|           user.email = user.newemail;
 | |
|           delete user.newemail;
 | |
|         }, ApiService.errorDisplay('Could not change user'));
 | |
|       };
 | |
| 
 | |
|       $scope.showChangePassword = function (user) {
 | |
|         $scope.userToChange = user;
 | |
|         $('#changePasswordModal').modal({});
 | |
|       };
 | |
| 
 | |
|       $scope.changeUserPassword = function (user) {
 | |
|         $('#changePasswordModal').modal('hide');
 | |
| 
 | |
|         var params = {
 | |
|           'username': user.username
 | |
|         };
 | |
| 
 | |
|         var data = {
 | |
|           'password': user.password
 | |
|         };
 | |
| 
 | |
|         ApiService.changeInstallUser(data, params).then(function (resp) {
 | |
|           loadUsersInternal();
 | |
|         }, ApiService.errorDisplay('Could not change user'));
 | |
|       };
 | |
| 
 | |
|       $scope.sendRecoveryEmail = function (user) {
 | |
|         var params = {
 | |
|           'username': user.username
 | |
|         };
 | |
| 
 | |
|         ApiService.sendInstallUserRecoveryEmail(null, params).then(function (resp) {
 | |
|           bootbox.dialog({
 | |
|             "message": "A recovery email has been sent to " + resp['email'],
 | |
|             "title": "Recovery email sent",
 | |
|             "buttons": {
 | |
|               "close": {
 | |
|                 "label": "Close",
 | |
|                 "className": "btn-primary"
 | |
|               }
 | |
|             }
 | |
|           });
 | |
| 
 | |
|         }, ApiService.errorDisplay('Cannot send recovery email'))
 | |
|       };
 | |
| 
 | |
|       $scope.showDeleteUser = function (user) {
 | |
|         if (user.username == UserService.currentUser().username) {
 | |
|           bootbox.dialog({
 | |
|             "message": 'Cannot delete yourself!',
 | |
|             "title": "Cannot delete user",
 | |
|             "buttons": {
 | |
|               "close": {
 | |
|                 "label": "Close",
 | |
|                 "className": "btn-primary"
 | |
|               }
 | |
|             }
 | |
|           });
 | |
|           return;
 | |
|         }
 | |
| 
 | |
|         $scope.userToDelete = user;
 | |
|         $('#confirmDeleteUserModal').modal({});
 | |
|       };
 | |
| 
 | |
|       $scope.deleteUser = function (user) {
 | |
|         $('#confirmDeleteUserModal').modal('hide');
 | |
| 
 | |
|         var params = {
 | |
|           'username': user.username
 | |
|         };
 | |
| 
 | |
|         ApiService.deleteInstallUser(null, params).then(function (resp) {
 | |
|           loadUsersInternal();
 | |
|         }, ApiService.errorDisplay('Cannot delete user'));
 | |
|       };
 | |
| 
 | |
|       $scope.askDisableUser = function (user) {
 | |
|         var message = 'Are you sure you want to disable this user? ' +
 | |
|           'They will be unable to login, pull or push.';
 | |
| 
 | |
|         if (!user.enabled) {
 | |
|           message = 'Are you sure you want to reenable this user? ' +
 | |
|             'They will be able to login, pull or push.'
 | |
|         }
 | |
| 
 | |
|         bootbox.confirm(message, function (resp) {
 | |
|           if (resp) {
 | |
|             var params = {
 | |
|               'username': user.username
 | |
|             };
 | |
| 
 | |
|             var data = {
 | |
|               'enabled': !user.enabled
 | |
|             };
 | |
| 
 | |
|             ApiService.changeInstallUser(data, params).then(function (resp) {
 | |
|               loadUsersInternal();
 | |
|             });
 | |
|           }
 | |
|         });
 | |
|       };
 | |
| 
 | |
|       $scope.askTakeOwnership = function (entity, is_org) {
 | |
|         $scope.takeOwnershipInfo = {
 | |
|           'entity': entity,
 | |
|           'is_org': is_org
 | |
|         };
 | |
|       };
 | |
| 
 | |
|       $scope.takeOwnership = function (info, callback) {
 | |
|         var errorDisplay = ApiService.errorDisplay('Could not take ownership of namespace', callback);
 | |
|         var params = {
 | |
|           'namespace': info.entity.username || info.entity.name
 | |
|         };
 | |
| 
 | |
|         ApiService.takeOwnership(null, params).then(function () {
 | |
|           callback(true);
 | |
|           $location.path('/organization/' + params.namespace);
 | |
|         }, errorDisplay)
 | |
|       };
 | |
| 
 | |
|       $scope.$watch('isEnabled', function (value) {
 | |
|         if (value) {
 | |
|           if ($scope.users) {
 | |
|             return;
 | |
|           }
 | |
|           loadUsersInternal();
 | |
|         }
 | |
|       });
 | |
|     }
 | |
|   };
 | |
|   return directiveDefinitionObject;
 | |
| });
 |