From e5f4cb6e5e19b09ca62ebc6160720858c58f24c1 Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期二, 15 七月 2025 17:57:23 +0800
Subject: [PATCH] 111

---
 server/services/src/main/java/com/doumee/service/business/CategoryService.java          |    3 
 server/web/src/main/java/com/doumee/api/web/PaymentCallback.java                        |    2 
 server/web/src/main/java/com/doumee/api/web/ConfigApi.java                              |   47 +++++
 server/services/src/main/java/com/doumee/config/wx/SendWxMessage.java                   |   60 +++++++
 server/services/src/main/java/com/doumee/service/business/impl/CategoryServiceImpl.java |   16 ++
 server/services/src/main/java/com/doumee/config/wx/WxMiniUtilService.java               |    2 
 server/services/src/main/java/com/doumee/config/wx/WxMsgVO.java                         |   23 ++
 server/web/src/main/java/com/doumee/api/web/OrdersApi.java                              |    2 
 server/services/src/main/java/com/doumee/core/constants/Constants.java                  |   48 ++++++
 server/services/src/main/java/com/doumee/config/wx/TemplateData.java                    |   19 ++
 server/services/src/main/java/com/doumee/dao/business/model/Orders.java                 |    6 
 server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java   |   10 
 server/services/src/main/java/com/doumee/service/business/OrdersService.java            |    7 
 server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java   |  184 +++++++++++++++++-----
 server/admin/src/main/java/com/doumee/api/business/OrdersController.java                |   18 +
 15 files changed, 392 insertions(+), 55 deletions(-)

diff --git a/server/admin/src/main/java/com/doumee/api/business/OrdersController.java b/server/admin/src/main/java/com/doumee/api/business/OrdersController.java
index 7cc1c54..05784c8 100644
--- a/server/admin/src/main/java/com/doumee/api/business/OrdersController.java
+++ b/server/admin/src/main/java/com/doumee/api/business/OrdersController.java
@@ -4,6 +4,7 @@
 import com.doumee.core.annotation.excel.ExcelExporter;
 import com.doumee.core.annotation.pr.PreventRepeat;
 import com.doumee.core.model.ApiResponse;
+import com.doumee.core.model.LoginUserInfo;
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.dao.business.model.Orders;
@@ -11,6 +12,7 @@
 import com.github.xiaoymin.knife4j.core.util.CollectionUtils;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
+import org.apache.shiro.SecurityUtils;
 import org.apache.shiro.authz.annotation.RequiresPermissions;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
@@ -80,11 +82,6 @@
     @RequiresPermissions("business:orders:exportExcel")
     public void exportExcel (@RequestBody PageWrap<Orders> pageWrap, HttpServletResponse response) {
         List<Orders> ordersList = ordersService.findPage(pageWrap).getRecords();
-
-
-
-
-
         ExcelExporter.build(Orders.class).export(ordersList, "璁㈠崟淇℃伅璁板綍", response);
     }
 
@@ -94,4 +91,15 @@
     public ApiResponse findById(@PathVariable Integer id) {
         return ApiResponse.success(ordersService.findById(id));
     }
+
+    @ApiOperation("骞冲彴鍙栨秷璁㈠崟")
+    @GetMapping("/cancel")
+    @RequiresPermissions("business:orders:update")
+    public ApiResponse cancel(@RequestParam Integer id) {
+        LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        ordersService.platformCancel(id,loginUserInfo);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+
 }
