feat: 添加根据状态查询所有链接任务的接口

This commit is contained in:
zyh
2025-08-30 22:58:56 +08:00
parent 6eb0ad5a0a
commit c788a4a70d
4 changed files with 238 additions and 0 deletions

View File

@@ -0,0 +1,122 @@
package com.gameplatform.server.service.admin;
import com.gameplatform.server.mapper.agent.LinkTaskMapper;
import com.gameplatform.server.model.entity.admin.Announcement;
import com.gameplatform.server.model.entity.agent.LinkTask;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class AnnouncementByCodeService {
private static final Logger logger = LoggerFactory.getLogger(AnnouncementByCodeService.class);
@Autowired
private LinkTaskMapper linkTaskMapper;
@Autowired
private AnnouncementService announcementService;
/**
* 根据codeNo获取对应代理商设置的公告
*
* @param codeNo 链接编号
* @return 代理商设置的启用公告列表
* @throws IllegalArgumentException 当codeNo为空或对应的链接任务不存在时
*/
public List<Announcement> getAnnouncementsByCodeNo(String codeNo) {
logger.info("开始根据codeNo查询代理商公告: {}", codeNo);
if (codeNo == null || codeNo.trim().isEmpty()) {
logger.warn("codeNo为空或空字符串: {}", codeNo);
throw new IllegalArgumentException("codeNo不能为空");
}
logger.debug("步骤1: 根据codeNo查询link_task表: {}", codeNo);
LinkTask linkTask = linkTaskMapper.findByCodeNo(codeNo);
if (linkTask == null) {
logger.warn("未找到对应的链接任务, codeNo: {}", codeNo);
throw new IllegalArgumentException("找不到对应的链接任务: " + codeNo);
}
logger.debug("查询到链接任务: id={}, agentId={}, status={}",
linkTask.getId(), linkTask.getAgentId(), linkTask.getStatus());
Long agentId = linkTask.getAgentId();
if (agentId == null) {
logger.warn("链接任务的代理商ID为空, codeNo: {}, taskId: {}", codeNo, linkTask.getId());
throw new IllegalArgumentException("链接任务的代理商ID为空: " + codeNo);
}
logger.debug("步骤2: 根据agentId查询announcement表: agentId={}", agentId);
List<Announcement> announcements = announcementService.getEnabledAnnouncementsByBelongId(agentId.intValue());
logger.info("查询完成, codeNo: {}, agentId: {}, 找到公告数量: {}",
codeNo, agentId, announcements.size());
if (logger.isDebugEnabled()) {
announcements.forEach(announcement ->
logger.debug("公告详情: id={}, title={}, belongId={}",
announcement.getId(), announcement.getTitle(), announcement.getBelongId()));
}
return announcements;
}
/**
* 检查codeNo是否有效链接任务存在
*
* @param codeNo 链接编号
* @return true 如果codeNo对应的链接任务存在否则false
*/
public boolean isCodeNoValid(String codeNo) {
logger.debug("检查codeNo是否有效: {}", codeNo);
if (codeNo == null || codeNo.trim().isEmpty()) {
logger.debug("codeNo为空返回false: {}", codeNo);
return false;
}
LinkTask linkTask = linkTaskMapper.findByCodeNo(codeNo);
boolean isValid = linkTask != null && linkTask.getAgentId() != null;
logger.debug("codeNo有效性检查结果: {}, 有效: {}", codeNo, isValid);
if (linkTask != null) {
logger.debug("链接任务存在: id={}, agentId={}", linkTask.getId(), linkTask.getAgentId());
}
return isValid;
}
/**
* 根据codeNo获取对应的代理商ID
*
* @param codeNo 链接编号
* @return 代理商ID如果codeNo无效返回null
*/
public Long getAgentIdByCodeNo(String codeNo) {
logger.debug("根据codeNo获取代理商ID: {}", codeNo);
if (codeNo == null || codeNo.trim().isEmpty()) {
logger.debug("codeNo为空返回null: {}", codeNo);
return null;
}
LinkTask linkTask = linkTaskMapper.findByCodeNo(codeNo);
Long agentId = linkTask != null ? linkTask.getAgentId() : null;
logger.debug("codeNo: {}, 对应的agentId: {}", codeNo, agentId);
if (linkTask != null) {
logger.debug("链接任务详情: id={}, status={}, agentId={}",
linkTask.getId(), linkTask.getStatus(), linkTask.getAgentId());
} else {
logger.debug("未找到对应的链接任务: {}", codeNo);
}
return agentId;
}
}