From 8acf1b32b94ad05ce47130fd02647e87662aff2a Mon Sep 17 00:00:00 2001
From: xiejun <xiejun@vci-tech.com>
Date: 星期五, 26 一月 2024 11:26:58 +0800
Subject: [PATCH] erp集成项目代号属性更新

---
 Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeDuckingSyncServiceImpl.java |  165 ++++++++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 144 insertions(+), 21 deletions(-)

diff --git a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeDuckingSyncServiceImpl.java b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeDuckingSyncServiceImpl.java
index be0ed51..227274c 100644
--- a/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeDuckingSyncServiceImpl.java
+++ b/Source/UBCS/ubcs-service/ubcs-code/src/main/java/com/vci/ubcs/code/service/impl/CodeDuckingSyncServiceImpl.java
@@ -7,6 +7,7 @@
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.thoughtworks.xstream.XStream;
 import com.thoughtworks.xstream.io.xml.DomDriver;
+import com.vci.ubcs.code.Scheduling.NonWebRequestAttributes;
 import com.vci.ubcs.code.bo.CodeClassifyFullInfoBO;
 import com.vci.ubcs.code.constant.MdmDuckingConstant;
 import com.vci.ubcs.code.dto.CodeOrderDTO;
@@ -54,6 +55,7 @@
 import com.vci.ubcs.starter.web.util.WebUtil;
 import com.vci.ubcs.system.user.entity.User;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.commons.collections4.map.CaseInsensitiveMap;
 import org.springblade.core.log.exception.ServiceException;
 import org.springblade.core.redis.cache.BladeRedis;
 import org.springblade.core.secure.BladeUser;
@@ -62,12 +64,16 @@
 import org.springblade.core.tool.utils.Func;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
+import org.springframework.mock.web.MockHttpServletRequest;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.springframework.transaction.support.DefaultTransactionStatus;
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.LinkedMultiValueMap;
 import org.springframework.util.MultiValueMap;
+import org.springframework.web.context.request.RequestAttributes;
+import org.springframework.web.context.request.RequestContextHolder;
+import org.springframework.web.context.request.ServletRequestAttributes;
 
 import javax.annotation.Resource;
 import javax.jws.WebMethod;
@@ -102,6 +108,11 @@
 
 	@Value("${erp.item.systemId:ERP}")
 	public String systemId;
+	@Value("${erp.item.secName:鍥哄畾鐮佹}")
+	public String secName;
+	@Value("${erp.item.secValue:A}")
+	public String secValue;
+
 
 	/**
 	 * 涓氬姟绫诲瀷鐨勬湇鍔�
@@ -122,8 +133,7 @@
 	private MdmIOService mdmIOService;
 	@Resource
 	private IPasswordFreeLoginService passwordFreeLoginService;
-	@Resource
-	private WebServiceContext webServiceContext;
+
 	@Resource
 	private IDockingLogeService dockingLogeService;
 	@Resource
@@ -152,7 +162,6 @@
 	private MdmSearchItemCodeProvider mdmSearchItemCodeProvider;
 	@Autowired
 	HttpServletRequest request;
-
 	@Override
 	public void DockingDataSyncScheduing() {
 
@@ -214,7 +223,40 @@
 		});
 		return  R.success("鎵嬪姩鎺ㄩ�佸畬鎴�,璇锋牳瀵规槸鍚︽帹閫佹垚鍔�");
 	}
+	private SearchItemDataVO initData(String status,String itemCode,String mmCode){
+		SearchItemDataVO searchItemDataVO=new SearchItemDataVO();
+		searchItemDataVO.setLastchangedon(new Date());
+		searchItemDataVO.setLastchangedby("19831133");
+		searchItemDataVO.setCreatby("19831133");
+		searchItemDataVO.setCreatedon(new Date());
+		searchItemDataVO.setIsenabled(status);
+		searchItemDataVO.setMaterialcode("XMDH0001");
+		searchItemDataVO.setStatus("1");
+		searchItemDataVO.setProjectcode("3333");
+		searchItemDataVO.setProjectitem(itemCode);
+		searchItemDataVO.setMmodelcode(mmCode);
 
+		return searchItemDataVO;
+	}
+
+	public HttpServletRequest  getRequest(){
+		HttpServletRequest request =null;
+		RequestAttributes requestAttributes = null;
+		try{
+			requestAttributes = RequestContextHolder.currentRequestAttributes();
+		}catch (IllegalStateException e){
+			//requestAttributes = new NonWebRequestAttributes();
+			//RequestContextHolder.setRequestAttributes(requestAttributes, true);
+			request = new MockHttpServletRequest();
+			RequestContextHolder.setRequestAttributes(new ServletRequestAttributes(request),true);
+		}finally {
+			if (requestAttributes instanceof  ServletRequestAttributes) {
+				ServletRequestAttributes servletRequestAttributes = (ServletRequestAttributes)RequestContextHolder.currentRequestAttributes();
+				request = servletRequestAttributes.getRequest();
+			}
+		}
+		return request;
+	}
 	/***
 	 * 鍚屾鍨嬪彿浠e彿
 	 */
