From 413a57e2524cb0b839d5d83d961de3b59814eb6e Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 24 Oct 2025 16:53:11 +0800
Subject: [PATCH] feat(ai): 实现产品依赖解锁功能 - 在AiMemberAnswerServiceImpl中注入AiProductDependencyService和AiMemberProductUnlockService - 修改insure方法,根据答题分数解锁符合条件的产品 - 新增selectListByProductIds和insertList方法到AiMemberProductUnlockService - 实现产品依赖关系查询方法selectListByProductId到AiProductDependencyService- 在AiProductServiceImpl中增加产品状态判断逻辑,支持锁定和解锁状态显示 - 添加memberId字段到ApiProductPageDto用于查询用户已解锁产品 - 在ApiProductVo中新增state字段表示产品锁定/解锁状态

---
 src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java |   40 +++++++++++++++++++++++++++++++++++++++-
 1 files changed, 39 insertions(+), 1 deletions(-)

diff --git a/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java b/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
index 8c587d6..10dffe2 100644
--- a/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
+++ b/src/main/java/cc/mrbird/febs/mall/quartz/WxxcxJob.java
@@ -4,13 +4,19 @@
 import cc.mrbird.febs.common.utils.HttpCurlUtil;
 import cc.mrbird.febs.common.utils.RedisUtils;
 import cc.mrbird.febs.common.utils.SpringContextHolder;
+import cc.mrbird.febs.mall.entity.MallMemberCoupon;
+import cc.mrbird.febs.mall.mapper.MallMemberCouponMapper;
+import cc.mrbird.febs.mall.service.MallInvoiceService;
 import cc.mrbird.febs.pay.util.WechatConfigure;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.date.DateUtil;
 import cn.hutool.core.util.StrUtil;
 import com.alibaba.fastjson.JSON;
 import com.alibaba.fastjson.JSONObject;
 import com.baomidou.mybatisplus.extension.exceptions.ApiException;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
 import org.springframework.scheduling.annotation.Scheduled;
 import org.springframework.stereotype.Component;
 import org.springframework.web.client.RestTemplate;
@@ -18,24 +24,33 @@
 import javax.annotation.Resource;
 import java.io.IOException;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 
 @Slf4j
 @Component
+@ConditionalOnProperty(prefix = "system", name = "job", havingValue = "false")
 public class WxxcxJob {
 
     private final XcxProperties xcxProperties = SpringContextHolder.getBean(XcxProperties.class);
 
     @Autowired
     private RedisUtils redisUtils;
+    @Autowired
+    private MallMemberCouponMapper mallMemberCouponMapper;
+    @Autowired
+    private MallInvoiceService mallInvoiceService;
     @Resource
     RestTemplate restTemplate;
+//    @Autowired
+//    private SpringContextHolder springContextHolder;
     /**
      * 获取access_token
      * 有效期两小时
      */
-    @Scheduled(cron = "0 0/5 * * * ? ")
+    @Scheduled(cron = "0 0 0/1 * * ? ")
     public void getAccessToken() throws IOException {
+        log.info("执行access_token刷新");
         String appId = xcxProperties.getXcxAppid();
         String appSecret = xcxProperties.getXcxSecret();
         String url = "https://api.weixin.qq.com/cgi-bin/token?grant_type=client_credential&appid=" + appId + "&secret=" + appSecret;
@@ -62,4 +77,27 @@
 
     }
 
+    @Scheduled(cron = "0 0 0/1 * * ? ")
+    public void expireCoupon() {
+        List<MallMemberCoupon> mallMemberCoupons = mallMemberCouponMapper.selectListByExpireTime(DateUtil.date());
+        if(CollUtil.isEmpty(mallMemberCoupons)){
+            return;
+        }
+        for(MallMemberCoupon mallMemberCoupon : mallMemberCoupons){
+            mallMemberCoupon.setState(3);
+            mallMemberCouponMapper.updateById(mallMemberCoupon);
+        }
+
+    }
+
+    /**
+     * 更新发票记录表数据
+     * 定时,每天凌晨一点
+     * 已完成的订单,更新到发票记录中
+     */
+    @Scheduled(cron = "0 0 1 * * ?")
+    public void mallInvoiceJob() {
+        mallInvoiceService.mallInvoiceJob();
+    }
+
 }

--
Gitblit v1.9.1