diff --git a/server/services/src/main/java/com/doumee/config/wx/SendWxMessage.java b/server/services/src/main/java/com/doumee/config/wx/SendWxMessage.java
new file mode 100644
index 0000000..6dd2bf3
--- /dev/null
+++ b/server/services/src/main/java/com/doumee/config/wx/SendWxMessage.java
@@ -0,0 +1,60 @@
+package com.doumee.config.wx;
+
+import com.alibaba.fastjson.JSONObject;
+import com.doumee.biz.system.SystemDictDataBiz;
+import com.doumee.core.constants.Constants;
+import com.doumee.core.utils.DateUtil;
+import lombok.extern.slf4j.Slf4j;
+import me.chanjar.weixin.common.error.WxErrorException;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.http.ResponseEntity;
+import org.springframework.stereotype.Service;
+import org.springframework.web.client.RestTemplate;
+
+import java.util.Date;
+import java.util.HashMap;
+import java.util.Map;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2022/12/7 17:27
+ */
+@Service
+@Slf4j
+public class SendWxMessage {
+
+    private static String goodsOrderUrl = "pages/settlementDetails/settlementDetails?goodsOrderId=";
+
+    @Autowired
+    private SystemDictDataBiz systemDictDataBiz;
+
+    public  void  bookingsCancel(String openid, String goodsOrderId, String accessToken, String bikeCode, Date startTime, Date endTime) throws WxErrorException {
+        RestTemplate restTemplate = new RestTemplate();
+        log.info("寰俊灏忕▼搴�->寰俊娑堟伅閫氱煡  -> accessToken锛歿}",accessToken);
+        //杩欓噷绠�鍗曡捣瑙佹垜浠瘡娆¢兘鑾峰彇鏈�鏂扮殑access_token锛堟椂闂村紑鍙戜腑锛屽簲璇ュ湪access_token蹇繃鏈熸椂鍐嶉噸鏂拌幏鍙栵級
+        String url = "https://api.weixin.qq.com/cgi-bin/message/subscribe/send?access_token="+WxMiniConfig.wxMaService.getAccessToken();
+        //鎷兼帴鎺ㄩ�佺殑妯$増
+        WxMsgVO wxMsgVo = new WxMsgVO();
+        //鐢ㄦ埛鐨刼penid锛堣鍙戦�佺粰閭d釜鐢ㄦ埛锛�
+        wxMsgVo.setTouser(openid);
+        //璁㈤槄娑堟伅妯℃澘id
+//        wxMsgVo.setTemplate_id(systemDictDataBiz.queryByCode(Constants.MINI_PROGRAMME,Constants.TIME_OUT_TEMPID).getCode());
+        Map<String, TemplateData> m = new HashMap<>(4);
+        m.put("character_string1", new TemplateData(bikeCode));
+        //瑙i攣鏃堕棿
+        m.put("date3", new TemplateData(DateUtil.getFomartDate(startTime,"yyyy/MM/dd HH:mm")));
+        //涓婇攣鏃堕棿
+        m.put("date4", new TemplateData(DateUtil.getFomartDate(endTime,"yyyy/MM/dd HH:mm")));
+        //娓╅Θ鎻愰啋
+        m.put("thing5", new TemplateData("涓存椂閿佽溅宸茶秴杩囨渶澶ф椂闀匡紝宸茶嚜鍔ㄨ繕杞�"));
+        wxMsgVo.setPage(goodsOrderUrl + goodsOrderId);
+        wxMsgVo.setData(m);
+        ResponseEntity<String> responseEntity =
+                restTemplate.postForEntity(url, wxMsgVo, String.class);
+        log.info("寰俊灏忕▼搴�->寰俊娑堟伅閫氱煡 涓存椂閿佽溅瓒呮椂锛歿}", JSONObject.toJSONString(responseEntity));
+    }
+
+
+}
diff --git a/server/services/src/main/java/com/doumee/config/wx/TemplateData.java b/server/services/src/main/java/com/doumee/config/wx/TemplateData.java
new file mode 100644
index 0000000..4db29c4
--- /dev/null
+++ b/server/services/src/main/java/com/doumee/config/wx/TemplateData.java
@@ -0,0 +1,19 @@
+package com.doumee.config.wx;
+
+import lombok.Data;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2022/12/7 17:28
+ */
+@Data
+public class TemplateData {
+    private String value;
+
+    public TemplateData(String value) {
+        this.value = value;
+    }
+
+}
diff --git a/server/services/src/main/java/com/doumee/config/wx/WxMiniUtilService.java b/server/services/src/main/java/com/doumee/config/wx/WxMiniUtilService.java
index 26bf4d0..4647c17 100644
--- a/server/services/src/main/java/com/doumee/config/wx/WxMiniUtilService.java
+++ b/server/services/src/main/java/com/doumee/config/wx/WxMiniUtilService.java
@@ -54,7 +54,7 @@
         withdrawalOrdersMapper.insert(withdrawalOrders);
         CreateRequest request = new CreateRequest();
         request.setOutTradeNo(orders.getCode());
-        request.setOutRefundNo("refund_"+orders.getCode());
+        request.setOutRefundNo(withdrawalOrders.getId().toString());
         request.setSubMchid(WxMiniConfig.wxProperties.getSubMchId());
         request.setNotifyUrl(WxMiniConfig.wxProperties.getRefundNotifyUrl());
         AmountReq amountReq = new AmountReq();
diff --git a/server/services/src/main/java/com/doumee/config/wx/WxMsgVO.java b/server/services/src/main/java/com/doumee/config/wx/WxMsgVO.java
new file mode 100644
index 0000000..eecc7fd
--- /dev/null
+++ b/server/services/src/main/java/com/doumee/config/wx/WxMsgVO.java
@@ -0,0 +1,23 @@
+package com.doumee.config.wx;
+
+import lombok.Data;
+
+import java.util.Map;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2022/12/7 17:27
+ */
+@Data
+public class WxMsgVO {
+    //鐢ㄦ埛openId
+    private String touser;
+    //妯$増id
+    private String template_id;
+    //鎺ㄩ�佹枃瀛�
+    private Map<String , TemplateData> data;
+    //璺宠浆璺緞 锛岄粯璁よ烦杞埌灏忕▼搴忛椤�
+    private String page="pages/index/index";
+}
diff --git a/server/services/src/main/java/com/doumee/core/constants/Constants.java b/server/services/src/main/java/com/doumee/core/constants/Constants.java
index df01084..e38d579 100644
--- a/server/services/src/main/java/com/doumee/core/constants/Constants.java
+++ b/server/services/src/main/java/com/doumee/core/constants/Constants.java
@@ -411,6 +411,8 @@
         COMMENT(10, "鍙戝崟鏂�-璇勪环瀹屾垚","{userName}瀹屾垚璇勪环",0),
         SYSTEM_CANCEL(11, "绯荤粺-璁㈠崟鍙栨秷","绯荤粺鍙栨秷",2),
         RELEASE_CANCEL(12, "鍙戝崟鏂�-璁㈠崟鍙栨秷","{userName}宸叉墜鍔ㄥ彇娑堣鍗�",0),