@@ -232,12 +274,26 @@
 		searchItemParam.setLastchangedon(lastchangedon);
 		searchItemParam.setStatus("1");//
 		Map<String,String>searchDataMap=  VciBaseUtil.objectToMapString(searchItemParam);
-		SearchItemVO searchItemVO= mdmSearchItemCodeProvider.getppModelByElem(searchDataMap);
+		//SearchItemVO searchItemVO= mdmSearchItemCodeProvider.getppModelByElem(searchDataMap);
+		SearchItemVO searchItemVO=new SearchItemVO();
+		List<SearchItemDataVO> data=new ArrayList<>();
+		SearchItemDataVO searchItemDataVO1=initData("1","","pro-00001");
+		SearchItemDataVO searchItemDataVO2=initData("0","item-00001","");
+		data.add(searchItemDataVO1);
+		data.add(searchItemDataVO2);
+		searchItemVO.setData(data);
+		searchItemVO.setCode("200");
+		searchItemVO.setMsg("");
+		String paramString="";
+		String backString="鎴愬姛";
+		String msg="鎴愬姛";
+		boolean success=true;
 		if(searchItemVO!=null) {
+			paramString = JSONObject.toJSON(searchItemVO).toString();
 			try {
 				//鍏嶅瘑鐧诲綍鐢宠token锛宺equest涓坊鍔犵敤鎴蜂俊鎭�
 				try {
-					passwordFreeLoginService.pwdFreeLoginByBoolean(systemId.toLowerCase(Locale.ROOT), request);
+					passwordFreeLoginService.pwdFreeLoginByBoolean(systemId.toLowerCase(Locale.ROOT),getRequest());
 				}catch (Throwable e){
 					throw new Throwable("鐢ㄦ埛閴存潈澶辫触.");
 				}
@@ -257,6 +313,8 @@
 				List<SearchItemDataVO> dataList = searchItemVO.getData();
 				Map<String, SearchItemDataVO> dataVOMap = new HashMap<>();
 				List<String> itemCodeList = new ArrayList<>();
+				ApplyDatasVO allDatasVO = new ApplyDatasVO();
+				List<ApplyDataVO> allObjectList=new ArrayList<>();
 				if (!CollectionUtils.isEmpty(dataList)) {
 					dataList.stream().forEach(searchItemDataVO -> {
 						String itemCode = StringUtils.isNotBlank(searchItemDataVO.getProjectitem()) ? searchItemDataVO.getProjectitem() : searchItemDataVO.getMmodelcode();//椤圭洰浠e彿
@@ -264,7 +322,7 @@
 						itemCodeList.add(itemCode);
 					});
 					String tableName = "";
-					R<BtmTypeVO> r = btmTypeClient.getAllAttributeByBtmId(btmName);
+					R<BtmTypeVO> r = btmTypeClient.getAllAttributeByBtmId(codeClassify.getBtmTypeId());
 					if (!r.isSuccess()) {
 						throw new Throwable(r.getMsg());
 					}
@@ -273,7 +331,7 @@
 						throw new Throwable("鏍规嵁涓氬姟绫诲瀷鏈煡璇㈠埌涓氬姟绫诲瀷瀵硅薄锛�");
 					}
 					tableName = btmTypeVO.getTableName();
-					if (com.alibaba.nacos.common.utils.StringUtils.isBlank(tableName)) {
+					if (StringUtils.isBlank(tableName)) {
 						throw new Throwable("鏍规嵁涓氬姟绫诲瀷鏈煡璇㈠埌涓氬姟绫诲瀷鐩稿叧鑱旂殑琛�");
 					}
 					StringBuffer sb = new StringBuffer();
@@ -282,19 +340,21 @@
 					sb.append(" where 1=1");
 					sb.append(" and lastr=1 and lastv=1");
 					sb.append(" and codeclsfid = '" + codeClassify.getOid() + "' ");
-					sb.append( VciBaseUtil.toInSql(attrKey,VciBaseUtil.array2String(itemCodeList.toArray(new String[]{}))));
+					sb.append(" and "+ VciBaseUtil.toInSql(attrKey,itemCodeList.toArray(new String[]{})));
 					List<Map<String, String>> newDataList = commonsMapper.queryByOnlySqlForMap(sb.toString());
 					//List<BaseModel> baseModelList=new ArrayList<>();
 					Map<String,BaseModel> baseModelMap=new HashMap<>();
 					newDataList.stream().forEach(dataMap->{
 						BaseModel baseModel=new BaseModel();
-						DefaultAttrAssimtUtil.copplyDefaultAttrAssimt(dataMap,baseModel,false,user);
+						Map<String,String> newDateMap=new CaseInsensitiveMap<>(dataMap);
+						DefaultAttrAssimtUtil.copplyDefaultAttrAssimt(newDateMap,baseModel,true,user);
 						DefaultAttrAssimtUtil.updateDefaultAttrAssimt(baseModel,user);
 						//baseModelList.add(baseModel);
-						String attrKeyValue=dataMap.getOrDefault(attrKey,"");
+
+						String attrKeyValue=newDateMap.getOrDefault(attrKey,"");
 						baseModelMap.put(attrKeyValue,baseModel);
 					});
-					ApplyDatasVO editDatasVO = new ApplyDatasVO();
+
 					List<ApplyDataVO> addObjectList=new ArrayList<>();
 					List<ApplyDataVO> editObjectList=new ArrayList<>();
 					dataVOMap.forEach((key,value)->{
@@ -305,6 +365,10 @@
 							changeObjectToMap(value,"",user,"create",addObjectList);
 						}
 					});
+					allObjectList.addAll(addObjectList);
+					allObjectList.addAll(editObjectList);
+					allDatasVO.setObject(allObjectList);
+					LinkedList<XMLResultDataObjectDetailDO> allResultDataObjectDetailDOS=new LinkedList<>();
 					if(!CollectionUtils.isEmpty(addObjectList)){
 						//瑙勫垯鐨勪富閿渶瑕佸幓鑾峰彇
 						CodeClassifyFullInfoBO classifyFullInfo = codeClassifyService.getClassifyFullInfo(codeClassify.getOid());
@@ -323,32 +387,89 @@
 						this.getConfigDatas(systemId, btmName, applyDatasVO, attrVOS, dataObjectVO);
 						CodeOrderDTO orderDTO = new CodeOrderDTO();
 						orderDTO.setCodeClassifyOid(codeClassify.getOid());//鍒嗙被涓婚敭
-
+						//鐮佹璁剧疆
+						List<SectionVO> section=new ArrayList<>();
+						SectionVO sectionVO=new SectionVO();
+						sectionVO.setValue(secValue);
+						sectionVO.setName(secName);
+						section.add(sectionVO);
 						log.info("end锛氳鍒欒幏鍙栧畬姣�");
-						List<CodeOrderSecDTO> codeOrderSecDTOList = getRuleCodeOrderSecDTOs(null, ruleVO,classifyFullInfo);
+						List<CodeOrderSecDTO> codeOrderSecDTOList = getRuleCodeOrderSecDTOs(section, ruleVO,classifyFullInfo);
 						log.info("end锛氱爜娈佃幏鍙栧畬姣�");
-
 						orderDTO.setSecDTOList(codeOrderSecDTOList);//鍒嗙被鐮佹
 						mdmIOService.batchSyncApplyCode(orderDTO, dataObjectVO, resultDataObjectDetailDOs,false);
+						allResultDataObjectDetailDOS.addAll(resultDataObjectDetailDOs);
 					}
-
+					//鏇存柊鏁版嵁锛堟洿鏂扮姸鎬侊級
 					if(!CollectionUtils.isEmpty(editObjectList)){
 						DataObjectVO dataObjectVO = new DataObjectVO();
 						ApplyDatasVO applyDatasVO = new ApplyDatasVO();
+						applyDatasVO.setObject(editObjectList);
 						LinkedList<XMLResultDataObjectDetailDO> resultDataObjectDetailDOs = new LinkedList<>();
 						CodeClassifyVO codeClassifyVO=new CodeClassifyVO();
 						BeanUtilForVCI.copyPropertiesIgnoreCase(codeClassify, codeClassifyVO);
 						this.getConfigDatas(systemId, btmName, applyDatasVO, attrVOS, dataObjectVO);
 						mdmIOService.batchSyncEditDatas(codeClassifyVO,dataObjectVO, resultDataObjectDetailDOs,false);
-
+						allResultDataObjectDetailDOS.addAll(resultDataObjectDetailDOs);
 					}
+					Object paramObject = JSONObject.toJSON(allDatasVO);
+					paramString=Func.isEmpty(paramObject)?"":paramObject.toString();
+					Object backObject = JSONObject.toJSON(allResultDataObjectDetailDOS);
+					backString=Func.isEmpty(backObject)?"":backObject.toString();
 				}
 			}
 			catch (Throwable e){
+				e.printStackTrace();;
 				log.error("鏌ヨ澶辫触--->"+e);
+				success=false;
+				backString="鏌ヨ澶辫触--->"+e;
+				msg="鏌ヨ澶辫触--->"+e;
+			}finally {
+				try {
+					//璁板綍鏃ュ織
+					this.saveLogs(systemId, systemId, paramString, backString, success, msg, "queryData");
+				}catch (Throwable e){
+					e.printStackTrace();
+					log.error(e.getMessage());
+				}
 			}
 		}
 	}
