gongchunyi
4 天以前 d709e8a7117704ac4717db5201e40964b90d4791
src/main/java/com/ruoyi/basic/task/ReturnVisitReminderTask.java
@@ -3,15 +3,12 @@
import com.ruoyi.basic.pojo.CustomerReturnVisit;
import com.ruoyi.basic.service.CustomerReturnVisitService;
import com.ruoyi.framework.redis.RedisCache;
import com.ruoyi.project.system.domain.SysUserClient;
import com.ruoyi.project.system.service.SysUserClientService;
import com.ruoyi.project.system.service.impl.UnipushService;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.scheduling.annotation.Scheduled;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;
import java.util.Set;
/**
@@ -25,21 +22,16 @@
 */
@Slf4j
@Component
@RequiredArgsConstructor
public class ReturnVisitReminderTask {
    private static final String REMINDER_QUEUE_KEY = "return_visit:reminder:queue";
    @Autowired
    private RedisCache redisCache;
    private final RedisCache redisCache;
    @Autowired
    private CustomerReturnVisitService customerReturnVisitService;
    private final CustomerReturnVisitService customerReturnVisitService;
    @Autowired
    private UnipushService unipushService;
    @Autowired
    private SysUserClientService userClientService;
    private final SysUserClientService userClientService;
    @SuppressWarnings("unchecked")
    @Scheduled(fixedDelay = 60000)
@@ -63,30 +55,22 @@
        }
    }
    @SuppressWarnings("unchecked")
    private void processReminder(Long returnVisitId) {
        CustomerReturnVisit returnVisit = customerReturnVisitService.getById(returnVisitId);
        if (returnVisit == null || returnVisit.getIsEnabled() == 0 || returnVisit.getIsCompleted() == 1) {
            return;
        }
        SysUserClient client = userClientService.getById(returnVisit.getRemindUserId());
        if (client == null || client.getCid() == null) {
            log.warn("用户未绑定CID, 无法发送Unipush推送: userId={}", returnVisit.getRemindUserId());
            return;
        }
        try {
            unipushService.sendReturnVisitReminder(returnVisitId, client.getCid(), returnVisit.getContent(), returnVisit.getCustomerId());
            // 标记已处理(推送功能已禁用)
            CustomerReturnVisit updateObj = new CustomerReturnVisit();
            updateObj.setId(returnVisitId);
            updateObj.setIsCompleted(1);
            customerReturnVisitService.updateById(updateObj);
            log.info("回访提醒已通过 Unipush 发送: ID={}", returnVisitId);
            log.info("回访提醒已处理(推送功能已禁用): ID={}", returnVisitId);
        } catch (Exception e) {
            log.error("发送回访提醒失败,重新加入队列: ID={}", returnVisitId, e);
            long retryTime = System.currentTimeMillis() + 60000;
            redisCache.redisTemplate.opsForZSet().add(REMINDER_QUEUE_KEY, returnVisitId, retryTime);
            log.error("处理回访提醒失败: ID={}", returnVisitId, e);
        }
    }
}