+        AUTO_COMMENT(13, "绯荤粺-鑷姩璇勪环","瓒呭嚭7鏃ユ湭璇勪环锛岀郴缁熷凡鑷姩璇勪环",2),
+        AUTO_AGREE(14, "绯荤粺-鑷姩鍚屾剰","鎺ュ崟鏂硅秴鏃舵湭澶勭悊锛屽凡鑷姩鍚屾剰",2),
 
         ;
         // 鎴愬憳鍙橀噺
@@ -525,4 +527,50 @@
     }
 
 
+    public  enum ordersStatus {
+        waitPay(0, "寰呮敮浠�"),
+        wait(1, "寰呮帴鍗�"),
+        accept(2, "宸叉帴鍗�"),
+        doing(3, "杩涜涓�"),
+        done(4, "宸插畬鎴�"),
+        cancel(99, "鍖呰宸�"),
+        ;
+        // 鎴愬憳鍙橀噺
+        private int key;
+        private String name;
+
+        // 鏋勯�犳柟娉�
+        ordersStatus(int key, String name) {
+            this.name = name;
+            this.key = key;
+        }
+
+        // 鏅�氭柟娉�
+        public static String getName(int index) {
+            for (ordersStatus c : ordersStatus.values()) {
+                if (c.getKey() == index) {
+                    return c.name;
+                }
+            }
+            return null;
+        }
+        // get set 鏂规硶
+        public String getName() {
+            return name;
+        }
+
+        public void setName(String name) {
+            this.name = name;
+        }
+
+        public int getKey() {
+            return key;
+        }
+
+        public void setKey(int key) {
+            this.key = key;
+        }
+
+    }
+
 }
diff --git a/server/services/src/main/java/com/doumee/dao/business/model/Orders.java b/server/services/src/main/java/com/doumee/dao/business/model/Orders.java
index 67d9c3f..f17f61e 100644
--- a/server/services/src/main/java/com/doumee/dao/business/model/Orders.java
+++ b/server/services/src/main/java/com/doumee/dao/business/model/Orders.java
@@ -187,6 +187,9 @@
     @ApiModelProperty(value = "鏄惁宸蹭慨鏀�:0=鍚︼紱1=鏄紱2=宸茬‘璁�;", example = "1")
     private Integer isUpdate;
 
+    @ApiModelProperty(value = "淇敼鏃堕棿", example = "1")
+    private Integer isUpdateTime;
+
     @ApiModelProperty(value = "鎺ュ崟鏂归粦鍚嶅崟member:id 澶氫釜浠�,鍒嗗壊")
     private String blackReceive;
 
@@ -206,6 +209,9 @@
     @TableField(exist = false)
     private List<OrderLog> orderLogList;
 
+    @ApiModelProperty(value = "璁㈠崟鐘舵�佹弿杩�", example = "1")
+    @TableField(exist = false)
+    private String statusName;
 
 
     @ApiModelProperty(value = "閫旂粡鐐�")
diff --git a/server/services/src/main/java/com/doumee/service/business/CategoryService.java b/server/services/src/main/java/com/doumee/service/business/CategoryService.java
index 8d2b1ad..a48a0d1 100644
--- a/server/services/src/main/java/com/doumee/service/business/CategoryService.java
+++ b/server/services/src/main/java/com/doumee/service/business/CategoryService.java
@@ -94,4 +94,7 @@
      * @return long
      */
     long count(Category category);
+
+
+    List<Category> getCategoryList(Integer type);
 }
diff --git a/server/services/src/main/java/com/doumee/service/business/OrdersService.java b/server/services/src/main/java/com/doumee/service/business/OrdersService.java
index c501dc0..4132624 100644
--- a/server/services/src/main/java/com/doumee/service/business/OrdersService.java
+++ b/server/services/src/main/java/com/doumee/service/business/OrdersService.java
@@ -9,6 +9,7 @@
 import com.doumee.dao.dto.ConfirmUpdOrderDTO;
 import com.doumee.dao.dto.DoneOrderDTO;
 import com.doumee.dao.dto.UpdOrderDataDTO;
+import com.wechat.pay.java.service.refund.model.RefundNotification;
 
 import java.util.List;
 
@@ -130,4 +131,10 @@
     PageData<Orders> findPageForMini(PageWrap<Orders> pageWrap);
 
     Orders getDetail(Integer id,Integer userType);
+
+    void refundCallback(RefundNotification refundNotification);
+
+    void autoComment();
+
+    void autoConfirm();
 }
diff --git a/server/services/src/main/java/com/doumee/service/business/impl/CategoryServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/CategoryServiceImpl.java
index 642bff7..9b1f873 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/CategoryServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/CategoryServiceImpl.java
@@ -248,4 +248,20 @@
         QueryWrapper<Category> wrapper = new QueryWrapper<>(category);
         return categoryMapper.selectCount(wrapper);
     }
