From 603fbdb1bd13acf72fc94b95d96d32403c0889c2 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期三, 06 三月 2024 18:15:16 +0800 Subject: [PATCH] 添加方法 --- cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupCompetitorServiceImpl.java | 103 ++++++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 100 insertions(+), 3 deletions(-) diff --git a/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupCompetitorServiceImpl.java b/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupCompetitorServiceImpl.java index bf244d5..11c1a73 100644 --- a/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupCompetitorServiceImpl.java +++ b/cloud-server-communityWorldCup/src/main/java/com/dsh/communityWorldCup/service/impl/WorldCupCompetitorServiceImpl.java @@ -1,11 +1,14 @@ package com.dsh.communityWorldCup.service.impl; +import com.alibaba.fastjson.JSON; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dsh.communityWorldCup.entity.WorldCup; import com.dsh.communityWorldCup.entity.WorldCupCompetitor; import com.dsh.communityWorldCup.feignclient.account.AppUserClient; import com.dsh.communityWorldCup.feignclient.account.StudentClient; import com.dsh.communityWorldCup.feignclient.account.model.AppUser; +import com.dsh.communityWorldCup.feignclient.account.model.AppUserIdsByCityName; import com.dsh.communityWorldCup.feignclient.account.model.TStudent; import com.dsh.communityWorldCup.feignclient.competition.ParticipantClient; import com.dsh.communityWorldCup.feignclient.competition.model.Participant; @@ -13,15 +16,15 @@ import com.dsh.communityWorldCup.mapper.WorldCupCompetitorMapper; import com.dsh.communityWorldCup.model.*; import com.dsh.communityWorldCup.service.IWorldCupCompetitorService; +import com.dsh.communityWorldCup.service.IWorldCupService; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import javax.annotation.Resource; import java.math.BigDecimal; import java.math.MathContext; import java.math.RoundingMode; -import java.util.ArrayList; -import java.util.List; -import java.util.Map; +import java.util.*; /** * @author zhibing.pu @@ -38,6 +41,9 @@ @Resource private AppUserClient appUserClient; + + @Autowired + private IWorldCupService worldCupService; @@ -245,4 +251,95 @@ } return list; } + + + /** + * 比赛结束后通知处理逻辑 + * @param custom 开始比赛接口上传的自定义参数 + * @param red_score 红方分数 + * @param blue 蓝方分数 + */ + @Override + public void endWorldCupCallback(String custom, Integer red_score, Integer blue) { + List<Long> ids = JSON.parseArray(custom, Long.class); + List<WorldCupCompetitor> worldCupCompetitors = this.listByIds(ids); + WorldCupCompetitor worldCupCompetitor1 = worldCupCompetitors.get(0); + WorldCup worldCup = worldCupService.getById(worldCupCompetitor1.getWorldCupId()); + for (WorldCupCompetitor worldCupCompetitor : worldCupCompetitors) { + //蓝方 + if(worldCupCompetitor.getParticipant() == 1){ + worldCupCompetitor.setMatchResult(blue.compareTo(red_score)); + worldCupCompetitor.setOurScore(blue); + worldCupCompetitor.setOpponentScore(red_score); + worldCupCompetitor.setEndTime(new Date()); + worldCupCompetitor.setWinIntegral(0); + if(null != worldCup.getWinIntegral() && 0 < worldCup.getWinIntegral() && blue.compareTo(red_score) >= 0){ + worldCupCompetitor.setWinIntegral(worldCup.getWinIntegral()); + AppUser appUser = appUserClient.getAppUser(worldCupCompetitor.getAppUserId()); + appUser.setIntegral(appUser.getIntegral() + worldCup.getWinIntegral()); + appUserClient.updateAppUser(appUser); + } + } + //红方 + if(worldCupCompetitor.getParticipant() == 2){ + worldCupCompetitor.setMatchResult(red_score.compareTo(blue)); + worldCupCompetitor.setOurScore(red_score); + worldCupCompetitor.setOpponentScore(blue); + worldCupCompetitor.setEndTime(new Date()); + worldCupCompetitor.setWinIntegral(0); + if(null != worldCup.getWinIntegral() && 0 < worldCup.getWinIntegral() && red_score.compareTo(blue) >= 0){ + worldCupCompetitor.setWinIntegral(worldCup.getWinIntegral()); + AppUser appUser = appUserClient.getAppUser(worldCupCompetitor.getAppUserId()); + appUser.setIntegral(appUser.getIntegral() + worldCup.getWinIntegral()); + appUserClient.updateAppUser(appUser); + } + } + } + + this.updateBatchById(worldCupCompetitors); + } + + + /** + * 获取比赛排行榜列表数据 + * @param worldCupRecords + * @return + */ + @Override + public Map<String, Object> worldCupRecordsList(WorldCupRecords worldCupRecords) { + Map<String, Object> map1 = new HashMap<>(); + AppUserIdsByCityName appUserIdsByCityName = new AppUserIdsByCityName(); + appUserIdsByCityName.setProvince(worldCupRecords.getProvince()); + appUserIdsByCityName.setCity(worldCupRecords.getCity()); + List<Integer> appUserIds = appUserClient.getAppUserIdsByCityName(appUserIdsByCityName); + List<Map<String, Object>> mapList = this.baseMapper.worldCupRecordsList(worldCupRecords, appUserIds); + for (int i = 0; i < mapList.size(); i++) { + Map<String, Object> map = mapList.get(i); + Integer participantType = Integer.valueOf(map.get("participantType").toString()); + Integer participantId = Integer.valueOf(map.get("participantId").toString()); + Integer appUserId = Integer.valueOf(map.get("appUserId").toString()); + Integer totalSession = Integer.valueOf(map.get("totalSession").toString()); + Integer win = Integer.valueOf(map.get("win").toString()); + Integer lose = totalSession - win; + map.put("lose", lose); + AppUser appUser = appUserClient.getAppUser(appUserId); + map.put("province", appUser.getProvince() + appUser.getCity()); + if(1 == participantType){ + TStudent tStudent = studentClient.queryById(participantId); + map.put("name", tStudent.getName()); + map.put("phone", tStudent.getPhone()); + }else{ + Participant participant = participantClient.getParticipant(participantId); + map.put("name", participant.getName()); + map.put("phone", participant.getPhone()); + } + } + Integer offset = worldCupRecords.getOffset(); + Integer limit = worldCupRecords.getLimit(); + limit += offset; + map1.put("rows", mapList.subList(offset, mapList.size() >= limit ? limit : mapList.size())); + int count = this.baseMapper.worldCupRecordsListCount(appUserIds); + map1.put("total", count); + return map1; + } } -- Gitblit v1.7.1