From 70225b084dc19db41a9f210bb3e64c27ed25d25c Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期一, 29 九月 2025 17:09:08 +0800
Subject: [PATCH] app任务

---
 ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java |   86 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 86 insertions(+), 0 deletions(-)

diff --git a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
index 3af9f45..b4a0014 100644
--- a/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
+++ b/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/TMissionServiceImpl.java
@@ -1,10 +1,27 @@
 package com.ruoyi.system.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.basic.PageInfo;
+import com.ruoyi.common.core.domain.BaseModel;
+import com.ruoyi.common.core.domain.BasePage;
+import com.ruoyi.common.core.redis.RedisCache;
 import com.ruoyi.system.mapper.TMissionMapper;
+import com.ruoyi.system.mapper.TMissionUserMapper;
 import com.ruoyi.system.model.TMission;
+import com.ruoyi.system.model.TMissionUser;
+import com.ruoyi.system.query.TMissionQuery;
 import com.ruoyi.system.service.TMissionService;
+import com.ruoyi.system.vo.MissionTotalVo;
+import com.ruoyi.system.vo.TMissionVO;
 import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.math.BigDecimal;
+import java.math.RoundingMode;
+import java.util.List;
+import java.util.UUID;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -17,4 +34,73 @@
 @Service
 public class TMissionServiceImpl extends ServiceImpl<TMissionMapper, TMission> implements TMissionService {
 
+    @Resource
+    private TMissionUserMapper missionUserMapper;
+
+    @Resource
+    private RedisCache redisCache;
+
+    @Override
+    public PageInfo<TMissionVO> pageList(TMissionQuery query) {
+        return null;
+    }
+
+    @Override
+    public MissionTotalVo missionTotal(String userId) {
+        MissionTotalVo missionTotalVo = new MissionTotalVo();
+        List<TMissionUser> tMissionUsers = missionUserMapper.selectList(new LambdaQueryWrapper<TMissionUser>().eq(TMissionUser::getAppUserId, userId).eq(TMissionUser::getStatus, 0));
+        if(tMissionUsers.isEmpty()){
+            return missionTotalVo;
+        }
+        List<String> missionIds = tMissionUsers.stream().map(TMissionUser::getMissionId).collect(Collectors.toList());
+        List<TMission> tMissions = this.baseMapper.selectBatchIds(missionIds);
+        long count = tMissions.stream().filter(e -> e.getStatus() == 2).count();
+        missionTotalVo.setNowNum((int) count);
+        missionTotalVo.setWaitNum(tMissions.size()-missionTotalVo.getNowNum());
+
+        List<TMissionUser> collect = tMissionUsers.stream().filter(e -> e.getStatus() == 1).collect(Collectors.toList());
+        missionTotalVo.setRate(new BigDecimal(collect.size()).divide(new BigDecimal(tMissionUsers.size()),2, RoundingMode.HALF_UP));
+
+        return missionTotalVo;
+    }
+
+    @Override
+    public void grabMission(String missionId, String userId) {
+        try {
+            boolean b = redisCache.trylockLoop(missionId, UUID.randomUUID().toString(), 30);
+            if(b){
+                TMissionUser tMissionUser = new TMissionUser();
+                tMissionUser.setAppUserId(userId);
+                tMissionUser.setMissionId(missionId);
+                tMissionUser.setStatus(0);
+                tMissionUser.setUserType(1);
+                missionUserMapper.insert(tMissionUser);
+            }
+        }finally {
+            redisCache.unlock(missionId, UUID.randomUUID().toString());
+        }
+    }
+
+    @Override
+    public PageInfo<TMission> pageNowList(BasePage query,String userId) {
+        PageInfo<TMission> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TMission> list = this.baseMapper.pageNowList(pageInfo,userId);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
+
+    @Override
+    public PageInfo<TMission> pageGrabList(BasePage query) {
+        PageInfo<TMission> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        PageInfo<TMission> tMissionPageInfo = this.baseMapper.selectPage(pageInfo, new LambdaQueryWrapper<TMission>().eq(TMission::getStatus, 1).eq(TMission::getIsMissionPool, 1).orderByDesc(BaseModel::getCreateTime));
+        return tMissionPageInfo;
+    }
+
+    @Override
+    public PageInfo<TMission> pageHistoryList(BasePage query, String userId) {
+        PageInfo<TMission> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize());
+        List<TMission> list = this.baseMapper.pageHistoryList(pageInfo,userId);
+        pageInfo.setRecords(list);
+        return pageInfo;
+    }
 }

--
Gitblit v1.7.1