From 8444e9a453fb076487c2d6852af910dd8220dc3b Mon Sep 17 00:00:00 2001 From: chenlong Date: Thu, 28 Mar 2024 19:14:33 +0800 Subject: [PATCH 1/6] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E7=B1=BB?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../common/constant/ModuleNameConstant.java | 2 +- .../opFailRetryPushPackage/PushStatus.java | 15 +++++ .../entity/OpFailRetryPushPackageEntity.java | 56 +++++++++++++++++ .../mapper/OpFailRetryPushPackageMapper.java | 11 ++++ .../OpFailRetryPushPackageService.java | 19 ++++++ .../OpFailRetryPushPackageServiceImpl.java | 61 +++++++++++++++++++ .../report/service/IndexCountService.java | 14 ----- .../impl/InLibraryDeliverServiceImpl.java | 2 +- .../service/impl/IndexCountServiceImpl.java | 8 +-- 9 files changed, 168 insertions(+), 20 deletions(-) create mode 100644 blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java create mode 100644 blade-service-api/logpm-factory-api/src/main/java/com/logpm/factory/oupai/entity/OpFailRetryPushPackageEntity.java create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java index b9e346f91..44f4f96b0 100644 --- a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java @@ -8,7 +8,7 @@ public interface ModuleNameConstant { /** * 如果不需要 "" */ - public static final String DEVAUTH =""; + public static final String DEVAUTH ="-chenlong"; /** * 工厂对接服务名称 diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java b/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java new file mode 100644 index 000000000..6616a0b1a --- /dev/null +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java @@ -0,0 +1,15 @@ +package org.springblade.common.constant.opFailRetryPushPackage; + +import lombok.AllArgsConstructor; +import lombok.Getter; + +@AllArgsConstructor +@Getter +enum PushStatus { + wait("等待中", 1), + complete("已完成", 2), + expire("已过期", 3); + + private final String name; + private final Integer value; +} diff --git a/blade-service-api/logpm-factory-api/src/main/java/com/logpm/factory/oupai/entity/OpFailRetryPushPackageEntity.java b/blade-service-api/logpm-factory-api/src/main/java/com/logpm/factory/oupai/entity/OpFailRetryPushPackageEntity.java new file mode 100644 index 000000000..b5d939ee7 --- /dev/null +++ b/blade-service-api/logpm-factory-api/src/main/java/com/logpm/factory/oupai/entity/OpFailRetryPushPackageEntity.java @@ -0,0 +1,56 @@ +package com.logpm.factory.oupai.entity; + + +import com.baomidou.mybatisplus.annotation.TableField; +import com.baomidou.mybatisplus.annotation.TableName; +import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; +import lombok.EqualsAndHashCode; +import org.springblade.core.mp.base.BaseEntity; + +@Data +@TableName("op_fail_retry_push_package") +@ApiModel(value = "opFailRetryPushPackage对象", description = "欧派失败重推包件") +@EqualsAndHashCode(callSuper = true) +public class OpFailRetryPushPackageEntity extends BaseEntity { + /** 预留1 */ + @ApiModelProperty(name = "预留1",notes = "") + private String reserve1 ; + + /** 预留2 */ + @ApiModelProperty(name = "预留2",notes = "") + private String reserve2 ; + + /** 预留3 */ + @ApiModelProperty(name = "预留3",notes = "") + private String reserve3 ; + + /** 预留4 */ + @ApiModelProperty(name = "预留4",notes = "") + private String reserve4 ; + + /** 预留5 */ + @ApiModelProperty(name = "预留5",notes = "") + private String reserve5 ; + + /** 预留5 */ + @TableField("order_package_code") + @ApiModelProperty(name = "包件码",notes = "") + private String orderPackageCode; + + /** 预留5 */ + @ApiModelProperty(name = "执行参数",notes = "") + private String params ; + + /** 预留5 */ + @TableField("push_status") + @ApiModelProperty(name = "状态:1=待处理,2=已处理,3=已过期",notes = "") + private Integer pushStatus ; + + /** 预留5 */ + @ApiModelProperty(name = "类型:1=入库,2=出库",notes = "") + private Integer type ; + + +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java new file mode 100644 index 000000000..5092a79ef --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java @@ -0,0 +1,11 @@ +package com.logpm.factory.oupai.mapper; + + +import com.baomidou.mybatisplus.core.mapper.BaseMapper; +import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; +import org.apache.ibatis.annotations.Mapper; + +@Mapper +public interface OpFailRetryPushPackageMapper extends BaseMapper{ + +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java new file mode 100644 index 000000000..744f5c7c9 --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java @@ -0,0 +1,19 @@ +package com.logpm.factory.oupai.service; + +import com.logpm.factory.comfac.dto.OrderStatusDTO; + +public interface OpFailRetryPushPackageService { + + /** + * 记录失败的数据 + * + * @param orderPackageCode 包条 + * @param orderStatusDTO + */ + void record(String orderPackageCode, OrderStatusDTO orderStatusDTO); + + /** + * 重推 + */ + void retry(); +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java new file mode 100644 index 000000000..0b5a3e433 --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java @@ -0,0 +1,61 @@ +package com.logpm.factory.oupai.service.impl; + +import com.alibaba.nacos.shaded.com.google.gson.Gson; +import com.logpm.factory.comfac.dto.OrderStatusDTO; +import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; +import com.logpm.factory.oupai.mapper.OpFailRetryPushPackageMapper; +import com.logpm.factory.oupai.service.OpFailRetryPushPackageService; +import lombok.AllArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.ArrayList; +import java.util.HashMap; +import java.util.List; + +/** + * 欧派数据失败重推 + */ +@Slf4j +@Service +@AllArgsConstructor +public class OpFailRetryPushPackageServiceImpl implements OpFailRetryPushPackageService { + + private OpFailRetryPushPackageMapper opFailRetryPushPackageMapper; + + private static boolean isRetrying = false; + private static List retryData; + + @Override + public void record(String orderPackageCode, OrderStatusDTO orderStatusDTO) { + if (isRetrying) { + return; + } + + try { + OpFailRetryPushPackageEntity opFailRetryPushPackageEntity = new OpFailRetryPushPackageEntity(); + + opFailRetryPushPackageEntity.setOrderPackageCode(orderPackageCode); + opFailRetryPushPackageEntity.setParams(new Gson().toJson(orderStatusDTO)); + + opFailRetryPushPackageMapper.insert(opFailRetryPushPackageEntity); + + }catch (Exception e){ + log.error(e.getMessage(),e); + } + } + + @Override + public synchronized void retry() { + isRetrying = true; + + retryData = new ArrayList<>(); + + // ...... + HashMap condition = new HashMap<>(); + condition.put("status", PushStatus.wait); + opFailRetryPushPackageMapper.selectByMap(condition); + + retryData = null; + } +} diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/service/IndexCountService.java b/blade-service/logpm-report/src/main/java/com/logpm/report/service/IndexCountService.java index 205658d90..8ef6c774f 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/service/IndexCountService.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/service/IndexCountService.java @@ -10,18 +10,4 @@ import com.logpm.report.vo.indexCount.QuantityAbnormalWorkOrdersVO; public interface IndexCountService { IndexCountVO indexCount(Long warehouseId); - - /** - * 当月异常工单数量 - * @param warehouseId - * @return - */ - QuantityAbnormalWorkOrdersVO numberOfAbnormalWorkOrdersTheMonth(Long warehouseId); - - /** - * 当月出入库数量 - * @param warehouseId - * @return - */ - InboundAndOutboundQuantityVO inboundAndOutboundQuantityTheMonth(Long warehouseId); } diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/InLibraryDeliverServiceImpl.java b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/InLibraryDeliverServiceImpl.java index 6542c0dd1..279fb645b 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/InLibraryDeliverServiceImpl.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/InLibraryDeliverServiceImpl.java @@ -31,7 +31,7 @@ public class InLibraryDeliverServiceImpl implements InLibraryDeliverService { /** * 上架数量 * @param id - * @param order_package_grounding_status 状态 ;1=已上架,2 = 未上架 + * @param order_package_grounding_status 状态 ;2=已上架,1 = 未上架 * @return */ public Integer theNumberOfShelvesInTheLibrary(Long id, Integer order_package_grounding_status){ diff --git a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/IndexCountServiceImpl.java b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/IndexCountServiceImpl.java index 910d9bbfc..a7139521c 100644 --- a/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/IndexCountServiceImpl.java +++ b/blade-service/logpm-report/src/main/java/com/logpm/report/service/impl/IndexCountServiceImpl.java @@ -10,6 +10,7 @@ import lombok.AllArgsConstructor; import org.springblade.common.constant.aftersales.WorkOrderStatusConstant; import org.springblade.common.constant.orderpackage.OrderPackageStatusConstant; import org.springblade.common.constant.stockup.StockupTypeConstant; +import org.springframework.cache.annotation.Cacheable; import org.springframework.stereotype.Service; import java.util.HashMap; @@ -33,6 +34,7 @@ public class IndexCountServiceImpl implements IndexCountService { /** * 首页统计数据 */ + @Cacheable(value = "indexCount=10", key = "#warehouseId") public IndexCountVO indexCount(Long warehouseId) { // 这里需要换这里的代码,测试是模拟请求携带仓库ID参数 // Long warehouseId = AuthUtil.getWarehouseId(); @@ -52,8 +54,8 @@ public class IndexCountServiceImpl implements IndexCountService { private InStoreDataVO inStoreData(Long warehouseId) { InStoreDataVO inStoreDataVO = new InStoreDataVO(); - Integer OnTheShelves = 1; // 上架 - Integer NotOnTheShelves = 2; // 未上架 + Integer OnTheShelves = 2; // 上架 + Integer NotOnTheShelves = 1; // 未上架 inStoreDataVO.setAll(inLibraryDeliverService.indexCount(warehouseId)); inStoreDataVO.setOnTheShelves(inLibraryDeliverService.theNumberOfShelvesInTheLibrary(warehouseId, OnTheShelves)); @@ -66,7 +68,6 @@ public class IndexCountServiceImpl implements IndexCountService { /** * 异常工单数据 */ - @Override public QuantityAbnormalWorkOrdersVO numberOfAbnormalWorkOrdersTheMonth(Long warehouseId) { String status = WorkOrderStatusConstant.daichuli.getValue(); @@ -81,7 +82,6 @@ public class IndexCountServiceImpl implements IndexCountService { * * @param warehouseId */ - @Override public InboundAndOutboundQuantityVO inboundAndOutboundQuantityTheMonth(Long warehouseId) { InboundAndOutboundQuantityVO inboundAndOutboundQuantityVO = new InboundAndOutboundQuantityVO(); String status = OrderPackageStatusConstant.yichuku.getValue(); From 6007abb9edc3a285edec612a0f62cc09aedac462 Mon Sep 17 00:00:00 2001 From: zhaoqiaobo Date: Fri, 29 Mar 2024 14:24:39 +0800 Subject: [PATCH 2/6] =?UTF-8?q?feat(mq):=20=E6=9A=82=E5=AD=98=E5=8D=95?= =?UTF-8?q?=E9=81=97=E7=95=99=E7=8A=B6=E6=80=81?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit 1 根据志邦的遗留状态给暂存单赋值 --- .../factorydata/zbom/mq/ZbomFactoryOrderListener.java | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/blade-service/logpm-factory-data/logpm-factory-data-zbom/src/main/java/com/logpm/factorydata/zbom/mq/ZbomFactoryOrderListener.java b/blade-service/logpm-factory-data/logpm-factory-data-zbom/src/main/java/com/logpm/factorydata/zbom/mq/ZbomFactoryOrderListener.java index 48fe3c9c1..08b8f8e6a 100644 --- a/blade-service/logpm-factory-data/logpm-factory-data-zbom/src/main/java/com/logpm/factorydata/zbom/mq/ZbomFactoryOrderListener.java +++ b/blade-service/logpm-factory-data/logpm-factory-data-zbom/src/main/java/com/logpm/factorydata/zbom/mq/ZbomFactoryOrderListener.java @@ -197,7 +197,7 @@ public class ZbomFactoryOrderListener { advanceEntity.setWaybillNo(""); advanceEntity.setTrainNumber(zbReceiptDTO.getDepartCode()); advanceEntity.setFreezeStatus("0"); - advanceEntity.setLegacyStatus("0"); + advanceEntity.setSenderFactory(zbReceiptDTO.getSenderName()); List packageList = new ArrayList<>(); for (OrderPackageDTO orderPackageDTO : value) { @@ -210,12 +210,18 @@ public class ZbomFactoryOrderListener { advanceEntity.setConsigneePerson(orderPackageDTO.getReceiverName()); advanceEntity.setConsigneeMobile(orderPackageDTO.getReceiverMobile()); advanceEntity.setConsigneeAddress(orderPackageDTO.getReceiverAddress()); + // 封装包件 TrunklineAdvanceDetailEntity advanceDetailEntity = new TrunklineAdvanceDetailEntity(); advanceDetailEntity.setWarehouseId(startWarehouseId); advanceDetailEntity.setWarehouseName(startWarehouseName); // advanceDetailEntity.setIncomingWarehouseId(0L); // advanceDetailEntity.setIncomingWarehouseName(""); + // 根据志邦的一流单标识赋值 + advanceEntity.setLegacyStatus("0"); + if(ObjectUtil.equal(orderPackageDTO.getLegacyFlag(),"Y")){ + advanceEntity.setLegacyStatus("1"); + } advanceDetailEntity.setOrderCode(orderPackageDTO.getPlatformOrderCode()); advanceDetailEntity.setBrand(zbReceiptDTO.getSenderName()); From 15860d626820f5eb5d4716673e20ee2e0b6c4449 Mon Sep 17 00:00:00 2001 From: chenlong Date: Fri, 29 Mar 2024 17:40:23 +0800 Subject: [PATCH 3/6] =?UTF-8?q?=E5=A2=9E=E5=8A=A0=E6=AC=A7=E6=B4=BE?= =?UTF-8?q?=E4=B8=8D=E5=AD=98=E5=9C=A8=E7=9A=84=E5=8C=85=E6=9D=A1=E7=9A=84?= =?UTF-8?q?=E9=87=8D=E6=8E=A8=E5=AE=9A=E6=97=B6=E4=BB=BB=E5=8A=A1?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../opFailRetryPushPackage/PushStatus.java | 22 ++++- .../jobhandler/OpFailPackageRetryJob.java | 69 ++++++++++++++ .../mapper/OpFailRetryPushPackageMapper.java | 5 + .../mapper/OpFailRetryPushPackageMapper.xml | 33 +++++++ .../oupai/service/IOuPaiFactoryService.java | 8 ++ .../OpFailRetryPushPackageService.java | 14 +-- .../OpPushFailedPackageRecordService.java | 15 +++ .../OpFailRetryPushPackageServiceImpl.java | 91 +++++++++++++------ .../OpPushFailedPackageRecordServiceImpl.java | 53 +++++++++++ .../service/impl/OuPaiFactoryServiceImpl.java | 35 ++++++- 10 files changed, 303 insertions(+), 42 deletions(-) create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/jobhandler/OpFailPackageRetryJob.java create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.xml create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpPushFailedPackageRecordService.java create mode 100644 blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpPushFailedPackageRecordServiceImpl.java diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java b/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java index 6616a0b1a..b106f20fb 100644 --- a/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/opFailRetryPushPackage/PushStatus.java @@ -5,11 +5,27 @@ import lombok.Getter; @AllArgsConstructor @Getter -enum PushStatus { +public enum PushStatus { wait("等待中", 1), complete("已完成", 2), expire("已过期", 3); - private final String name; - private final Integer value; + private String name; + private Integer value; + + public String getName() { + return name; + } + + public void setName(String name) { + this.name = name; + } + + public Integer getValue() { + return value; + } + + public void setValue(Integer value) { + this.value = value; + } } diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/jobhandler/OpFailPackageRetryJob.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/jobhandler/OpFailPackageRetryJob.java new file mode 100644 index 000000000..d62b1af9c --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/jobhandler/OpFailPackageRetryJob.java @@ -0,0 +1,69 @@ +package com.logpm.factory.jobhandler; + +import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; +import com.logpm.factory.oupai.mapper.OpFailRetryPushPackageMapper; +import com.logpm.factory.oupai.service.OpFailRetryPushPackageService; +import com.xxl.job.core.biz.model.ReturnT; +import com.xxl.job.core.handler.annotation.XxlJob; +import lombok.AllArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springblade.common.constant.opFailRetryPushPackage.PushStatus; +import org.springframework.beans.factory.annotation.Qualifier; +import org.springframework.stereotype.Component; + +import java.util.HashMap; +import java.util.List; + + +@Slf4j +@Component +@AllArgsConstructor +public class OpFailPackageRetryJob { + + private final OpFailRetryPushPackageService opFailRetryPushPackageService; + + private OpFailRetryPushPackageMapper opFailRetryPushPackageMapper; + + // 是否开启多线程处理 + private static final boolean IsMultithreadingHandle = false; + + // 多线程批次处理的时候,每次最大处理的数据量 + private static final Integer batchHandleQuantity = 1000; + + /** + * 欧派数据推送失败的进行定时重推 + * @return + */ + @XxlJob("opFailPackageRetryJob") + public ReturnT execute(String param) { + + try { + if (IsMultithreadingHandle) { + batchHandleData(null); + } else { + HashMap condition = new HashMap<>(); + condition.put("push_status", PushStatus.wait.getValue()); + List opFailRetryPushPackageEntities = opFailRetryPushPackageMapper.selectByMap(condition); + opFailRetryPushPackageService.retry(opFailRetryPushPackageEntities); + } + }catch (Exception exception){ + log.error("OpFailPackageRetryJob error:{}",exception.getMessage()); + } + + return ReturnT.SUCCESS; + } + + /** + * 批次处理 + * @param startId + */ + private void batchHandleData(Long startId) { + List batchData = opFailRetryPushPackageMapper.selectWaitData(batchHandleQuantity, startId); + + if (batchData.size() == batchHandleQuantity) { + batchHandleData(batchData.get(batchHandleQuantity - 1).getId()); + } + + opFailRetryPushPackageService.retry(batchData); + } +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java index 5092a79ef..393c882c9 100644 --- a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.java @@ -5,7 +5,12 @@ import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; import org.apache.ibatis.annotations.Mapper; +import java.util.List; + @Mapper public interface OpFailRetryPushPackageMapper extends BaseMapper{ + void updateStatusToCompleteByIds(List ids); + void updateStatusToExpireByIds(List ids, String date); + List selectWaitData(Integer limit, Long startId); } diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.xml b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.xml new file mode 100644 index 000000000..825e5078b --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/mapper/OpFailRetryPushPackageMapper.xml @@ -0,0 +1,33 @@ + + + + + UPDATE logpm_factory.op_fail_retry_push_package + SET push_status = 2 + WHERE id IN + + #{id} + + + + + UPDATE logpm_factory.op_fail_retry_push_package + SET push_status = 3 + WHERE id IN + + #{id} + + AND create_time #{date} + + + + + diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/IOuPaiFactoryService.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/IOuPaiFactoryService.java index 588e3f22e..dae259581 100644 --- a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/IOuPaiFactoryService.java +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/IOuPaiFactoryService.java @@ -40,5 +40,13 @@ public interface IOuPaiFactoryService { */ R handleStatusData(OrderStatusDTO orderStatusDTO); + /** + * 欧派推送包件状态 + * @see IOuPaiFactoryService#handleStatusData + * @param orderStatusDTO + * @return + */ + boolean retryHandleStatusData(OrderStatusDTO orderStatusDTO); + R newSystemHandleStatusData(OrderStatusDTO orderStatusDTO); } diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java index 744f5c7c9..8498c61a2 100644 --- a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpFailRetryPushPackageService.java @@ -1,19 +1,13 @@ package com.logpm.factory.oupai.service; -import com.logpm.factory.comfac.dto.OrderStatusDTO; +import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; -public interface OpFailRetryPushPackageService { +import java.util.List; - /** - * 记录失败的数据 - * - * @param orderPackageCode 包条 - * @param orderStatusDTO - */ - void record(String orderPackageCode, OrderStatusDTO orderStatusDTO); +public interface OpFailRetryPushPackageService { /** * 重推 */ - void retry(); + void retry(List waitData); } diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpPushFailedPackageRecordService.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpPushFailedPackageRecordService.java new file mode 100644 index 000000000..6b0acdc11 --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/OpPushFailedPackageRecordService.java @@ -0,0 +1,15 @@ +package com.logpm.factory.oupai.service; + +import com.logpm.factory.comfac.dto.OrderStatusDTO; + +public interface OpPushFailedPackageRecordService { + + /** + * 记录失败的数据 + * + * @param orderPackageCode 包条 + * @param orderStatusDTO + */ + void record(String orderPackageCode, OrderStatusDTO orderStatusDTO); + +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java index 0b5a3e433..8fc004111 100644 --- a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpFailRetryPushPackageServiceImpl.java @@ -1,61 +1,96 @@ package com.logpm.factory.oupai.service.impl; import com.alibaba.nacos.shaded.com.google.gson.Gson; +import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.logpm.factory.comfac.dto.OrderStatusDTO; import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; import com.logpm.factory.oupai.mapper.OpFailRetryPushPackageMapper; +import com.logpm.factory.oupai.service.IOuPaiFactoryService; import com.logpm.factory.oupai.service.OpFailRetryPushPackageService; import lombok.AllArgsConstructor; import lombok.extern.slf4j.Slf4j; + +import org.springblade.common.constant.opFailRetryPushPackage.PushStatus; +import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; -import java.util.ArrayList; -import java.util.HashMap; -import java.util.List; +import java.text.SimpleDateFormat; +import java.util.*; /** * 欧派数据失败重推 */ @Slf4j -@Service +@Service("one") @AllArgsConstructor public class OpFailRetryPushPackageServiceImpl implements OpFailRetryPushPackageService { - private OpFailRetryPushPackageMapper opFailRetryPushPackageMapper; + protected OpFailRetryPushPackageMapper opFailRetryPushPackageMapper; - private static boolean isRetrying = false; - private static List retryData; + protected IOuPaiFactoryService ouPaiFactoryService; - @Override - public void record(String orderPackageCode, OrderStatusDTO orderStatusDTO) { - if (isRetrying) { - return; - } + protected final int MAX_RETRY_TIMES = 3; - try { - OpFailRetryPushPackageEntity opFailRetryPushPackageEntity = new OpFailRetryPushPackageEntity(); + @Async + @Override + public void retry(List waitData){ + ArrayList completeIds = new ArrayList<>(); + ArrayList failIds = new ArrayList<>(); - opFailRetryPushPackageEntity.setOrderPackageCode(orderPackageCode); - opFailRetryPushPackageEntity.setParams(new Gson().toJson(orderStatusDTO)); + waitData.forEach(opFailRetryPushPackageEntity -> executeRetry(opFailRetryPushPackageEntity, completeIds, failIds)); - opFailRetryPushPackageMapper.insert(opFailRetryPushPackageEntity); + updatePushStatus(completeIds, failIds); + } - }catch (Exception e){ - log.error(e.getMessage(),e); + /** + * 更新推送状态 + * @param completeIds + * @param failIds + */ + protected void updatePushStatus(ArrayList completeIds, ArrayList failIds){ + if (!completeIds.isEmpty()) { + opFailRetryPushPackageMapper.updateStatusToCompleteByIds(completeIds); + } + if (!failIds.isEmpty()) { + opFailRetryPushPackageMapper.updateStatusToExpireByIds(failIds, getExpireTime()); } } - @Override - public synchronized void retry() { - isRetrying = true; + /** + * 获取过期的时间 + * + * @return + */ + protected String getExpireTime(){ + Calendar calendar = Calendar.getInstance(); + Date date = new Date(); + + calendar.setTime(date); + calendar.add(Calendar.DATE, -MAX_RETRY_TIMES); - retryData = new ArrayList<>(); + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); - // ...... - HashMap condition = new HashMap<>(); - condition.put("status", PushStatus.wait); - opFailRetryPushPackageMapper.selectByMap(condition); + return sdf.format(calendar.getTime()); + } - retryData = null; + /** + * 执行重试 + * @param opFailRetryPushPackageEntity + * @param completeIds + */ + protected void executeRetry(OpFailRetryPushPackageEntity opFailRetryPushPackageEntity, ArrayList completeIds, ArrayList failIds) { + try { + OrderStatusDTO orderStatusDTO = new Gson().fromJson(opFailRetryPushPackageEntity.getParams(), OrderStatusDTO.class); + + boolean res = ouPaiFactoryService.retryHandleStatusData(orderStatusDTO); + + if (res) { + completeIds.add(opFailRetryPushPackageEntity.getId()); + } else { + failIds.add(opFailRetryPushPackageEntity.getId()); + } + } catch (Exception e) { + log.error("executeRetry error: {}", e.getMessage()); + } } } diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpPushFailedPackageRecordServiceImpl.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpPushFailedPackageRecordServiceImpl.java new file mode 100644 index 000000000..67e89772e --- /dev/null +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OpPushFailedPackageRecordServiceImpl.java @@ -0,0 +1,53 @@ +package com.logpm.factory.oupai.service.impl; + +import com.alibaba.nacos.shaded.com.google.gson.Gson; +import com.logpm.factory.comfac.dto.OrderStatusDTO; +import com.logpm.factory.oupai.entity.OpFailRetryPushPackageEntity; +import com.logpm.factory.oupai.mapper.OpFailRetryPushPackageMapper; +import com.logpm.factory.oupai.service.OpPushFailedPackageRecordService; +import lombok.AllArgsConstructor; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Service; + +import java.util.Date; +import java.util.HashMap; + +@Slf4j +@Service +@AllArgsConstructor +public class OpPushFailedPackageRecordServiceImpl implements OpPushFailedPackageRecordService { + + private OpFailRetryPushPackageMapper opFailRetryPushPackageMapper; + + /** + * 记录失败的数据 + * + * @param orderPackageCode 包条 + * @param orderStatusDTO + */ + @Override + public void record(String orderPackageCode, OrderStatusDTO orderStatusDTO){ + + try { + OpFailRetryPushPackageEntity opFailRetryPushPackageEntity = new OpFailRetryPushPackageEntity(); + + opFailRetryPushPackageEntity.setOrderPackageCode(orderPackageCode); + opFailRetryPushPackageEntity.setParams(new Gson().toJson(orderStatusDTO)); + opFailRetryPushPackageEntity.setCreateTime(new Date()); + + // 判重 +// HashMap queryMap = new HashMap<>(); +// queryMap.put("orderPackageCode", orderPackageCode); +// if (opFailRetryPushPackageMapper.selectByMap(queryMap) != null) { +// return; +// } + + opFailRetryPushPackageMapper.insert(opFailRetryPushPackageEntity); + + }catch (Exception e){ + log.error(e.getMessage(),e); + } + + } + +} diff --git a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OuPaiFactoryServiceImpl.java b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OuPaiFactoryServiceImpl.java index 1bcf982eb..a04f40e86 100644 --- a/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OuPaiFactoryServiceImpl.java +++ b/blade-service/logpm-factory/src/main/java/com/logpm/factory/oupai/service/impl/OuPaiFactoryServiceImpl.java @@ -94,6 +94,9 @@ public class OuPaiFactoryServiceImpl implements IOuPaiFactoryService { @Autowired private IDistributionParcelListClient distributionParcelListClient; + @Autowired + private OpPushFailedPackageRecordService opPushFailedPackageRecordService; + @Override public String saveOuPaiFactoryOrderDTOByCarCarNumber(String code) { @@ -403,9 +406,33 @@ public class OuPaiFactoryServiceImpl implements IOuPaiFactoryService { return orderCode; } - @Override public R handleStatusData(OrderStatusDTO orderStatusDTO) { + // 重写 handleStatusData, 增加重试参数 + // 原调用执行 + return handleStatusData(orderStatusDTO, false); + } + + /** + * 重推 + * @see #handleStatusData(OrderStatusDTO, boolean) + * @param orderStatusDTO + * @return + */ + public boolean retryHandleStatusData(OrderStatusDTO orderStatusDTO){ + R res = handleStatusData(orderStatusDTO, true); + return res.getCode() == 200; + // 测试功能时使用 +// return res.getCode() == 200 || Math.random() < 0.5; + } + + /** + * + * @param orderStatusDTO + * @param isRetry 是否是重推调用 + * @return + */ + private R handleStatusData(OrderStatusDTO orderStatusDTO, boolean isRetry) { // 推送数据 String status = orderStatusDTO.getStatus(); String unitNo = orderStatusDTO.getUnitNo(); @@ -439,6 +466,12 @@ public class OuPaiFactoryServiceImpl implements IOuPaiFactoryService { FactoryOrderEntity factoryOrder = factoryOrderService.selectEntityByOrderPackageCode(unitNo); if (Objects.isNull(factoryOrder)) { + + // 不是重试的时候,记录对应数据 + if (!isRetry) { + opPushFailedPackageRecordService.record(unitNo, orderStatusDTO); + } + return Resp.fail(400, "未查询到该单据推送订单信息"); } // 如何判断这个包间是非干仓配的数据 From e9ccb50fdf851e5f2b9eb575c008841917ad9dc0 Mon Sep 17 00:00:00 2001 From: chenlong Date: Fri, 29 Mar 2024 17:44:55 +0800 Subject: [PATCH 4/6] =?UTF-8?q?=E8=BF=98=E5=8E=9F=E6=A8=A1=E5=9D=97?= =?UTF-8?q?=E9=85=8D=E7=BD=AE?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../org/springblade/common/constant/ModuleNameConstant.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java index 69ad7c76a..9a32fef3f 100644 --- a/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java +++ b/blade-biz-common/src/main/java/org/springblade/common/constant/ModuleNameConstant.java @@ -8,7 +8,7 @@ public interface ModuleNameConstant { /** * 如果不需要 "" */ - public static final String DEVAUTH ="-chenlong"; + public static final String DEVAUTH =""; /** * 工厂对接服务名称 From d882277dd299b08109c13d517ae8be889d4bd23e Mon Sep 17 00:00:00 2001 From: "pref_mail@163.com" Date: Sat, 30 Mar 2024 09:54:18 +0800 Subject: [PATCH 5/6] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E4=BB=A3=E7=A0=81?= =?UTF-8?q?=20=E8=87=AA=E6=8F=90=E5=A4=87=E8=B4=A7=E9=A1=B5=E9=9D=A2=20nul?= =?UTF-8?q?l=E6=8C=87=E9=92=88=E5=BC=82=E5=B8=B8=E7=9A=84=E9=97=AE?= =?UTF-8?q?=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../service/impl/DistributionStockupServiceImpl.java | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java index 9801f5d5e..b7ddf5bf9 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java @@ -862,22 +862,22 @@ public class DistributionStockupServiceImpl extends BaseServiceImpl Date: Sat, 30 Mar 2024 11:16:59 +0800 Subject: [PATCH 6/6] =?UTF-8?q?fix:=20=E4=BF=AE=E5=A4=8D=E4=BB=A3=E7=A0=81?= =?UTF-8?q?=20=E8=87=AA=E6=8F=90=E5=A4=87=E8=B4=A7=E9=A1=B5=E9=9D=A2=20?= =?UTF-8?q?=E6=B2=A1=E6=9C=89=E8=87=AA=E6=8F=90=E5=A4=87=E8=B4=A7=E5=BA=93?= =?UTF-8?q?=E5=AD=98=E5=93=81=20=E7=9A=84=E9=97=AE=E9=A2=98?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../impl/DistributionStockupServiceImpl.java | 36 +++++++++---------- 1 file changed, 18 insertions(+), 18 deletions(-) diff --git a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java index b7ddf5bf9..389e271d3 100644 --- a/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java +++ b/blade-service/logpm-distribution/src/main/java/com/logpm/distribution/service/impl/DistributionStockupServiceImpl.java @@ -1150,26 +1150,11 @@ public class DistributionStockupServiceImpl extends BaseServiceImpl list = distributionStockupService.selectStockupSelf(reservationId); + List list = distributionStockupService.selectStockupSelf(stockupDTO.getReservationId()); list.forEach(i -> { if (i.getPlanNum().equals(i.getRealNum())) { i.setCompleteStact(true); @@ -1192,7 +1177,22 @@ public class DistributionStockupServiceImpl extends BaseServiceImpl list = distributionReservationService.selectStockupStockList(reservationId,myCurrentWarehouse.getId(),mallName); for (DistributionStockupStockListVO distributionStockupStockListVO : list) {