+
+	/***
+	 * 璁板綍鏃ュ織淇℃伅
+	 * @param systemId
+	 * @param parmaData
+	 * @param result
+	 * @return
+	 */
+	private  void saveLogs(String systemId,String systemName,String parmaData, String result,boolean isSucess,String msg,String operation){
+		//璁板綍鏃ュ織淇℃伅
+		DockingLog dockingLoge=new DockingLog();
+		//String oid=redisService.getUUIDEveryDay();
+		dockingLoge.setSystemCode(StringUtils.isBlank(systemId)?"-":systemId);//璁剧疆绯荤粺鏍囪瘑
+		dockingLoge.setSystemName(StringUtils.isBlank(systemName)?"-":systemName);
+		dockingLoge.setMsg(msg);//鏃ュ織娑堟伅
+		dockingLoge.setClassifyId("-");//鍒嗙被缂栧彿
+		dockingLoge.setClassifyName("-");//鍒嗙被鍚嶇О
+		dockingLoge.setClassifyOid("-");//鍒嗙被涓婚敭
+		dockingLoge.setUniqueCode("-");//鍞竴鏍囪瘑
+		dockingLoge.setSystemOid("-");//绯荤粺鏍囪瘑
+//        dockingLogeDO.setName(operation);
+		//dockingLogeDO.setOid(oid);//鏃ュ織涓婚敭
+		dockingLoge.setParamString(parmaData);//鍙傛暟淇℃伅
+		dockingLoge.setReturnString(result);//杩斿洖淇℃伅
+		dockingLoge.setType(operation);//鏃ュ織鎿嶄綔绫诲瀷
+		dockingLoge.setCreateTime(new Date());
+		if(isSucess) {
+			dockingLoge.setInterfaceStatus("true");//鎺ュ彛闆嗘垚鐘舵��
+		}else{
+			dockingLoge.setInterfaceStatus("false");//鎺ュ彛闆嗘垚鐘舵��
+		}
+		dockingLogeService.save(dockingLoge);
+		log.info("闆嗘垚鎺ㄩ�佹暟鎹垚鍔�,systemId:"+systemId+",systemname:"+systemName+",operation:"+operation+",param:"+parmaData);
+	}
+
 	/***
 	 * 鏍规嵁浼犲叆鐨勫弬鏁颁俊鎭牎楠岀爜娈佃鍒�
 	 */
