| package com.zy.asrs.task.handler; | 
|   | 
| import com.alibaba.fastjson.JSON; | 
| import com.alibaba.fastjson.JSONObject; | 
| import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
| import com.core.common.Cools; | 
| import com.core.exception.CoolException; | 
| import com.zy.asrs.entity.*; | 
| import com.zy.asrs.entity.param.BalconyWrkMastParam; | 
| import com.zy.asrs.service.*; | 
| import com.zy.asrs.task.AbstractHandler; | 
| import com.zy.asrs.task.core.ReturnT; | 
| import com.zy.common.service.CommonService; | 
| import com.zy.common.utils.HttpHandler; | 
| import lombok.extern.slf4j.Slf4j; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.beans.factory.annotation.Value; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.transaction.annotation.Transactional; | 
|   | 
| import java.util.List; | 
|   | 
| /** | 
|  * Created by Monkey D. Luffy on 2023.09.17 | 
|  * 徐工汉云..............以下.............上饶江铜.............自动上报月台 | 
|  */ | 
| @Slf4j | 
| @Service | 
| @Transactional | 
| public class RailwayPlatformHandler extends AbstractHandler<String> { | 
|   | 
|     @Autowired | 
|     private WrkMastService wrkMastService; | 
|     @Autowired | 
|     private WrkDetlService wrkDetlService; | 
|     @Autowired | 
|     private CommonService commonService; | 
|     @Autowired | 
|     private StaDescService staDescService; | 
|     @Autowired | 
|     private ApiLogService apiLogService; | 
|     @Autowired | 
|     private BasDevpService basDevpService; | 
|     @Autowired | 
|     private OrderService orderService; | 
|   | 
|     @Value("${srXghyErp.url}") | 
|     private String erpUrl; | 
|     @Value("${srXghyErp.railwayPlatformpath}") | 
|     private String railwayPlatformpath; | 
|   | 
|     public ReturnT<String> start(int staNo) { | 
|         try { | 
|             BasDevp basDevp = basDevpService.selectById(staNo); | 
|             if (!Cools.isEmpty(basDevp) && !Cools.isEmpty(basDevp.getWrkNo()) && (basDevp.getWrkNo()<9900 || basDevp.getWrkNo()>9999) && basDevp.getWrkNo()!=32222){ | 
|                 WrkMast wrkMast = wrkMastService.selectOne(new EntityWrapper<WrkMast>().eq("wrk_no", basDevp.getWrkNo()).eq("sta_no", staNo).eq("wrk_sts", 55L)); | 
|                 if (!Cools.isEmpty(wrkMast)){ | 
|                     List<WrkDetl> wrkDetls = wrkDetlService.selectByWrkNo(wrkMast.getWrkNo()); | 
|                     BalconyWrkMastParam balconyWrkMastParam = new BalconyWrkMastParam(wrkMast, wrkDetls); | 
|   | 
|                     ReturnT<String> result = null; | 
|                     balconyWrkMastParam.setBalcony(1); | 
|                     result = postMesData(railwayPlatformpath,balconyWrkMastParam); | 
| //                        System.out.println(result); | 
|                     if (result.getCode()==200){ | 
|                         wrkMast.setWrkSts(56L); | 
|                         wrkMastService.updateById(wrkMast); | 
|                         return SUCCESS; | 
|                     }else { | 
|                         log.error("出库信息上传中控失败,月台编号{}",1); | 
|                     } | 
|   | 
|                 } | 
|             } | 
|         }catch (Exception e){ | 
|             log.error("异常!!!"+e); | 
|             return FAIL; | 
|         } | 
|         return FAIL; | 
|     } | 
|   | 
|     private ReturnT<String> postMesData(String erpPath,Object combParam){ | 
|         if(combParam != null){ | 
|             String response = ""; | 
|             boolean success = false; | 
|             try { | 
|                 response = new HttpHandler.Builder() | 
|                         .setUri(erpUrl) | 
|                         .setPath(erpPath) | 
|                         .setJson(JSON.toJSONString(combParam)) | 
|                         .build() | 
|                         .doPost(); | 
|                 JSONObject jsonObject = JSON.parseObject(response); | 
|                 if (jsonObject.getString("result").equals("Y")) { | 
|                     success = true; | 
|                 } else { | 
|                     log.error("请求接口失败!!!url:{};request:{};response:{}"+erpUrl+erpPath, JSON.toJSONString(combParam), response); | 
|                     throw new CoolException("上报erp系统失败"); | 
|                 } | 
|             } catch (Exception e) { | 
|                 log.error("fail", e); | 
| //                      TransactionAspectSupport.currentTransactionStatus().setRollbackOnly(); | 
|                 return FAIL.setMsg(e.getMessage()); | 
|             } finally { | 
|                 try { | 
|                     // 保存接口日志 | 
|                     apiLogService.save( | 
|                             "上报erp系统", | 
|                             erpUrl + erpPath, | 
|                             null, | 
|                             erpUrl, | 
|                             JSON.toJSONString(combParam), | 
|                             response, | 
|                             success | 
|                     ); | 
|                 } catch (Exception e) { log.error("", e); } | 
|             } | 
|         } | 
|         return SUCCESS; | 
|     } | 
| } |