| | |
| | | package com.vci.frameworkcore.compatibility.impl; |
| | | |
| | | import com.vci.corba.framework.data.DeptInfo; |
| | | import com.vci.corba.framework.data.RoleInfo; |
| | | import com.vci.dto.SmUserDTO; |
| | | import com.vci.common.util.ThreeDES; |
| | | import com.vci.corba.common.PLException; |
| | |
| | | import com.vci.frameworkcore.compatibility.SmPwdStrategyQueryServiceI; |
| | | import com.vci.frameworkcore.compatibility.SmRoleQueryServiceI; |
| | | import com.vci.frameworkcore.compatibility.SmUserQueryServiceI; |
| | | import com.vci.frameworkcore.enumpck.OrgTypeEnum; |
| | | import com.vci.model.SmUserDO; |
| | | import com.vci.pagemodel.SmUserVO; |
| | | import com.vci.po.SmUserPO; |
| | | import com.vci.pagemodel.OrgDepartmentVO; |
| | | import com.vci.pagemodel.SmPasswordStrategyVO; |
| | | import com.vci.pagemodel.SmRoleVO; |
| | | import com.vci.frameworkcore.properties.ConfigReader; |
| | | import com.vci.frameworkcore.properties.ConfigCorbaReader; |
| | | import com.vci.omd.utils.ObjectTool; |
| | | import com.vci.starter.poi.bo.ReadExcelOption; |
| | | import com.vci.starter.poi.bo.WriteExcelData; |
| | |
| | | import com.vci.web.util.WebUtil; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.apache.poi.hssf.util.HSSFColor; |
| | | import org.apache.poi.ss.formula.functions.T; |
| | | import org.slf4j.Logger; |
| | | import org.slf4j.LoggerFactory; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | |
| | | /** |
| | | * 必填列 |
| | | */ |
| | | private ArrayList<Integer> ColumnNameisRed = new ArrayList<Integer>(); |
| | | private List<Integer> ColumnNameisRed = new ArrayList<Integer>(); |
| | | |
| | | /** |
| | | * 用户分页查询时获取部门放到这里避免重复查询 |
| | |
| | | return treeList; |
| | | } |
| | | |
| | | /** |
| | | /** |
| | | * 获取角色数据 |
| | | * @param treeQueryObject |
| | | * @return |
| | | * @throws VciBaseException |
| | | */ |
| | | @Override |
| | | public List<Tree> refPersonOrgTree(TreeQueryObject treeQueryObject) throws VciBaseException { |
| | | List<Tree> rootTreeList=new ArrayList<>(); |
| | | Map<String,String> conditionMap=treeQueryObject.getConditionMap(); |
| | | if(CollectionUtils.isEmpty(conditionMap)) { |
| | | conditionMap = new HashMap<>(); |
| | | } |
| | | String dataType=StringUtils.isNotBlank(conditionMap.get("dataType"))?conditionMap.get("dataType"):"";//数据类型 |
| | | String parentId=StringUtils.isNotBlank(conditionMap.get("parentId"))?conditionMap.get("parentId"):"";//父节点 |
| | | String orgType=StringUtils.isNotBlank(conditionMap.get("orgType"))?conditionMap.get("orgType"):"";//接口查询包含的类型 |
| | | try { |
| | | initChildTree(dataType,orgType,parentId,rootTreeList); |
| | | } catch (PLException e) { |
| | | throw new VciBaseException("用户权限选择树加载失败:"+e.getMessage()); |
| | | } |
| | | return rootTreeList; |
| | | } |
| | | |
| | | /*** |
| | | * |
| | | * @param dataType |
| | | * @param orgType |
| | | * @param parentId |
| | | */ |
| | | private void initChildTree(String dataType,String orgType, String parentId, List<Tree>rootTreeList) throws PLException { |
| | | if(StringUtils.isBlank(parentId)){ |
| | | Tree rootTree=new Tree("root","人员组织","root"); |
| | | rootTree.setParentBtmName("root"); |
| | | rootTree.setExpanded(true); |
| | | List<Tree> childList=new ArrayList<>(); |
| | | if(OrgTypeEnum.ORG_TYPE_USER.getValue().equals(orgType)){//如果是人员 |
| | | Tree userTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_USER.getValue(),"用户",OrgTypeEnum.ORG_TYPE_USER.getValue(),OrgTypeEnum.ORG_TYPE_USER.getValue(),rootTree); |
| | | childList.add(userTree); |
| | | }else if(OrgTypeEnum.ORG_TYPE_DEPT.getValue().equals(orgType)){//如果是部门 |
| | | Tree departmentTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_DEPT.getValue(),"部门",OrgTypeEnum.ORG_TYPE_DEPT.getValue(),OrgTypeEnum.ORG_TYPE_DEPT.getValue(),rootTree); |
| | | childList.add(departmentTree); |
| | | }else if(OrgTypeEnum.ORG_TYPE_ROLE.getValue().equals(orgType)){//如果是角色 |
| | | Tree roleTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_ROLE.getValue(),"角色",OrgTypeEnum.ORG_TYPE_ROLE.getValue(),OrgTypeEnum.ORG_TYPE_ROLE.getValue(),rootTree); |
| | | childList.add(roleTree); |
| | | }else{ |
| | | Tree userTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_USER.getValue(),"用户",OrgTypeEnum.ORG_TYPE_USER.getValue(),OrgTypeEnum.ORG_TYPE_USER.getValue(),rootTree); |
| | | childList.add(userTree); |
| | | Tree departmentTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_DEPT.getValue(),"部门",OrgTypeEnum.ORG_TYPE_DEPT.getValue(),OrgTypeEnum.ORG_TYPE_DEPT.getValue(),rootTree); |
| | | childList.add(departmentTree); |
| | | Tree roleTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_ROLE.getValue(),"角色",OrgTypeEnum.ORG_TYPE_ROLE.getValue(),OrgTypeEnum.ORG_TYPE_ROLE.getValue(),rootTree); |
| | | childList.add(roleTree); |
| | | } |
| | | if(childList.size()>0){ |
| | | rootTree.setExpanded(true); |
| | | rootTree.setChildren(childList); |
| | | } |
| | | rootTreeList.add(rootTree); |
| | | }else{ |
| | | if(OrgTypeEnum.ORG_TYPE_ROOT.getValue().equals(dataType)){//如果父节点有值,则需要判断是加载什么节点 |
| | | Tree rootTree=new Tree("root","人员组织","root"); |
| | | rootTree.setParentBtmName("root"); |
| | | rootTree.setExpanded(true); |
| | | if(OrgTypeEnum.ORG_TYPE_USER.getValue().equals(orgType)){//如果是人员 |
| | | Tree userTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_USER.getValue(),"用户",OrgTypeEnum.ORG_TYPE_USER.getValue(),OrgTypeEnum.ORG_TYPE_USER.getValue(),rootTree); |
| | | rootTreeList.add(userTree); |
| | | }else if(OrgTypeEnum.ORG_TYPE_DEPT.getValue().equals(orgType)){//如果是部门 |
| | | Tree departmentTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_DEPT.getValue(),"部门",OrgTypeEnum.ORG_TYPE_DEPT.getValue(),OrgTypeEnum.ORG_TYPE_DEPT.getValue(),rootTree); |
| | | rootTreeList.add(departmentTree); |
| | | }else if(OrgTypeEnum.ORG_TYPE_ROLE.getValue().equals(orgType)){//如果是角色 |
| | | Tree roleTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_ROLE.getValue(),"角色",OrgTypeEnum.ORG_TYPE_ROLE.getValue(),OrgTypeEnum.ORG_TYPE_ROLE.getValue(),rootTree); |
| | | rootTreeList.add(roleTree); |
| | | }else{ |
| | | Tree userTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_USER.getValue(),"用户",OrgTypeEnum.ORG_TYPE_USER.getValue(),OrgTypeEnum.ORG_TYPE_USER.getValue(),rootTree); |
| | | rootTreeList.add(userTree); |
| | | Tree departmentTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_DEPT.getValue(),"部门",OrgTypeEnum.ORG_TYPE_DEPT.getValue(),OrgTypeEnum.ORG_TYPE_DEPT.getValue(),rootTree); |
| | | rootTreeList.add(departmentTree); |
| | | Tree roleTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_ROLE.getValue(),"角色",OrgTypeEnum.ORG_TYPE_ROLE.getValue(),OrgTypeEnum.ORG_TYPE_ROLE.getValue(),rootTree); |
| | | rootTreeList.add(roleTree); |
| | | } |
| | | }else if(OrgTypeEnum.ORG_TYPE_USER.getValue().equals(dataType)) {//如果传进来的是user节点 |
| | | if(OrgTypeEnum.ORG_TYPE_USER.getValue().equals(parentId)) { |
| | | Tree userTree = initDataTreeNode(OrgTypeEnum.ORG_TYPE_USER.getValue(), "用户", OrgTypeEnum.ORG_TYPE_USER.getValue(), OrgTypeEnum.ORG_TYPE_USER.getValue(), null); |
| | | UserInfo[] infos = platformClientUtil.getFrameworkService().fetchUserInfo(); |
| | | Arrays.stream(infos).forEach(info -> { |
| | | Tree childTree = initDataTreeNode(info.id, info.trueName + "(" + info.userName + ")", info, OrgTypeEnum.ORG_TYPE_USER.getValue(), userTree); |
| | | rootTreeList.add(childTree); |
| | | }); |
| | | } |
| | | }else if(OrgTypeEnum.ORG_TYPE_DEPT.getValue().equals(dataType)) {//如果是部门 |
| | | DeptInfo[] deptInfos=new DeptInfo[]{}; |
| | | Tree departmentTree=new Tree(); |
| | | if(OrgTypeEnum.ORG_TYPE_DEPT.getValue().equals(parentId)) { |
| | | departmentTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_DEPT.getValue(),"部门",OrgTypeEnum.ORG_TYPE_DEPT.getValue(),OrgTypeEnum.ORG_TYPE_DEPT.getValue(),null); |
| | | deptInfos = platformClientUtil.getFrameworkService().fetchDepartmentInfo(); |
| | | }else{ |
| | | deptInfos=platformClientUtil.getFrameworkService().fetchDepartmentInfoByParentId(parentId); |
| | | DeptInfo deptInfo=platformClientUtil.getFrameworkService().fetchDepartmentInfoById(parentId); |
| | | departmentTree=initDataTreeNode(deptInfo.id,deptInfo.name,deptInfo,OrgTypeEnum.ORG_TYPE_DEPT.getValue(),null); |
| | | } |
| | | if(!CollectionUtils.isEmpty(Arrays.asList(deptInfos))){ |
| | | Tree finalDepartmentTree = departmentTree; |
| | | Arrays.stream(deptInfos).forEach(deptInfo -> { |
| | | Tree childTree=initDataTreeNode(deptInfo.id,deptInfo.name,deptInfo,OrgTypeEnum.ORG_TYPE_DEPT.getValue(), finalDepartmentTree); |
| | | rootTreeList.add(childTree); |
| | | }); |
| | | } |
| | | if(!OrgTypeEnum.ORG_TYPE_DEPT.getValue().equals(parentId)) { |
| | | UserInfo[] infos = platformClientUtil.getFrameworkService().getUserByDeptId(parentId); |
| | | if (infos != null && infos.length > 0) { |
| | | Tree finalDepartmentTree = departmentTree; |
| | | Arrays.stream(infos).forEach(info -> { |
| | | Tree childTree = initDataTreeNode(info.id, info.trueName + "(" + info.userName + ")", info, OrgTypeEnum.ORG_TYPE_USER.getValue(), finalDepartmentTree); |
| | | rootTreeList.add(childTree); |
| | | }); |
| | | } |
| | | } |
| | | |
| | | }else if(OrgTypeEnum.ORG_TYPE_ROLE.getValue().equals(dataType)) {//如果是角色 |
| | | if(OrgTypeEnum.ORG_TYPE_ROLE.getValue().equals(parentId)){ |
| | | Tree roleTree=initDataTreeNode(OrgTypeEnum.ORG_TYPE_ROLE.getValue(),"角色",OrgTypeEnum.ORG_TYPE_ROLE.getValue(),OrgTypeEnum.ORG_TYPE_ROLE.getValue(),null); |
| | | RoleInfo[] roleInfos=platformClientUtil.getFrameworkService().fetchRoleInfo(); |
| | | if(roleInfos!=null&&roleInfos.length>0) { |
| | | Arrays.stream(roleInfos).forEach(info -> { |
| | | Tree childTree = initDataTreeNode(info.id, info.name, info, OrgTypeEnum.ORG_TYPE_ROLE.getValue(), roleTree); |
| | | rootTreeList.add(childTree); |
| | | }); |
| | | } |
| | | }else{ |
| | | RoleInfo roleInfo=platformClientUtil.getFrameworkService().fetchRoleInfoById(parentId); |
| | | Tree roleTree=initDataTreeNode(roleInfo.id,roleInfo.name,roleInfo,OrgTypeEnum.ORG_TYPE_ROLE.getValue(),null); |
| | | UserInfo[] infos=platformClientUtil.getFrameworkService().fetchUserInfoByRoleId(roleInfo.id,roleInfo.type); |
| | | if(infos!=null&&infos.length>0) { |
| | | Arrays.stream(infos).forEach(info -> { |
| | | Tree childTree = initDataTreeNode(info.id, info.trueName + "(" + info.userName + ")", info, OrgTypeEnum.ORG_TYPE_USER.getValue(), roleTree); |
| | | rootTreeList.add(childTree); |
| | | }); |
| | | } |
| | | } |
| | | } |
| | | } |
| | | } |
| | | |
| | | /*** |
| | | * |
| | | * @param oid |
| | | * @param text |
| | | * @param o |
| | | * @param type |
| | | * @param parentTree |
| | | * @return |
| | | */ |
| | | private Tree initDataTreeNode(String oid,String text,Object o,String type,Tree parentTree){ |
| | | Tree ObjectTreeNode=new Tree(oid,text,o); |
| | | ObjectTreeNode.setParentBtmName(type); |
| | | if(parentTree!=null) { |
| | | ObjectTreeNode.setParentId(parentTree.getParentId()); |
| | | ObjectTreeNode.setParentName(parentTree.getParentName()); |
| | | } |
| | | return ObjectTreeNode; |
| | | } |
| | | /** |
| | | * 校验密码是否相同,在新平台中存储的密码是两次md5 |
| | | * @param userOid 用户主键 |
| | | * @param md5Password 已经md5加密一次的密码--老的平台里不能加密 |
| | |
| | | // 设置表单列名 |
| | | List<String> columns = new ArrayList<>(Arrays.asList("账号", "密码", "姓名", "电子邮箱", "专业", "描述", "部门(上下级部门之间以反斜杠隔开(/))")); |
| | | //获取是否导出密级配置项 |
| | | String flag = ConfigReader.getConfigValue("exportSecretGrade"); |
| | | String flag = ConfigCorbaReader.getConfigValue("exportSecretGrade"); |
| | | if (flag != null && flag.equalsIgnoreCase("true")) { |
| | | columns = new ArrayList<>(Arrays.asList("账号", "密码", "姓名", "电子邮箱", "专业", "描述", "部门(上下级部门之间以反斜杠隔开(/))" ,"密级")); |
| | | } |
| | |
| | | String loginUserId = WebThreadLocalUtil.getCurrentUserSessionInfoInThread().getUserId(); |
| | | UserEntityInfo userEntityInfo = new UserEntityInfo(loginUserId,null); |
| | | //是否导入密级配置 |
| | | boolean exportSecretGrade = Boolean.parseBoolean(ConfigReader.getConfigValue("exportSecretGrade")); |
| | | boolean exportSecretGrade = Boolean.parseBoolean(ConfigCorbaReader.getConfigValue("exportSecretGrade")); |
| | | List<SmUserPO> poList = ExcelUtil.readDataObjectFromExcel(file, SmUserPO.class,excelOption,(value, po, fieldName)->{ |
| | | Integer secretValue = UserSecretEnum.getSecretValueByText(po.getSecretGradeText()); |
| | | //是否必须导入密级 |
| | |
| | | //当前excel中是否重复用的判重Map:(key:账号,value:行号) |
| | | Map<String, String> excelReapeat = new HashMap<>(); |
| | | //先获取全部部门名称的父子对应关系:key为部门子父级名称路径,value为部门信息 |
| | | Map<String,OrgDepartmentVO> deptVOMap = orgDeptQueryService.getDeptAllTreeMap(); |
| | | List<OrgDepartmentVO> orgDepartmentVOList = orgDeptQueryService.getDeptAllFullName(); |
| | | Map<String, OrgDepartmentVO> deptVOMap = orgDepartmentVOList.stream().collect(Collectors.toMap(OrgDepartmentVO::getFullDeptNamePath, s->s)); |
| | | //Map<String,OrgDepartmentVO> deptVOMap = orgDeptQueryService.getDeptAllTreeMap(); |
| | | //判断必填属性是否为空,用户是否已存在,以及部门是否填错等校验逻辑 |
| | | List<String> finalRepeatUserId = repeatUserId; |
| | | poList.stream().forEach(smUserPO -> { |