mirror of
				https://github.com/gyurix1968/guacamole-client.git
				synced 2025-10-31 00:53:21 +00:00 
			
		
		
		
	GUAC-932: Remove filtering user service. Add permission filtering support to user retrieval endpoint.
This commit is contained in:
		| @@ -27,7 +27,6 @@ import org.glyptodon.guacamole.net.basic.rest.connection.ConnectionService; | ||||
| import org.glyptodon.guacamole.net.basic.rest.connectiongroup.ConnectionGroupService; | ||||
| import org.glyptodon.guacamole.net.basic.rest.permission.PermissionService; | ||||
| import org.glyptodon.guacamole.net.basic.rest.protocol.ProtocolRetrievalService; | ||||
| import org.glyptodon.guacamole.net.basic.rest.user.UserService; | ||||
|  | ||||
| /** | ||||
|  * A Guice Module for setting up dependency injection for the  | ||||
| @@ -44,7 +43,6 @@ public class RESTModule extends AbstractModule { | ||||
|         bind(ConnectionService.class); | ||||
|         bind(ConnectionGroupService.class); | ||||
|         bind(PermissionService.class); | ||||
|         bind(UserService.class); | ||||
|         bind(ProtocolRetrievalService.class); | ||||
|          | ||||
|     } | ||||
|   | ||||
| @@ -28,7 +28,6 @@ import java.util.List; | ||||
| import java.util.Map; | ||||
| import javax.ws.rs.Consumes; | ||||
| import javax.ws.rs.GET; | ||||
| import javax.ws.rs.POST; | ||||
| import javax.ws.rs.Path; | ||||
| import javax.ws.rs.PathParam; | ||||
| import javax.ws.rs.Produces; | ||||
|   | ||||
| @@ -23,6 +23,7 @@ | ||||
| package org.glyptodon.guacamole.net.basic.rest.user; | ||||
|  | ||||
| import com.google.inject.Inject; | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import java.util.UUID; | ||||
| import javax.ws.rs.Consumes; | ||||
| @@ -39,6 +40,7 @@ import org.glyptodon.guacamole.GuacamoleException; | ||||
| import org.glyptodon.guacamole.net.auth.Directory; | ||||
| import org.glyptodon.guacamole.net.auth.User; | ||||
| import org.glyptodon.guacamole.net.auth.UserContext; | ||||
| import org.glyptodon.guacamole.net.auth.permission.UserPermission; | ||||
| import org.glyptodon.guacamole.net.basic.rest.AuthProviderRESTExposure; | ||||
| import org.glyptodon.guacamole.net.basic.rest.HTTPException; | ||||
| import org.glyptodon.guacamole.net.basic.rest.auth.AuthenticationService; | ||||
| @@ -67,29 +69,47 @@ public class UserRESTService { | ||||
|     private AuthenticationService authenticationService; | ||||
|      | ||||
|     /** | ||||
|      * A service for managing the REST endpoint APIPermission objects.  | ||||
|      */ | ||||
|     @Inject | ||||
|     private UserService userService; | ||||
|      | ||||
|     /** | ||||
|      * Gets a list of users in the system. | ||||
|      * @param authToken The authentication token that is used to authenticate | ||||
|      *                  the user performing the operation. | ||||
|      * Gets a list of users in the system, filtering the returned list by the | ||||
|      * given permission, if specified. | ||||
|      *  | ||||
|      * @param authToken | ||||
|      *     The authentication token that is used to authenticate the user | ||||
|      *     performing the operation. | ||||
|      * | ||||
|      * @param permission | ||||
|      *     If specified, limit the returned list to only those users for whom | ||||
|      *     the current user has the given permission. Otherwise, all visible | ||||
|      *     users are returned. | ||||
|      *  | ||||
|      * @return The user list. | ||||
|      * @throws GuacamoleException If a problem is encountered while listing users. | ||||
|      *  | ||||
|      * @throws GuacamoleException | ||||
|      *     If an error is encountered while retrieving users. | ||||
|      */ | ||||
|     @GET | ||||
|     @AuthProviderRESTExposure | ||||
|     public List<APIUser> getUsers(@QueryParam("token") String authToken) throws GuacamoleException { | ||||
|     public List<APIUser> getUsers(@QueryParam("token") String authToken, | ||||
|             @QueryParam("permission") UserPermission.Type permission) | ||||
|             throws GuacamoleException { | ||||
|  | ||||
|         UserContext userContext = authenticationService.getUserContext(authToken); | ||||
|         User self = userContext.self(); | ||||
|  | ||||
|         // Get the directory | ||||
|         Directory<String, User> userDirectory = userContext.getUserDirectory(); | ||||
|  | ||||
|         // Convert and return the user directory listing | ||||
|         return userService.convertUserList(userDirectory); | ||||
|         List<APIUser> users = new ArrayList<APIUser>(); | ||||
|  | ||||
|         // Add all users matching the given permission filter | ||||
|         for (String username : userDirectory.getIdentifiers()) { | ||||
|  | ||||
|             if (permission == null || self.hasPermission(new UserPermission(permission, username))) | ||||
|                 users.add(new APIUser(userDirectory.get(username))); | ||||
|  | ||||
|         } | ||||
|          | ||||
|         // Return the user directory listing | ||||
|         return users; | ||||
|  | ||||
|     } | ||||
|      | ||||
|   | ||||
| @@ -1,59 +0,0 @@ | ||||
| /* | ||||
|  * Copyright (C) 2014 Glyptodon LLC | ||||
|  * | ||||
|  * Permission is hereby granted, free of charge, to any person obtaining a copy | ||||
|  * of this software and associated documentation files (the "Software"), to deal | ||||
|  * in the Software without restriction, including without limitation the rights | ||||
|  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||
|  * copies of the Software, and to permit persons to whom the Software is | ||||
|  * furnished to do so, subject to the following conditions: | ||||
|  * | ||||
|  * The above copyright notice and this permission notice shall be included in | ||||
|  * all copies or substantial portions of the Software. | ||||
|  * | ||||
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||
|  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN | ||||
|  * THE SOFTWARE. | ||||
|  */ | ||||
|  | ||||
| package org.glyptodon.guacamole.net.basic.rest.user; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import org.glyptodon.guacamole.GuacamoleException; | ||||
| import org.glyptodon.guacamole.net.auth.Directory; | ||||
| import org.glyptodon.guacamole.net.auth.User; | ||||
|  | ||||
| /** | ||||
|  * A service for performing useful manipulations on REST Users. | ||||
|  *  | ||||
|  * @author James Muehlner | ||||
|  */ | ||||
| public class UserService { | ||||
|      | ||||
|     /** | ||||
|      * Converts a user directory to a list of APIUser objects for  | ||||
|      * exposing with the REST endpoints. | ||||
|      *  | ||||
|      * @param userDirectory The user directory to convert for REST endpoint use. | ||||
|      * @return A List of APIUser objects for use with the REST endpoint. | ||||
|      * @throws GuacamoleException If an error occurs while converting the  | ||||
|      *                            user directory. | ||||
|      */ | ||||
|     public List<APIUser> convertUserList(Directory<String, User> userDirectory)  | ||||
|             throws GuacamoleException { | ||||
|  | ||||
|         List<APIUser> restUsers = new ArrayList<APIUser>(); | ||||
|          | ||||
|         for(String username : userDirectory.getIdentifiers()) | ||||
|             restUsers.add(new APIUser(userDirectory.get(username))); | ||||
|              | ||||
|         return restUsers; | ||||
|  | ||||
|     } | ||||
|      | ||||
| } | ||||
		Reference in New Issue
	
	Block a user