@@ -540,13 +661,15 @@
 	 //String status= searchItemDataVO.getStatus();//鏁版嵁鐘舵�� 瀛楃鍨嬶紝鏋氫妇鍊硷紱鍒跺崟锛�0锛涘鎵逛腑锛�1锛涢�氳繃锛�2锛涢┏鍥烇細3锛�
 
 	 String mmodelCode=searchItemDataVO.getMmodelcode();//鍒堕�犲瀷鍙蜂唬鍙�
-	 initProperty("mmodelCode","","mmodelCode",propList);
+	 initProperty("mmodelcode","",mmodelCode,propList);
 	 String projectCode= searchItemDataVO.getProjectcode();//椤圭洰缂栫爜
-	 initProperty("projectcode","","projectCode",propList);
+	 initProperty("projectcode","",projectCode,propList);
 	 String projectItem=searchItemDataVO.getProjectitem();//椤圭洰浠e彿
-	 initProperty("projectitem","","projectItem",propList);
+	 initProperty("projectitem","",projectItem,propList);
 	 String materialCode=searchItemDataVO.getMaterialcode();//浜у搧缂栫爜
-	 initProperty("materialcode","","materialCode",propList);
+	 initProperty("materialcode","",materialCode,propList);
+	 //缁勫悎灞炴�х殑澶勭悊
+	 initProperty(attrKey,"",StringUtils.isNotBlank(projectItem)?projectItem:mmodelCode,propList);
 	 String creatBy=searchItemDataVO.getCreatby();//鍒涘缓鑰�
 	 Date cretaeDon= searchItemDataVO.getCreatedon();//鍒涘缓鏃ユ湡 鏃ユ湡鍨嬶紝濡傦細2023-09-08 19:24:11
 	 String lastchangeBy=searchItemDataVO.getLastchangedby();//鏇存敼鑰�
@@ -554,7 +677,7 @@
 	 String isenabled=  searchItemDataVO.getIsenabled();//瀛楃鍨嬶紝鏋氫妇鍊硷紱鍋滅敤锛�0锛涘惎鐢細1锛�
 	 applyDataVO.setOperate(operation);
 	 applyDataVO.setCode(code);
-	 if(isenabled.equals(0)){
+	 if(isenabled.equals("0")){
 		 applyDataVO.setStatus(CodeDefaultLC.DISABLE.getValue());
 	 }else{
 		 applyDataVO.setStatus(CodeDefaultLC.RELEASED.getValue());

--
Gitblit v1.9.3