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.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 {
|
|
@Autowired
|
private ApiLogService apiLogService;
|
|
@Resource
|
private WrkMastMapper wrkMastMapper;
|
|
@Transactional
|
public void startCkrwPushGwcs(WrkMast wrkMast) {
|
|
// 获取请求头
|
Map<String, Object> 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.URL)
|
.setPath(MesConstant.PAKIN_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<String, Object> headers = new HashMap<>();
|
headers.put("digi-type", "sync ");
|
headers.put("digi-protocol", "raw");
|
|
// 构造请求体
|
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)) {
|
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);
|
}
|
}
|
}
|
}
|