package com.zy.asrs.task.handler; import com.alibaba.fastjson.JSONObject; import com.core.common.Cools; import com.core.exception.CoolException; import com.zy.asrs.entity.Order; import com.zy.asrs.entity.WrkMast; import com.zy.asrs.mapper.OrderMapper; import com.zy.asrs.mapper.WrkMastMapper; import com.zy.asrs.service.ApiLogService; import com.zy.common.constant.MesConstant; import com.zy.common.utils.HttpHandler; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import javax.annotation.Resource; import java.util.HashMap; import java.util.Map; /** * @author pang.jiabao * @description 冠鸿江铜定时任务实现 * @createDate 2024/7/3 9:09 */ @Slf4j @Service public class GhjtHandler { @Resource private OrderMapper orderMapper; @Autowired private ApiLogService apiLogService; @Resource private WrkMastMapper wrkMastMapper; @Transactional public void startCkrwPushGwcs(WrkMast wrkMast) { // 获取请求头 Map headers = new HashMap<>(); headers.put("Content-Type", "application/json;charset=UTF-8"); // 构造请求体 JSONObject jsonObject = new JSONObject(); jsonObject.put("workNo", wrkMast.getWrkNo()); jsonObject.put("staNo", wrkMast.getStaNo()); jsonObject.put("sourceStaNo", wrkMast.getSourceStaNo()); String body = jsonObject.toJSONString(); boolean success = false; String response = ""; try { response = new HttpHandler.Builder() .setUri(MesConstant.GWCS_IP_PORT) .setPath(MesConstant.GWCS_DCKK_URL) .setHeaders(headers) .setJson(body) .build() .doPost(); if (!Cools.isEmpty(response)) { wrkMast.setWrkSts(2L); // 更新为设备上走 wrkMastMapper.updateById(wrkMast); success = true; } else { log.error("请求接口失败!!!url:{};request:{};response:{}", MesConstant.URL + MesConstant.PAKIN_URL, body, response); throw new CoolException("下发出库任务给GWCS(从出库码头到出库口)失败"); } } catch (Exception e) { log.error("下发出库任务给GWCS(从出库码头到出库口)异常,工作号:{},{}", wrkMast.getWrkNo(), e.getMessage()); } finally { try { // 保存接口日志 apiLogService.save( "从出库码头到出库口", MesConstant.URL + MesConstant.PAKIN_URL, null, "127.0.0.1", jsonObject.toJSONString(), response, success ); } catch (Exception e) { log.error("接口日志保存异常", e); } } } @Transactional public void OutBoundCompleteReport(Order order) { // 获取请求头 Map headers = new HashMap<>(); headers.put("Content-Type", "application/json;charset=UTF-8"); // 构造请求体 JSONObject jsonObject = new JSONObject(); jsonObject.put("orderNo", order.getOrderNo()); jsonObject.put("complete", 1); // 订单完成为1,其他... String body = jsonObject.toJSONString(); boolean success = false; String response = ""; try { response = new HttpHandler.Builder() .setUri(MesConstant.URL) .setPath(MesConstant.PAKIN_URL) .setHeaders(headers) .setJson(body) .build() .doPost(); if (!Cools.isEmpty(response)) { order.setSettle(6L); orderMapper.updateById(order); success = true; } else { log.error("请求接口失败!!!url:{};request:{};response:{}", MesConstant.URL + MesConstant.PAKIN_URL, body, response); throw new CoolException("下发出库任务给GWCS(从出库码头到出库口)失败"); } } catch (Exception e) { log.error("出库订单完成上报MES异常,工作号:{},{}", order.getOrderNo(), e.getMessage()); } finally { try { // 保存接口日志 apiLogService.save( "出库订单完成上报MES", MesConstant.URL + MesConstant.PAKIN_URL, null, "127.0.0.1", jsonObject.toJSONString(), response, success ); } catch (Exception e) { log.error("接口日志保存异常", e); } } } }