From e899587f6d4abdc299b82bed0c043f88276a64c3 Mon Sep 17 00:00:00 2001 From: puzhibing <393733352@qq.com> Date: 星期一, 10 七月 2023 19:08:45 +0800 Subject: [PATCH] 更新赛事模块剩余接口 --- cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java | 207 +++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 207 insertions(+), 0 deletions(-) diff --git a/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java b/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java index ec3eed7..6db453b 100644 --- a/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java +++ b/cloud-server-competition/src/main/java/com/dsh/competition/service/impl/PaymentCompetitionServiceImpl.java @@ -1,10 +1,40 @@ package com.dsh.competition.service.impl; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.dsh.competition.entity.Competition; +import com.dsh.competition.entity.Participant; import com.dsh.competition.entity.PaymentCompetition; +import com.dsh.competition.entity.UserCompetition; +import com.dsh.competition.feignclient.account.AppUserClient; +import com.dsh.competition.feignclient.account.StudentClient; +import com.dsh.competition.feignclient.account.model.AppUser; +import com.dsh.competition.feignclient.account.model.Student; +import com.dsh.competition.feignclient.course.CoursePackagePaymentClient; +import com.dsh.competition.feignclient.course.model.PaymentDeductionClassHour; +import com.dsh.competition.feignclient.other.StoreClient; +import com.dsh.competition.feignclient.other.model.Store; import com.dsh.competition.mapper.PaymentCompetitionMapper; +import com.dsh.competition.model.CompetitionInfo; +import com.dsh.competition.model.CompetitionListVo; +import com.dsh.competition.model.ParticipantVo; +import com.dsh.competition.service.CompetitionService; +import com.dsh.competition.service.IParticipantService; import com.dsh.competition.service.IPaymentCompetitionService; +import com.dsh.competition.service.UserCompetitionService; +import com.dsh.competition.util.*; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; + +import javax.annotation.Resource; +import java.math.BigDecimal; +import java.math.RoundingMode; +import java.text.SimpleDateFormat; +import java.util.ArrayList; +import java.util.Date; +import java.util.List; +import java.util.Map; +import java.util.stream.Collectors; /** * @author zhibing.pu @@ -12,4 +42,181 @@ */ @Service public class PaymentCompetitionServiceImpl extends ServiceImpl<PaymentCompetitionMapper, PaymentCompetition> implements IPaymentCompetitionService { + + @Autowired + private CompetitionService competitionService; + + @Resource + private StoreClient storeClient; + + @Autowired + private UserCompetitionService userCompetitionService; + + @Autowired + private IParticipantService participantService; + + @Autowired + private PayMoneyUtil payMoneyUtil; + + @Resource + private AppUserClient appUserClient; + + @Resource + private CoursePackagePaymentClient coursePackagePaymentClient; + + @Resource + private StudentClient studentClient; + + + + + /** + * 获取我的报名赛事记录 + * @param uid + * @param type + * @param pageSize + * @param pageNo + * @return + * @throws Exception + */ + @Override + public List<CompetitionListVo> queryMyCompetitionList(Integer uid, Integer type, Integer pageSize, Integer pageNo) throws Exception { + pageSize = (pageSize - 1) * pageNo; + return this.baseMapper.queryMyCompetitionList(uid, type, pageSize, pageNo); + } + + + /** + * 获取我报名的赛事详情 + * @param id + * @return + * @throws Exception + */ + @Override + public CompetitionInfo queryMyCompetitionInfo(Long id) throws Exception { + PaymentCompetition paymentCompetition = this.getById(id); + SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm"); + Competition competition = competitionService.getById(paymentCompetition.getCompetitionId()); + CompetitionInfo competitionInfo = new CompetitionInfo(); + competitionInfo.setId(id); + competitionInfo.setImgs(competition.getImgs()); + competitionInfo.setName(competition.getName()); + competitionInfo.setRegisterCondition(competition.getRegisterCondition()); + Store store = storeClient.queryStoreById(competition.getStoreId()); + competitionInfo.setStoreName(store.getName()); + competitionInfo.setStoreAddress(store.getAddress()); + competitionInfo.setStoreLon(store.getLon()); + competitionInfo.setStoreLat(store.getLat()); + competitionInfo.setStoreCoverDrawing(store.getCoverDrawing()); + competitionInfo.setRegisterEndTime(sdf.format(competition.getRegisterEndTime())); + competitionInfo.setStartTime(sdf.format(competition.getStartTime())); + competitionInfo.setEndTime(sdf.format(competition.getEndTime())); + competitionInfo.setAge(competition.getStartAge() + "-" + competition.getEndAge()); + competitionInfo.setProvince(competition.getEntryProvince()); + competitionInfo.setCity(competition.getEntryCity()); + competitionInfo.setAddress(competition.getEntryAddress()); + competitionInfo.setPayType(competition.getPayType()); + competitionInfo.setPrice(competition.getPrice().doubleValue()); + competitionInfo.setIntroduction(competition.getIntroduction()); + competitionInfo.setRegistrationNotes(competition.getRegistrationNotes()); + competitionInfo.setApply(1); + List<ParticipantVo> participant = new ArrayList<>(); + List<UserCompetition> list = userCompetitionService.list(new QueryWrapper<UserCompetition>().eq("paymentCompetitionId", paymentCompetition.getId())); + List<Integer> collect = list.stream().map(UserCompetition::getParticipantId).collect(Collectors.toList()); + List<Participant> participants = participantService.listByIds(collect); + SimpleDateFormat sdf_year = new SimpleDateFormat("yyyy"); + for (Participant participant1 : participants) { + ParticipantVo participantVo = new ParticipantVo(); + participantVo.setId(participant1.getId()); + participantVo.setName(participant1.getName()); + participantVo.setIdcard(participant1.getIdcard()); + Integer age = Integer.valueOf(sdf_year.format(new Date())) - Integer.valueOf(sdf_year.format(participant1.getBirthday())); + participantVo.setAge(age); + participant.add(participantVo); + } + competitionInfo.setParticipant(participant); + return competitionInfo; + } + + + /** + * 取消赛事报名 + * @param id + * @return + * @throws Exception + */ + @Override + public ResultUtil cancelMyCompetition(Long id) throws Exception { + PaymentCompetition paymentCompetition = this.getById(id); + if(paymentCompetition.getPayStatus() == 3){ + return ResultUtil.error("不能重复取消"); + } + String code = paymentCompetition.getCode(); + Double amount = paymentCompetition.getAmount(); + Competition competition = competitionService.getById(paymentCompetition.getCompetitionId()); + if(System.currentTimeMillis() >= competition.getRegisterEndTime().getTime()){ + return ResultUtil.error("赛事已结束报名,无法取消"); + } + + String payOrderNo = paymentCompetition.getPayOrderNo(); + if(paymentCompetition.getPayType() == 1){//微信支付 + Map<String, String> map = payMoneyUtil.wxRefund(payOrderNo, code, amount.toString(), amount.toString(), "/base/competition/weChatCancelPaymentCompetitionCallback"); + String return_code = map.get("return_code"); + if(!"SUCCESS".equals(return_code)){ + return ResultUtil.error(map.get("return_msg")); + } + String refund_id = map.get("refund_id"); + paymentCompetition.setRefundOrderNo(refund_id); + this.updateById(paymentCompetition); + } + if(paymentCompetition.getPayType() == 2){//支付宝支付 + Map<String, String> map = payMoneyUtil.aliRefund(payOrderNo, amount.toString()); + String return_code = map.get("code"); + if(!"10000".equals(return_code)){ + return ResultUtil.error(map.get("msg")); + } + String refund_id = map.get("trade_no"); + paymentCompetition.setRefundOrderNo(refund_id); + paymentCompetition.setRefundTime(new Date()); + paymentCompetition.setPayStatus(3); + this.updateById(paymentCompetition); + + competition.setApplicantsNumber(competition.getApplicantsNumber() - 1); + competitionService.updateById(competition); + } + if(paymentCompetition.getPayType() == 3){//玩湃币支付 + AppUser appUser = appUserClient.queryAppUser(paymentCompetition.getAppUserId()); + appUser.setPlayPaiCoins(appUser.getPlayPaiCoins() + amount.intValue()); + appUserClient.updateAppUser(appUser); + + paymentCompetition.setRefundOrderNo(""); + paymentCompetition.setRefundTime(new Date()); + paymentCompetition.setPayStatus(3); + this.updateById(paymentCompetition); + + competition.setApplicantsNumber(competition.getApplicantsNumber() - 1); + competitionService.updateById(competition); + } + if(paymentCompetition.getPayType() == 4){//课程支付 + List<UserCompetition> list = userCompetitionService.list(new QueryWrapper<UserCompetition>().eq("paymentCompetitionId", paymentCompetition.getId())); + for (UserCompetition userCompetition : list) { + Participant participant = participantService.getById(userCompetition.getId()); + Student student = studentClient.queryStudentByPhone(participant.getPhone()); + PaymentDeductionClassHour paymentDeductionClassHour = new PaymentDeductionClassHour(); + paymentDeductionClassHour.setId(student.getId()); + paymentDeductionClassHour.setClassHour(competition.getPrice().intValue()); + paymentDeductionClassHour.setCode(code); + coursePackagePaymentClient.rollbackPaymentDeductionClassHour(paymentDeductionClassHour); + } + + paymentCompetition.setRefundOrderNo(""); + paymentCompetition.setRefundTime(new Date()); + paymentCompetition.setPayStatus(3); + this.updateById(paymentCompetition); + + competition.setApplicantsNumber(competition.getApplicantsNumber() - 1); + competitionService.updateById(competition); + } + return ResultUtil.success(); + } } -- Gitblit v1.7.1