+
+    @Override
+    public List<Category> getCategoryList(Integer type){
+        List<Category> categoryList = categoryMapper.selectList(new QueryWrapper<Category>().lambda().eq(Category::getDeleted,Constants.ZERO).eq(Category::getStatus,Constants.ZERO)
+                .eq(Objects.nonNull(type),Category::getType,type));
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(categoryList)){
+            for (Category category:categoryList) {
+                if(StringUtils.isNotBlank(category.getDetail())){
+                    category.setDetailList(JSONArray.parseArray(category.getDetail()));
+                }
+            }
+        }
+        return categoryList;
+    }
+
+
 }
diff --git a/server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
index 1dd509d..8e21399 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/MemberServiceImpl.java
@@ -392,15 +392,15 @@
         List<Orders> releaseOrders = ordersMapper.selectList(new QueryWrapper<Orders>().lambda().eq(Orders::getDeleted,Constants.ZERO).eq(Orders::getReleaseMemberId,member));
         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(releaseOrders)){
             userCenterVO.setReleaseTaskTotal(releaseOrders.size());
-            userCenterVO.setWaitCommentTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ZERO)).collect(Collectors.toList()).size());
-            userCenterVO.setDoingTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.TWO)).collect(Collectors.toList()).size());
-            userCenterVO.setWaitCommentTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.THREE)&&Constants.equalsInteger(i.getCommentStatus(),Constants.ZERO)).collect(Collectors.toList()).size());
+            userCenterVO.setWaitCommentTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ordersStatus.waitPay.getKey())).collect(Collectors.toList()).size());
+            userCenterVO.setDoingTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ordersStatus.accept.getKey())).collect(Collectors.toList()).size());
+            userCenterVO.setWaitCommentTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ordersStatus.doing.getKey())&&Constants.equalsInteger(i.getCommentStatus(),Constants.ZERO)).collect(Collectors.toList()).size());
         }
         List<Orders> acceptOrders = ordersMapper.selectList(new QueryWrapper<Orders>().lambda().eq(Orders::getDeleted,Constants.ZERO).eq(Orders::getAcceptMemberId,member));
         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(acceptOrders)){
             userCenterVO.setReceiveTotal(acceptOrders.size());
-            userCenterVO.setTaskingTotal(acceptOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.TWO)).collect(Collectors.toList()).size());
-            userCenterVO.setDoneTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.THREE)).collect(Collectors.toList()).size());
+            userCenterVO.setTaskingTotal(acceptOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ordersStatus.accept.getKey())).collect(Collectors.toList()).size());
+            userCenterVO.setDoneTotal(releaseOrders.stream().filter(i->Constants.equalsInteger(i.getStatus(),Constants.ordersStatus.doing.getKey())).collect(Collectors.toList()).size());
         }
 
         userCenterVO.setAboutUs(StringUtils.trimToNull(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.ABOUT_US).getCode()));
diff --git a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
index 8a3f607..6ad3885 100644
--- a/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
+++ b/server/services/src/main/java/com/doumee/service/business/impl/OrdersServiceImpl.java
@@ -27,7 +27,9 @@
 import com.wechat.pay.java.service.partnerpayments.jsapi.model.Payer;
 import com.wechat.pay.java.service.partnerpayments.jsapi.model.PrepayRequest;
 import com.wechat.pay.java.service.partnerpayments.jsapi.model.PrepayWithRequestPaymentResponse;
+import com.wechat.pay.java.service.refund.model.RefundNotification;
 import jodd.util.StringUtil;
+import lombok.With;
 import nonapi.io.github.classgraph.json.Id;
 import org.apache.poi.sl.image.ImageHeaderEMF;
 import org.checkerframework.checker.units.qual.A;
@@ -38,11 +40,13 @@
 import org.springframework.util.CollectionUtils;
 import org.springframework.util.StringUtils;
 
+import javax.annotation.Resource;
 import java.math.BigDecimal;
 import java.util.Date;
 import java.util.List;
 import java.util.Objects;
 import java.util.UUID;
