| package com.dsh.account.service.impl; | 
|   | 
| import com.alipay.api.response.AlipayTradeQueryResponse; | 
| import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; | 
| import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; | 
| import com.dsh.account.entity.RechargeRecords; | 
| import com.dsh.account.entity.TAppUser; | 
| import com.dsh.account.entity.VipPayment; | 
| import com.dsh.account.enums.RechargeRecordEnum; | 
| import com.dsh.account.feignclient.competition.DeductionCompetitionsClient; | 
| import com.dsh.account.feignclient.competition.model.PaymentCompetition; | 
| import com.dsh.account.feignclient.course.CoursePaymentClient; | 
| import com.dsh.account.feignclient.course.model.CouponPaymentVo; | 
| import com.dsh.account.feignclient.course.model.TCoursePackagePayment; | 
| import com.dsh.account.feignclient.other.RechargeConfigClient; | 
| import com.dsh.account.feignclient.other.SiteClient; | 
| import com.dsh.account.feignclient.other.model.SiteBooking; | 
| import com.dsh.account.mapper.RechargeRecordsMapper; | 
| import com.dsh.account.mapper.TAppUserMapper; | 
| import com.dsh.account.model.IncomeQuery; | 
| import com.dsh.account.model.query.RechargeRecordsQuery; | 
| import com.dsh.account.model.vo.RechargeRecordsVO; | 
| import com.dsh.account.model.vo.userBenefitDetail.RechargeDetailsVo; | 
| import com.dsh.account.model.vo.userBenefitDetail.RechargePayRequest; | 
| import com.dsh.account.model.vo.userBenefitDetail.RechargesDetail; | 
| import com.dsh.account.service.RechargeRecordsService; | 
| import com.dsh.account.util.*; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import org.springframework.data.domain.Page; | 
| import org.springframework.data.domain.PageImpl; | 
| import org.springframework.data.domain.PageRequest; | 
| import org.springframework.data.domain.Pageable; | 
| import org.springframework.stereotype.Service; | 
| import org.springframework.util.StringUtils; | 
|   | 
| import javax.annotation.Resource; | 
| import java.math.BigDecimal; | 
| import java.text.ParseException; | 
| import java.text.SimpleDateFormat; | 
| import java.util.*; | 
| import java.util.stream.Collectors; | 
|   | 
| /** | 
|  * <p> | 
|  * 充值记录 服务实现类 | 
|  * </p> | 
|  * | 
|  * @author jqs | 
|  * @since 2023-07-07 | 
|  */ | 
| @Service | 
| public class RechargeRecordsServiceImpl extends ServiceImpl<RechargeRecordsMapper, RechargeRecords> implements RechargeRecordsService { | 
|   | 
|     @Resource | 
|     private RechargeRecordsMapper rereMapper; | 
|   | 
|   | 
|     @Resource | 
|     private TAppUserMapper tappMapper; | 
|   | 
|     @Autowired | 
|     private CoursePaymentClient cpClient; | 
|   | 
|     @Autowired | 
|     private DeductionCompetitionsClient deducClient; | 
|   | 
|     @Autowired | 
|     private PayMoneyUtil payMoneyUtil; | 
|   | 
|     @Resource | 
|     private SiteClient stClient; | 
|   | 
|   | 
|     @Resource | 
|     private RechargeConfigClient reconMapper; | 
|     @Autowired | 
|     private RechargeRecordsMapper rechargeRecordsMapper; | 
|   | 
|   | 
|     @Override | 
|     public List<RechargesDetail> getAppUserRechargeRecord(String yearMonth, Integer recordId, Integer appUserId, Integer pageNum, Integer pageSize) { | 
|         List<RechargesDetail> details = new ArrayList<>(); | 
|         SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm"); | 
|   | 
|         Date monthStart = null; | 
|         Date monthEnd = null; | 
|         if (StringUtils.hasText(yearMonth)) { | 
|             monthStart = DateTimeHelper.getCurrentIdetMouthStart(yearMonth); | 
|             monthEnd = DateTimeHelper.getCurrentIdeaMouthEnd(yearMonth); | 
|         } else { | 
|             monthStart = DateTimeHelper.getCurrentMouthStart(); | 
|             monthEnd = DateTimeHelper.getCurrentMouthEnd(); | 
|         } | 
|   | 
| //            1.赛事报名 | 
|         List<PaymentCompetition> playPaiFGoldPayRecord = deducClient.getPlayPaiFGoldPayRecord(appUserId); | 
|         if (playPaiFGoldPayRecord.size() > 0) { | 
|             for (PaymentCompetition competition : playPaiFGoldPayRecord) { | 
|                 if (competition.getPayStatus() == 2) { | 
|                     RechargesDetail consumeDetail = new RechargesDetail(); | 
|                     consumeDetail.setConsumeName(RechargeRecordEnum.EVENT_REGISTRATION.getMsg()); | 
|                     consumeDetail.setConsumeTime(simpleDateFormat.format(competition.getInsertTime())); | 
|                     consumeDetail.setConsumeAmount("-" + competition.getAmount()); | 
|                     consumeDetail.setRecordId(2); | 
|                     details.add(consumeDetail); | 
|                 } else { | 
|   | 
|   | 
|                     RechargesDetail consumeDetail1 = new RechargesDetail(); | 
|                     consumeDetail1.setConsumeName(RechargeRecordEnum.CANCEL_EVENT_REGISTRATION.getMsg()); | 
|                     consumeDetail1.setConsumeTime(simpleDateFormat.format(competition.getRefundTime())); | 
|                     consumeDetail1.setConsumeAmount("+" + competition.getAmount()); | 
|                     consumeDetail1.setRecordId(1); | 
|                     details.add(consumeDetail1); | 
|   | 
|                     RechargesDetail consumeDetail = new RechargesDetail(); | 
|                     consumeDetail.setConsumeName(RechargeRecordEnum.EVENT_REGISTRATION.getMsg()); | 
|                     consumeDetail.setConsumeTime(simpleDateFormat.format(competition.getInsertTime())); | 
|                     consumeDetail.setConsumeAmount("-" + competition.getAmount()); | 
|                     consumeDetail.setRecordId(2); | 
|                     details.add(consumeDetail); | 
|   | 
|   | 
|                 } | 
|             } | 
|         } | 
| //            2.课包购买 | 
|         List<CouponPaymentVo> appuserCourseList = cpClient.getAppuserCourseList(appUserId); | 
|         if (appuserCourseList.size() > 0) { | 
|             for (CouponPaymentVo tCoursePackagePayment : appuserCourseList) { | 
|                 RechargesDetail consumeDetail = new RechargesDetail(); | 
|                 consumeDetail.setConsumeName(RechargeRecordEnum.COURSE_PACKAGE_PURCHASE.getMsg()); | 
|                 consumeDetail.setConsumeTime(tCoursePackagePayment.getTime()); | 
|                 consumeDetail.setConsumeAmount("-" + tCoursePackagePayment.getAmount()); | 
|                 consumeDetail.setRecordId(2); | 
|                 details.add(consumeDetail); | 
|             } | 
|         } | 
| //            3.场地预约 | 
|         List<SiteBooking> siteBookings = stClient.wanpaiGoldSiteBookingList(appUserId); | 
|         if (siteBookings.size() > 0) { | 
|             for (SiteBooking booking : siteBookings) { | 
|                 if (booking.getStatus() != 5) { | 
|                     RechargesDetail consumeDetail = new RechargesDetail(); | 
|                     consumeDetail.setConsumeName(RechargeRecordEnum.VENUE_RESERVATION.getMsg()); | 
|                     consumeDetail.setConsumeTime(simpleDateFormat.format(booking.getInsertTime())); | 
|                     consumeDetail.setConsumeAmount("-" + booking.getPayMoney()); | 
|                     consumeDetail.setRecordId(2); | 
|                     details.add(consumeDetail); | 
|                 } else { | 
|                     RechargesDetail consumeDetail1 = new RechargesDetail(); | 
|                     consumeDetail1.setConsumeName(RechargeRecordEnum.CANCEL_VENUE_RESERVATION.getMsg()); | 
|                     consumeDetail1.setConsumeTime(simpleDateFormat.format(booking.getCancelTime())); | 
|                     consumeDetail1.setConsumeAmount("+" + booking.getPayMoney()); | 
|                     consumeDetail1.setRecordId(1); | 
|                     details.add(consumeDetail1); | 
|   | 
|                     RechargesDetail consumeDetail = new RechargesDetail(); | 
|                     consumeDetail.setConsumeName(RechargeRecordEnum.VENUE_RESERVATION.getMsg()); | 
|                     consumeDetail.setConsumeTime(simpleDateFormat.format(booking.getInsertTime())); | 
|                     consumeDetail.setConsumeAmount("-" + booking.getPayMoney()); | 
|                     consumeDetail.setRecordId(2); | 
|                     details.add(consumeDetail); | 
|   | 
|   | 
|                 } | 
|             } | 
|         } | 
|         //    4.智慧球场 | 
|         List<Map<String, Object>> list = stClient.game(appUserId); | 
|         if (list.size() > 0) { | 
|             for (Map<String, Object> booking : list) { | 
|                 RechargesDetail consumeDetail = new RechargesDetail(); | 
|                 consumeDetail.setConsumeName("激战游戏"); | 
|                 consumeDetail.setConsumeTime(simpleDateFormat.format(new Date(Long.valueOf(booking.get("time").toString())))); | 
|                 consumeDetail.setConsumeAmount("-" + String.valueOf(booking.get("money"))); | 
|                 consumeDetail.setRecordId(2); | 
|                 details.add(consumeDetail); | 
|             } | 
|         } | 
|   | 
|   | 
|         //  5.充值 | 
|         List<RechargeRecords> rechargeRecords = this.baseMapper.selectList(new QueryWrapper<RechargeRecords>() | 
|                 .eq("payStatus", 2) | 
|                 .eq("appUserId", appUserId) | 
|                 .between("insertTime", monthStart, monthEnd)); | 
|         if (rechargeRecords.size() > 0) { | 
|             for (RechargeRecords rechargeRecord : rechargeRecords) { | 
|                 RechargesDetail consumeDetail = new RechargesDetail(); | 
|                 consumeDetail.setConsumeName(RechargeRecordEnum.RECHARGE.getMsg() + ":¥" + rechargeRecord.getAmount()); | 
|                 consumeDetail.setConsumeTime(simpleDateFormat.format(rechargeRecord.getInsertTime())); | 
|                 consumeDetail.setConsumeAmount("+" + rechargeRecord.getPlayPaiCoins()); | 
|                 consumeDetail.setRecordId(1); | 
|                 details.add(consumeDetail); | 
|             } | 
|         } | 
|         if (ToolUtil.isNotEmpty(recordId)) { | 
|             details = details.stream() | 
|                     .filter(record -> record.getRecordId().equals(recordId)) | 
|                     .collect(Collectors.toList()); | 
|         } | 
|         if (details.size() > 0) { | 
|             Collections.sort(details, new Comparator<RechargesDetail>() { | 
|                 @Override | 
|                 public int compare(RechargesDetail o1, RechargesDetail o2) { | 
|                     try { | 
|                         Date date1 = simpleDateFormat.parse(o1.getConsumeTime()); | 
|                         Date date2 = simpleDateFormat.parse(o2.getConsumeTime()); | 
|                         return date2.compareTo(date1); // 降序排序 | 
|                     } catch (ParseException e) { | 
|                         e.printStackTrace(); | 
|                     } | 
|                     return 0; | 
|                 } | 
|             }); | 
|         } | 
|         //当前第几页 | 
|         int pageNo = pageNum; | 
|         //一页五条 | 
|         int size = pageSize; | 
|   | 
|   | 
|         SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); | 
|         List<RechargesDetail> filteredList = new ArrayList<>(); | 
|         for (RechargesDetail detail : details) { | 
|             try { | 
|                 Date consumeTime = dateFormat.parse(detail.getConsumeTime()); | 
|                 if (consumeTime.after(monthStart) && consumeTime.before(monthEnd)) { | 
|                     String substring = detail.getConsumeTime().substring(5); | 
|                     detail.setConsumeTime(substring); | 
|                     filteredList.add(detail); | 
|                 } | 
|             } catch (ParseException e) { | 
|                 e.printStackTrace(); | 
|             } | 
|         } | 
|   | 
|   | 
|         //分页 | 
|         filteredList = filteredList.stream().skip((pageNo - 1) * size).limit(size). | 
|                 collect(Collectors.toList()); | 
|   | 
|         return filteredList; | 
|     } | 
|   | 
|     @Override | 
|     public ResultUtil rechargeCenPayment(Integer userIdFormRedis, RechargePayRequest request) { | 
|         TAppUser tAppUser = tappMapper.selectById(userIdFormRedis); | 
|         SimpleDateFormat sdf = new SimpleDateFormat("yyyyMMddHHmmssSSS"); | 
|         String code = sdf.format(new Date()) + UUIDUtil.getNumberRandom(5); | 
|         RechargeRecords rechargeRecords = new RechargeRecords(); | 
|         rechargeRecords.setCode(code); | 
|         rechargeRecords.setAppUserId(userIdFormRedis); | 
|   | 
|         List<Map<String, Object>> rechargeConfig = reconMapper.getRechargeConfig(); | 
|         BigDecimal amount = BigDecimal.ZERO; | 
|         if (rechargeConfig.size() > 0) { | 
|             for (Map<String, Object> stringObjectMap : rechargeConfig) { | 
|                 double o = (double) stringObjectMap.get("money"); | 
|                 if (BigDecimal.valueOf(o).compareTo(request.getAmount()) == 0) { | 
|                     amount = BigDecimal.valueOf(o); | 
|                     rechargeRecords.setAmount(BigDecimal.valueOf(o)); | 
|                     if (tAppUser.getIsVip() == 1) { | 
|                         rechargeRecords.setPlayPaiCoins((Integer) stringObjectMap.get("MemberCoins")); | 
|                     } else { | 
|                         rechargeRecords.setPlayPaiCoins((Integer) stringObjectMap.get("usersCoins")); | 
|                     } | 
|                 } | 
|             } | 
|         } | 
|         rechargeRecords.setPayStatus(1); | 
|         rechargeRecords.setState(1); | 
|         rechargeRecords.setInsertTime(new Date()); | 
|         this.baseMapper.insert(rechargeRecords); | 
|         try { | 
|             switch (request.getPayType()) { | 
|                 case 1: | 
|                     return WeChatPayment(code, amount); | 
|                 case 2: | 
|                     return AlipayPayment(code, amount); | 
|                 default: | 
|                     break; | 
|             } | 
|         } catch (Exception e) { | 
|             ResultUtil.runErr(); | 
|         } | 
|         return ResultUtil.success(); | 
|     } | 
|   | 
|     private String smid = "2088330203191220";//平台支付宝商户号 | 
|     private ResultUtil AlipayPayment(String code, BigDecimal amount) { | 
|         ResultUtil alipay = payMoneyUtil.alipay(smid,"玩湃币充值", "玩湃币充值", "", code, amount.toString(), | 
|                 "/base/recharge/alipayRechargeCallback"); | 
|         if (alipay.getCode() == 200) { | 
|             new Thread(new Runnable() { | 
|                 @Override | 
|                 public void run() { | 
|                     try { | 
|                         int num = 1; | 
|                         int wait = 0; | 
|                         while (num <= 10) { | 
|                             int min = 5000; | 
|                             wait += (min * num); | 
|                             Thread.sleep(wait); | 
|   | 
|                             RechargeRecords records = rereMapper.selectOne(new QueryWrapper<RechargeRecords>() | 
|                                     .eq("code", code)); | 
|                             if (records.getPayStatus() == 2) { | 
|                                 break; | 
|                             } | 
|                             AlipayTradeQueryResponse resultUtil = payMoneyUtil.queryALIOrder(code); | 
|   | 
|                             if (resultUtil.getCode().equals("10000") && records.getPayStatus() == 1) { | 
|                                 /** | 
|                                  * WAIT_BUYER_PAY(交易创建,等待买家付款)、 | 
|                                  * TRADE_CLOSED(未付款交易超时关闭,或支付完成后全额退款)、 | 
|                                  * TRADE_SUCCESS(交易支付成功)、 | 
|                                  * TRADE_FINISHED(交易结束,不可退款) | 
|                                  */ | 
| //                                Map<String, String> data1 = resultUtil.getData(); | 
| //                                String s = data1.get("tradeStatus"); | 
| //                                String tradeNo = data1.get("tradeNo"); | 
|   | 
|                                 String tradeNo = resultUtil.getTradeNo(); | 
|                                 String tradeStatus = resultUtil.getTradeStatus(); | 
|                                 System.out.println("ssssss" + tradeStatus); | 
|                                 if ("TRADE_CLOSED".equals(tradeStatus) || "TRADE_FINISHED".equals(tradeStatus) || num == 10) { | 
|                                     records.setState(3); | 
|                                     rereMapper.deleteById(records.getId()); | 
|                                     if ("TRADE_FINISHED".equals(tradeStatus)) { | 
|                                         // todo 资金结算 | 
|                                         payMoneyUtil.confirm(smid,code,tradeNo,amount.toString()); | 
|                                         break; | 
|                                     } | 
|                                     break; | 
|                                 } | 
|   | 
|                                 if ("TRADE_SUCCESS".equals(tradeStatus)) { | 
|                                     records.setAppUserId(null); | 
|                                     records.setPayStatus(2); | 
|                                     records.setPayTime(new Date()); | 
|                                     records.setOrderNumber(tradeNo); | 
|                                     rereMapper.updateById(records); | 
|   | 
|                                     RechargeRecords rechargeRecords = rereMapper.selectOne(new QueryWrapper<RechargeRecords>() | 
|                                             .eq("code", code)); | 
|                                     if (rechargeRecords.getPayStatus() == 2) { | 
|                                         TAppUser tAppUser = tappMapper.selectById(rechargeRecords.getAppUserId()); | 
|                                         tAppUser.setPlayPaiCoins(null == tAppUser.getPlayPaiCoins() ? rechargeRecords.getPlayPaiCoins() : tAppUser.getPlayPaiCoins() + rechargeRecords.getPlayPaiCoins()); | 
|                                         tappMapper.updateById(tAppUser); | 
|                                         break; | 
|                                     } | 
|   | 
|   | 
|                                     break; | 
|                                 } | 
|                                 if ("WAIT_BUYER_PAY".equals(tradeStatus)) { | 
|                                     num++; | 
|                                 } | 
|                             } | 
|                         } | 
|                     } catch (Exception e) { | 
|                         e.printStackTrace(); | 
|                     } | 
|                 } | 
|             }).start(); | 
|         } | 
|         return alipay; | 
|     } | 
|   | 
|     private ResultUtil WeChatPayment(String code, BigDecimal amount) throws Exception { | 
|         ResultUtil weixinpay = payMoneyUtil.weixinpay("玩湃币充值", "", code, amount.toString(), | 
|                 "/base/recharge/wechatRechargeCallback", "APP", ""); | 
|         if (weixinpay.getCode() == 200) { | 
|             new Thread(new Runnable() { | 
|                 @Override | 
|                 public void run() { | 
|                     try { | 
|                         int num = 1; | 
|                         int wait = 0; | 
|                         while (num <= 10) { | 
|                             int min = 5000; | 
|                             wait += (min * num); | 
|                             Thread.sleep(wait); | 
|                             RechargeRecords records = rereMapper.selectOne(new QueryWrapper<RechargeRecords>() | 
|                                     .eq("code", code)); | 
|                             if (records.getPayStatus() == 2) { | 
|                                 break; | 
|                             } | 
|                             ResultUtil<Map<String, String>> resultUtil = payMoneyUtil.queryWXOrder(code, ""); | 
|                             if (resultUtil.getCode() == 200 && records.getPayStatus() == 1) { | 
|                                 /** | 
|                                  * SUCCESS—支付成功, | 
|                                  * REFUND—转入退款, | 
|                                  * NOTPAY—未支付, | 
|                                  * CLOSED—已关闭, | 
|                                  * REVOKED—已撤销(刷卡支付), | 
|                                  * USERPAYING--用户支付中, | 
|                                  * PAYERROR--支付失败(其他原因,如银行返回失败) | 
|                                  */ | 
|                                 Map<String, String> data1 = resultUtil.getData(); | 
|                                 String s = data1.get("trade_state"); | 
|                                 String transaction_id = data1.get("transaction_id"); | 
|                                 if ("REFUND".equals(s) || "NOTPAY".equals(s) || "CLOSED".equals(s) || "REVOKED".equals(s) || "PAYERROR".equals(s) || num == 10) { | 
|                                     records.setState(3); | 
|                                     rereMapper.deleteById(records.getId()); | 
|                                     break; | 
|                                 } | 
|                                 if ("SUCCESS".equals(s)) { | 
|                                     records.setPayStatus(2); | 
|                                     records.setOrderNumber(transaction_id); | 
|                                     rereMapper.updateById(records); | 
|                                     break; | 
|                                 } | 
|                                 if ("USERPAYING".equals(s)) { | 
|                                     num++; | 
|                                 } | 
|                             } | 
|                         } | 
|                     } catch (Exception e) { | 
|                         e.printStackTrace(); | 
|                     } | 
|                 } | 
|             }).start(); | 
|         } | 
|         return weixinpay; | 
|   | 
|     } | 
|   | 
|     @Override | 
|     public ResultUtil addRechargeCallbackPay(String code, String orderNumber) { | 
|         RechargeRecords rechargeRecords = this.baseMapper.selectOne(new QueryWrapper<RechargeRecords>() | 
|                 .eq("code", code)); | 
|         if (rechargeRecords.getPayStatus() == 2) { | 
|             return ResultUtil.success(); | 
|         } | 
|         rechargeRecords.setAppUserId(null); | 
|         rechargeRecords.setPayStatus(2); | 
|         rechargeRecords.setPayTime(new Date()); | 
|         rechargeRecords.setOrderNumber(orderNumber); | 
|         this.baseMapper.updateById(rechargeRecords); | 
|   | 
|         TAppUser tAppUser = tappMapper.selectById(rechargeRecords.getAppUserId()); | 
|         tAppUser.setPlayPaiCoins(null == tAppUser.getPlayPaiCoins() ? rechargeRecords.getPlayPaiCoins() : tAppUser.getPlayPaiCoins() + rechargeRecords.getPlayPaiCoins()); | 
|         tappMapper.updateById(tAppUser); | 
|         return null; | 
|     } | 
|   | 
|     @Override | 
|     public List<RechargeRecordsVO> rechargeList(RechargeRecordsQuery query) { | 
|         String STime = null; | 
|         String ETime = null; | 
|         if (StringUtils.hasLength(query.getTime())) { | 
|             STime = query.getTime().split(" - ")[0] + " 00:00:00"; | 
|             ETime = query.getTime().split(" - ")[1] + " 23:59:59"; | 
|         } | 
|   | 
|         return rechargeRecordsMapper.rechargeList(query, STime, ETime); | 
|   | 
|     } | 
|   | 
|     @Override | 
|     public List<VipPayment> listAll(IncomeQuery query) { | 
|         String STime = null; | 
|         String ETime = null; | 
|         if (StringUtils.hasLength(query.getTime())) { | 
|             STime = query.getTime().split(" - ")[0] + " 00:00:00"; | 
|             ETime = query.getTime().split(" - ")[1] + " 23:59:59"; | 
|         } | 
|         return rechargeRecordsMapper.listAll(query, STime, ETime, query.getAmount(), query.getInsertType()); | 
|     } | 
|   | 
|     public static <T> List<T> pageList(List<T> list, int pageNum, int pageSize) { | 
|         //计算总页数 | 
|         int page = list.size() % pageSize == 0 ? list.size() / pageSize : list.size() / pageSize + 1; | 
|         //兼容性分页参数错误 | 
|         pageNum = pageNum <= 0 ? 1 : pageNum; | 
|         pageNum = pageNum >= page ? page : pageNum; | 
|         // 开始索引 | 
|         int begin = 0; | 
|         // 结束索引 | 
|         int end = 0; | 
|         if (pageNum != page) { | 
|             begin = (pageNum - 1) * pageSize; | 
|             end = begin + pageSize; | 
|         } else { | 
|             begin = (pageNum - 1) * pageSize; | 
|             end = list.size(); | 
|         } | 
|         return list.subList(begin, end); | 
|     } | 
|   | 
| } |