package org.jeecg.modules.sap.service.impl; import com.sap.conn.jco.JCoDestination; import com.sap.conn.jco.JCoFunction; import com.sap.conn.jco.JCoRepository; import com.sap.conn.jco.JCoTable; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang3.StringUtils; import org.jeecg.common.aspect.annotation.ApiLog; import org.jeecg.common.constant.ApiLogCategoryEnum; import org.jeecg.config.sap.SapRfcConnectionManager; import org.jeecg.modules.sap.FunctionConst; import org.jeecg.modules.sap.dto.ProductionOrderDTO; import org.jeecg.modules.sap.request.ProductionOrderSyncRequest; import org.jeecg.modules.sap.service.ProductionOrderSync; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; /** * 生成订单同步服务 */ @Service @Slf4j public class ProductionOrderSyncImpl implements ProductionOrderSync { @Autowired private SapRfcConnectionManager connectionManager; @Override @ApiLog(apiName = "生产订单同步(ZPPF_033_1)", apiCategory = ApiLogCategoryEnum.SAP) public Map syncProductionOrder(ProductionOrderSyncRequest request) throws Exception { Map resultMap = new HashMap<>(); JCoDestination destination = connectionManager.getDestination(); JCoRepository repository = destination.getRepository(); JCoFunction function = repository.getFunction(FunctionConst.ZPPF_033_1); if (function == null) { throw new RuntimeException("RFC 函数 ZPPF_033_1 未找到!"); } // 设置输入参数 //订单号查询条件 if (StringUtils.isNotBlank(request.getOrderCode())) { JCoTable AUFNRTable = function.getTableParameterList().getTable("ZTAB_AUFNR"); String[] split = request.getOrderCode().split(","); for (String code : split) { AUFNRTable.appendRow(); AUFNRTable.setValue("AUFNR", code); } } //订单类型 标准生产订单 if (StringUtils.isNotBlank(request.getOrderTypeCode())) { JCoTable AUARTTable = function.getTableParameterList().getTable("ZTAB_AUART"); String[] split = request.getOrderTypeCode().split(","); for (String code : split) { AUARTTable.appendRow(); AUARTTable.setValue("AUART", code); } } if (StringUtils.isNotBlank(request.getProductionManager())) { JCoTable FEVORTable = function.getTableParameterList().getTable("ZTAB_FEVOR"); String[] split = request.getProductionManager().split(","); for (String code : split) { FEVORTable.appendRow(); FEVORTable.setValue("FEVOR", code); } } if (StringUtils.isNotBlank(request.getFactoryCode())) { //新火炬 JCoTable WERKSTable = function.getTableParameterList().getTable("ZTAB_WERKS"); String[] split = request.getFactoryCode().split(","); for (String code : split) { WERKSTable.appendRow(); WERKSTable.setValue("WERKS", code); } } if (StringUtils.isNotBlank(request.getOrderStatus())) { //新火炬 JCoTable TXT04Table = function.getTableParameterList().getTable("ZTAB_TXT04"); String[] split = request.getOrderStatus().split(","); for (String code : split) { TXT04Table.appendRow(); TXT04Table.setValue("TXT04", code); } } if (StringUtils.isNotBlank(request.getCreateTimeLow())) { JCoTable UDATETable = function.getTableParameterList().getTable("ZTAB_UDATE"); UDATETable.appendRow(); UDATETable.setValue("LOW", request.getCreateTimeLow()); } if (StringUtils.isNotBlank(request.getCreateTimeHigh())) { JCoTable UDATETable = function.getTableParameterList().getTable("ZTAB_UDATE"); UDATETable.appendRow(); UDATETable.setValue("HIGH", request.getCreateTimeHigh()); } if (StringUtils.isNotBlank(request.getUpdateTimeLow())) { JCoTable LAEDATable = function.getTableParameterList().getTable("ZTAB_LAEDA"); LAEDATable.appendRow(); LAEDATable.setValue("LOW", request.getUpdateTimeLow()); } if (StringUtils.isNotBlank(request.getUpdateTimeHigh())) { JCoTable LAEDATable = function.getTableParameterList().getTable("ZTAB_LAEDA"); LAEDATable.appendRow(); LAEDATable.setValue("HIGH", request.getUpdateTimeHigh()); } // 执行调用 function.execute(destination); //获取返回结果 String zmess = function.getExportParameterList().getValue("ZMESS").toString(); String ztype = function.getExportParameterList().getValue("ZTYPE").toString();//S 标识 成功 // 获取输出参数 JCoTable outputTable = function.getTableParameterList().getTable("ZTAB_OUT"); int numRows = outputTable.getNumRows(); List resultList = new ArrayList<>(); ProductionOrderDTO dto; for (int i = 0; i < numRows; i++) { outputTable.setRow(i); dto = new ProductionOrderDTO(); dto.setKDPOS(outputTable.getString("KDPOS")); dto.setCHARG(outputTable.getString("CHARG")); dto.setMAKTX(outputTable.getString("MAKTX")); dto.setMATNR(outputTable.getString("MATNR")); dto.setKDAUF(outputTable.getString("KDAUF")); dto.setAUFNR(outputTable.getString("AUFNR")); dto.setDAUAT(outputTable.getString("DAUAT")); dto.setGAMNG(outputTable.getString("GAMNG")); dto.setGMEIN(outputTable.getString("GMEIN")); dto.setAPRIO(outputTable.getString("APRIO")); dto.setAUFPL(outputTable.getString("AUFPL")); dto.setSTLNR(outputTable.getString("STLNR")); dto.setDWERK(outputTable.getString("DWERK")); dto.setNAME1(outputTable.getString("NAME1")); dto.setFEVOR(outputTable.getString("FEVOR")); dto.setTXT(outputTable.getString("TXT")); dto.setUSNAM(outputTable.getString("USNAM")); dto.setUDATE(outputTable.getString("UDATE")); dto.setLAEDA(outputTable.getString("LAEDA")); dto.setTIMES(outputTable.getString("TIMES")); dto.setTXT04(outputTable.getString("TXT04")); dto.setTXT30(outputTable.getString("TXT30")); dto.setGSTRP(outputTable.getString("GSTRP")); dto.setGLTRP(outputTable.getString("GLTRP")); //添加结果集 resultList.add(dto); log.info(dto.toString()); } resultMap.put("zmess", zmess); resultMap.put("ztype", ztype); resultMap.put("importParameters", request); resultMap.put("result", resultList); return resultMap; } }