mirror of
https://github.com/gyurix1968/guacamole-client.git
synced 2025-09-06 21:27:40 +00:00
GUACAMOLE-220: Map and allow manipulation of the user group parents of users.
This commit is contained in:
@@ -91,6 +91,7 @@ import org.apache.guacamole.auth.jdbc.usergroup.UserGroupParentUserGroupMapper;
|
|||||||
import org.apache.guacamole.auth.jdbc.usergroup.UserGroupService;
|
import org.apache.guacamole.auth.jdbc.usergroup.UserGroupService;
|
||||||
import org.mybatis.guice.MyBatisModule;
|
import org.mybatis.guice.MyBatisModule;
|
||||||
import org.mybatis.guice.datasource.builtin.PooledDataSourceProvider;
|
import org.mybatis.guice.datasource.builtin.PooledDataSourceProvider;
|
||||||
|
import org.apache.guacamole.auth.jdbc.user.UserParentUserGroupMapper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Guice module which configures the injections used by the JDBC authentication
|
* Guice module which configures the injections used by the JDBC authentication
|
||||||
@@ -144,6 +145,7 @@ public class JDBCAuthenticationProviderModule extends MyBatisModule {
|
|||||||
addMapperClass(UserGroupParentUserGroupMapper.class);
|
addMapperClass(UserGroupParentUserGroupMapper.class);
|
||||||
addMapperClass(UserGroupPermissionMapper.class);
|
addMapperClass(UserGroupPermissionMapper.class);
|
||||||
addMapperClass(UserMapper.class);
|
addMapperClass(UserMapper.class);
|
||||||
|
addMapperClass(UserParentUserGroupMapper.class);
|
||||||
addMapperClass(UserPermissionMapper.class);
|
addMapperClass(UserPermissionMapper.class);
|
||||||
addMapperClass(UserRecordMapper.class);
|
addMapperClass(UserRecordMapper.class);
|
||||||
|
|
||||||
|
@@ -20,6 +20,7 @@
|
|||||||
package org.apache.guacamole.auth.jdbc.user;
|
package org.apache.guacamole.auth.jdbc.user;
|
||||||
|
|
||||||
import com.google.inject.Inject;
|
import com.google.inject.Inject;
|
||||||
|
import com.google.inject.Provider;
|
||||||
import java.sql.Date;
|
import java.sql.Date;
|
||||||
import java.sql.Time;
|
import java.sql.Time;
|
||||||
import java.sql.Timestamp;
|
import java.sql.Timestamp;
|
||||||
@@ -49,7 +50,6 @@ import org.apache.guacamole.net.auth.ActivityRecord;
|
|||||||
import org.apache.guacamole.net.auth.Permissions;
|
import org.apache.guacamole.net.auth.Permissions;
|
||||||
import org.apache.guacamole.net.auth.RelatedObjectSet;
|
import org.apache.guacamole.net.auth.RelatedObjectSet;
|
||||||
import org.apache.guacamole.net.auth.User;
|
import org.apache.guacamole.net.auth.User;
|
||||||
import org.apache.guacamole.net.auth.simple.SimpleRelatedObjectSet;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
@@ -176,6 +176,13 @@ public class ModeledUser extends ModeledPermissions<UserModel> implements User {
|
|||||||
@Inject
|
@Inject
|
||||||
private SaltService saltService;
|
private SaltService saltService;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Provider for RelatedObjectSets containing the user groups of which this
|
||||||
|
* user is a member.
|
||||||
|
*/
|
||||||
|
@Inject
|
||||||
|
private Provider<UserParentUserGroupSet> parentUserGroupSetProvider;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether attributes which control access restrictions should be exposed
|
* Whether attributes which control access restrictions should be exposed
|
||||||
* via getAttributes() or allowed to be set via setAttributes().
|
* via getAttributes() or allowed to be set via setAttributes().
|
||||||
@@ -747,7 +754,9 @@ public class ModeledUser extends ModeledPermissions<UserModel> implements User {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public RelatedObjectSet getUserGroups() throws GuacamoleException {
|
public RelatedObjectSet getUserGroups() throws GuacamoleException {
|
||||||
return new SimpleRelatedObjectSet();
|
UserParentUserGroupSet parentUserGroupSet = parentUserGroupSetProvider.get();
|
||||||
|
parentUserGroupSet.init(getCurrentUser(), this);
|
||||||
|
return parentUserGroupSet;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@@ -0,0 +1,28 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.guacamole.auth.jdbc.user;
|
||||||
|
|
||||||
|
import org.apache.guacamole.auth.jdbc.base.ObjectRelationMapper;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mapper for the one-to-many relationship between a user and the user groups
|
||||||
|
* of which it is a member.
|
||||||
|
*/
|
||||||
|
public interface UserParentUserGroupMapper extends ObjectRelationMapper<UserModel> {}
|
@@ -0,0 +1,59 @@
|
|||||||
|
/*
|
||||||
|
* Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
* or more contributor license agreements. See the NOTICE file
|
||||||
|
* distributed with this work for additional information
|
||||||
|
* regarding copyright ownership. The ASF licenses this file
|
||||||
|
* to you under the Apache License, Version 2.0 (the
|
||||||
|
* "License"); you may not use this file except in compliance
|
||||||
|
* with the License. You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing,
|
||||||
|
* software distributed under the License is distributed on an
|
||||||
|
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
* KIND, either express or implied. See the License for the
|
||||||
|
* specific language governing permissions and limitations
|
||||||
|
* under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.apache.guacamole.auth.jdbc.user;
|
||||||
|
|
||||||
|
import com.google.inject.Inject;
|
||||||
|
import org.apache.guacamole.GuacamoleException;
|
||||||
|
import org.apache.guacamole.auth.jdbc.base.ObjectRelationMapper;
|
||||||
|
import org.apache.guacamole.auth.jdbc.base.RelatedObjectSet;
|
||||||
|
import org.apache.guacamole.net.auth.permission.ObjectPermissionSet;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* RelatedObjectSet implementation which represents the one-to-many
|
||||||
|
* relationship between a particular user and the user groups of which it is a
|
||||||
|
* member.
|
||||||
|
*/
|
||||||
|
public class UserParentUserGroupSet extends RelatedObjectSet<ModeledUser, UserModel> {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Mapper for the relations between users and the user groups of which they
|
||||||
|
* are members.
|
||||||
|
*/
|
||||||
|
@Inject
|
||||||
|
private UserParentUserGroupMapper userParentUserGroupMapper;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ObjectRelationMapper<UserModel> getObjectRelationMapper() {
|
||||||
|
return userParentUserGroupMapper;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ObjectPermissionSet
|
||||||
|
getParentObjectEffectivePermissionSet() throws GuacamoleException {
|
||||||
|
return getCurrentUser().getUser().getEffectivePermissions().getUserPermissions();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected ObjectPermissionSet getChildObjectEffectivePermissionSet()
|
||||||
|
throws GuacamoleException {
|
||||||
|
return getCurrentUser().getUser().getEffectivePermissions().getUserGroupPermissions();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@@ -0,0 +1,96 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
|
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
|
||||||
|
|
||||||
|
<!--
|
||||||
|
Licensed to the Apache Software Foundation (ASF) under one
|
||||||
|
or more contributor license agreements. See the NOTICE file
|
||||||
|
distributed with this work for additional information
|
||||||
|
regarding copyright ownership. The ASF licenses this file
|
||||||
|
to you under the Apache License, Version 2.0 (the
|
||||||
|
"License"); you may not use this file except in compliance
|
||||||
|
with the License. You may obtain a copy of the License at
|
||||||
|
|
||||||
|
http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
|
||||||
|
Unless required by applicable law or agreed to in writing,
|
||||||
|
software distributed under the License is distributed on an
|
||||||
|
"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
||||||
|
KIND, either express or implied. See the License for the
|
||||||
|
specific language governing permissions and limitations
|
||||||
|
under the License.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<mapper namespace="org.apache.guacamole.auth.jdbc.user.UserParentUserGroupMapper" >
|
||||||
|
|
||||||
|
<!-- Select the names of all parent user groups -->
|
||||||
|
<select id="selectChildIdentifiers" resultType="string">
|
||||||
|
SELECT name
|
||||||
|
FROM guacamole_user_group_member
|
||||||
|
JOIN guacamole_user_group ON guacamole_user_group_member.user_group_id = guacamole_user_group.user_group_id
|
||||||
|
JOIN guacamole_entity ON guacamole_entity.entity_id = guacamole_user_group.entity_id
|
||||||
|
WHERE
|
||||||
|
guacamole_user_group_member.member_entity_id = #{parent.entityID,jdbcType=INTEGER}
|
||||||
|
AND guacamole_entity.type = 'USER_GROUP'::guacamole_entity_type
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<!-- Select the names of all readable parent user groups -->
|
||||||
|
<select id="selectReadableChildIdentifiers" resultType="string">
|
||||||
|
SELECT guacamole_entity.name
|
||||||
|
FROM guacamole_user_group_member
|
||||||
|
JOIN guacamole_user_group ON guacamole_user_group_member.user_group_id = guacamole_user_group.user_group_id
|
||||||
|
JOIN guacamole_entity ON guacamole_entity.entity_id = guacamole_user_group.entity_id
|
||||||
|
JOIN guacamole_user_group_permission ON affected_user_group_id = guacamole_user_group.user_group_id
|
||||||
|
WHERE
|
||||||
|
<include refid="org.apache.guacamole.auth.jdbc.base.EntityMapper.isRelatedEntity">
|
||||||
|
<property name="column" value="guacamole_user_group_permission.entity_id"/>
|
||||||
|
<property name="entityID" value="#{user.entityID,jdbcType=INTEGER}"/>
|
||||||
|
<property name="groups" value="effectiveGroups"/>
|
||||||
|
</include>
|
||||||
|
AND guacamole_user_group_member.member_entity_id = #{parent.entityID,jdbcType=INTEGER}
|
||||||
|
AND guacamole_entity.type = 'USER_GROUP'::guacamole_entity_type
|
||||||
|
AND permission = 'READ'
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<!-- Delete parent groups by name -->
|
||||||
|
<delete id="delete">
|
||||||
|
DELETE FROM guacamole_user_group_member
|
||||||
|
USING guacamole_user_group, guacamole_entity
|
||||||
|
WHERE
|
||||||
|
member_entity_id = #{parent.entityID,jdbcType=INTEGER}
|
||||||
|
AND guacamole_user_group.user_group_id = guacamole_user_group_member.user_group_id
|
||||||
|
AND guacamole_entity.entity_id = guacamole_user_group.entity_id
|
||||||
|
AND guacamole_entity.type = 'USER_GROUP'::guacamole_entity_type
|
||||||
|
AND guacamole_entity.name IN
|
||||||
|
<foreach collection="children" item="identifier"
|
||||||
|
open="(" separator="," close=")">
|
||||||
|
#{identifier,jdbcType=VARCHAR}
|
||||||
|
</foreach>
|
||||||
|
</delete>
|
||||||
|
|
||||||
|
<!-- Insert parent groups by name -->
|
||||||
|
<insert id="insert">
|
||||||
|
INSERT INTO guacamole_user_group_member (
|
||||||
|
user_group_id,
|
||||||
|
member_entity_id
|
||||||
|
)
|
||||||
|
SELECT DISTINCT
|
||||||
|
guacamole_user_group.user_group_id,
|
||||||
|
#{parent.entityID,jdbcType=INTEGER}
|
||||||
|
FROM guacamole_user_group
|
||||||
|
JOIN guacamole_entity ON guacamole_user_group.entity_id = guacamole_entity.entity_id
|
||||||
|
WHERE
|
||||||
|
guacamole_entity.name IN
|
||||||
|
<foreach collection="children" item="identifier"
|
||||||
|
open="(" separator="," close=")">
|
||||||
|
#{identifier,jdbcType=VARCHAR}
|
||||||
|
</foreach>
|
||||||
|
AND guacamole_entity.type = 'USER_GROUP'::guacamole_entity_type
|
||||||
|
AND guacamole_user_group.user_group_id NOT IN (
|
||||||
|
SELECT guacamole_user_group_member.user_group_id
|
||||||
|
FROM guacamole_user_group_member
|
||||||
|
WHERE guacamole_user_group_member.member_entity_id = #{parent.entityID,jdbcType=INTEGER}
|
||||||
|
)
|
||||||
|
</insert>
|
||||||
|
|
||||||
|
</mapper>
|
Reference in New Issue
Block a user