+import java.util.concurrent.TimeUnit;
 
 /**
  * 璁㈠崟淇℃伅璁板綍Service瀹炵幇
@@ -77,7 +81,13 @@
     private IdentityInfoMapper identityInfoMapper;
 
     @Autowired
+    private WithdrawalOrdersMapper withdrawalOrdersMapper;
+
+    @Autowired
     private WxMiniUtilService wxMiniUtilService;
+
+    @Resource
+    private RedisTemplate<String,Object> redisTemplate;
 
     @Override
     @Transactional(rollbackFor = {Exception.class,BusinessException.class})
@@ -98,11 +108,11 @@
         }
         //鐢ㄩ璁㈠崟
         if(Constants.equalsInteger(orders.getType(),Constants.TWO)){
-            orders.setStatus(Constants.ZERO);
+            orders.setStatus(Constants.ordersStatus.waitPay.getKey());
             //鍞よ捣鏀粯涓氬姟
             objects = this.getWxPayResponse(orders,orders.getMember().getOpenid());
         }else{
-            orders.setStatus(Constants.ONE);
+            orders.setStatus(Constants.ordersStatus.wait.getKey());
         }
         ordersMapper.insert(orders);
         if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(orders.getMultifileList())){
@@ -449,11 +459,12 @@
         queryWrapper.eq(Objects.nonNull(model.getType()),Orders::getType, model.getType());
         queryWrapper.eq(Objects.nonNull(model.getStatus()),Orders::getStatus, model.getStatus());
         queryWrapper.eq(Objects.nonNull(model.getAcceptType()),Orders::getAcceptType, model.getAcceptType());
-        queryWrapper.like(org.apache.commons.lang3.StringUtils.isNotBlank(model.getReleaseName()),"m1.name", model.getReleaseName());
-        queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getAcceptName())," i.LINK_NAME like '%"+model.getAcceptName()+"%' or i.company_name like '%"+model.getAcceptName()+"%' ");
+        queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getReleaseName()),"m1.name", model.getReleaseName());
+        queryWrapper.apply(org.apache.commons.lang3.StringUtils.isNotBlank(model.getAcceptName()),"( i.LINK_NAME like '%"+model.getAcceptName()+"%' or i.company_name like '%"+model.getAcceptName()+"%' or i.TELEPHONE like '%"+model.getAcceptName()+"%' ) ");
         IPage<Orders> iPage = ordersMapper.selectJoinPage(page,Orders.class,queryWrapper);
         for (Orders orders:iPage.getRecords()) {
            this.getOrderContent(orders);
+           orders.setStatusName(Constants.ordersStatus.getName(orders.getStatus()));
         }
         return PageData.from(iPage);
     }
@@ -516,7 +527,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.ONE)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.wait.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇ユ搷浣�");
         }
         if(Constants.equalsInteger(orders.getReleaseMemberId(),member.getId())){
@@ -540,7 +551,7 @@
         orders.setAcceptType(Constants.ZERO);
         orders.setAcceptTime(new Date());
         orders.setAcceptMemberId(member.getId());
-        orders.setStatus(Constants.TWO);
+        orders.setStatus(Constants.ordersStatus.accept.getKey());
         ordersMapper.updateById(orders);
         //鏇存柊鎺ュ崟閲�
         memberMapper.update(new UpdateWrapper<Member>().lambda().set(Member::getPublishNum," (publish_num + 1 )").eq(Member::getId,member.getId()));
@@ -569,7 +580,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.TWO)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇ユ搷浣�");
         }
         if(Constants.equalsInteger(orders.getReleaseMemberId(),member.getId())){
@@ -579,7 +590,7 @@
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟淇敼寰呯‘璁わ紝鏃犳硶杩涜璇ユ搷浣�");
         }
         orders.setUpdateTime(new Date());
-        orders.setStatus(Constants.THREE);
+        orders.setStatus(Constants.ordersStatus.doing.getKey());
         orders.setWorkStartTime(new Date());
         ordersMapper.updateById(orders);
 
@@ -608,7 +619,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.TWO)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇ユ搷浣�");
         }
         if(Constants.equalsInteger(orders.getReleaseMemberId(),updOrderDataDTO.getMember().getId())){
@@ -638,6 +649,7 @@
                 .set(Orders::getEndDate,updOrderDataDTO.getEndDate())
                 .set(Orders::getTotalDays,updOrderDataDTO.getTotalDays())
                 .set(Orders::getIsUpdate,Constants.ONE)
+                .set(Orders::getIsUpdateTime,"now()")
                 .set(Orders::getUpdateTime,"now()")
                 .set(Orders::getEstimatedAccount,total)
                 .eq(Orders::getId,orders.getId())
@@ -683,7 +695,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.TWO)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇ユ搷浣�");
         }
         if(!Constants.equalsInteger(orders.getIsUpdate(),Constants.ONE)){
@@ -706,7 +718,7 @@
             ordersMapper.update(new UpdateWrapper<Orders>().lambda()
                     .set(Orders::getIsUpdate,Constants.TWO)
                     .set(Orders::getUpdateTime,"now()")
-                    .set(Orders::getStatus,Constants.ONE)
+                    .set(Orders::getStatus,Constants.ordersStatus.wait.getKey())
                     .set(Orders::getAcceptMemberId,null)
                     .set(Orders::getAcceptType,null)
                     .eq(Orders::getId,orders.getId())
@@ -737,9 +749,9 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!(Constants.equalsInteger(orders.getStatus(),Constants.ONE)
-                ||Constants.equalsInteger(orders.getStatus(),Constants.ZERO)
-        || Constants.equalsInteger(orders.getStatus(),Constants.TWO))){
+        if(!(Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.wait.getKey())
+                ||Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.waitPay.getKey())
+        || Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜鍙栨秷");
         }
         if(Constants.equalsInteger(orders.getReleaseMemberId(),member.getId())){
@@ -754,15 +766,14 @@
                 withdrawalOrders.setCreateTime(new Date());
                 withdrawalOrders.setMemberId(orders.getReleaseMemberId());
                 withdrawalOrders.setAmount(orders.getPayAccount());
-                withdrawalOrders.setWxExternalNo("refund_"+orders.getCode());
-                withdrawalOrders.setStatus(Constants.ONE);
+                withdrawalOrders.setStatus(Constants.ZERO);
                 withdrawalOrders.setDoneTime(new Date());
                 withdrawalOrders.setType(Constants.ONE);
                 withdrawalOrders.setObjId(orders.getId());
                 wxMiniUtilService.wxRefund(withdrawalOrders,orders);
             }
             ordersMapper.update(new UpdateWrapper<Orders>().lambda()
-                    .set(Orders::getStatus,99)
+                    .set(Orders::getStatus,Constants.ordersStatus.cancel.getKey())
                     .set(Orders::getUpdateTime,"now()")
                     .set(Orders::getCancelTime,"now()")
                     .set(Orders::getCancelType,Constants.ZERO)
@@ -773,7 +784,7 @@
             Integer totalCancelTimes = Integer.valueOf(systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.RELEASE_CANCEL_TIMES).getCode());
             Long cancelTimes = ordersMapper.selectCount(new QueryWrapper<Orders>().lambda()
                     .apply(" DATE(cancel_time) = DATE(NOW()) ")
-                    .eq(Orders::getStatus,99)
+                    .eq(Orders::getStatus,Constants.ordersStatus.cancel.getKey())
                     .eq(Orders::getReleaseMemberId,orders.getReleaseMemberId()));
             //鏌ヨ鍙栨秷娆℃暟
             if(totalCancelTimes<=cancelTimes){
@@ -800,7 +811,7 @@
                 wxMiniUtilService.wxRefund(withdrawalOrders,orders);
             }
             ordersMapper.update(new UpdateWrapper<Orders>().lambda()
-                    .set(Orders::getStatus,99)
+                    .set(Orders::getStatus,Constants.ordersStatus.cancel.getKey())
                     .set(Orders::getUpdateTime,"now()")
                     .set(Orders::getCancelTime,"now()")
                     .set(Orders::getCancelType,Constants.ONE)
@@ -833,7 +844,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.TWO)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜鍙栨秷");
         }
         if(Constants.equalsInteger(orders.getAcceptMemberId(),member.getId())){
@@ -857,7 +868,7 @@
         }
         ordersMapper.update(new UpdateWrapper<Orders>().lambda()
                 .set(Orders::getUpdateTime,"now()")
-                .set(Orders::getStatus,Constants.ONE)
+                .set(Orders::getStatus,Constants.ordersStatus.wait.getKey())
                 .set(Orders::getAcceptMemberId,null)
                 .set(Orders::getAcceptType,null)
                 .eq(Orders::getId,orders.getId())
@@ -892,7 +903,7 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.THREE)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.doing.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜鍙栨秷");
         }
         if(Constants.equalsInteger(orders.getReleaseMemberId(),doneOrderDTO.getMember().getId())){
@@ -909,7 +920,7 @@
             //鍞よ捣鏀粯涓氬姟
             object = this.getWxPayResponse(orders,orders.getMember().getOpenid());
         }else{
-            orders.setStatus(Constants.FOUR);
+            orders.setStatus(Constants.ordersStatus.done.getKey());
             //鏃ュ織瀛樺偍
             Constants.OrdersLog ordersLog = Constants.OrdersLog.DONE;
             this.saveOrderLog(orders,ordersLog,
@@ -928,8 +939,8 @@
         if(Objects.isNull(orders)||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!(Constants.equalsInteger(orders.getStatus(),Constants.ONE)||Constants.equalsInteger(orders.getStatus(),Constants.TWO)
-            ||Constants.equalsInteger(orders.getStatus(),Constants.THREE))){
+        if(!(Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.wait.getKey())||Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.accept.getKey())
+                ||Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.doing.getKey())||Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.waitPay.getKey()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜鍙栨秷");
         }
         //濡傛灉宸叉敮浠� 鍒欓渶瑕佽繘琛岄��娆�
@@ -955,7 +966,7 @@
         }
 
         ordersMapper.update(new UpdateWrapper<Orders>().lambda()
-                .set(Orders::getStatus,99)
+                .set(Orders::getStatus,Constants.ordersStatus.cancel.getKey())
                 .set(Orders::getUpdateTime,"now()")
                 .set(Orders::getCancelTime,"now()")
                 .set(Orders::getCancelType,Constants.TWO)
@@ -984,7 +995,7 @@
                 ||Constants.equalsInteger(orders.getDeleted(),Constants.ONE)){
             throw new BusinessException(ResponseStatus.DATA_EMPTY);
         }
-        if(!Constants.equalsInteger(orders.getStatus(),Constants.FOUR)){
+        if(!Constants.equalsInteger(orders.getStatus(),Constants.ordersStatus.done.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"璁㈠崟鐘舵�佸凡娴佽浆,鏃犳硶杩涜璇勪环");
         }
         if(Constants.equalsInteger(orders.getCommentStatus(),Constants.ONE)){
@@ -1033,7 +1044,7 @@
                 //澶勭悊鏀粯瀹屾垚閫昏緫
                 ordersMapper.update(new UpdateWrapper<Orders>().lambda()
                         .set(Orders::getUpdateTime,"now()")
-                        .set(Orders::getStatus,Constants.ONE)
+                        .set(Orders::getStatus,Constants.ordersStatus.wait)
                         .set(Orders::getPayStatus,Constants.ONE)
                         .set(Orders::getWxExternalNo,paymentNo)
                         .eq(Orders::getId,orders.getId())
@@ -1253,22 +1264,111 @@
     }
 
 
-
-
     public synchronized String  getNextCode(Integer type){
-//        String prefix = "YG";
-//        if(!Constants.equalsInteger(type,Constants.ZERO)){
-//            prefix = (Constants.equalsInteger(type,Constants.ONE)?"YC-":"SC-");
-//        }
-//        prefix =  DateUtil.getDate(new Date(),"yyyyMMdd") +"-";
-//        Integer countNum  = RedisUtil.getObject(redisTemplate, Constants.RedisKeys.ORDER_CODE, Integer.class);
-//        countNum = Constants.formatIntegerNum(countNum)+1;
-//        //鏇存柊缂撳瓨
-//        RedisUtil.addObject(redisTemplate,Constants.RedisKeys.ORDER_CODE,countNum);
-//        String nextIndex =Integer.toString( countNum );
-//        return prefix + org.apache.commons.lang3.StringUtils.leftPad(nextIndex,3,"0");
-        return null;
+        String prefix = "YG";
+        if(!Constants.equalsInteger(type,Constants.ZERO)){
+            prefix = (Constants.equalsInteger(type,Constants.ONE)?"YH-":"DC-");
+        }
+        prefix =  DateUtil.getDate(new Date(),"yyyyMMddHHmmss") +"-";
+
+        Integer countNum  = (Integer) redisTemplate.opsForValue().get(Constants.RedisKeys.ORDER_CODE);//RedisUtil.getObject(redisTemplate, Constants.RedisKeys.ORDER_CODE, Integer.class);
+        countNum = Constants.formatIntegerNum(countNum)+1;
+        //鏇存柊缂撳瓨
+        redisTemplate.opsForValue().set(Constants.RedisKeys.ORDER_CODE,countNum);
+        String nextIndex =Integer.toString( countNum );
+        return prefix + org.apache.commons.lang3.StringUtils.leftPad(nextIndex,3,"0");
     }
 
 
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void refundCallback(RefundNotification refundNotification){
+        WithdrawalOrders withdrawalOrders = withdrawalOrdersMapper.selectById(refundNotification.getOutRefundNo());
+        if(Objects.isNull(withdrawalOrders)||!Constants.equalsInteger(withdrawalOrders.getStatus(),Constants.ZERO)){
+            return;
+        }
+        withdrawalOrders.setWxExternalNo(refundNotification.getTransactionId());
+        withdrawalOrders.setUpdateTime(new Date());
+        withdrawalOrders.setDoneTime(withdrawalOrders.getUpdateTime());
+        if (!"SUCCESS".equals(refundNotification.getRefundStatus().name())) {
+            // 濡傛灉閫�娆剧姸鎬佷笉姝g‘锛屼慨鏀归��娆惧崟鐘舵��
+            withdrawalOrders.setStatus(Constants.TWO);
+        }else{
+            withdrawalOrders.setStatus(Constants.ONE);
+        }
+        //鏇存柊閫�娆惧崟鐘舵��
+        withdrawalOrdersMapper.updateById(withdrawalOrders);
+    }
+
+
+
+    //todo 鑷姩娲惧崟
+    public void autoGrabOrders(){
+
+
+    }
+
+    //鑷姩璇勪环 璁㈠崟瀹屾垚7澶╁悗鑷姩璇勪环4鏄�
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void autoComment(){
+        List<Orders> ordersList = ordersMapper.selectList(new QueryWrapper<Orders>().lambda()
+                .eq(Orders::getStatus,Constants.FOUR).eq(Orders::getCommentStatus,Constants.ZERO)
+                .apply(" DATE_ADD(finish_time, INTERVAL 7 DAY) < now() ")
+                .last("limit 100")
+        );
+
+        for (Orders orders:ordersList) {
+            ordersMapper.update(new UpdateWrapper<Orders>().lambda()
+                    .set(Orders::getCommentStatus,Constants.ONE)
+                    .set(Orders::getUpdateTime,"now()")
+                    .set(Orders::getCommentTime,"now()")
+                    .set(Orders::getCommentLevel,Constants.FOUR)
+                    .set(Orders::getCommentType,Constants.ZERO)
+                    .eq(Orders::getId,orders.getId())
+            );
+
+            memberMapper.update(new UpdateWrapper<Member>().lambda()
+                    .set(Member::getScore," ( total_score +" + Constants.FOUR + " ) / (score_order_num + 1 )")
+                    .set(Member::getTotalScore," total_score +" + Constants.FOUR)
+                    .set(Member::getScoreOrderNum," score_order_num + 1 " ).eq(Member::getId,orders.getAcceptMemberId())
+            );
+
+            //鏃ュ織瀛樺偍
+            Constants.OrdersLog ordersLog = Constants.OrdersLog.AUTO_COMMENT;
+            this.saveOrderLog(orders,ordersLog,
+                    ordersLog.getInfo(),orders.getAcceptMemberId(),null);
+        }
+    }
+
+
+    //鑷姩纭 璁㈠崟淇敼鍚庤嫢鏈鐞� 鏍规嵁閰嶇疆鑷姩澶勭悊
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void autoConfirm(){
+        String autoConfirmTime = systemDictDataBiz.queryByCode(Constants.SYSTEM,Constants.AUTO_CONFIRM).getCode();
+        List<Orders> ordersList = ordersMapper.selectList(new QueryWrapper<Orders>().lambda()
+                .eq(Orders::getStatus,Constants.ordersStatus.accept).eq(Orders::getIsUpdate,Constants.ONE)
+                .apply(" DATE_ADD(IS_UPDATE_TIME, INTERVAL "+autoConfirmTime+" MINUTE) < now() ")
+                .last("limit 100")
+        );
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(ordersList)){
+            for (Orders orders:ordersList) {
+                ordersMapper.update(new UpdateWrapper<Orders>().lambda()
+                        .set(Orders::getIsUpdate,Constants.TWO)
+                        .set(Orders::getUpdateTime,"now()")
+                        .eq(Orders::getId,orders.getId())
+                );
+                //璁板綍鍚屾剰淇敼鐨勬棩蹇�
+                Constants.OrdersLog ordersLog = Constants.OrdersLog.AUTO_AGREE;
+                this.saveOrderLog(orders,ordersLog,
+                        ordersLog.getInfo(),orders.getAcceptMemberId(),null);
+            }
+        }
+    }
+
+
+
+
+
 }
diff --git a/server/web/src/main/java/com/doumee/api/web/ConfigApi.java b/server/web/src/main/java/com/doumee/api/web/ConfigApi.java
new file mode 100644
index 0000000..187160a
--- /dev/null
+++ b/server/web/src/main/java/com/doumee/api/web/ConfigApi.java
@@ -0,0 +1,47 @@
+package com.doumee.api.web;
+
+import com.doumee.core.annotation.trace.Trace;
+import com.doumee.core.model.ApiResponse;
+import com.doumee.dao.business.model.Category;
+import com.doumee.dao.vo.AccountResponse;
+import com.doumee.service.business.CategoryService;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiImplicitParam;
+import io.swagger.annotations.ApiImplicitParams;
+import io.swagger.annotations.ApiOperation;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.GetMapping;
+import org.springframework.web.bind.annotation.RequestMapping;
+import org.springframework.web.bind.annotation.RequestParam;
+import org.springframework.web.bind.annotation.RestController;
+
+import java.util.List;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2025/7/15 15:49
+ */
+@Api(tags = "閰嶇疆绫绘帴鍙�")
+@Trace(exclude = true)
+@RestController
+@RequestMapping("/web/orders")
+@Slf4j
+public class ConfigApi extends ApiController{
+
+    @Autowired
+    private CategoryService categoryService;
+
+    @ApiOperation(value = "鑾峰彇鍒嗙被鍒楄〃", notes = "灏忕▼搴忕")
+    @GetMapping("/getCategoryList")
+    @ApiImplicitParams({
+            @ApiImplicitParam(paramType = "query", dataType = "Integer", name = "type", value = "绫诲瀷:0=鍝佺閰嶇疆;1=杞﹁締绫诲瀷閰嶇疆;2=椁愭爣閰嶇疆;3=鎵嬬画璐归厤缃�;", required = true)
+    })
+    public ApiResponse<List<Category>> getCategoryList(@RequestParam Integer type) {
+        return  ApiResponse.success("鎿嶄綔鎴愬姛",categoryService.getCategoryList(type));
+    }
+
+
+}
diff --git a/server/web/src/main/java/com/doumee/api/web/OrdersApi.java b/server/web/src/main/java/com/doumee/api/web/OrdersApi.java
index 21be535..d874b2a 100644
--- a/server/web/src/main/java/com/doumee/api/web/OrdersApi.java
+++ b/server/web/src/main/java/com/doumee/api/web/OrdersApi.java
@@ -31,7 +31,7 @@
  * @Author : Rk
  * @create 2025/7/10 9:29
  */
-@Api(tags = "1銆佽鍗曚笟鍔�")
+@Api(tags = "璁㈠崟涓氬姟")
 @Trace(exclude = true)
 @RestController
 @RequestMapping("/web/orders")
diff --git a/server/web/src/main/java/com/doumee/api/web/PaymentCallback.java b/server/web/src/main/java/com/doumee/api/web/PaymentCallback.java
index c6b0c4e..764db1f 100644
--- a/server/web/src/main/java/com/doumee/api/web/PaymentCallback.java
+++ b/server/web/src/main/java/com/doumee/api/web/PaymentCallback.java
@@ -146,7 +146,7 @@
             RefundNotification result = parser.parse(requestParam, RefundNotification.class);
 //            if ("SUCCESS".equals(result.getRefundStatus().name())) {
                 // 鏀粯鎴愬姛ge
-//                     goodsorderService.closeGoodsorderDone(result);
+                     ordersService.refundCallback(result);
 //            }
             return ApiResponse.success("澶勭悊鎴愬姛");
         } catch (Exception e) {

--
Gitblit v1.9.3