package com.vci.frameworkcore.compatibility.impl; import com.alibaba.fastjson.JSONObject; import com.vci.corba.common.PLException; import com.vci.corba.framework.data.FunctionInfo; import com.vci.corba.framework.data.RoleRightInfo; import com.vci.corba.omd.data.BusinessObject; import com.vci.corba.portal.data.PLUILayout; import com.vci.frameworkcore.compatibility.ISmFunctionQueryService; import com.vci.frameworkcore.enumpck.ResourceControlTypeEnum; import com.vci.model.SmFunctionForPlatform1; import com.vci.model.SmRoleForPlatform1; import com.vci.pagemodel.MenuVO; import com.vci.pagemodel.SmFunctionVO; import com.vci.omd.utils.ObjectTool; import com.vci.pagemodel.SmFunctionVO; import com.vci.starter.web.constant.QueryOptionConstant; import com.vci.starter.web.exception.VciBaseException; import com.vci.starter.web.pagemodel.*; import com.vci.starter.web.wrapper.VciQueryWrapperForDO; import com.vci.pagemodel.UIContentVO; import com.vci.web.service.UIEngineServiceI; import com.vci.web.service.WebBoServiceI; import com.vci.web.util.PlatformClientUtil; import com.vci.web.util.RightControlUtil; import com.vci.web.util.WebUtil; import org.apache.commons.lang3.StringUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.context.annotation.Lazy; import org.springframework.stereotype.Service; import org.springframework.util.CollectionUtils; import java.util.*; import java.util.stream.Collectors; /** * 老平台的权限服务 * @author weidy * @date 2020/3/1 */ @Service public class SmFunctionQueryServicePlatformImpl implements ISmFunctionQueryService { /** * 日志 */ private Logger logger = LoggerFactory.getLogger(getClass()); /** * 菜单的根节点主键,这个是平台定义的 */ private final String ROOT_MENU_Id = "modelManagmentNode"; /** * 使用用户查询 */ public static final String QUERY_BY_USER = "select r.PLFUNCOID from plroleright r left join pluserrole u on r.PLROLEOID = u.PLROLEUID "; /** * 业务数据服务 */ @Autowired private WebBoServiceI boService; /** * 加载自身 */ @Autowired(required = false) @Lazy private ISmFunctionQueryService self; @Autowired private UIEngineServiceI uiEngineServiceI; @Autowired private PlatformClientUtil platformClientUtil; @Autowired RightControlUtil rightControlUtil; /** * 查询所有的功能 * * @return 功能的显示对象 */ @Override public List selectAllFunction() { VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(null, SmFunctionForPlatform1.class); List functions = boService.selectByQueryWrapper(queryWrapper, SmFunctionForPlatform1.class); return functionForPlatform1ToFunctionDOs(functions); } /** * 查询所有的功能映射 * * @return 功能的显示对象 */ @Override public Map selectAllFunctionMap() { return Optional.ofNullable(self.selectAllFunction()).orElseGet(()->new ArrayList<>()).stream().collect(Collectors.toMap(s->s.getOid(),t->t)); } /** * 根据用户查询关联的权限 * * @param userOid 用户的主键 * @param queryMap 查询条件,如果要用用户的属性查询,可以使用pkUser.xxx * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象,未转化为上下级关系 */ @Override public List listFunctionByUserOid(String userOid, Map queryMap, ResourceControlTypeEnum resourceControlTypeEnum) { if(StringUtils.isBlank(userOid)){ return new ArrayList<>(); } VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(queryMap,SmFunctionForPlatform1.class); queryWrapper.in("ploid",QUERY_BY_USER + " where u.pluseruid = '" + userOid.trim() + "'"); List functions = boService.selectByQueryWrapper(queryWrapper, SmFunctionForPlatform1.class); if(CollectionUtils.isEmpty(functions)){ return new ArrayList<>(); } //TODO 密级的控制 //超级管理员,一般不让登录,登录后可以看业务的功能,也可以看管理功能 //三员的,只看管理的 //普通的只看业务的 if(resourceControlTypeEnum == null){ resourceControlTypeEnum = ResourceControlTypeEnum.BS; } String controlType = resourceControlTypeEnum.getValue(); List functionVOS = functionForPlatform1ToFunctionDOs(functions); return functionVOS.stream().filter(s->controlType.equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); } /** * 原平台功能转换为新平台的功能 * @param functionForPlatform1List 原平台功能对象列表 * @return 新平台功能对象 */ private List functionForPlatform1ToFunctionDOs(List functionForPlatform1List){ List functionVOList = new ArrayList(); if(!CollectionUtils.isEmpty(functionForPlatform1List)){ for(int i = 0 ; i < functionForPlatform1List.size(); i ++ ) { functionVOList.add(functionForPlatform1ToFunctionVO(functionForPlatform1List.get(i))); } } return functionVOList; } /** * 原平台功能转换为新平台的功能 * * @param functionForPlatform1 原平台功能对象 * @return 新平台功能对象 */ private SmFunctionVO functionForPlatform1ToFunctionVO(SmFunctionForPlatform1 functionForPlatform1){ SmFunctionVO functionVO = new SmFunctionVO(); functionVO.setOid(functionForPlatform1.getPloid()); functionVO.setId(String.valueOf(functionForPlatform1.getPlmoduleno())); functionVO.setName(functionForPlatform1.getPlname()); functionVO.setLogName(functionForPlatform1.getPlaliasname()); if(StringUtils.isNotBlank(functionForPlatform1.getPlresourceb())){ functionVO.setResourceControlType(ResourceControlTypeEnum.BS.getValue()); functionVO.setUrl(functionForPlatform1.getPlresourceb()); }else if(StringUtils.isNotBlank(functionForPlatform1.getPlresourcedotnet())) { functionVO.setResourceControlType(ResourceControlTypeEnum.DOTNET.getValue()); functionVO.setUrl(functionForPlatform1.getPlresourcedotnet()); }else if(StringUtils.isNotBlank(functionForPlatform1.getPlresourcemobil())) { functionVO.setResourceControlType(ResourceControlTypeEnum.MOBILE.getValue()); functionVO.setUrl(functionForPlatform1.getPlresourcemobil()); }else { functionVO.setResourceControlType(ResourceControlTypeEnum.CS.getValue()); functionVO.setUrl(functionForPlatform1.getPlresourcec()); } functionVO.setResourceControlTypeText(ResourceControlTypeEnum.getTextByValue(functionVO.getResourceControlType())); functionVO.setDisplayFlag((functionForPlatform1.getPlisvalid() !=null&& 1 == functionForPlatform1.getPlisvalid())? true:false); functionVO.setControlRightFlag(true); functionVO.setParentFunctionId(functionForPlatform1.getPlparentid()); functionVO.setOrderNum(functionForPlatform1.getPlmodulesequence()); if(StringUtils.isNotBlank(functionForPlatform1.getPlimage())) { functionVO.setIconCss(functionForPlatform1.getPlimage()); } //以前的老图标没办法转换了,但是支持layui的图标 if(StringUtils.isNotBlank(functionForPlatform1.getPldesc())){ //需要在平台中设置菜单的图标路径,在描述字段中添加 //{iconSrc:xxxx,desc:yyyy} try{ JSONObject jo = JSONObject.parseObject(functionForPlatform1.getPldesc()); if(jo!=null&&jo.containsKey("iconSrc")){ functionVO.setIconCss(jo.getString("iconSrc")); } if(jo!=null&&jo.containsKey("desc")){ functionVO.setDescription(jo.getString("desc")); } }catch(Exception e){ functionVO.setDescription(functionForPlatform1.getPldesc()); } } functionVO.setBtmname("function"); //老的数据里创建人,最后修改人等都没有 return functionVO; } /** * 获取当前角色的菜单 * * @param treeQueryObject 属性查询对象 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 菜单,包含上下级 */ @Override public List treeCurrentUserMenu(TreeQueryObject treeQueryObject, ResourceControlTypeEnum resourceControlTypeEnum) throws PLException { SessionInfo sessionInfo = WebUtil.getCurrentUserSessionInfoNotException(); String parentId; if (rightControlUtil.isAdminOrDeveloperOrRoot(sessionInfo.getUserId())) { // 系统菜单 parentId = "systemManagmentNode" ; } else if (rightControlUtil.isThreeAdminCurUser()) { parentId = "systemManagmentNode" ; } else { parentId = "modelManagmentNode" ; } RoleRightInfo[] userRoleRights = rightControlUtil.getRoleRightByUserName(sessionInfo.getUserId()); Map> map = rightControlUtil.getAllChildrenFunctionsByUserName( parentId, sessionInfo.getUserId(), userRoleRights); List functionVOList = new ArrayList<>(); if(CollectionUtils.isEmpty(map.get(parentId))){ return functionVOList; } for (FunctionInfo menu : map.get(parentId)) { if(!menu.isValid){ continue; } MenuVO functionVO = new MenuVO(); functionVO.setId(menu.id); functionVO.setSource(menu.image); // if(StringUtils.isBlank(menu.resourceB)){ // continue; // } functionVO.setPath(menu.resourceB); functionVO.setParentId(menu.parentId); functionVO.setCode(menu.aliasName); functionVO.setAlias(menu.aliasName); functionVO.setName(menu.name); functionVO.getMeta().put("keepAlive",false); functionVO.setSort((int) menu.seq); functionVO.setChildren(findChildFunctionVO(menu.id, map)); if(functionVO.getChildren().size() > 0){ functionVO.setHasChildren(true); }else { functionVO.setHasChildren(false); } functionVOList.add(functionVO); } return functionVOList.stream().sorted(Comparator.comparing(s -> s.getSort())).collect(Collectors.toList()); } public List findChildFunctionVO(String parentOid,Map> map) throws PLException { List menus = map.get(parentOid); List functionVOList = new ArrayList<>(); if(menus == null){ return functionVOList; } for (FunctionInfo menu : menus) { if(!menu.isValid){ continue; } MenuVO functionVO = new MenuVO(); functionVO.setId(menu.id); functionVO.setSource(menu.image); // if(StringUtils.isBlank(menu.resourceB) ){ // continue; // } functionVO.setPath(menu.resourceB); functionVO.setCode(menu.aliasName); functionVO.setAlias(menu.aliasName); functionVO.setParentId(menu.parentId); functionVO.setName(menu.name); functionVO.getMeta().put("keepAlive",false); functionVO.setSort((int) menu.seq); functionVO.setChildren(findChildFunctionVO(menu.id,map)); if(functionVO.getChildren().size() > 0){ functionVO.setHasChildren(true); }else { functionVO.setHasChildren(false); } functionVOList.add(functionVO); } return functionVOList.stream().sorted(Comparator.comparing(s -> s.getSort())).collect(Collectors.toList()); } @Override public UIContentVO getUIContentByBtmTypeAndId(TreeQueryObject treeQueryObject, ResourceControlTypeEnum resourceControlTypeEnum) throws PLException { SessionInfo sessionInfo = WebUtil.getCurrentUserSessionInfoNotException(); if(resourceControlTypeEnum == null){ resourceControlTypeEnum = ResourceControlTypeEnum.BS; } for (PLUILayout allPLUILayout : platformClientUtil.getUIService().getAllPLUILayouts()) { if(treeQueryObject.getConditionMap().getOrDefault("type","").equals(allPLUILayout.plRelatedType) && treeQueryObject.getConditionMap().getOrDefault("context","").equals(allPLUILayout.plCode)){ return uiEngineServiceI.UIContentDO2VO(allPLUILayout,true); } } return null; } /** * 获取所有的功能菜单 * * @param treeQueryObject 树查询对象 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 树节点,出现错误会在异常处理器中统一返回Json */ @Override public List treeAllMenu(TreeQueryObject treeQueryObject, ResourceControlTypeEnum resourceControlTypeEnum) { List functionVOList = self.selectAllFunction().stream().filter(s -> s.isDisplayFlag() && resourceControlTypeEnum.getValue().equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); if(!treeQueryObject.isQueryAllLevel() && StringUtils.isNotBlank(treeQueryObject.getParentOid())){ functionVOList = functionVOList.stream().filter(s->treeQueryObject.getParentOid().equalsIgnoreCase(s.getParentFunctionId())).collect(Collectors.toList()); } return dos2Trees(functionVOList.stream().sorted(Comparator.comparing(s -> s.getOrderNum())).collect(Collectors.toList()),treeQueryObject == null?null:treeQueryObject.getParentOid()); } /** * 批量将数据对象转换为树节点 * @param functionVOList 数据对象列表 * @param rootId 根节点的主键,最顶层使用null或者"" * @return 树节点列表,不存在数据时返回空列表 */ public List dos2Trees(List functionVOList,String rootId){ if(!CollectionUtils.isEmpty(functionVOList)) { List rootList = new ArrayList<>(); List childList = new ArrayList<>(); functionVOList.stream().forEach(s -> { Tree tree = DO2Tree(s); if (tree.getParentId() == null || tree.getParentId().equals(rootId) || ROOT_MENU_Id.equalsIgnoreCase(tree.getParentId())) { rootList.add(tree); } else { childList.add(tree); } }); return Tree.getChildList(rootList, childList); }else{ return new ArrayList<>(); } } /** * 数据对象转换为树节点 * @param functionVO 数据显示对象 * @return 树节点对象 */ public Tree DO2Tree(SmFunctionVO functionVO){ Tree tree = new Tree(); tree.setOid(functionVO.getOid()); tree.setText(functionVO.getName()); tree.setIndex(functionVO.getOrderNum() + ""); tree.setParentId(functionVO.getParentFunctionId()); tree.setIconCls(functionVO.getIconCss()); tree.setHref(functionVO.getUrl()); try { tree.setAttributes(WebUtil.objectToMapString(functionVO)); } catch (Throwable e) { logger.error("拷贝信息",e); } return tree; } /** * 通过上级节点获取下级的所有的菜单节点 * * @param treeQueryObject 树查询对象 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 树节点,出现错误会在异常处理器中统一返回Json */ @Override public List treeFunctionByParent(TreeQueryObject treeQueryObject, ResourceControlTypeEnum resourceControlTypeEnum) { List functionVOList = self.selectAllFunction().stream().filter(s -> s.isDisplayFlag() && resourceControlTypeEnum.getValue().equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); if(!treeQueryObject.isQueryAllLevel() && StringUtils.isNotBlank(treeQueryObject.getParentOid())){ functionVOList = functionVOList.stream().filter(s->treeQueryObject.getParentOid().equalsIgnoreCase(s.getParentFunctionId())).collect(Collectors.toList()); } return dos2Trees(functionVOList,treeQueryObject == null?null:treeQueryObject.getParentOid()); } /** * 通过上级节点获取当前角色有权限的下级的所有的菜单节点 * * @param treeQueryObject 树查询对象 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 树节点,出现错误会在异常处理器中统一返回Json */ @Override public List treeCurrentFunctionByParent(TreeQueryObject treeQueryObject, ResourceControlTypeEnum resourceControlTypeEnum) { SessionInfo sessionInfo = WebUtil.getCurrentUserSessionInfo(); List functionVOList =self.selectAllFunction().stream().filter(s -> s.isDisplayFlag() && resourceControlTypeEnum.getValue().equalsIgnoreCase(s.getResourceControlType()) && !CollectionUtils.isEmpty(sessionInfo.getFunctionOids()) && sessionInfo.getFunctionOids().contains(s.getOid()) ).collect(Collectors.toList()); if(!treeQueryObject.isQueryAllLevel() && StringUtils.isNotBlank(treeQueryObject.getParentOid())){ functionVOList = functionVOList.stream().filter(s->treeQueryObject.getParentOid().equalsIgnoreCase(s.getParentFunctionId())).collect(Collectors.toList()); } return dos2Trees(functionVOList,treeQueryObject == null?null:treeQueryObject.getParentOid()); } /** * 获取系统功能列表 * * @param queryMap 查询条件 * @param pageHelper 排序和分页对象 * @return DataGrid 系统功能列表 */ @Override public DataGrid dataGrid(Map queryMap, PageHelper pageHelper) { VciQueryWrapperForDO queryWrapperForDO = new VciQueryWrapperForDO(queryMap,SmFunctionForPlatform1.class,pageHelper); List functionForPlatform1s = boService.selectByQueryWrapper(queryWrapperForDO, SmFunctionForPlatform1.class); List functionVOS = functionForPlatform1ToFunctionDOs(functionForPlatform1s); DataGrid dataGrid = new DataGrid(); dataGrid.setData(functionVOS); if(!CollectionUtils.isEmpty(functionVOS)){ dataGrid.setTotal(boService.countByQueryWrapper(queryWrapperForDO,SmFunctionForPlatform1.class)); } return dataGrid; } /** * 根据角色主键获取关联的权限 * * @param roleOid 角色主键 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkUser.xxxx * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象 */ @Override public List listFunctionByRoleOid(String roleOid, Map queryMap, ResourceControlTypeEnum resourceControlTypeEnum) { String controlType = resourceControlTypeEnum == null? ResourceControlTypeEnum.BS.getValue(): resourceControlTypeEnum.getValue(); return Optional.ofNullable(listFunctionByRoleOid(roleOid,queryMap,false)).orElseGet(()->new ArrayList<>()).stream().filter(s->controlType.equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); } /** * 获取未关联某个角色的权限 * * @param roleOid 角色主键 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkUser.xxxx * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象 */ @Override public List listFunctionUnInRoleOid(String roleOid, Map queryMap, ResourceControlTypeEnum resourceControlTypeEnum) { String controlType = resourceControlTypeEnum == null? ResourceControlTypeEnum.BS.getValue(): resourceControlTypeEnum.getValue(); return Optional.ofNullable(listFunctionByRoleOid(roleOid,queryMap,true)).orElseGet(()->new ArrayList<>()).stream().filter(s->controlType.equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); } /** * 使用角色主键查询权限 * @param roleOid 用户主键 * @param queryMap 查询条件 * @param notIn 是否为不包含 * @return 角色的显示对象 */ private List listFunctionByRoleOid(String roleOid, Map queryMap, boolean notIn){ if(StringUtils.isBlank(roleOid)){ return new ArrayList<>(); } if(queryMap == null){ queryMap = new HashMap<>(); } List functions = new ArrayList<>(); if(roleOid.contains(",")){ Map finalQueryMap = queryMap; WebUtil.switchCollectionForOracleIn(WebUtil.str2List(roleOid)).stream().forEach(roleOids->{ Map conditionMap = new HashMap<>(); finalQueryMap.forEach((key,value)->{ conditionMap.put(key,value); }); conditionMap.put("ploid", notIn ? QueryOptionConstant.NOTIN : QueryOptionConstant.IN + "select plfuncoid from plroleright where plroleoid in (" + WebUtil.toInSql(roleOids.toArray(new String[0])) + ")"); VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(conditionMap, SmRoleForPlatform1.class); List functionForPlatform1s = boService.selectByQueryWrapper(queryWrapper, SmFunctionForPlatform1.class); if(!CollectionUtils.isEmpty(functionForPlatform1s)){ functions.addAll(functionForPlatform1s); } }); }else { queryMap.put("ploid", notIn ? QueryOptionConstant.NOTIN : QueryOptionConstant.IN + "select plfuncoid from plroleright where plroleoid ='" + roleOid.trim() + "'"); } VciQueryWrapperForDO queryWrapper = new VciQueryWrapperForDO(queryMap,SmRoleForPlatform1.class); List roleForPlatform1s = boService.selectByQueryWrapper(queryWrapper, SmFunctionForPlatform1.class); if(!CollectionUtils.isEmpty(roleForPlatform1s)){ functions.addAll(roleForPlatform1s); } return functionForPlatform1ToFunctionDOs(functions); } /** * 获取未关联某个角色的权限 * * @param roleOid 角色主键 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkUser.xxxx * @param pageHelper 分页和排序对象,老平台不支持使用权限编号来排序 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象 */ @Override public DataGrid gridFunctionUninRoleOid(String roleOid, Map queryMap, PageHelper pageHelper, ResourceControlTypeEnum resourceControlTypeEnum) { return gridFunctionByRoleOid(roleOid,queryMap,pageHelper,resourceControlTypeEnum,true); } /** * 批量根据角色的主键来获取权限 * * @param roleOidCollection 角色主键集合 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkRole.xxxx * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象,key是角色主键,value是这个角色关联的权限 */ @Override public Map> batchListFunctionByRoleOids(Collection roleOidCollection, Map queryMap, ResourceControlTypeEnum resourceControlTypeEnum) { if(CollectionUtils.isEmpty(roleOidCollection)){ return new HashMap<>(); } List functionVOList = new ArrayList<>(); Map> roleFunctionOidMap = new HashMap<>(); String roleContoll = resourceControlTypeEnum == null?ResourceControlTypeEnum.BS.getValue():resourceControlTypeEnum.getValue(); WebUtil.switchCollectionForOracleIn(roleOidCollection).stream().forEach(roleOids->{ List functionVOS = Optional.ofNullable(listFunctionByRoleOid(roleOids.stream().collect(Collectors.joining(",")), queryMap, false)).orElseGet(()->new ArrayList<>()).stream().filter(s->roleContoll.equalsIgnoreCase(s.getResourceControlType())).collect(Collectors.toList()); if(!CollectionUtils.isEmpty(functionVOS)){ functionVOList.addAll(functionVOS); String sql = "select plfuncoid,plroleoid from plroleright where plroleoid in (" + WebUtil.toInSql(roleOids.toArray(new String[0])) + ")"; List cbos = boService.queryBySql(sql, null); if(!CollectionUtils.isEmpty(cbos)){ cbos.stream().forEach(cbo->{ String roleOid = ObjectTool.getBOAttributeValue(cbo,"plroleoid"); List functionOids = roleFunctionOidMap.getOrDefault(roleOid,new ArrayList<>()); functionOids.add(ObjectTool.getBOAttributeValue(cbo,"plfuncoid")); roleFunctionOidMap.put(roleOid,functionOids); }); } } }); if(!CollectionUtils.isEmpty(functionVOList)){ Map functionVOMap = functionVOList.stream().collect(Collectors.toMap(s -> s.getOid(), t -> t)); Map> roleFunctionVOMap = new HashMap<>(); roleFunctionOidMap.forEach((roleOid,functionOids)->{ List functionVOS = new ArrayList<>(); functionOids.forEach(functionOid->{ if(functionVOMap.containsKey(functionOid)){ functionVOS.add(functionVOMap.get(functionOid)); } }); roleFunctionVOMap.put(roleOid,functionVOS); }); return roleFunctionVOMap; } return new HashMap<>(); } /** * 使用角色查询权限表 * @param roleOid 角色的主键 * @param queryMap 查询条件 * @param pageHelper 分页对象 * @param notIn 不包含 * @return 列表数据 */ private DataGrid gridFunctionByRoleOid(String roleOid,Map queryMap,PageHelper pageHelper,ResourceControlTypeEnum resourceControlTypeEnum,boolean notIn){ if(queryMap == null){ queryMap = new HashMap<>(); } if(StringUtils.isBlank(roleOid)){ return new DataGrid<>(); } if(roleOid.contains(",")){ String[] roleOids = roleOid.trim().split(","); if(roleOids.length>1000){ //这个方法不支持超过1000个的用户查询 throw new VciBaseException("这个方法不支持超过1000个角色的主键来查询"); } queryMap.put("ploid", notIn ? QueryOptionConstant.NOTIN : QueryOptionConstant.IN + "select plfuncoid from plroleright where plroleoid in (" + WebUtil.toInSql(roleOid) + ")"); }else { queryMap.put("ploid", notIn ? QueryOptionConstant.NOTIN : QueryOptionConstant.IN + "select plfuncoid from plroleright where plroleoid ='" + roleOid.trim() + "'"); } if(resourceControlTypeEnum == null){ resourceControlTypeEnum = ResourceControlTypeEnum.BS; } switch (resourceControlTypeEnum){ case BS: queryMap.put("plresourceb",QueryOptionConstant.ISNOTNULL); break; case DOTNET: queryMap.put("plresourcedotnet",QueryOptionConstant.ISNOTNULL); break; case MOBILE: queryMap.put("plresourcemobil",QueryOptionConstant.ISNOTNULL); break; default: queryMap.put("plsuffixc",QueryOptionConstant.ISNOTNULL); } return dataGrid(queryMap,pageHelper); } /** * 批量根据角色的主键获取关联的权限 * * @param roleOidCollection 角色的主键集合 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkRole.xxxx * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象, 会去除重复的项 */ @Override public List listFunctionByRoleOids(Collection roleOidCollection, Map queryMap, ResourceControlTypeEnum resourceControlTypeEnum) { if(CollectionUtils.isEmpty(roleOidCollection)){ return new ArrayList<>(); } return listFunctionByRoleOid(roleOidCollection.stream().collect(Collectors.joining(",")),queryMap,false); } /** * 批量根据角色的主键获取关联的权限 * * @param roleOidCollection 角色的主键集合 * @param queryMap 查询条件,如果需要使用角色的属性来查询可以使用pkRole.xxxx * @param pageHelper 分页对象 * @param resourceControlTypeEnum 角色控制区域,也是功能控制的区域 * @return 权限的显示对象, 会去除重复的项 */ @Override public DataGrid gridFunctionByRoleOids(Collection roleOidCollection, Map queryMap, PageHelper pageHelper, ResourceControlTypeEnum resourceControlTypeEnum) { if(CollectionUtils.isEmpty(roleOidCollection)){ return new DataGrid<>(); } return gridFunctionByRoleOid(roleOidCollection.stream().collect(Collectors.joining(",")), queryMap,pageHelper,resourceControlTypeEnum,false); } /** * 清除缓存 */ @Override public void clearCache() { } }