mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 13:17:41 +00:00
GUAC-1104: Add parent group validation. Switch to beforeCreate/beforeUpdate/beforeDelete validation functions.
This commit is contained in:
@@ -37,8 +37,8 @@ import org.glyptodon.guacamole.net.auth.permission.ObjectPermissionSet;
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Service which provides convenience methods for creating, retrieving, and
|
* Service which provides convenience methods for creating, retrieving, and
|
||||||
* manipulating users. This service will automatically enforce the
|
* manipulating objects within directories. This service will automatically
|
||||||
* permissions of the current user.
|
* enforce the permissions of the current user.
|
||||||
*
|
*
|
||||||
* @author Michael Jumper
|
* @author Michael Jumper
|
||||||
* @param <InternalType>
|
* @param <InternalType>
|
||||||
@@ -215,52 +215,77 @@ public abstract class DirectoryObjectService<InternalType extends DirectoryObjec
|
|||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns whether the contents of the given model are valid and can be
|
* Called before any object is created through this directory object
|
||||||
* used to create a new object as-is. The object does not yet exist in the
|
* service. This function serves as a final point of validation before
|
||||||
* database, but the user desires to create a new object with the given
|
* the create operation occurs. In its default implementation,
|
||||||
* model. This function will be called prior to any creation operation, and
|
* beforeCreate() performs basic permissions checks.
|
||||||
* provides a means for the implementation to abort prior to completion. The
|
|
||||||
* default implementation does nothing.
|
|
||||||
*
|
*
|
||||||
* @param user
|
* @param user
|
||||||
* The user creating the object.
|
* The user creating the object.
|
||||||
*
|
*
|
||||||
* @param model
|
* @param model
|
||||||
* The model to validate.
|
* The model of the object being created.
|
||||||
*
|
*
|
||||||
* @throws GuacamoleException
|
* @throws GuacamoleException
|
||||||
* If the object is invalid, or an error prevents validating the given
|
* If the object is invalid, or an error prevents validating the given
|
||||||
* object.
|
* object.
|
||||||
*/
|
*/
|
||||||
protected void validateNewModel(AuthenticatedUser user,
|
protected void beforeCreate(AuthenticatedUser user,
|
||||||
ModelType model) throws GuacamoleException {
|
ModelType model ) throws GuacamoleException {
|
||||||
|
|
||||||
// By default, do nothing.
|
// Verify permission to create objects
|
||||||
|
if (!user.getUser().isAdministrator() && !hasCreatePermission(user))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns whether the given model is valid and can be used to update an
|
* Called before any object is updated through this directory object
|
||||||
* existing object as-is. The object already exists in the database, but the
|
* service. This function serves as a final point of validation before
|
||||||
* user desires to update the object to the given model. This function will
|
* the update operation occurs. In its default implementation,
|
||||||
* be called prior to update operation, and provides a means for the
|
* beforeUpdate() performs basic permissions checks.
|
||||||
* implementation to abort prior to completion. The default implementation
|
|
||||||
* does nothing.
|
|
||||||
*
|
*
|
||||||
* @param user
|
* @param user
|
||||||
* The user updating the existing object.
|
* The user updating the existing object.
|
||||||
*
|
*
|
||||||
* @param model
|
* @param model
|
||||||
* The model to validate.
|
* The model of the object being updated.
|
||||||
*
|
*
|
||||||
* @throws GuacamoleException
|
* @throws GuacamoleException
|
||||||
* If the object is invalid, or an error prevents validating the given
|
* If the object is invalid, or an error prevents validating the given
|
||||||
* object.
|
* object.
|
||||||
*/
|
*/
|
||||||
protected void validateExistingModel(AuthenticatedUser user,
|
protected void beforeUpdate(AuthenticatedUser user,
|
||||||
ModelType model) throws GuacamoleException {
|
ModelType model) throws GuacamoleException {
|
||||||
|
|
||||||
// By default, do nothing.
|
// By default, do nothing.
|
||||||
|
if (!hasObjectPermission(user, model.getIdentifier(), ObjectPermission.Type.UPDATE))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called before any object is deleted through this directory object
|
||||||
|
* service. This function serves as a final point of validation before
|
||||||
|
* the delete operation occurs. In its default implementation,
|
||||||
|
* beforeDelete() performs basic permissions checks.
|
||||||
|
*
|
||||||
|
* @param user
|
||||||
|
* The user deleting the existing object.
|
||||||
|
*
|
||||||
|
* @param identifier
|
||||||
|
* The identifier of the object being deleted.
|
||||||
|
*
|
||||||
|
* @throws GuacamoleException
|
||||||
|
* If the object is invalid, or an error prevents validating the given
|
||||||
|
* object.
|
||||||
|
*/
|
||||||
|
protected void beforeDelete(AuthenticatedUser user,
|
||||||
|
String identifier) throws GuacamoleException {
|
||||||
|
|
||||||
|
// Verify permission to delete objects
|
||||||
|
if (!hasObjectPermission(user, identifier, ObjectPermission.Type.DELETE))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -359,43 +384,35 @@ public abstract class DirectoryObjectService<InternalType extends DirectoryObjec
|
|||||||
public InternalType createObject(AuthenticatedUser user, ExternalType object)
|
public InternalType createObject(AuthenticatedUser user, ExternalType object)
|
||||||
throws GuacamoleException {
|
throws GuacamoleException {
|
||||||
|
|
||||||
// Only create object if user has permission to do so
|
ModelType model = getModelInstance(user, object);
|
||||||
if (user.getUser().isAdministrator() || hasCreatePermission(user)) {
|
beforeCreate(user, model);
|
||||||
|
|
||||||
|
// Create object
|
||||||
|
getObjectMapper().insert(model);
|
||||||
|
|
||||||
// Validate object prior to creation
|
// Build list of implicit permissions
|
||||||
ModelType model = getModelInstance(user, object);
|
Collection<ObjectPermissionModel> implicitPermissions =
|
||||||
validateNewModel(user, model);
|
new ArrayList<ObjectPermissionModel>(IMPLICIT_OBJECT_PERMISSIONS.length);
|
||||||
|
|
||||||
// Create object
|
UserModel userModel = user.getUser().getModel();
|
||||||
getObjectMapper().insert(model);
|
for (ObjectPermission.Type permission : IMPLICIT_OBJECT_PERMISSIONS) {
|
||||||
|
|
||||||
// Build list of implicit permissions
|
// Create model which grants this permission to the current user
|
||||||
Collection<ObjectPermissionModel> implicitPermissions =
|
ObjectPermissionModel permissionModel = new ObjectPermissionModel();
|
||||||
new ArrayList<ObjectPermissionModel>(IMPLICIT_OBJECT_PERMISSIONS.length);
|
permissionModel.setUserID(userModel.getObjectID());
|
||||||
|
permissionModel.setUsername(userModel.getIdentifier());
|
||||||
|
permissionModel.setType(permission);
|
||||||
|
permissionModel.setObjectIdentifier(model.getIdentifier());
|
||||||
|
|
||||||
UserModel userModel = user.getUser().getModel();
|
// Add permission
|
||||||
for (ObjectPermission.Type permission : IMPLICIT_OBJECT_PERMISSIONS) {
|
implicitPermissions.add(permissionModel);
|
||||||
|
|
||||||
// Create model which grants this permission to the current user
|
|
||||||
ObjectPermissionModel permissionModel = new ObjectPermissionModel();
|
|
||||||
permissionModel.setUserID(userModel.getObjectID());
|
|
||||||
permissionModel.setUsername(userModel.getIdentifier());
|
|
||||||
permissionModel.setType(permission);
|
|
||||||
permissionModel.setObjectIdentifier(model.getIdentifier());
|
|
||||||
|
|
||||||
// Add permission
|
|
||||||
implicitPermissions.add(permissionModel);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add implicit permissions
|
|
||||||
getPermissionMapper().insert(implicitPermissions);
|
|
||||||
|
|
||||||
return getObjectInstance(user, model);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// User lacks permission to create
|
// Add implicit permissions
|
||||||
throw new GuacamoleSecurityException("Permission denied.");
|
getPermissionMapper().insert(implicitPermissions);
|
||||||
|
|
||||||
|
return getObjectInstance(user, model);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -416,14 +433,10 @@ public abstract class DirectoryObjectService<InternalType extends DirectoryObjec
|
|||||||
public void deleteObject(AuthenticatedUser user, String identifier)
|
public void deleteObject(AuthenticatedUser user, String identifier)
|
||||||
throws GuacamoleException {
|
throws GuacamoleException {
|
||||||
|
|
||||||
// Only delete object if user has permission to do so
|
beforeDelete(user, identifier);
|
||||||
if (hasObjectPermission(user, identifier, ObjectPermission.Type.DELETE)) {
|
|
||||||
getObjectMapper().delete(identifier);
|
// Delete object
|
||||||
return;
|
getObjectMapper().delete(identifier);
|
||||||
}
|
|
||||||
|
|
||||||
// User lacks permission to delete
|
|
||||||
throw new GuacamoleSecurityException("Permission denied.");
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -444,20 +457,11 @@ public abstract class DirectoryObjectService<InternalType extends DirectoryObjec
|
|||||||
public void updateObject(AuthenticatedUser user, InternalType object)
|
public void updateObject(AuthenticatedUser user, InternalType object)
|
||||||
throws GuacamoleException {
|
throws GuacamoleException {
|
||||||
|
|
||||||
// Only update object if user has permission to do so
|
ModelType model = object.getModel();
|
||||||
if (hasObjectPermission(user, object.getIdentifier(), ObjectPermission.Type.UPDATE)) {
|
beforeUpdate(user, model);
|
||||||
|
|
||||||
// Validate object prior to creation
|
// Update object
|
||||||
ModelType model = object.getModel();
|
getObjectMapper().update(model);
|
||||||
validateExistingModel(user, model);
|
|
||||||
|
|
||||||
// Update object
|
|
||||||
getObjectMapper().update(model);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// User lacks permission to update
|
|
||||||
throw new GuacamoleSecurityException("Permission denied.");
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -0,0 +1,196 @@
|
|||||||
|
/*
|
||||||
|
* Copyright (C) 2015 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.auth.jdbc.base;
|
||||||
|
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Collections;
|
||||||
|
import org.glyptodon.guacamole.GuacamoleException;
|
||||||
|
import org.glyptodon.guacamole.GuacamoleSecurityException;
|
||||||
|
import org.glyptodon.guacamole.auth.jdbc.user.AuthenticatedUser;
|
||||||
|
import org.glyptodon.guacamole.net.auth.permission.ObjectPermission;
|
||||||
|
import org.glyptodon.guacamole.net.auth.permission.ObjectPermissionSet;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Service which provides convenience methods for creating, retrieving, and
|
||||||
|
* manipulating objects that can be within connection groups. This service will
|
||||||
|
* automatically enforce the permissions of the current user.
|
||||||
|
*
|
||||||
|
* @author Michael Jumper
|
||||||
|
* @param <InternalType>
|
||||||
|
* The specific internal implementation of the type of object this service
|
||||||
|
* provides access to.
|
||||||
|
*
|
||||||
|
* @param <ExternalType>
|
||||||
|
* The external interface or implementation of the type of object this
|
||||||
|
* service provides access to, as defined by the guacamole-ext API.
|
||||||
|
*
|
||||||
|
* @param <ModelType>
|
||||||
|
* The underlying model object used to represent InternalType in the
|
||||||
|
* database.
|
||||||
|
*/
|
||||||
|
public abstract class GroupedDirectoryObjectService<InternalType extends GroupedDirectoryObject<ModelType>,
|
||||||
|
ExternalType, ModelType extends GroupedObjectModel>
|
||||||
|
extends DirectoryObjectService<InternalType, ExternalType, ModelType> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the set of parent connection groups that are modified by the
|
||||||
|
* given model object (by virtue of the object changing parent groups). If
|
||||||
|
* the model is not changing parents, the resulting collection will be
|
||||||
|
* empty.
|
||||||
|
*
|
||||||
|
* @param user
|
||||||
|
* The user making the given changes to the model.
|
||||||
|
*
|
||||||
|
* @param identifier
|
||||||
|
* The identifier of the object that has been modified, if it exists.
|
||||||
|
* If the object is being created, this will be null.
|
||||||
|
*
|
||||||
|
* @param model
|
||||||
|
* The model that has been modified, if any. If the object is being
|
||||||
|
* deleted, this will be null.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* A collection of the identifiers of all parent connection groups
|
||||||
|
* that will be affected (updated) by the change.
|
||||||
|
*
|
||||||
|
* @throws GuacamoleException
|
||||||
|
* If an error occurs while determining which parent connection groups
|
||||||
|
* are affected.
|
||||||
|
*/
|
||||||
|
protected Collection<String> getModifiedGroups(AuthenticatedUser user,
|
||||||
|
String identifier, ModelType model) throws GuacamoleException {
|
||||||
|
|
||||||
|
// Get old parent identifier
|
||||||
|
String oldParentIdentifier = null;
|
||||||
|
if (identifier != null) {
|
||||||
|
ModelType current = retrieveObject(user, identifier).getModel();
|
||||||
|
oldParentIdentifier = current.getParentIdentifier();
|
||||||
|
}
|
||||||
|
|
||||||
|
// Get new parent identifier
|
||||||
|
String parentIdentifier = null;
|
||||||
|
if (model != null) {
|
||||||
|
|
||||||
|
parentIdentifier = model.getParentIdentifier();
|
||||||
|
|
||||||
|
// If both parents have the same identifier, nothing has changed
|
||||||
|
if (parentIdentifier != null && parentIdentifier.equals(oldParentIdentifier))
|
||||||
|
return Collections.EMPTY_LIST;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
// Return collection of all non-root groups involved
|
||||||
|
Collection<String> groups = new ArrayList<String>(2);
|
||||||
|
if (oldParentIdentifier != null) groups.add(oldParentIdentifier);
|
||||||
|
if (parentIdentifier != null) groups.add(parentIdentifier);
|
||||||
|
return groups;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns whether the given user has permission to modify the parent
|
||||||
|
* connection groups affected by the modifications made to the given model
|
||||||
|
* object.
|
||||||
|
*
|
||||||
|
* @param user
|
||||||
|
* The user who changed the model object.
|
||||||
|
*
|
||||||
|
* @param identifier
|
||||||
|
* The identifier of the object that has been modified, if it exists.
|
||||||
|
* If the object is being created, this will be null.
|
||||||
|
*
|
||||||
|
* @param model
|
||||||
|
* The model that has been modified, if any. If the object is being
|
||||||
|
* deleted, this will be null.
|
||||||
|
*
|
||||||
|
* @return
|
||||||
|
* true if the user has update permission for all modified groups,
|
||||||
|
* false otherwise.
|
||||||
|
*
|
||||||
|
* @throws GuacamoleException
|
||||||
|
* If an error occurs while determining which parent connection groups
|
||||||
|
* are affected.
|
||||||
|
*/
|
||||||
|
protected boolean canUpdateModifiedGroups(AuthenticatedUser user,
|
||||||
|
String identifier, ModelType model) throws GuacamoleException {
|
||||||
|
|
||||||
|
// If user is an administrator, no need to check
|
||||||
|
if (user.getUser().isAdministrator())
|
||||||
|
return true;
|
||||||
|
|
||||||
|
// Verify that we have permission to modify any modified groups
|
||||||
|
Collection<String> modifiedGroups = getModifiedGroups(user, identifier, model);
|
||||||
|
if (!modifiedGroups.isEmpty()) {
|
||||||
|
|
||||||
|
ObjectPermissionSet permissionSet = user.getUser().getConnectionGroupPermissions();
|
||||||
|
Collection<String> updateableGroups = permissionSet.getAccessibleObjects(
|
||||||
|
Collections.singleton(ObjectPermission.Type.UPDATE),
|
||||||
|
modifiedGroups
|
||||||
|
);
|
||||||
|
|
||||||
|
return updateableGroups.size() == modifiedGroups.size();
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void beforeCreate(AuthenticatedUser user,
|
||||||
|
ModelType model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeCreate(user, model);
|
||||||
|
|
||||||
|
// Validate that we can update all applicable parent groups
|
||||||
|
if (!canUpdateModifiedGroups(user, null, model))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void beforeUpdate(AuthenticatedUser user,
|
||||||
|
ModelType model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeUpdate(user, model);
|
||||||
|
|
||||||
|
// Validate that we can update all applicable parent groups
|
||||||
|
if (!canUpdateModifiedGroups(user, model.getIdentifier(), model))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void beforeDelete(AuthenticatedUser user,
|
||||||
|
String identifier) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeDelete(user, identifier);
|
||||||
|
|
||||||
|
// Validate that we can update all applicable parent groups
|
||||||
|
if (!canUpdateModifiedGroups(user, identifier, null))
|
||||||
|
throw new GuacamoleSecurityException("Permission denied.");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -33,11 +33,11 @@ import java.util.Map;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.user.AuthenticatedUser;
|
import org.glyptodon.guacamole.auth.jdbc.user.AuthenticatedUser;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectMapper;
|
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectMapper;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectService;
|
|
||||||
import org.glyptodon.guacamole.auth.jdbc.socket.GuacamoleSocketService;
|
import org.glyptodon.guacamole.auth.jdbc.socket.GuacamoleSocketService;
|
||||||
import org.glyptodon.guacamole.GuacamoleClientException;
|
import org.glyptodon.guacamole.GuacamoleClientException;
|
||||||
import org.glyptodon.guacamole.GuacamoleException;
|
import org.glyptodon.guacamole.GuacamoleException;
|
||||||
import org.glyptodon.guacamole.GuacamoleSecurityException;
|
import org.glyptodon.guacamole.GuacamoleSecurityException;
|
||||||
|
import org.glyptodon.guacamole.auth.jdbc.base.GroupedDirectoryObjectService;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.permission.ConnectionPermissionMapper;
|
import org.glyptodon.guacamole.auth.jdbc.permission.ConnectionPermissionMapper;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.permission.ObjectPermissionMapper;
|
import org.glyptodon.guacamole.auth.jdbc.permission.ObjectPermissionMapper;
|
||||||
import org.glyptodon.guacamole.net.GuacamoleSocket;
|
import org.glyptodon.guacamole.net.GuacamoleSocket;
|
||||||
@@ -55,7 +55,7 @@ import org.glyptodon.guacamole.protocol.GuacamoleClientInformation;
|
|||||||
*
|
*
|
||||||
* @author Michael Jumper, James Muehlner
|
* @author Michael Jumper, James Muehlner
|
||||||
*/
|
*/
|
||||||
public class ConnectionService extends DirectoryObjectService<ModeledConnection, Connection, ConnectionModel> {
|
public class ConnectionService extends GroupedDirectoryObjectService<ModeledConnection, Connection, ConnectionModel> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Mapper for accessing connections.
|
* Mapper for accessing connections.
|
||||||
@@ -148,9 +148,11 @@ public class ConnectionService extends DirectoryObjectService<ModeledConnection,
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateNewModel(AuthenticatedUser user,
|
protected void beforeCreate(AuthenticatedUser user,
|
||||||
ConnectionModel model) throws GuacamoleException {
|
ConnectionModel model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeCreate(user, model);
|
||||||
|
|
||||||
// Name must not be blank
|
// Name must not be blank
|
||||||
if (model.getName().trim().isEmpty())
|
if (model.getName().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("Connection names must not be blank.");
|
throw new GuacamoleClientException("Connection names must not be blank.");
|
||||||
@@ -163,9 +165,11 @@ public class ConnectionService extends DirectoryObjectService<ModeledConnection,
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateExistingModel(AuthenticatedUser user,
|
protected void beforeUpdate(AuthenticatedUser user,
|
||||||
ConnectionModel model) throws GuacamoleException {
|
ConnectionModel model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeUpdate(user, model);
|
||||||
|
|
||||||
// Name must not be blank
|
// Name must not be blank
|
||||||
if (model.getName().trim().isEmpty())
|
if (model.getName().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("Connection names must not be blank.");
|
throw new GuacamoleClientException("Connection names must not be blank.");
|
||||||
@@ -179,7 +183,7 @@ public class ConnectionService extends DirectoryObjectService<ModeledConnection,
|
|||||||
throw new GuacamoleClientException("The connection \"" + model.getName() + "\" already exists.");
|
throw new GuacamoleClientException("The connection \"" + model.getName() + "\" already exists.");
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@@ -27,11 +27,11 @@ import com.google.inject.Provider;
|
|||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.user.AuthenticatedUser;
|
import org.glyptodon.guacamole.auth.jdbc.user.AuthenticatedUser;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectMapper;
|
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectMapper;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.base.DirectoryObjectService;
|
|
||||||
import org.glyptodon.guacamole.auth.jdbc.socket.GuacamoleSocketService;
|
import org.glyptodon.guacamole.auth.jdbc.socket.GuacamoleSocketService;
|
||||||
import org.glyptodon.guacamole.GuacamoleClientException;
|
import org.glyptodon.guacamole.GuacamoleClientException;
|
||||||
import org.glyptodon.guacamole.GuacamoleException;
|
import org.glyptodon.guacamole.GuacamoleException;
|
||||||
import org.glyptodon.guacamole.GuacamoleSecurityException;
|
import org.glyptodon.guacamole.GuacamoleSecurityException;
|
||||||
|
import org.glyptodon.guacamole.auth.jdbc.base.GroupedDirectoryObjectService;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.permission.ConnectionGroupPermissionMapper;
|
import org.glyptodon.guacamole.auth.jdbc.permission.ConnectionGroupPermissionMapper;
|
||||||
import org.glyptodon.guacamole.auth.jdbc.permission.ObjectPermissionMapper;
|
import org.glyptodon.guacamole.auth.jdbc.permission.ObjectPermissionMapper;
|
||||||
import org.glyptodon.guacamole.net.GuacamoleSocket;
|
import org.glyptodon.guacamole.net.GuacamoleSocket;
|
||||||
@@ -48,7 +48,7 @@ import org.glyptodon.guacamole.protocol.GuacamoleClientInformation;
|
|||||||
*
|
*
|
||||||
* @author Michael Jumper, James Muehlner
|
* @author Michael Jumper, James Muehlner
|
||||||
*/
|
*/
|
||||||
public class ConnectionGroupService extends DirectoryObjectService<ModeledConnectionGroup,
|
public class ConnectionGroupService extends GroupedDirectoryObjectService<ModeledConnectionGroup,
|
||||||
ConnectionGroup, ConnectionGroupModel> {
|
ConnectionGroup, ConnectionGroupModel> {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -130,9 +130,11 @@ public class ConnectionGroupService extends DirectoryObjectService<ModeledConnec
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateNewModel(AuthenticatedUser user,
|
protected void beforeCreate(AuthenticatedUser user,
|
||||||
ConnectionGroupModel model) throws GuacamoleException {
|
ConnectionGroupModel model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeCreate(user, model);
|
||||||
|
|
||||||
// Name must not be blank
|
// Name must not be blank
|
||||||
if (model.getName().trim().isEmpty())
|
if (model.getName().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("Connection group names must not be blank.");
|
throw new GuacamoleClientException("Connection group names must not be blank.");
|
||||||
@@ -145,9 +147,11 @@ public class ConnectionGroupService extends DirectoryObjectService<ModeledConnec
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateExistingModel(AuthenticatedUser user,
|
protected void beforeUpdate(AuthenticatedUser user,
|
||||||
ConnectionGroupModel model) throws GuacamoleException {
|
ConnectionGroupModel model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeUpdate(user, model);
|
||||||
|
|
||||||
// Name must not be blank
|
// Name must not be blank
|
||||||
if (model.getName().trim().isEmpty())
|
if (model.getName().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("Connection group names must not be blank.");
|
throw new GuacamoleClientException("Connection group names must not be blank.");
|
||||||
|
@@ -126,9 +126,11 @@ public class UserService extends DirectoryObjectService<ModeledUser, User, UserM
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateNewModel(AuthenticatedUser user, UserModel model)
|
protected void beforeCreate(AuthenticatedUser user, UserModel model)
|
||||||
throws GuacamoleException {
|
throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeCreate(user, model);
|
||||||
|
|
||||||
// Username must not be blank
|
// Username must not be blank
|
||||||
if (model.getIdentifier().trim().isEmpty())
|
if (model.getIdentifier().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("The username must not be blank.");
|
throw new GuacamoleClientException("The username must not be blank.");
|
||||||
@@ -141,9 +143,11 @@ public class UserService extends DirectoryObjectService<ModeledUser, User, UserM
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void validateExistingModel(AuthenticatedUser user,
|
protected void beforeUpdate(AuthenticatedUser user,
|
||||||
UserModel model) throws GuacamoleException {
|
UserModel model) throws GuacamoleException {
|
||||||
|
|
||||||
|
super.beforeUpdate(user, model);
|
||||||
|
|
||||||
// Username must not be blank
|
// Username must not be blank
|
||||||
if (model.getIdentifier().trim().isEmpty())
|
if (model.getIdentifier().trim().isEmpty())
|
||||||
throw new GuacamoleClientException("The username must not be blank.");
|
throw new GuacamoleClientException("The username must not be blank.");
|
||||||
|
Reference in New Issue
Block a user