From 6138318ebe15d251d6ae6e3e1ec57c8af94216d7 Mon Sep 17 00:00:00 2001 From: ludc <pUXmgxCf6A> Date: 星期四, 18 五月 2023 10:53:27 +0800 Subject: [PATCH] 以及发布webservice接口功能搭建,将通通用接口移植过来 --- Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/UniversalInterfaceImpl.java | 307 +++++++++++++++++++++++++------------------------- 1 files changed, 152 insertions(+), 155 deletions(-) diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/UniversalInterfaceImpl.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/UniversalInterfaceImpl.java index 402f6bb..7ee87d7 100644 --- a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/UniversalInterfaceImpl.java +++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/UniversalInterfaceImpl.java @@ -2,16 +2,13 @@ import com.alibaba.cloud.commons.lang.StringUtils; import com.alibaba.fastjson.JSONObject; -import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.thoughtworks.xstream.XStream; import com.thoughtworks.xstream.io.xml.DomDriver; import com.vci.ubcs.code.bo.CodeClassifyFullInfoBO; import com.vci.ubcs.code.dto.CodeOrderDTO; import com.vci.ubcs.code.dto.CodeOrderSecDTO; -import com.vci.ubcs.code.entity.CodeBasicSec; -import com.vci.ubcs.code.entity.CodeClassify; -import com.vci.ubcs.code.entity.DockingLog; +import com.vci.ubcs.code.entity.*; import com.vci.ubcs.code.enumpack.CodeSecTypeEnum; import com.vci.ubcs.code.service.*; import com.vci.ubcs.code.util.gennerAttrMapUtil; @@ -69,8 +66,8 @@ /** * 涓绘暟鎹紩鎿庣殑鏈嶅姟 */ - //@Resource - //private MdmEngineService engineService; + @Resource + private MdmEngineService engineService; /** * 瀵嗙骇鐨勬湇鍔� @@ -99,152 +96,152 @@ @Override public String applyCode(String data, String dataType) throws Throwable { { -// String resultStr = ""; -// String errorid="0"; -// msg="鎴愬姛"; -// objerrorCode="0"; -// objerrorMsg="鎴愬姛"; -// logger.info("鐢宠缂栫爜鐨勬暟鎹弬鏁�:->"+data); -// logger.info("鐢宠缂栫爜鐨勬暟鎹被鍨�:->"+dataType); -// String systemId=""; -// List<XMLResultClassfyVO> resultClassfyVOList = new ArrayList<>(); -// try { -// if(StringUtils.isBlank(data)) { -// errorid="101"; -// throw new Throwable("鎺ュ彛鍙傛暟锛氫紶閫掍负绌�"); -// } -// InterParameterVO interParameterVO =new InterParameterVO(); -// //濡傛灉dataType鏄痻ml鍒欙紝閫氳繃xml搴忓垪鍖栨垚瀵硅薄褰㈠紡锛屽鏋滄槸json鍒欓�氳繃json杞崲鎴愬璞℃牸寮� -// try { -// if ("xml".equals(dataType)) { -// XStream xStream = new XStream(new DomDriver()); -// xStream.processAnnotations(RootDataVO.class); -// xStream.autodetectAnnotations(true); -// RootDataVO rootDataVO = (RootDataVO) xStream.fromXML(data); -// interParameterVO.setData(rootDataVO); -// } else { -// interParameterVO = JSONObject.toJavaObject(JSONObject.parseObject(data), InterParameterVO.class); -// } -// }catch (Throwable e){ -// errorid="101"; -// throw new Throwable("鎺ュ彛鍙傛暟锛氫紶鍏ユ暟鎹弬鏁拌В鏋愬け璐�"); -// } -// ClassfysVO classfysVO = interParameterVO.getData().getClassifys(); -// systemId = interParameterVO.getData().getSystemId(); -// UserVO userVo = interParameterVO.getData().getUser(); -// List<ClassfyVO> classVOList = classfysVO.getClassify(); -// InterParameterVO finalInterParameterVO = interParameterVO; -// -// //杩欐槸璐﹀彿淇℃伅 -// SessionInfo sessionInfo = new SessionInfo(); -// sessionInfo.setUserId(userVo.getUserName()); -// sessionInfo.setUserName(userVo.getTrueName()); -// sessionInfo.setIp(userVo.getIp()); -// VciBaseUtil.setCurrentUserSessionInfo(sessionInfo); -// -// String finalSystemId = systemId; -// classVOList.stream().forEach(classVO -> { -// logger.info("鍙傛暟锛氬垎绫籆Ode:" + classVO.getClassCode()); -// LinkedList<XMLResultDataObjectDetailDO> resultDataObjectDetailDOs = new LinkedList<>(); -// //鑾峰彇鍒嗙被淇℃伅 -// try { -// String libray = classVO.getLibrary(); -// CodeClassifyVO codeClassifyVO = getClassfy(classVO); -// logger.info("end锛氬垎绫绘煡璇㈠畬姣�"); -// //鑾峰彇鍒嗙被妯℃澘淇℃伅 -// if(codeClassifyVO==null || StringUtils.isBlank(codeClassifyVO.getOid())){ -// objerrorCode="100"; -// throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧埌鍒嗙被淇℃伅"); -// } -// CodeClstemplateVO templateVO = engineService.getUsedTemplateByClassifyOid(codeClassifyVO.getOid()); -// if(templateVO==null||StringUtils.isBlank(templateVO.getOid())){ -// objerrorCode="1"; -// throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙朚DM绯荤粺涓搴旀ā鏉�"); -// } -// logger.info("end锛氭ā鏉挎煡璇㈠畬姣�"); -// ApplyDatasVO applyDatasVO = classVO.getObjects(); -// DataObjectVO dataObjectVO = new DataObjectVO(); -// List<CodeClassifyTemplateAttrVO> attrVOS = templateVO.getAttributes().stream().filter(s -> !DEFAULT_SYNC_ATTR_LIST.contains(s.getId()) && VciBaseUtil.getBoolean(s.getFormDisplayFlag()) -// ).collect(Collectors.toList()); -// this.getConfigDatas(finalSystemId, libray, applyDatasVO, attrVOS, dataObjectVO); -// logger.info("end锛氭暟鎹粍缁囧畬姣�"); -// //瑙勫垯鐨勪富閿渶瑕佸幓鑾峰彇 -// CodeClassifyFullInfoBO classifyFullInfo = classifyService.getClassifyFullInfo(codeClassifyVO.getOid()); -// if(classifyFullInfo==null ||classifyFullInfo.getCurrentClassifyVO()==null || StringUtils.isBlank(classifyFullInfo.getCurrentClassifyVO().getOid())){ -// objerrorCode="1"; -// logger.info("classifyFullInfo:"+"鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧垎绫荤浉鍏充俊鎭�"); -// throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧垎绫荤浉鍏充俊鎭�"); -// } -// CodeRuleVO ruleVO = engineService.getCodeRuleByClassifyFullInfo(classifyFullInfo); -// if(ruleVO==null|| StringUtils.isBlank(ruleVO.getOid())){ -// objerrorCode="102"; -// throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙朚DM绯荤粺涓搴旇鍒�"); -// } -// logger.info("end锛氳鍒欒幏鍙栧畬姣�"); -// List<CodeOrderSecDTO> codeOrderSecDTOList = getRuleCodeOrderSecDTOs(classVO.getSections().getSection(), ruleVO); -// logger.info("end锛氱爜娈佃幏鍙栧畬姣�"); -// CodeOrderDTO orderDTO = new CodeOrderDTO(); -// orderDTO.setCodeClassifyOid(codeClassifyVO.getOid());//鍒嗙被涓婚敭 -// orderDTO.setSecDTOList(codeOrderSecDTOList);//鍒嗙被鐮佹 -// mdmIOService.batchSyncApplyCode(orderDTO, dataObjectVO, resultDataObjectDetailDOs); -// logger.info("end锛氱敵璇疯幏鍙栧畬姣�"); -// } catch (Throwable e) { -// XMLResultDataObjectDetailDO xmlResultDataObjectDetailDO=new XMLResultDataObjectDetailDO(); -// xmlResultDataObjectDetailDO.setCode(""); -// xmlResultDataObjectDetailDO.setId(""); -// xmlResultDataObjectDetailDO.setErrorid(objerrorCode); -// xmlResultDataObjectDetailDO.setMsg("缂栫爜鐢宠澶辫触:"+e.getMessage()); -// resultDataObjectDetailDOs.add(xmlResultDataObjectDetailDO); -// e.printStackTrace(); -// }finally { -// XMLResultClassfyVO resultClassfyVO = new XMLResultClassfyVO(); -// resultClassfyVO.setClassCode(classVO.getClassCode()); -// resultClassfyVO.setLibrary(classVO.getLibrary()); -// resultClassfyVO.setFullclsfNamePath(classVO.getFullclsfNamePath()); -// resultClassfyVO.setObjects(resultDataObjectDetailDOs); -// resultClassfyVOList.add(resultClassfyVO); -// } -// }); -// XMLResultSystemVO xmlResultSystemVO=new XMLResultSystemVO(); -// xmlResultSystemVO.setClassifys(resultClassfyVOList); -// xmlResultSystemVO.setMsg(msg); -// xmlResultSystemVO.setErrorid(errorid); -// resultStr= transferResultXMl(xmlResultSystemVO,dataType); -// }catch (Throwable e){ -// e.printStackTrace();; -// msg="鐢宠缂栫爜澶辫触:"+e.getMessage(); -// }finally { -// XMLResultSystemVO xmlResultSystemVO=new XMLResultSystemVO(); -// xmlResultSystemVO.setClassifys(resultClassfyVOList); -// xmlResultSystemVO.setMsg(msg); -// xmlResultSystemVO.setErrorid(errorid); -// resultStr= transferResultXMl(xmlResultSystemVO,dataType); -// final boolean[] issucess = {true}; -// if(!errorid.equals("0")) { -// issucess[0] = false; -// }else { -// if(!CollectionUtils.isEmpty(resultClassfyVOList)) { -// resultClassfyVOList.stream().forEach(xMLResultClassfyVO -> { -// xMLResultClassfyVO.getObjects().stream().forEach(objec -> { -// if (!(objec.getErrorid().equals("0") || objec.getErrorid().equals("204"))) { -// issucess[0] = false; -// msg=objec.getMsg(); -// } -// }); -// }); -// } -// -// } -// try { -// //璁板綍鏃ュ織 -// this.saveLogs(systemId, systemId, data, resultStr, issucess[0], msg, "applyCode"); -// }catch (Throwable e){ -// e.printStackTrace(); -// } -// } -// logger.info("杩斿洖鍙傛暟:"+resultStr); + String resultStr = ""; + String errorid="0"; + msg="鎴愬姛"; + objerrorCode="0"; + objerrorMsg="鎴愬姛"; + logger.info("鐢宠缂栫爜鐨勬暟鎹弬鏁�:->"+data); + logger.info("鐢宠缂栫爜鐨勬暟鎹被鍨�:->"+dataType); + String systemId=""; + List<XMLResultClassfyVO> resultClassfyVOList = new ArrayList<>(); + try { + if(StringUtils.isBlank(data)) { + errorid="101"; + throw new Throwable("鎺ュ彛鍙傛暟锛氫紶閫掍负绌�"); + } + InterParameterVO interParameterVO =new InterParameterVO(); + //濡傛灉dataType鏄痻ml鍒欙紝閫氳繃xml搴忓垪鍖栨垚瀵硅薄褰㈠紡锛屽鏋滄槸json鍒欓�氳繃json杞崲鎴愬璞℃牸寮� + try { + if ("xml".equals(dataType)) { + XStream xStream = new XStream(new DomDriver()); + xStream.processAnnotations(RootDataVO.class); + xStream.autodetectAnnotations(true); + RootDataVO rootDataVO = (RootDataVO) xStream.fromXML(data); + interParameterVO.setData(rootDataVO); + } else { + interParameterVO = JSONObject.toJavaObject(JSONObject.parseObject(data), InterParameterVO.class); + } + }catch (Throwable e){ + errorid="101"; + throw new Throwable("鎺ュ彛鍙傛暟锛氫紶鍏ユ暟鎹弬鏁拌В鏋愬け璐�"); + } + ClassfysVO classfysVO = interParameterVO.getData().getClassifys(); + systemId = interParameterVO.getData().getSystemId(); + UserVO userVo = interParameterVO.getData().getUser(); + List<ClassfyVO> classVOList = classfysVO.getClassify(); + InterParameterVO finalInterParameterVO = interParameterVO; - return ""; + //杩欐槸璐﹀彿淇℃伅 + SessionInfo sessionInfo = new SessionInfo(); + sessionInfo.setUserId(userVo.getUserName()); + sessionInfo.setUserName(userVo.getTrueName()); + sessionInfo.setIp(userVo.getIp()); + VciBaseUtil.setCurrentUserSessionInfo(sessionInfo); + + String finalSystemId = systemId; + classVOList.stream().forEach(classVO -> { + logger.info("鍙傛暟锛氬垎绫籆Ode:" + classVO.getClassCode()); + LinkedList<XMLResultDataObjectDetailDO> resultDataObjectDetailDOs = new LinkedList<>(); + //鑾峰彇鍒嗙被淇℃伅 + try { + String libray = classVO.getLibrary(); + CodeClassifyVO codeClassifyVO = getClassfy(classVO); + logger.info("end锛氬垎绫绘煡璇㈠畬姣�"); + //鑾峰彇鍒嗙被妯℃澘淇℃伅 + if(codeClassifyVO==null || StringUtils.isBlank(codeClassifyVO.getOid())){ + objerrorCode="100"; + throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧埌鍒嗙被淇℃伅"); + } + CodeClassifyTemplateVO templateVO = engineService.getUsedTemplateByClassifyOid(codeClassifyVO.getOid()); + if(templateVO==null||StringUtils.isBlank(templateVO.getOid())){ + objerrorCode="1"; + throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙朚DM绯荤粺涓搴旀ā鏉�"); + } + logger.info("end锛氭ā鏉挎煡璇㈠畬姣�"); + ApplyDatasVO applyDatasVO = classVO.getObjects(); + DataObjectVO dataObjectVO = new DataObjectVO(); + List<CodeClassifyTemplateAttrVO> attrVOS = templateVO.getAttributes().stream().filter(s -> !DEFAULT_SYNC_ATTR_LIST.contains(s.getId()) && VciBaseUtil.getBoolean(s.getFormDisplayFlag()) + ).collect(Collectors.toList()); + this.getConfigDatas(finalSystemId, libray, applyDatasVO, attrVOS, dataObjectVO); + logger.info("end锛氭暟鎹粍缁囧畬姣�"); + //瑙勫垯鐨勪富閿渶瑕佸幓鑾峰彇 + CodeClassifyFullInfoBO classifyFullInfo = classifyService.getClassifyFullInfo(codeClassifyVO.getOid()); + if(classifyFullInfo==null ||classifyFullInfo.getCurrentClassifyVO()==null || StringUtils.isBlank(classifyFullInfo.getCurrentClassifyVO().getOid())){ + objerrorCode="1"; + logger.info("classifyFullInfo:"+"鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧垎绫荤浉鍏充俊鎭�"); + throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙栧垎绫荤浉鍏充俊鎭�"); + } + CodeRuleVO ruleVO = engineService.getCodeRuleByClassifyFullInfo(classifyFullInfo); + if(ruleVO==null|| StringUtils.isBlank(ruleVO.getOid())){ + objerrorCode="102"; + throw new Throwable ("鏍规嵁浼犺緭鐨勫垎绫伙紝鏈幏鍙朚DM绯荤粺涓搴旇鍒�"); + } + logger.info("end锛氳鍒欒幏鍙栧畬姣�"); + List<CodeOrderSecDTO> codeOrderSecDTOList = getRuleCodeOrderSecDTOs(classVO.getSections().getSection(), ruleVO); + logger.info("end锛氱爜娈佃幏鍙栧畬姣�"); + CodeOrderDTO orderDTO = new CodeOrderDTO(); + orderDTO.setCodeClassifyOid(codeClassifyVO.getOid());//鍒嗙被涓婚敭 + orderDTO.setSecDTOList(codeOrderSecDTOList);//鍒嗙被鐮佹 + //mdmIOService.batchSyncApplyCode(orderDTO, dataObjectVO, resultDataObjectDetailDOs); + logger.info("end锛氱敵璇疯幏鍙栧畬姣�"); + } catch (Throwable e) { + XMLResultDataObjectDetailDO xmlResultDataObjectDetailDO=new XMLResultDataObjectDetailDO(); + xmlResultDataObjectDetailDO.setCode(""); + xmlResultDataObjectDetailDO.setId(""); + xmlResultDataObjectDetailDO.setErrorid(objerrorCode); + xmlResultDataObjectDetailDO.setMsg("缂栫爜鐢宠澶辫触:"+e.getMessage()); + resultDataObjectDetailDOs.add(xmlResultDataObjectDetailDO); + e.printStackTrace(); + }finally { + XMLResultClassfyVO resultClassfyVO = new XMLResultClassfyVO(); + resultClassfyVO.setClassCode(classVO.getClassCode()); + resultClassfyVO.setLibrary(classVO.getLibrary()); + resultClassfyVO.setFullclsfNamePath(classVO.getFullclsfNamePath()); + resultClassfyVO.setObjects(resultDataObjectDetailDOs); + resultClassfyVOList.add(resultClassfyVO); + } + }); + XMLResultSystemVO xmlResultSystemVO=new XMLResultSystemVO(); + xmlResultSystemVO.setClassifys(resultClassfyVOList); + xmlResultSystemVO.setMsg(msg); + xmlResultSystemVO.setErrorid(errorid); + resultStr= transferResultXMl(xmlResultSystemVO,dataType); + }catch (Throwable e){ + e.printStackTrace();; + msg="鐢宠缂栫爜澶辫触:"+e.getMessage(); + }finally { + XMLResultSystemVO xmlResultSystemVO=new XMLResultSystemVO(); + xmlResultSystemVO.setClassifys(resultClassfyVOList); + xmlResultSystemVO.setMsg(msg); + xmlResultSystemVO.setErrorid(errorid); + resultStr= transferResultXMl(xmlResultSystemVO,dataType); + final boolean[] issucess = {true}; + if(!errorid.equals("0")) { + issucess[0] = false; + }else { + if(!CollectionUtils.isEmpty(resultClassfyVOList)) { + resultClassfyVOList.stream().forEach(xMLResultClassfyVO -> { + xMLResultClassfyVO.getObjects().stream().forEach(objec -> { + if (!(objec.getErrorid().equals("0") || objec.getErrorid().equals("204"))) { + issucess[0] = false; + msg=objec.getMsg(); + } + }); + }); + } + + } + try { + //璁板綍鏃ュ織 + this.saveLogs(systemId, systemId, data, resultStr, issucess[0], msg, "applyCode"); + }catch (Throwable e){ + e.printStackTrace(); + } + } + logger.info("杩斿洖鍙傛暟:"+resultStr); + + return resultStr; } } @@ -315,10 +312,10 @@ throw new Throwable("鏍规嵁鍒嗙被浠e彿鏈煡璇㈠埌鐩稿簲鐨勫垎绫讳俊鎭�"); } } else { - //classifyVO = classifyService.getObjectByClsfNamePath(className.replace(separator, "/")); - //if(StringUtils.isBlank(classifyVO.getOid())){ - // throw new Throwable("鏍规嵁鍒嗙被鍚嶇О璺緞鏈煡璇㈠埌鐩稿簲鐨勫垎绫讳俊鎭�"); - //} + classifyVO = classifyService.getObjectByClsfNamePath(className.replace(separator, "/")); + if(StringUtils.isBlank(classifyVO.getOid())){ + throw new Throwable("鏍规嵁鍒嗙被鍚嶇О璺緞鏈煡璇㈠埌鐩稿簲鐨勫垎绫讳俊鎭�"); + } } }catch (Throwable e){ objerrorCode="100"; -- Gitblit v1.9.3