//$Id: AuthorityService.java,v 1.5 2007/01/13 07:06:51 chaostone Exp $ /* * * Copyright c 2005-2009 * Licensed under the Apache License, Version 2.0 (the "License") * http://www.apache.org/licenses/LICENSE-2.0 * */ /******************************************************************************** * @author chaostone * * MODIFICATION DESCRIPTION * * Name Date Description * ============ ============ ============ * dell Created * chaostone 2005-9-26 rename * ********************************************************************************/ package org.beanfuse.security.service; import java.util.Collection; import java.util.List; import java.util.Set; import org.beanfuse.security.Authority; import org.beanfuse.security.Group; import org.beanfuse.security.Resource; import org.beanfuse.security.User; import org.beanfuse.security.dao.AuthorityDao; /** * 用户用户组权限管理服务接口. 权限实体@see <code>Authority</code> 系统资源实体@see * <code>Resource</code> 系统功能点实体@see <code>Action</code> 数据权限实体@see * <code>Restriction</code> * * @author dell,chaostone 2005-9-27 */ public interface AuthorityService { /** * 按照资源名称查询单独的资源 * @param name * @return */ public Resource getResource(String name); /** * 查询用户的访问资源范围 * @param user * @return */ public List getResources(User user); /** * 用户组内对应的资源 * * @param group * @return */ public List getResources(Group group); /** * 用户组内对应的资源ID * * @param group * @return */ public Set getResourceIds(Group group); /** * 依据默认深度(小于或等于)得到用户的所有权限 * * @param user * @return */ public List getAuthorities(User user); /** * 依据默认深度得到用户组拥有的权限 * * @param group * @return */ public List getAuthorities(Group group); /** * 依据资源和用户取得对应的权限 * @param user * @param resource * @return */ public Authority getAuthority(User user, Resource resource); /** * 依据资源和用户组取得对应的权限 * * @param userId * @param resource * @return */ public Authority getAuthority(Group group, Resource resource); /** * 保存新的权限设置 * * @param authority */ public void saveOrUpdate(Authority authority); /** * 删除权限的信息设置 * * @param authority */ public void remove(Authority authority); /** * 授权 * * @param ao * @param resources * @param authorityClass */ public void authorize(Group group, Set resources); /** * 拷贝权限 * * @param fromGroup * @param toGroups */ public void copyAuthority(Group fromGroup, Collection toGroups); public void setAuthorityDao(AuthorityDao authorityDao); public void setUserService(UserService userService); }