org.sonar.db.user.RoleDao Maven / Gradle / Ivy
/*
* SonarQube
* Copyright (C) 2009-2016 SonarSource SA
* mailto:contact AT sonarsource DOT com
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 3 of the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public License
* along with this program; if not, write to the Free Software Foundation,
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
*/
package org.sonar.db.user;
import java.util.List;
import javax.annotation.Nullable;
import org.apache.ibatis.session.SqlSession;
import org.sonar.api.security.DefaultGroups;
import org.sonar.db.Dao;
import org.sonar.db.DbSession;
public class RoleDao implements Dao {
public List selectUserPermissions(DbSession session, String userLogin, @Nullable Long resourceId) {
return session.getMapper(RoleMapper.class).selectUserPermissions(userLogin, resourceId);
}
public List selectGroupPermissions(DbSession session, String groupName, @Nullable Long resourceId) {
return session.getMapper(RoleMapper.class).selectGroupPermissions(groupName, resourceId, DefaultGroups.isAnyone(groupName));
}
public void insertGroupRole(DbSession session, GroupRoleDto groupRole) {
mapper(session).insertGroupRole(groupRole);
}
public void insertUserRole(DbSession session, UserRoleDto userRole) {
mapper(session).insertUserRole(userRole);
}
public void deleteUserRole(UserRoleDto userRole, SqlSession session) {
mapper(session).deleteUserRole(userRole);
}
public void deleteGroupRole(GroupRoleDto groupRole, SqlSession session) {
mapper(session).deleteGroupRole(groupRole);
}
public void deleteGroupRolesByResourceId(DbSession session, Long resourceId) {
mapper(session).deleteGroupRolesByResourceId(resourceId);
}
public void deleteUserRolesByResourceId(DbSession session, Long resourceId) {
mapper(session).deleteUserRolesByResourceId(resourceId);
}
public int countResourceGroupRoles(DbSession session, Long resourceId) {
return mapper(session).countResourceGroupRoles(resourceId);
}
public int countResourceUserRoles(DbSession session, Long resourceId) {
return mapper(session).countResourceUserRoles(resourceId);
}
public void deleteGroupRolesByGroupId(DbSession session, long groupId) {
mapper(session).deleteGroupRolesByGroupId(groupId);
}
public int countComponentPermissions(DbSession session, Long componentId) {
return countResourceGroupRoles(session, componentId) + countResourceUserRoles(session, componentId);
}
public int countUserPermissions(DbSession session, String permission, @Nullable Long allGroupsExceptThisGroupId) {
return mapper(session).countUsersWithPermission(permission, allGroupsExceptThisGroupId);
}
public void removeAllPermissions(DbSession session, Long resourceId) {
deleteGroupRolesByResourceId(session, resourceId);
deleteUserRolesByResourceId(session, resourceId);
}
private static RoleMapper mapper(SqlSession session) {
return session.getMapper(RoleMapper.class);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy