init
This commit is contained in:
@@ -3,6 +3,8 @@ package com.ruoyi.xq.service;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import com.ruoyi.xq.domain.UserExtend;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
/**
|
||||
* 用户邀请Service接口
|
||||
*
|
||||
@@ -11,4 +13,5 @@ import com.ruoyi.xq.domain.UserExtend;
|
||||
*/
|
||||
public interface UserExtendService extends IService<UserExtend> {
|
||||
|
||||
boolean withdraw(Long userId, BigDecimal withdrawPrice);
|
||||
}
|
||||
|
||||
@@ -2,6 +2,7 @@ package com.ruoyi.xq.service;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import com.ruoyi.xq.domain.UserVip;
|
||||
import com.ruoyi.xq.domain.VipOrder;
|
||||
|
||||
/**
|
||||
* VIP用户Service接口
|
||||
@@ -16,4 +17,5 @@ public interface UserVipService extends IService<UserVip> {
|
||||
UserVip getUserVipNormal(Long userId, Integer vipType);
|
||||
|
||||
UserVip getByUserVipMaster(Long userId);
|
||||
|
||||
}
|
||||
|
||||
@@ -1,7 +1,11 @@
|
||||
package com.ruoyi.xq.service;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.IService;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.ruoyi.xq.domain.UserWithdraw;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListAppVo;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListPageQuery;
|
||||
|
||||
/**
|
||||
* 用户提现审核Service接口
|
||||
@@ -11,4 +15,7 @@ import com.ruoyi.xq.domain.UserWithdraw;
|
||||
*/
|
||||
public interface UserWithdrawService extends IService<UserWithdraw> {
|
||||
|
||||
void saveWithdraw(Long userId, Long withdrawSettingId);
|
||||
|
||||
Page<WithdrawListAppVo> pageApp(PageQuery pageQuery, WithdrawListPageQuery query);
|
||||
}
|
||||
|
||||
@@ -10,4 +10,5 @@ import com.ruoyi.xq.domain.VipOrder;
|
||||
* @date 2024-03-04
|
||||
*/
|
||||
public interface VipOrderService extends IService<VipOrder> {
|
||||
VipOrder createVipOrder(Long userId, Long vipPriceSettingId);
|
||||
}
|
||||
|
||||
@@ -11,4 +11,5 @@ import com.ruoyi.xq.domain.WithdrawSetting;
|
||||
*/
|
||||
public interface WithdrawSettingService extends IService<WithdrawSetting> {
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -7,6 +7,8 @@ import com.ruoyi.xq.service.UserExtendService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
/**
|
||||
* 用户邀请Service业务层处理
|
||||
*
|
||||
@@ -17,4 +19,11 @@ import org.springframework.stereotype.Service;
|
||||
@Service
|
||||
public class UserExtendServiceImpl extends ServiceImpl<UserExtendMapper,UserExtend> implements UserExtendService {
|
||||
|
||||
|
||||
@Override
|
||||
public boolean withdraw(Long userId, BigDecimal withdrawPrice){
|
||||
boolean exists = baseMapper.decrIncome(userId, withdrawPrice);
|
||||
return exists;
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -23,7 +23,6 @@ import java.util.List;
|
||||
@Service
|
||||
public class UserVipServiceImpl extends ServiceImpl<UserVipMapper,UserVip> implements UserVipService {
|
||||
|
||||
|
||||
@Override
|
||||
public UserVip getUserVip(Long userId, Integer vipType){
|
||||
return this.getOne(Wrappers.lambdaQuery(UserVip.class)
|
||||
|
||||
@@ -1,11 +1,30 @@
|
||||
package com.ruoyi.xq.service.impl;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.ruoyi.common.exception.ServiceException;
|
||||
import com.ruoyi.xq.domain.User;
|
||||
import com.ruoyi.xq.domain.UserWithdraw;
|
||||
import com.ruoyi.xq.domain.WithdrawSetting;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListAppVo;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListPageQuery;
|
||||
import com.ruoyi.xq.enums.common.AuditEnum;
|
||||
import com.ruoyi.xq.enums.common.OrderTypeEnum;
|
||||
import com.ruoyi.xq.enums.common.TraceIdEnum;
|
||||
import com.ruoyi.xq.manager.OrderNoUtil;
|
||||
import com.ruoyi.xq.manager.TraceIdManager;
|
||||
import com.ruoyi.xq.mapper.UserWithdrawMapper;
|
||||
import com.ruoyi.xq.service.UserExtendService;
|
||||
import com.ruoyi.xq.service.UserService;
|
||||
import com.ruoyi.xq.service.UserWithdrawService;
|
||||
import com.ruoyi.xq.service.WithdrawSettingService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import java.math.BigDecimal;
|
||||
|
||||
/**
|
||||
* 用户提现审核Service业务层处理
|
||||
@@ -17,4 +36,42 @@ import org.springframework.stereotype.Service;
|
||||
@Service
|
||||
public class UserWithdrawServiceImpl extends ServiceImpl<UserWithdrawMapper,UserWithdraw> implements UserWithdrawService {
|
||||
|
||||
@Autowired
|
||||
private WithdrawSettingService withdrawSettingService;
|
||||
@Autowired
|
||||
private UserExtendService userExtendService;
|
||||
@Autowired
|
||||
private UserService userService;
|
||||
|
||||
@Override
|
||||
@Transactional(rollbackFor = Exception.class)
|
||||
public void saveWithdraw(Long userId, Long withdrawSettingId) {
|
||||
User user = userService.getById(userId);
|
||||
WithdrawSetting withdrawSetting = withdrawSettingService.getById(withdrawSettingId);
|
||||
if(withdrawSetting == null){
|
||||
throw new ServiceException("提现参数错误");
|
||||
}
|
||||
boolean withdraw = userExtendService.withdraw(userId, withdrawSetting.getMoney());
|
||||
if(!withdraw){
|
||||
throw new ServiceException("提现失败,余额不足");
|
||||
}
|
||||
String traceId = TraceIdManager.gen(TraceIdEnum.WITHDRAW);
|
||||
String orderNo = OrderNoUtil.gen(OrderTypeEnum.WITHDRAW);
|
||||
UserWithdraw userWithdraw = new UserWithdraw();
|
||||
userWithdraw.setUserId(user.getId());
|
||||
userWithdraw.setUsercode(user.getUsercode());
|
||||
userWithdraw.setTraceId(traceId);
|
||||
userWithdraw.setOrderNo(orderNo);
|
||||
userWithdraw.setWithdrawMoney(withdrawSetting.getMoney());
|
||||
userWithdraw.setRealWithdrawMoney(withdrawSetting.getMoney());
|
||||
userWithdraw.setWithdrawFees(BigDecimal.ZERO);
|
||||
userWithdraw.setWithdrawFeesCate(BigDecimal.ZERO);
|
||||
userWithdraw.setAuditStatus(AuditEnum.AUDITING.getCode());
|
||||
this.save(userWithdraw);
|
||||
}
|
||||
|
||||
@Override
|
||||
public Page<WithdrawListAppVo> pageApp(PageQuery pageQuery, WithdrawListPageQuery query) {
|
||||
return baseMapper.pageApp(pageQuery.build(), query);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,10 +1,19 @@
|
||||
package com.ruoyi.xq.service.impl;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import com.ruoyi.common.exception.ServiceException;
|
||||
import com.ruoyi.xq.domain.User;
|
||||
import com.ruoyi.xq.domain.VipOrder;
|
||||
import com.ruoyi.xq.domain.VipPrice;
|
||||
import com.ruoyi.xq.enums.common.OrderTypeEnum;
|
||||
import com.ruoyi.xq.enums.pay.PayStatusEnum;
|
||||
import com.ruoyi.xq.manager.OrderNoUtil;
|
||||
import com.ruoyi.xq.mapper.VipOrderMapper;
|
||||
import com.ruoyi.xq.service.UserService;
|
||||
import com.ruoyi.xq.service.VipOrderService;
|
||||
import com.ruoyi.xq.service.VipPriceService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
/**
|
||||
@@ -17,4 +26,29 @@ import org.springframework.stereotype.Service;
|
||||
@Service
|
||||
public class VipOrderServiceImpl extends ServiceImpl<VipOrderMapper,VipOrder> implements VipOrderService {
|
||||
|
||||
@Autowired
|
||||
private VipPriceService vipPriceService;
|
||||
@Autowired
|
||||
private UserService userService;
|
||||
@Override
|
||||
public VipOrder createVipOrder(Long userId, Long vipPriceSettingId) {
|
||||
VipPrice vipPrice = vipPriceService.getById(vipPriceSettingId);
|
||||
if(vipPrice == null){
|
||||
throw new ServiceException("vip价格错误");
|
||||
}
|
||||
String orderNo = OrderNoUtil.gen(OrderTypeEnum.VIP);
|
||||
User user = userService.getById(userId);
|
||||
VipOrder vipOrder = new VipOrder();
|
||||
vipOrder.setUserId(user.getId());
|
||||
vipOrder.setUsercode(user.getUsercode());
|
||||
vipOrder.setVipId(vipPrice.getId());
|
||||
vipOrder.setVipType(vipPrice.getVipType());
|
||||
vipOrder.setVipTime(vipPrice.getVipTime());
|
||||
vipOrder.setVipPrice(vipPrice.getVipPrice());
|
||||
vipOrder.setOrderNo(orderNo);
|
||||
vipOrder.setOrderName(vipPrice.getVipName());
|
||||
vipOrder.setPayStatus(PayStatusEnum.READY_PAY.getCode());
|
||||
this.save(vipOrder);
|
||||
return vipOrder;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,11 +1,19 @@
|
||||
package com.ruoyi.xq.service.impl;
|
||||
|
||||
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
||||
import com.ruoyi.common.core.domain.PageQuery;
|
||||
import com.ruoyi.common.exception.ServiceException;
|
||||
import com.ruoyi.xq.domain.WithdrawSetting;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListAppVo;
|
||||
import com.ruoyi.xq.dto.app.withdraw.WithdrawListPageQuery;
|
||||
import com.ruoyi.xq.mapper.WithdrawSettingMapper;
|
||||
import com.ruoyi.xq.service.UserExtendService;
|
||||
import com.ruoyi.xq.service.WithdrawSettingService;
|
||||
import lombok.RequiredArgsConstructor;
|
||||
import org.springframework.beans.factory.annotation.Autowired;
|
||||
import org.springframework.stereotype.Service;
|
||||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
/**
|
||||
* 提现配置Service业务层处理
|
||||
|
||||
Reference in New Issue
Block a user