| | |
| | | package cc.mrbird.febs.dapp.service.impl; |
| | | |
| | | import cc.mrbird.febs.common.configure.i18n.MessageSourceUtils; |
| | | import cc.mrbird.febs.common.contants.AppContants; |
| | | import cc.mrbird.febs.common.entity.FebsResponse; |
| | | import cc.mrbird.febs.common.entity.QueryRequest; |
| | |
| | | import cc.mrbird.febs.dapp.contract.andao.AndaoContractMain; |
| | | import cc.mrbird.febs.dapp.dto.*; |
| | | import cc.mrbird.febs.dapp.entity.*; |
| | | import cc.mrbird.febs.dapp.enumerate.DataDictionaryEnum; |
| | | import cc.mrbird.febs.dapp.enumerate.FundFlowEnum; |
| | | import cc.mrbird.febs.dapp.enumerate.MemberLevelEnum; |
| | | import cc.mrbird.febs.dapp.enumerate.PoolEnum; |
| | | import cc.mrbird.febs.dapp.enumerate.*; |
| | | import cc.mrbird.febs.dapp.mapper.*; |
| | | import cc.mrbird.febs.dapp.service.DappMemberService; |
| | | import cc.mrbird.febs.dapp.vo.*; |
| | | import cc.mrbird.febs.rabbit.producer.ChainProducer; |
| | | import cc.mrbird.febs.system.entity.User; |
| | | import cn.hutool.core.collection.CollUtil; |
| | | import cn.hutool.core.date.DateTime; |
| | | import cn.hutool.core.date.DateUtil; |
| | | import cn.hutool.core.util.ObjectUtil; |
| | | import cn.hutool.core.util.StrUtil; |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; |
| | | import com.baomidou.mybatisplus.core.metadata.IPage; |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import lombok.RequiredArgsConstructor; |
| | | import org.apache.commons.lang3.StringUtils; |
| | | import org.jsoup.helper.DataUtil; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | import org.web3j.utils.Strings; |
| | | |
| | | import java.math.BigDecimal; |
| | | import java.math.BigInteger; |
| | | import java.util.*; |
| | | import java.util.stream.Collectors; |
| | | |
| | |
| | | private final DappMemberNodeMapper dappMemberNodeMapper; |
| | | private final DappAKlineMapper dappAKlineMapper; |
| | | private final DappUsdtPerkEntityMapper dappUsdtPerkEntityMapper; |
| | | private final MallGoodsMapper mallGoodsMapper; |
| | | private final MallOrderInfoMapper mallOrderInfoMapper; |
| | | private final MallOrderItemMapper mallOrderItemMapper; |
| | | private final MallAchieveRecordMapper mallAchieveRecordMapper; |
| | | private final DappAccountMoneyChangeDao dappAccountMoneyChangeDao; |
| | | private final MallAddressInfoMapper mallAddressInfoMapper; |
| | | private final MallGoodsCategoryMapper mallGoodsCategoryMapper; |
| | | private final PlatformBannerMapper platformBannerMapper; |
| | | private final MallGoodsImagesMapper goodsImagesMapper; |
| | | |
| | | @Override |
| | | @Transactional(rollbackFor = Exception.class) |
| | |
| | | |
| | | if (member == null) { |
| | | String referenceID = null; |
| | | int nodeType = 0; |
| | | // |
| | | if (!"asdf4321".equals(connectDto.getInviteId())) { |
| | | // DappMemberEntity parent = dappMemberDao.selectMemberInfoByInviteId(connectDto.getInviteId()); |
| | | DappMemberEntity parent = dappMemberDao.selectByAddress(connectDto.getInviteId(), null); |
| | | DappMemberEntity parent = dappMemberDao.selectMemberInfoByInviteId(connectDto.getInviteId()); |
| | | if (parent == null) { |
| | | throw new FebsException("recommender is not exist"); |
| | | } |
| | | referenceID = parent.getInviteId(); |
| | | |
| | | // List<DappMemberEntity> child = dappMemberDao.selectChildMemberDirectOrNot(connectDto.getInviteId(), 1, null); |
| | | // if (child.size() == 6) { |
| | | // throw new FebsException("Invite Code is Invalid"); |
| | | // } |
| | | } else { |
| | | connectDto.setInviteId(null); |
| | | } |
| | | member = insertMember(connectDto.getAddress(), referenceID); |
| | | //升级用户的代理等级 |
| | | // DappMemberEntity dappMemberEntity = dappMemberDao.selectMemberInfoByInviteId(connectDto.getInviteId()); |
| | | // chainProducer.sendAgentUpMsg(dappMemberEntity.getId()); |
| | | member = insertMember(connectDto.getAddress(), referenceID,nodeType); |
| | | } |
| | | |
| | | String key = LoginUserUtil.getLoginKey(connectDto.getAddress(), connectDto.getNonce(), connectDto.getSign()); |
| | |
| | | member.setCurrentUser(currentUser.getUserId()); |
| | | } |
| | | IPage<DappMemberEntity> dappMemberEntityIPage = dappMemberDao.selectInPage(member, page); |
| | | List<DappMemberEntity> records = dappMemberEntityIPage.getRecords(); |
| | | if(CollUtil.isNotEmpty(records)){ |
| | | for(DappMemberEntity memberEntity : records){ |
| | | Long memberId = memberEntity.getId(); |
| | | //直推收益 |
| | | BigDecimal directProfit = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId,3,2); |
| | | memberEntity.setDirectProfit(directProfit); |
| | | //购买节点数量 |
| | | List<DappMemberNodeVo> dappMemberNodeVos = dappMemberNodeMapper.selectListByMemberId(memberId); |
| | | memberEntity.setMemberNodeCnt(CollUtil.isEmpty(dappMemberNodeVos) ? 0 : dappMemberNodeVos.size()); |
| | | |
| | | BigDecimal memberNodeSumPrice = BigDecimal.ZERO; |
| | | if(CollUtil.isNotEmpty(dappMemberNodeVos)){ |
| | | for(DappMemberNodeVo dappMemberNodeVo : dappMemberNodeVos){ |
| | | BigDecimal nodePrice = dappMemberNodeVo.getNodePrice(); |
| | | memberNodeSumPrice = memberNodeSumPrice.add(nodePrice); |
| | | } |
| | | } |
| | | memberEntity.setMemberNodeSumPrice(memberNodeSumPrice.setScale(8,BigDecimal.ROUND_DOWN)); |
| | | } |
| | | } |
| | | // List<DappMemberEntity> records = dappMemberEntityIPage.getRecords(); |
| | | // if(CollUtil.isNotEmpty(records)){ |
| | | // for(DappMemberEntity memberEntity : records){ |
| | | // Long memberId = memberEntity.getId(); |
| | | // DappWalletCoinEntity dappWalletCoinEntity = dappWalletCoinDao.selectByMemberId(memberId); |
| | | // memberEntity.setCoinAmount(ObjectUtil.isEmpty(dappWalletCoinEntity) ? BigDecimal.ZERO : dappWalletCoinEntity.getAvailableAmount()); |
| | | // |
| | | // DappWalletMineEntity dappWalletMineEntity = dappWalletMineDao.selectByMemberId(memberId); |
| | | // memberEntity.setScoreAmount(ObjectUtil.isEmpty(dappWalletMineEntity) ? BigDecimal.ZERO : dappWalletMineEntity.getAvailableAmount()); |
| | | // } |
| | | // } |
| | | return dappMemberEntityIPage; |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | @Override |
| | | public DappMemberEntity insertMember(String address, String refererId) { |
| | | public DappMemberEntity insertMember(String address, String refererId,int nodeType) { |
| | | |
| | | return insertMember(address, refererId, "BSC", DataDictionaryEnum.MEMBER.getCode()); |
| | | return insertMember(address, refererId, "BSC", MemberLevelEnum.MEMBER.getType(),nodeType); |
| | | } |
| | | |
| | | @Override |
| | | public DappMemberEntity insertMember(String address, String refererId, String chainType, String accountType) { |
| | | public DappMemberEntity insertMember(String address, String refererId, String chainType, String accountType,int nodeType) { |
| | | DappMemberEntity member = new DappMemberEntity(); |
| | | member.setAddress(address); |
| | | member.setChainType(chainType); |
| | | member.setAccountType(accountType); |
| | | member.setActiveStatus(2); |
| | | member.setNodeType(nodeType); |
| | | |
| | | dappMemberDao.insert(member); |
| | | |
| | |
| | | // 若没有推荐人,则直接激活 |
| | | member.setActiveStatus(2); |
| | | } |
| | | |
| | | member.setInviteId(ShareCodeUtil.toSerialCode(member.getId())); |
| | | String inviteIdStr = ShareCodeUtil.toSerialCode(member.getId()); |
| | | member.setInviteId(inviteIdStr); |
| | | member.setInviteLeft(inviteIdStr+"L"); |
| | | member.setInviteRight(inviteIdStr+"R"); |
| | | member.setRefererId(refererId); |
| | | if (StrUtil.isNotBlank(refererId)) { |
| | | boolean flag = false; |
| | |
| | | |
| | | @Override |
| | | public TeamListVo findTeamList() { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | TeamListVo teamListVo = new TeamListVo(); |
| | | List<DappMemberEntity> childs = dappMemberDao.selectMemberInfoByRefererId(member.getInviteId()); |
| | | teamListVo.setDirectCnt(CollUtil.isEmpty(childs) ? 0 : childs.size()); |
| | | //团队业绩 |
| | | BigDecimal teamIncomeMax = BigDecimal.ZERO; |
| | | if(CollUtil.isNotEmpty(childs)){ |
| | | // 直推用户 |
| | | List<String> childsInviteIds = childs.stream().map(DappMemberEntity::getInviteId).collect(Collectors.toList()); |
| | | for(String inviteId : childsInviteIds){ |
| | | BigDecimal totalIncomeMember = dappMemberDao.selectAllAchieveByInviteId(inviteId); |
| | | teamIncomeMax = teamIncomeMax.add(totalIncomeMember); |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | DappMemberEntity dappMemberEntity = this.baseMapper.selectById(memberId); |
| | | |
| | | TeamListVo myTeamVo = new TeamListVo(); |
| | | myTeamVo.setMyAchieve(mallAchieveRecordMapper.selectAchieveByMemberId(dappMemberEntity.getInviteId(), 1)); |
| | | myTeamVo.setMyTeamAchieve(mallAchieveRecordMapper.selectAchieveByMemberId(dappMemberEntity.getInviteId(), 2)); |
| | | List<DappMemberEntity> child = dappMemberDao.selectAllMemberInfoByRefererId(dappMemberEntity.getInviteId()); |
| | | myTeamVo.setMyTeamCnt(CollUtil.isEmpty(child) ? 0 : child.size()); |
| | | |
| | | List<TeamChildListVo> list = mallAchieveRecordMapper.selectTeamListByInviteId(dappMemberEntity.getInviteId()); |
| | | if(CollUtil.isNotEmpty(list)){ |
| | | for(TeamChildListVo teamChildListVo : list){ |
| | | List<DappMemberEntity> childDirect = dappMemberDao.selectAllMemberInfoByRefererId(teamChildListVo.getInviteId()); |
| | | teamChildListVo.setCnt(CollUtil.isEmpty(childDirect) ? 0 : childDirect.size()); |
| | | List<MallAchieveRecord> memberAchieveList = mallAchieveRecordMapper.selectCountByInvitedId(teamChildListVo.getInviteId(), 1); |
| | | if(CollUtil.isEmpty(memberAchieveList)){ |
| | | teamChildListVo.setAchieveState(2); |
| | | }else{ |
| | | teamChildListVo.setAchieveState(1); |
| | | } |
| | | List<MallAchieveRecord> mallAchieveRecords = mallAchieveRecordMapper.selectCountByInvitedId(teamChildListVo.getInviteId(), 2); |
| | | if(CollUtil.isEmpty(mallAchieveRecords)){ |
| | | teamChildListVo.setRealAchieve(BigDecimal.ZERO); |
| | | teamChildListVo.setOrderCnt(0); |
| | | }else{ |
| | | BigDecimal reduce = mallAchieveRecords.stream().map(MallAchieveRecord::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | teamChildListVo.setRealAchieve(reduce); |
| | | teamChildListVo.setOrderCnt(mallAchieveRecords.size()); |
| | | } |
| | | } |
| | | teamIncomeMax = teamIncomeMax.setScale(4,BigDecimal.ROUND_DOWN); |
| | | myTeamVo.setTeam(list); |
| | | } |
| | | teamListVo.setAchieve(teamIncomeMax); |
| | | return teamListVo; |
| | | return myTeamVo; |
| | | } |
| | | |
| | | @Override |
| | | public void setSystemFee(AdminSystemFeeVo adminSystemFeeVo) { |
| | | String rebatePercent = adminSystemFeeVo.getRebatePercent(); |
| | | DataDictionaryCustom rebateDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.REBATE_PERCENT.getType(), DataDictionaryEnum.REBATE_PERCENT.getCode()); |
| | | rebateDic.setValue(rebatePercent); |
| | | dataDictionaryCustomMapper.updateById(rebateDic); |
| | | |
| | | String serviceFee = adminSystemFeeVo.getServiceFee(); |
| | | DataDictionaryCustom serviceFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getType(), DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getCode()); |
| | | serviceFeeDic.setValue(serviceFee); |
| | | dataDictionaryCustomMapper.updateById(serviceFeeDic); |
| | | |
| | | String memberFee = adminSystemFeeVo.getMemberFee(); |
| | | DataDictionaryCustom memberFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.MEMBER_FEE.getType(), DataDictionaryEnum.MEMBER_FEE.getCode()); |
| | | memberFeeDic.setValue(memberFee); |
| | | dataDictionaryCustomMapper.updateById(memberFeeDic); |
| | | |
| | | String symbolPrice = adminSystemFeeVo.getSymbolPrice(); |
| | | DataDictionaryCustom symbolPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SYMBOL_PRICE.getType(), DataDictionaryEnum.SYMBOL_PRICE.getCode()); |
| | | symbolPriceDic.setValue(symbolPrice); |
| | | dataDictionaryCustomMapper.updateById(symbolPriceDic); |
| | | |
| | | String directProfit = adminSystemFeeVo.getDirectProfit(); |
| | | DataDictionaryCustom directProfitDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.DIRECT_PROFIT.getType(), DataDictionaryEnum.DIRECT_PROFIT.getCode()); |
| | | directProfitDic.setValue(directProfit); |
| | | dataDictionaryCustomMapper.updateById(directProfitDic); |
| | | // String rebatePercent = adminSystemFeeVo.getRebatePercent(); |
| | | // DataDictionaryCustom rebateDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.REBATE_PERCENT.getType(), DataDictionaryEnum.REBATE_PERCENT.getCode()); |
| | | // rebateDic.setValue(rebatePercent); |
| | | // dataDictionaryCustomMapper.updateById(rebateDic); |
| | | // |
| | | // String serviceFee = adminSystemFeeVo.getServiceFee(); |
| | | // DataDictionaryCustom serviceFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getType(), DataDictionaryEnum.WITHDRAW_SERVICE_FEE.getCode()); |
| | | // serviceFeeDic.setValue(serviceFee); |
| | | // dataDictionaryCustomMapper.updateById(serviceFeeDic); |
| | | // |
| | | // String memberFee = adminSystemFeeVo.getMemberFee(); |
| | | // DataDictionaryCustom memberFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.MEMBER_FEE.getType(), DataDictionaryEnum.MEMBER_FEE.getCode()); |
| | | // memberFeeDic.setValue(memberFee); |
| | | // dataDictionaryCustomMapper.updateById(memberFeeDic); |
| | | // |
| | | // String symbolPrice = adminSystemFeeVo.getSymbolPrice(); |
| | | // DataDictionaryCustom symbolPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.SYMBOL_PRICE.getType(), DataDictionaryEnum.SYMBOL_PRICE.getCode()); |
| | | // symbolPriceDic.setValue(symbolPrice); |
| | | // dataDictionaryCustomMapper.updateById(symbolPriceDic); |
| | | // |
| | | // String directProfit = adminSystemFeeVo.getDirectProfit(); |
| | | // DataDictionaryCustom directProfitDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | // DataDictionaryEnum.DIRECT_PROFIT.getType(), DataDictionaryEnum.DIRECT_PROFIT.getCode()); |
| | | // directProfitDic.setValue(directProfit); |
| | | // dataDictionaryCustomMapper.updateById(directProfitDic); |
| | | } |
| | | |
| | | @Override |
| | | public ApiRunListInfoVo findRunListInfo() { |
| | | ApiRunListInfoVo apiRunListInfoVo = new ApiRunListInfoVo(); |
| | | //获取当前是第几轮队列 |
| | | String redisKey = "QUEUE_COUNT"; |
| | | String memberOutCount = redisUtils.getString(redisKey); |
| | | DataDictionaryCustom queueCountSet = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.QUEUE_COUNT.getType(), DataDictionaryEnum.QUEUE_COUNT.getCode()); |
| | | String queueCount = queueCountSet.getValue(); |
| | | if(StrUtil.isBlank(memberOutCount)|| !queueCount.equals(memberOutCount)){ |
| | | redisUtils.set(redisKey,queueCount,0L); |
| | | memberOutCount = queueCount; |
| | | } |
| | | //出局条件的人数 |
| | | /** |
| | | * 初始大小 5+4*0 |
| | | * 1 1,2,3,4,5 1出局 5+4*0 |
| | | * 2 2,3,4,5,1(复投),7,8,9,10 2出局 5+4*1 |
| | | * 3 3,4,5,1(复投),7,8,9,10,2(复投),12,13,14,15 3出局 5+4*2 |
| | | * 4 4,5,1(复投),7,8,9,10,2(复投),12,13,14,15,3(复投),17,18,19,20 4出局 5+4*3 |
| | | */ |
| | | Integer memberCount = Integer.parseInt(memberOutCount) * 4 + 5; |
| | | //判断当前是否符合出局条件 |
| | | QueryWrapper<DappSystemProfit> objectQueryWrapper = new QueryWrapper<>(); |
| | | objectQueryWrapper.eq("state",DappSystemProfit.STATE_IN); |
| | | //实际投资人数 |
| | | Integer selectCount = dappSystemProfitDao.selectCount(objectQueryWrapper); |
| | | int runPercentNum = memberCount - selectCount; |
| | | runPercentNum = 5-runPercentNum > 0 ? 5-runPercentNum : 1; |
| | | apiRunListInfoVo.setRunPercent(new BigDecimal(runPercentNum).multiply(new BigDecimal(0.4)).setScale(BigDecimal.ROUND_DOWN,1)); |
| | | // BigDecimal runPercent = new BigDecimal(selectCount).divide(new BigDecimal(memberCount), 2, BigDecimal.ROUND_DOWN).multiply(new BigDecimal(100)); |
| | | // apiRunListInfoVo.setRunPercent(runPercent); |
| | | //实际投资人数小于出局条件人数 |
| | | //符合则出局 实际投资人数等于出局条件人数 |
| | | DappSystemProfit dappSystemProfitIn = dappSystemProfitDao.selectSystemProfitInByState(DappSystemProfit.STATE_IN); |
| | | apiRunListInfoVo.setLuckyMemberNext(ObjectUtil.isEmpty(dappSystemProfitIn) ? 0L : dappSystemProfitIn.getId()); |
| | | DappSystemProfit dappSystemProfitOut = dappSystemProfitDao.selectSystemProfitOutByState(DappSystemProfit.STATE_OUT); |
| | | apiRunListInfoVo.setLuckyMember(ObjectUtil.isEmpty(dappSystemProfitOut) ? 0L : dappSystemProfitOut.getId()); |
| | | // //获取当前是第几轮队列 |
| | | // String redisKey = "QUEUE_COUNT"; |
| | | // String memberOutCount = redisUtils.getString(redisKey); |
| | | // DataDictionaryCustom queueCountSet = dataDictionaryCustomMapper.selectDicDataByTypeAndCode(DataDictionaryEnum.QUEUE_COUNT.getType(), DataDictionaryEnum.QUEUE_COUNT.getCode()); |
| | | // String queueCount = queueCountSet.getValue(); |
| | | // if(StrUtil.isBlank(memberOutCount)|| !queueCount.equals(memberOutCount)){ |
| | | // redisUtils.set(redisKey,queueCount,0L); |
| | | // memberOutCount = queueCount; |
| | | // } |
| | | // //出局条件的人数 |
| | | // /** |
| | | // * 初始大小 5+4*0 |
| | | // * 1 1,2,3,4,5 1出局 5+4*0 |
| | | // * 2 2,3,4,5,1(复投),7,8,9,10 2出局 5+4*1 |
| | | // * 3 3,4,5,1(复投),7,8,9,10,2(复投),12,13,14,15 3出局 5+4*2 |
| | | // * 4 4,5,1(复投),7,8,9,10,2(复投),12,13,14,15,3(复投),17,18,19,20 4出局 5+4*3 |
| | | // */ |
| | | // Integer memberCount = Integer.parseInt(memberOutCount) * 4 + 5; |
| | | // //判断当前是否符合出局条件 |
| | | // QueryWrapper<DappSystemProfit> objectQueryWrapper = new QueryWrapper<>(); |
| | | // objectQueryWrapper.eq("state",DappSystemProfit.STATE_IN); |
| | | // //实际投资人数 |
| | | // Integer selectCount = dappSystemProfitDao.selectCount(objectQueryWrapper); |
| | | // int runPercentNum = memberCount - selectCount; |
| | | // runPercentNum = 5-runPercentNum > 0 ? 5-runPercentNum : 1; |
| | | // apiRunListInfoVo.setRunPercent(new BigDecimal(runPercentNum).multiply(new BigDecimal(0.4)).setScale(BigDecimal.ROUND_DOWN,1)); |
| | | //// BigDecimal runPercent = new BigDecimal(selectCount).divide(new BigDecimal(memberCount), 2, BigDecimal.ROUND_DOWN).multiply(new BigDecimal(100)); |
| | | //// apiRunListInfoVo.setRunPercent(runPercent); |
| | | // //实际投资人数小于出局条件人数 |
| | | // //符合则出局 实际投资人数等于出局条件人数 |
| | | // DappSystemProfit dappSystemProfitIn = dappSystemProfitDao.selectSystemProfitInByState(DappSystemProfit.STATE_IN); |
| | | // apiRunListInfoVo.setLuckyMemberNext(ObjectUtil.isEmpty(dappSystemProfitIn) ? 0L : dappSystemProfitIn.getId()); |
| | | // DappSystemProfit dappSystemProfitOut = dappSystemProfitDao.selectSystemProfitOutByState(DappSystemProfit.STATE_OUT); |
| | | // apiRunListInfoVo.setLuckyMember(ObjectUtil.isEmpty(dappSystemProfitOut) ? 0L : dappSystemProfitOut.getId()); |
| | | return apiRunListInfoVo; |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse getNodeInfo() { |
| | | List<DappNodeOrderVo> dappNodeOrderVos = dappNodeOrderMapper.selectNodeOrderList(); |
| | | return new FebsResponse().success().data(dappNodeOrderVos); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse getMemberNode() { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | List<DappMemberNodeVo> dappMemberNodeVos = dappMemberNodeMapper.selectListByMemberId(member.getId()); |
| | | return new FebsResponse().success().data(dappMemberNodeVos); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse getMemberInfo() { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | DappMemberInfoVo dappMemberInfoVo = dappMemberDao.selectByMemberId(member.getId()); |
| | |
| | | dappMemberInfoVo.setAccountType(levelDescription); |
| | | } |
| | | |
| | | BigDecimal amountPerkTotal = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(member.getId(), |
| | | FundFlowEnum.MEMBER_AMOUNT_PERK_TOTAL.getCode(), 2); |
| | | dappMemberInfoVo.setAmountPerkTotal(amountPerkTotal); |
| | | DappWalletCoinEntity dappWalletCoinEntity = dappWalletCoinDao.selectByMemberId(member.getId()); |
| | | dappMemberInfoVo.setAmount(ObjectUtil.isEmpty(dappWalletCoinEntity) ? BigDecimal.ZERO : dappWalletCoinEntity.getTotalAmount()); |
| | | |
| | | DataDictionaryCustom ausdPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.TRANSFER_A_AUSD_PERCENT.getType(), |
| | | PoolEnum.TRANSFER_A_AUSD_PERCENT.getCode() |
| | | ); |
| | | BigDecimal ausdPercent = new BigDecimal(ausdPercentDic.getValue()); |
| | | dappMemberInfoVo.setAusdtFee(ausdPercent); |
| | | |
| | | DataDictionaryCustom aroundFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.ANDAO_MEMBER_TO_MENBER_PERCENT.getType(), |
| | | PoolEnum.ANDAO_MEMBER_TO_MENBER_PERCENT.getCode() |
| | | ); |
| | | BigDecimal aroundFee = new BigDecimal(aroundFeeDic.getValue()); |
| | | dappMemberInfoVo.setAroundFee(aroundFee); |
| | | //ausd价格 |
| | | DataDictionaryCustom ausdPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.TRANSFER_A_AUSD_PRICE.getType(), |
| | | PoolEnum.TRANSFER_A_AUSD_PRICE.getCode() |
| | | ); |
| | | dappMemberInfoVo.setAusdPrice(ObjectUtil.isEmpty(ausdPriceDic) ? new BigDecimal("1") : new BigDecimal(ausdPriceDic.getValue()).setScale(4,BigDecimal.ROUND_DOWN)); |
| | | //资产到闪兑的手续费比例 |
| | | DataDictionaryCustom mineToCoinFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.WALLET_MINE_TO_COIN_PERCENT.getType(), |
| | | PoolEnum.WALLET_MINE_TO_COIN_PERCENT.getCode() |
| | | ); |
| | | dappMemberInfoVo.setMineToCoinFee(ObjectUtil.isEmpty(mineToCoinFeeDic) ? new BigDecimal("0.03") : new BigDecimal(mineToCoinFeeDic.getValue())); |
| | | //提现手续费比例 |
| | | DataDictionaryCustom coinOutFeeDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.WALLET_COIN_TO_USDT_PERCENT.getType(), |
| | | PoolEnum.WALLET_COIN_TO_USDT_PERCENT.getCode() |
| | | ); |
| | | dappMemberInfoVo.setCoinOutFee(ObjectUtil.isEmpty(coinOutFeeDic) ? new BigDecimal("0.01") : new BigDecimal(coinOutFeeDic.getValue())); |
| | | //A币的价格 |
| | | DataDictionaryCustom coinAPriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.COIN_A_PRICE.getType(), |
| | | PoolEnum.COIN_A_PRICE.getCode() |
| | | ); |
| | | dappMemberInfoVo.setCoinAPrice((ObjectUtil.isEmpty(coinAPriceDic) ? new BigDecimal("1") : new BigDecimal(coinAPriceDic.getValue())) |
| | | .setScale(12,BigDecimal.ROUND_DOWN)); |
| | | |
| | | /** |
| | | * 今日涨幅 |
| | | */ |
| | | //最新的一条记录 |
| | | DappAKlineEntity dappAKlineNow = dappAKlineMapper.selectOneByType(); |
| | | BigDecimal closePriceNow = dappAKlineNow.getClosePrice(); |
| | | //拿日线的最后一条数据 |
| | | DappAKlineEntity dappAKlineStart = dappAKlineMapper.selectDayByType(); |
| | | BigDecimal closePriceStart = dappAKlineStart.getClosePrice(); |
| | | |
| | | BigDecimal subtract = closePriceNow.subtract(closePriceStart); |
| | | BigDecimal bigDecimal = subtract.divide(closePriceStart, 4, BigDecimal.ROUND_DOWN).multiply(new BigDecimal(100)).setScale(2, BigDecimal.ROUND_DOWN); |
| | | dappMemberInfoVo.setTodayIncrease(bigDecimal); |
| | | |
| | | /** |
| | | * 全网剩余ANDAO总量,燃烧ANDAO总量 |
| | | */ |
| | | DataDictionaryCustom coinACntDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | PoolEnum.COIN_A_CNT.getType(), |
| | | PoolEnum.COIN_A_CNT.getCode() |
| | | ); |
| | | dappMemberInfoVo.setAndaoNum( |
| | | ObjectUtil.isEmpty(coinACntDic) ? |
| | | new BigDecimal("0") : |
| | | new BigDecimal(coinACntDic.getValue()).setScale(2,BigDecimal.ROUND_DOWN) |
| | | ); |
| | | |
| | | BigDecimal bigDecimal1 = dappFundFlowDao.selectSumAmountByType(FundFlowEnum.A_COIN_FIRE.getCode()); |
| | | dappMemberInfoVo.setFireAndaoNum(bigDecimal1.setScale(2,BigDecimal.ROUND_DOWN)); |
| | | |
| | | DappWalletMineEntity dappWalletMineEntity = dappWalletMineDao.selectByMemberId(member.getId()); |
| | | dappMemberInfoVo.setScore(ObjectUtil.isEmpty(dappWalletMineEntity) ? BigDecimal.ZERO : dappWalletMineEntity.getTotalAmount()); |
| | | Integer waitPayCnt = dappMemberDao.selectOrderCntByMemberIdAndStatus(member.getId(),1); |
| | | Integer payCnt = dappMemberDao.selectOrderCntByMemberIdAndStatus(member.getId(),2); |
| | | Integer cancelCnt = dappMemberDao.selectOrderCntByMemberIdAndStatus(member.getId(),3); |
| | | dappMemberInfoVo.setWaitPayCnt(waitPayCnt); |
| | | dappMemberInfoVo.setPayCnt(payCnt); |
| | | dappMemberInfoVo.setCancelCnt(cancelCnt); |
| | | return new FebsResponse().success().data(dappMemberInfoVo); |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | @Override |
| | | public String aKLine(AKLineDto aKLineDto) { |
| | | int type = aKLineDto.getType(); |
| | | String redisKey = null; |
| | | if(1 == type){ |
| | | redisKey = AppContants.K_LINE_HOUR; |
| | | }else if(2 == type){ |
| | | redisKey = AppContants.K_LINE_DAY; |
| | | }else if(3 == type){ |
| | | redisKey = AppContants.K_LINE_WEEK; |
| | | }else if(4 == type){ |
| | | redisKey = AppContants.K_LINE_MONTH; |
| | | }else{ |
| | | redisKey = AppContants.K_LINE_NOW; |
| | | } |
| | | Object o = redisUtils.get(redisKey); |
| | | if(ObjectUtil.isNotEmpty(o)){ |
| | | return redisUtils.get(redisKey).toString(); |
| | | } |
| | | return null; |
| | | } |
| | | |
| | | @Override |
| | | public MyInviteInfoVo findInviteInfo() { |
| | | MyInviteInfoVo myInviteInfoVo = new MyInviteInfoVo(); |
| | | |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | Long memberId = member.getId(); |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); |
| | | myInviteInfoVo.setMemberAddress(dappMemberEntity.getAddress()); |
| | | DappUsdtPerkEntity dappUsdtPerkEntity = dappUsdtPerkEntityMapper.selectByMemberId(memberId); |
| | | if(ObjectUtil.isEmpty(dappUsdtPerkEntity)){ |
| | | dappUsdtPerkEntity = new DappUsdtPerkEntity(); |
| | | dappUsdtPerkEntity.setMemberId(memberId); |
| | | dappUsdtPerkEntityMapper.insert(dappUsdtPerkEntity); |
| | | } |
| | | myInviteInfoVo.setMemberAchieve(dappUsdtPerkEntity.getAchieveAmount()); |
| | | String refererId = dappMemberEntity.getRefererId(); |
| | | DappMemberEntity parentMember = dappMemberDao.selectMemberInfoByInviteId(refererId); |
| | | myInviteInfoVo.setReferenceAddress(ObjectUtil.isEmpty(parentMember) ? "-" : parentMember.getAddress()); |
| | | HashMap<String, BigDecimal> maxMinAchieve = getMaxMinAchieve(memberId); |
| | | myInviteInfoVo.setMaxAchieve(maxMinAchieve.get(AppContants.MAXACHIEVE)); |
| | | myInviteInfoVo.setMinAchieve(maxMinAchieve.get(AppContants.MINACHIEVE)); |
| | | |
| | | List<MyInviteChildInfoVo> myInviteChildInfoVos = new ArrayList<>(); |
| | | List<DappMemberEntity> childs = dappMemberDao.selectMemberInfoByRefererId(member.getInviteId()); |
| | | if(CollUtil.isNotEmpty(childs)){ |
| | | for(DappMemberEntity child : childs){ |
| | | MyInviteChildInfoVo myInviteChildInfoVo = new MyInviteChildInfoVo(); |
| | | myInviteChildInfoVo.setAddress(child.getAddress()); |
| | | myInviteChildInfoVo.setAccountType(child.getAccountType()); |
| | | DappUsdtPerkEntity childUsdtPerkEntity = dappUsdtPerkEntityMapper.selectByMemberId(child.getId()); |
| | | // BigDecimal achieveAmountByMemberId = dappUsdtPerkEntityMapper.selectAchieveAmountByMemberId(child.getId()); |
| | | if(ObjectUtil.isEmpty(childUsdtPerkEntity)){ |
| | | childUsdtPerkEntity = new DappUsdtPerkEntity(); |
| | | childUsdtPerkEntity.setMemberId(child.getId()); |
| | | dappUsdtPerkEntityMapper.insert(childUsdtPerkEntity); |
| | | } |
| | | |
| | | myInviteChildInfoVo.setMemberAchieve(ObjectUtil.isEmpty(childUsdtPerkEntity.getAchieveAmount()) ? BigDecimal.ZERO : childUsdtPerkEntity.getAchieveAmount()); |
| | | HashMap<String, BigDecimal> childMaxMinAchieve = getMaxMinAchieve(child.getId()); |
| | | myInviteChildInfoVo.setMaxAchieve(childMaxMinAchieve.get(AppContants.MAXACHIEVE)); |
| | | myInviteChildInfoVo.setMinAchieve(childMaxMinAchieve.get(AppContants.MINACHIEVE)); |
| | | myInviteChildInfoVos.add(myInviteChildInfoVo); |
| | | } |
| | | } |
| | | |
| | | myInviteInfoVo.setMyInviteChildInfoVos(myInviteChildInfoVos); |
| | | return myInviteInfoVo; |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse getFundFlowInfo() { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | Long memberId = member.getId(); |
| | | FundFlowInfoVo fundFlowInfoVo = new FundFlowInfoVo(); |
| | | BigDecimal myDonateCnt = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(member.getId(), |
| | | FundFlowEnum.BUY_A_COIN.getCode(), 2); |
| | | fundFlowInfoVo.setMyDonateCnt(myDonateCnt.abs()); |
| | | fundFlowInfoVo.setMyDonateCntNum(FundFlowEnum.BUY_A_COIN.getCode()); |
| | | |
| | | BigDecimal amountPerkTotal = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(member.getId(), |
| | | FundFlowEnum.MEMBER_AMOUNT_PERK_TOTAL.getCode(), 2); |
| | | fundFlowInfoVo.setAmountPerkTotal(amountPerkTotal.abs()); |
| | | fundFlowInfoVo.setAmountPerkTotalNum(FundFlowEnum.MEMBER_AMOUNT_PERK_TOTAL.getCode()); |
| | | |
| | | DappUsdtPerkEntity dappUsdtPerkEntity = dappUsdtPerkEntityMapper.selectByMemberId(memberId); |
| | | fundFlowInfoVo.setAmountPerkAva(ObjectUtil.isEmpty(dappUsdtPerkEntity) ? BigDecimal.ZERO : dappUsdtPerkEntity.getAmount()); |
| | | |
| | | BigDecimal directAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.DIRECT_A_PERCENT.getCode(), 2); |
| | | fundFlowInfoVo.setDirectAmount(directAmount); |
| | | fundFlowInfoVo.setDirectAmountNum(FundFlowEnum.DIRECT_A_PERCENT.getCode()); |
| | | |
| | | BigDecimal staticAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.POOL_MEMBER_A_CNT.getCode(), 2); |
| | | fundFlowInfoVo.setStaticAmount(staticAmount); |
| | | fundFlowInfoVo.setStaticAmountNum(FundFlowEnum.POOL_MEMBER_A_CNT.getCode()); |
| | | |
| | | BigDecimal nodeAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.NODE_A_PERCENT_TO_MEMBER.getCode(), 2); |
| | | fundFlowInfoVo.setNodeAmount(nodeAmount); |
| | | fundFlowInfoVo.setNodeAmountNum(FundFlowEnum.NODE_A_PERCENT_TO_MEMBER.getCode()); |
| | | |
| | | BigDecimal levelEqualAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.DAO_5_NODE_EQUALS_PERK.getCode(), 2); |
| | | fundFlowInfoVo.setLevelEqualAmount(levelEqualAmount); |
| | | fundFlowInfoVo.setLevelEqualAmountNum(FundFlowEnum.DAO_5_NODE_EQUALS_PERK.getCode()); |
| | | |
| | | BigDecimal levelAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.LEVEL_A_PERCENT_CNT_MEMBER.getCode(), 2); |
| | | fundFlowInfoVo.setLevelAmount(levelAmount); |
| | | fundFlowInfoVo.setLevelAmountNum(FundFlowEnum.LEVEL_A_PERCENT_CNT_MEMBER.getCode()); |
| | | |
| | | BigDecimal daoThreeAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.DAO_3_NODE_PERK.getCode(), 2); |
| | | fundFlowInfoVo.setDaoThreeAmount(daoThreeAmount); |
| | | fundFlowInfoVo.setDaoThreeAmountNum(FundFlowEnum.DAO_3_NODE_PERK.getCode()); |
| | | |
| | | BigDecimal daoFourAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.DAO_4_NODE_PERK.getCode(), 2); |
| | | fundFlowInfoVo.setDaoFourAmount(daoFourAmount); |
| | | fundFlowInfoVo.setDaoFourAmountNum(FundFlowEnum.DAO_4_NODE_PERK.getCode()); |
| | | |
| | | BigDecimal daoFiveAmount = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, |
| | | FundFlowEnum.DAO_5_NODE_PERK.getCode(), 2); |
| | | fundFlowInfoVo.setDaoFiveAmount(daoFiveAmount); |
| | | fundFlowInfoVo.setDaoFiveAmountNum(FundFlowEnum.DAO_5_NODE_PERK.getCode()); |
| | | |
| | | return new FebsResponse().success().data(fundFlowInfoVo); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse insideWithYes(Long id) { |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(id); |
| | | if(ObjectUtil.isEmpty(dappMemberEntity)) { |
| | | return new FebsResponse().fail().message("会员信息不存在"); |
| | | } |
| | | dappMemberEntity.setNodeType(1); |
| | | dappMemberEntity.setAccountType(MemberLevelEnum.NODE_5.getType()); |
| | | dappMemberEntity.setActiveStatus(1); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | return new FebsResponse().success(); |
| | | } |
| | |
| | | if(ObjectUtil.isEmpty(dappMemberEntity)) { |
| | | return new FebsResponse().fail().message("会员信息不存在"); |
| | | } |
| | | dappMemberEntity.setNodeType(2); |
| | | dappMemberEntity.setAccountType(MemberLevelEnum.MEMBER.getType()); |
| | | dappMemberEntity.setActiveStatus(2); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | return new FebsResponse().success(); |
| | | } |
| | |
| | | return new FebsResponse().success(); |
| | | } |
| | | |
| | | @Override |
| | | public IPage<MallGoodsListVo> findMallGoodsListInPage(MallGoodsQueryDto queryDto) { |
| | | Page<MallGoodsListVo> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize()); |
| | | return dappMemberDao.selectMallGoodsListQueryInPage(queryDto, page); |
| | | } |
| | | |
| | | @Override |
| | | public IPage<MallOrderListVo> findMallOrderListInPage(MallOrderQueryDto queryDto) { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | queryDto.setMemberId(member.getId()); |
| | | Page<MallOrderListVo> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize()); |
| | | return dappMemberDao.selectMallOrderListQueryInPage(queryDto, page); |
| | | } |
| | | |
| | | @Override |
| | | public MallOrderListVo findOrderDetailsById(Long id) { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | MallOrderListVo mallOrderListVo = dappMemberDao.selectMallOrderListVoById(id); |
| | | List<MallOrderItemVo> mallOrderItemVoList = dappMemberDao.selectMallOrderItemVoByOrderId(id); |
| | | mallOrderListVo.setItems(mallOrderItemVoList); |
| | | long addressId = ObjectUtil.isEmpty(mallOrderListVo.getAddressId()) ? 0L : mallOrderListVo.getAddressId(); |
| | | MallAddressInfo mallAddressInfo = mallAddressInfoMapper.selectById(addressId); |
| | | if(ObjectUtil.isNotEmpty(mallAddressInfo)){ |
| | | mallOrderListVo.setName(mallAddressInfo.getName()); |
| | | mallOrderListVo.setPhone(mallAddressInfo.getPhone()); |
| | | mallOrderListVo.setArea(mallAddressInfo.getArea()); |
| | | mallOrderListVo.setAddress(mallAddressInfo.getAddress()); |
| | | } |
| | | return mallOrderListVo; |
| | | } |
| | | |
| | | @Override |
| | | public MallGoodsListVo findGoodsDetailsById(Long id) { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | MallGoodsListVo mallGoodsListVo = dappMemberDao.selectMallGoodsListVoById(id); |
| | | |
| | | List<String> images = goodsImagesMapper.selectGoodsImagesByGoodsId(id); |
| | | mallGoodsListVo.setImages(images); |
| | | return mallGoodsListVo; |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public Long createOrder(AddOrderDto addOrderDto) { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | // DappMemberEntity member = dappMemberDao.selectById(1L); |
| | | /** |
| | | * 1、商品是否上架 |
| | | * 2、用户余额是否足够 |
| | | */ |
| | | MallGoods mallGoods = mallGoodsMapper.selectById(addOrderDto.getGoodsId()); |
| | | if(ObjectUtil.isEmpty(mallGoods)){ |
| | | throw new FebsException("商品不存在"); |
| | | } |
| | | if(MallGoods.ISSALE_STATUS_DISABLED == mallGoods.getIsSale()){ |
| | | throw new FebsException("商品已下架"); |
| | | } |
| | | DappWalletCoinEntity dappWalletCoinEntity = dappWalletCoinDao.selectByMemberId(member.getId()); |
| | | if(ObjectUtil.isEmpty(dappWalletCoinEntity)){ |
| | | throw new FebsException("余额不足"); |
| | | } |
| | | BigDecimal presentPrice = new BigDecimal(mallGoods.getPresentPrice()); |
| | | BigDecimal totalAmount = presentPrice.multiply(new BigDecimal(addOrderDto.getGoodsCnt())).setScale(2,BigDecimal.ROUND_DOWN); |
| | | if(BigDecimal.ZERO.compareTo(totalAmount) >= 0){ |
| | | throw new FebsException("商品异常"); |
| | | } |
| | | BigDecimal availableAmount = dappWalletCoinEntity.getAvailableAmount(); |
| | | if(totalAmount.compareTo(availableAmount) > 0){ |
| | | throw new FebsException("余额不足"); |
| | | } |
| | | /** |
| | | * 生成一条待支付的订单 |
| | | */ |
| | | |
| | | String orderNo = MallUtils.getOrderNum(); |
| | | MallOrderInfo mallOrderInfo = new MallOrderInfo(); |
| | | mallOrderInfo.setOrderNo(orderNo); |
| | | mallOrderInfo.setMemberId(member.getId()); |
| | | mallOrderInfo.setOrderTime(DateUtil.date()); |
| | | mallOrderInfo.setAmount(totalAmount); |
| | | mallOrderInfo.setStatus(MallOrderInfo.STATUS_WAIT); |
| | | mallOrderInfo.setDeliverType(addOrderDto.getDeliverType()); |
| | | mallOrderInfo.setAddressId(addOrderDto.getAddressId()); |
| | | // if(1 == addOrderDto.getDeliverType()){ |
| | | // mallOrderInfo.setAddressId(addOrderDto.getAddressId()); |
| | | // } |
| | | mallOrderInfo.setOrderType(1); |
| | | mallOrderInfoMapper.insert(mallOrderInfo); |
| | | MallOrderItem mallOrderItem = new MallOrderItem(); |
| | | mallOrderItem.setOrderId(mallOrderInfo.getId()); |
| | | mallOrderItem.setGoodsId(addOrderDto.getGoodsId()); |
| | | mallOrderItem.setGoodsName(mallGoods.getGoodsName()); |
| | | mallOrderItem.setCnt(addOrderDto.getGoodsCnt()); |
| | | mallOrderItem.setPrice(presentPrice); |
| | | mallOrderItem.setAmount(totalAmount); |
| | | mallOrderItemMapper.insert(mallOrderItem); |
| | | return mallOrderInfo.getId(); |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void cancelOrder(Long id) { |
| | | // DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | DappMemberEntity member = dappMemberDao.selectById(1L); |
| | | MallOrderInfo orderInfo = mallOrderInfoMapper.selectById(id); |
| | | if (ObjectUtil.isEmpty(orderInfo)) { |
| | | throw new FebsException("订单异常"); |
| | | } |
| | | |
| | | if (MallOrderInfo.STATUS_WAIT != orderInfo.getStatus()) { |
| | | throw new FebsException("只能取消待支付的订单"); |
| | | } |
| | | |
| | | orderInfo.setStatus(MallOrderInfo.STATUS_CANCEL); |
| | | orderInfo.setCancelType(MallOrderInfo.CANCEL_BY_SELF); |
| | | mallOrderInfoMapper.updateById(orderInfo); |
| | | } |
| | | |
| | | @Override |
| | | @Transactional |
| | | public void payOrder(Long id) { |
| | | DappMemberEntity member = LoginUserUtil.getAppUser(); |
| | | // DappMemberEntity member = dappMemberDao.selectById(1L); |
| | | MallOrderInfo orderInfo = mallOrderInfoMapper.selectById(id); |
| | | if (ObjectUtil.isEmpty(orderInfo)) { |
| | | throw new FebsException("订单异常"); |
| | | } |
| | | if (MallOrderInfo.STATUS_WAIT != orderInfo.getStatus()) { |
| | | throw new FebsException("只能支付待支付的订单"); |
| | | } |
| | | /** |
| | | * 限制用户的购买总量 |
| | | */ |
| | | //实际可购买数量 |
| | | BigDecimal achieveAva = BigDecimal.ZERO; |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(member.getId()); |
| | | String accountType = dappMemberEntity.getAccountType(); |
| | | //普通会员的购买上线 |
| | | if(MemberLevelEnum.MEMBER.getType().equals(accountType)){ |
| | | DataDictionaryCustom memberBuyMaxAmountDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.MEMBER_BUY_MAX_AMOUNT.getType(), |
| | | DataDictionaryEnum.MEMBER_BUY_MAX_AMOUNT.getCode() |
| | | ); |
| | | achieveAva = new BigDecimal(ObjectUtil.isEmpty(memberBuyMaxAmountDic) ? "1000" : memberBuyMaxAmountDic.getValue()); |
| | | }else{ |
| | | DataDictionaryCustom memberBuyMaxAmountDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | "TEAM_LEVEL",accountType |
| | | ); |
| | | if(ObjectUtil.isEmpty(memberBuyMaxAmountDic)){ |
| | | achieveAva = new BigDecimal("1000"); |
| | | }else{ |
| | | TeamLevelPerk adminAgentInfo = JSONObject.parseObject(memberBuyMaxAmountDic.getValue(), TeamLevelPerk.class); |
| | | BigDecimal buyMaxAmount = adminAgentInfo.getBuyMaxAmount(); |
| | | achieveAva = buyMaxAmount; |
| | | } |
| | | } |
| | | List<MallAchieveRecord> mallAchieveRecords = mallAchieveRecordMapper.selectListByMemberId(dappMemberEntity.getId()); |
| | | if(CollUtil.isNotEmpty(mallAchieveRecords)){ |
| | | BigDecimal reduce = mallAchieveRecords.stream().map(MallAchieveRecord::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add); |
| | | achieveAva = achieveAva.subtract(reduce); |
| | | } |
| | | if(BigDecimal.ZERO.compareTo(achieveAva) >= 0){ |
| | | throw new FebsException("用户无法购买"); |
| | | } |
| | | BigDecimal totalAmount = orderInfo.getAmount(); |
| | | if(achieveAva.compareTo(totalAmount) < 0){ |
| | | throw new FebsException("用户最多购买"+achieveAva.setScale(2,BigDecimal.ROUND_DOWN)+"USDT"); |
| | | } |
| | | |
| | | DappWalletCoinEntity dappWalletCoinEntity = dappWalletCoinDao.selectByMemberId(member.getId()); |
| | | BigDecimal availableAmount = dappWalletCoinEntity.getAvailableAmount(); |
| | | if(totalAmount.compareTo(availableAmount) > 0){ |
| | | throw new FebsException("余额不足"); |
| | | } |
| | | orderInfo.setPayTime(DateUtil.date()); |
| | | String payOrderNo = MallUtils.getOrderNum("PAY"); |
| | | orderInfo.setPayOrderNo(payOrderNo); |
| | | orderInfo.setPayMethod("余额支付"); |
| | | orderInfo.setPayResult(1); |
| | | orderInfo.setStatus(MallOrderInfo.STATUS_PAY); |
| | | orderInfo.setDeliverState(MallOrderInfo.DELIVER_STATUS_WAIT); |
| | | mallOrderInfoMapper.updateById(orderInfo); |
| | | /** |
| | | * 更新用户余额 |
| | | */ |
| | | dappWalletCoinDao.reduceTotalAndAvailableByMemberId(member.getId(),totalAmount); |
| | | DappFundFlowEntity donateScoreFlow = new DappFundFlowEntity( |
| | | AccountFlowEnum.AMOUNT.getCode(), |
| | | member.getId(), |
| | | totalAmount.negate(), |
| | | FundFlowEnum.PAY_ORDER.getCode(), |
| | | 2, |
| | | BigDecimal.ZERO, |
| | | payOrderNo, |
| | | id); |
| | | dappFundFlowDao.insert(donateScoreFlow); |
| | | |
| | | /** |
| | | * 支付成功,消费后成有效账户后可分享(有效用户可推广) |
| | | */ |
| | | if(2 == dappMemberEntity.getActiveStatus()){ |
| | | dappMemberEntity.setActiveStatus(1); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | } |
| | | /** |
| | | * todo 发送一条订单出的消息 |
| | | */ |
| | | chainProducer.sendSpeedPayOrderMsg(id); |
| | | chainProducer.sendAutoLevelUpTeamMsg(member.getId()); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse packageInfo() { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | PackageInfoVo packageInfoVo = new PackageInfoVo(); |
| | | DataDictionaryCustom packageTotalScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getType(), |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getCode() |
| | | ); |
| | | BigDecimal packageTotalScore = new BigDecimal(ObjectUtil.isEmpty(packageTotalScoreDic) ? "0" : packageTotalScoreDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | packageInfoVo.setPackageTotalScore(packageTotalScore); |
| | | |
| | | DataDictionaryCustom packageScorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getType(), |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getCode() |
| | | ); |
| | | BigDecimal packageScorePrice = new BigDecimal(ObjectUtil.isEmpty(packageScorePriceDic) ? "0" : packageScorePriceDic.getValue()).setScale(8, BigDecimal.ROUND_DOWN); |
| | | packageInfoVo.setPackageScorePrice(packageScorePrice); |
| | | |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); |
| | | BigDecimal balance = dappMemberEntity.getBalance(); |
| | | packageInfoVo.setPackageMemberScore(balance); |
| | | return new FebsResponse().success().data(packageInfoVo); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse salePackage(SalePackageDto salePackageDto) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | BigDecimal cnt = salePackageDto.getCnt(); |
| | | if(ObjectUtil.isEmpty(salePackageDto.getCnt())){ |
| | | throw new FebsException("请输入正确的数量"); |
| | | } |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); |
| | | BigDecimal saleDoing = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(memberId, FundFlowEnum.SALE_PACKAGE.getCode(), DappFundFlowEntity.WITHDRAW_STATUS_ING); |
| | | if(BigDecimal.ZERO.compareTo(saleDoing) < 0){ |
| | | throw new FebsException("正在进行中,请稍后再试"); |
| | | } |
| | | BigDecimal balance = dappMemberEntity.getBalance(); |
| | | if(BigDecimal.ZERO.compareTo(cnt) >= 0){ |
| | | throw new FebsException("资产不足"); |
| | | } |
| | | if(cnt.compareTo(balance) > 0){ |
| | | throw new FebsException("资产不足"); |
| | | } |
| | | //生成一条资金流水 |
| | | DappFundFlowEntity scoreFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | cnt, |
| | | FundFlowEnum.SALE_PACKAGE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_ING, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(scoreFlow); |
| | | |
| | | BigDecimal subtract = balance.subtract(cnt); |
| | | dappMemberEntity.setBalance(subtract); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | |
| | | chainProducer.sendSalePackageMsg(scoreFlow.getId()); |
| | | return new FebsResponse().success(); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse updateSystemPay(MallSystemPayDto mallSystemPayDto) { |
| | | Long memberId = mallSystemPayDto.getId(); |
| | | DappMemberEntity mallMember = dappMemberDao.selectById(memberId); |
| | | if(ObjectUtil.isEmpty(mallMember)){ |
| | | return new FebsResponse().fail().message("系统繁忙,请刷新页面重试"); |
| | | } |
| | | |
| | | BigDecimal bigDecimal = mallSystemPayDto.getAddBalance(); |
| | | |
| | | Integer type = mallSystemPayDto.getType(); |
| | | if (type == 1) { |
| | | dappWalletCoinDao.addTotalAndaddAvailableByMemberId(memberId,bigDecimal); |
| | | //插入流水 |
| | | DappFundFlowEntity amountFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | bigDecimal, |
| | | FundFlowEnum.SYSTEM_AMOUNT.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(amountFlow); |
| | | } else if (type == 2) { |
| | | dappWalletMineDao.addTotalAndaddAvailableById(bigDecimal,memberId); |
| | | //插入流水 |
| | | DappFundFlowEntity amountFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | bigDecimal, |
| | | FundFlowEnum.SYSTEM_SCORE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(amountFlow); |
| | | } else if (type == 3) { |
| | | BigDecimal balance = mallMember.getBalance(); |
| | | balance = balance.add(bigDecimal); |
| | | mallMember.setBalance(balance); |
| | | dappMemberDao.updateById(mallMember); |
| | | //插入流水 |
| | | DappFundFlowEntity amountFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | bigDecimal, |
| | | FundFlowEnum.SYSTEM_PACKAGE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(amountFlow); |
| | | } else { |
| | | throw new FebsException("参数错误"); |
| | | } |
| | | return new FebsResponse().success(); |
| | | } |
| | | |
| | | @Override |
| | | public IPage<MemberMoneyFlowVo> memberMoneyFlow(QueryRequest request, DappMemberEntity dappMemberEntity) { |
| | | Page<MemberMoneyFlowVo> page = new Page<>(request.getPageNum(), request.getPageSize()); |
| | | IPage<MemberMoneyFlowVo> memberMoneyFlowVos = dappAccountMoneyChangeDao.selectMemberMoneyFlowInPage(page, dappMemberEntity); |
| | | return memberMoneyFlowVos; |
| | | } |
| | | |
| | | @Override |
| | | public void delOrder(Long id) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallOrderInfo mallOrderInfo = mallOrderInfoMapper.selectById(id); |
| | | if(MallOrderInfo.STATUS_PAY == mallOrderInfo.getStatus()){ |
| | | throw new FebsException("当前订单不允许删除"); |
| | | } |
| | | |
| | | mallOrderInfoMapper.deleteById(id); |
| | | QueryWrapper<MallOrderItem> objectQueryWrapper = new QueryWrapper<>(); |
| | | objectQueryWrapper.eq("order_id", id); |
| | | List<MallOrderItem> mallOrderItems = mallOrderItemMapper.selectList(objectQueryWrapper); |
| | | if(CollUtil.isNotEmpty(mallOrderItems)){ |
| | | for(MallOrderItem mallOrderItem : mallOrderItems){ |
| | | mallOrderItemMapper.deleteById(mallOrderItem.getId()); |
| | | } |
| | | } |
| | | } |
| | | |
| | | @Override |
| | | public void createAddress(CreateAddressDto createAddressDto) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallAddressInfo mallAddressInfo = new MallAddressInfo(); |
| | | mallAddressInfo.setMemberId(memberId); |
| | | mallAddressInfo.setName(createAddressDto.getName()); |
| | | mallAddressInfo.setPhone(createAddressDto.getPhone()); |
| | | mallAddressInfo.setArea(createAddressDto.getArea()); |
| | | mallAddressInfo.setAddress(createAddressDto.getAddress()); |
| | | mallAddressInfo.setIsDefault(1); |
| | | mallAddressInfoMapper.insert(mallAddressInfo); |
| | | } |
| | | |
| | | @Override |
| | | public void delAddress(Long id) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallAddressInfo mallAddressInfo = mallAddressInfoMapper.selectById(id); |
| | | if(ObjectUtil.isEmpty(mallAddressInfo)){ |
| | | throw new FebsException("地址不存在"); |
| | | } |
| | | mallAddressInfo.setIsDefault(2); |
| | | mallAddressInfoMapper.updateById(mallAddressInfo); |
| | | } |
| | | |
| | | @Override |
| | | public IPage<MallAddressInfo> findAddressList(MallGoodsQueryDto queryDto) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | Page<MallAddressInfo> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize()); |
| | | queryDto.setMemberId(memberId); |
| | | return dappMemberDao.selectAddressListInPage(queryDto, page); |
| | | } |
| | | |
| | | @Override |
| | | public MallAddressInfo addressDetails(Long id) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallAddressInfo mallAddressInfo = mallAddressInfoMapper.selectById(id); |
| | | return mallAddressInfo; |
| | | } |
| | | |
| | | @Override |
| | | public void updateAddress(CreateAddressDto createAddressDto) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | |
| | | MallAddressInfo mallAddressInfo = mallAddressInfoMapper.selectById(createAddressDto.getId()); |
| | | if(ObjectUtil.isEmpty(mallAddressInfo)){ |
| | | throw new FebsException("地址不存在"); |
| | | } |
| | | mallAddressInfo.setName(createAddressDto.getName()); |
| | | mallAddressInfo.setPhone(createAddressDto.getPhone()); |
| | | mallAddressInfo.setArea(createAddressDto.getArea()); |
| | | mallAddressInfo.setAddress(createAddressDto.getAddress()); |
| | | mallAddressInfoMapper.updateById(mallAddressInfo); |
| | | } |
| | | |
| | | @Override |
| | | public List<MallGoodsCategory> categoryList() { |
| | | return mallGoodsCategoryMapper.selectRecommendCategoryList(); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse balanceSystem() { |
| | | |
| | | List<DappMemberEntity> dappMemberEntities = dappMemberDao.selectAllMemberForInCome(); |
| | | if(CollUtil.isNotEmpty(dappMemberEntities)){ |
| | | if(dappMemberEntities.size() <= 100){ |
| | | for(DappMemberEntity dappMemberEntity : dappMemberEntities){ |
| | | Long memberId = dappMemberEntity.getId(); |
| | | BigDecimal balance = dappMemberEntity.getBalance(); |
| | | |
| | | BigDecimal cnt = balance.divide(new BigDecimal(2) , 2 ,BigDecimal.ROUND_DOWN); |
| | | dappMemberEntity.setBalance(balance.subtract(cnt)); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | |
| | | DataDictionaryCustom packageScorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getType(), |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getCode() |
| | | ); |
| | | BigDecimal packageScorePrice = new BigDecimal(ObjectUtil.isEmpty(packageScorePriceDic) ? "0" : packageScorePriceDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //卖出资产乘以价格获取到预期获取的总额 |
| | | BigDecimal totalAmount = cnt.multiply(packageScorePrice).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //资产包卖出划入底池比例 |
| | | DataDictionaryCustom packageToPoorPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getType(), |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getCode() |
| | | ); |
| | | BigDecimal packageToPoorPercent = new BigDecimal(ObjectUtil.isEmpty(packageToPoorPercentDic) ? "0.1" : packageToPoorPercentDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //划入底池的金额 |
| | | BigDecimal poorAmount = totalAmount.multiply(packageToPoorPercent).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //实际获取的金额 |
| | | BigDecimal realAmount = totalAmount.subtract(poorAmount); |
| | | //生成一条资金流水 |
| | | DappFundFlowEntity scoreFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | realAmount, |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(scoreFlow); |
| | | dappWalletCoinDao.addTotalAndaddAvailableByMemberId(memberId,realAmount); |
| | | DappFundFlowEntity feeFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | poorAmount.negate(), |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(feeFlow); |
| | | |
| | | //卖出积分直接销毁。 |
| | | DataDictionaryCustom packageTotalScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getType(), |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getCode() |
| | | ); |
| | | BigDecimal avaPackageTotalScore = new BigDecimal(ObjectUtil.isEmpty(packageTotalScoreDic) ? "21000" : packageTotalScoreDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //更新USDT底池 |
| | | DataDictionaryCustom packagePoorDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_POOR.getType(), |
| | | DataDictionaryEnum.PACKAGE_POOR.getCode() |
| | | ); |
| | | BigDecimal packagePoor = new BigDecimal(ObjectUtil.isEmpty(packagePoorDic) ? "0" : packagePoorDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | BigDecimal avaPackagePoor = packagePoor.add(poorAmount); |
| | | packagePoorDic.setValue(avaPackagePoor.toString()); |
| | | dataDictionaryCustomMapper.updateById(packagePoorDic); |
| | | //计算当前价格 |
| | | BigDecimal divide = avaPackagePoor.divide(avaPackageTotalScore, 8, BigDecimal.ROUND_DOWN); |
| | | packageScorePriceDic.setValue(divide.toString()); |
| | | dataDictionaryCustomMapper.updateById(packageScorePriceDic); |
| | | } |
| | | return new FebsResponse().success(); |
| | | } |
| | | List<MallAchieveRecord> mallAchieveRecordList = new ArrayList<>(); |
| | | for(DappMemberEntity dappMemberEntity : dappMemberEntities){ |
| | | //获取每个人的业绩 |
| | | //业绩集合 |
| | | List<BigDecimal> list = new ArrayList<>(); |
| | | //所有直推团队,就是这个会员的所有区域的业绩。 |
| | | |
| | | BigDecimal teamIncomeMax = dappFundFlowDao.selectSumAmountByMemberIdAndTypeAndStatus(dappMemberEntity.getId(), |
| | | FundFlowEnum.ADD_AMOUNT_REAL.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE); |
| | | if(BigDecimal.ZERO.compareTo(teamIncomeMax) >= 0){ |
| | | continue; |
| | | } |
| | | |
| | | MallAchieveRecord mallAchieveRecord = new MallAchieveRecord(); |
| | | mallAchieveRecord.setMemberId(dappMemberEntity.getId()); |
| | | mallAchieveRecord.setAmount(teamIncomeMax); |
| | | mallAchieveRecordList.add(mallAchieveRecord); |
| | | // // 直推用户 |
| | | // List<DappMemberEntity> childs = dappMemberDao.selectMemberInfoByRefererId(dappMemberEntity.getInviteId()); |
| | | // List<String> childsInviteIds = childs.stream().map(DappMemberEntity::getInviteId).collect(Collectors.toList()); |
| | | // if(CollUtil.isNotEmpty(childsInviteIds)){ |
| | | // for(String inviteId : childsInviteIds){ |
| | | // BigDecimal totalIncomeMember = dappMemberDao.selectAchieveRecordByInviteId(inviteId); |
| | | // teamIncomeMax = teamIncomeMax.add(totalIncomeMember); |
| | | // list.add(totalIncomeMember); |
| | | // } |
| | | // //去掉一个最大区的业绩 |
| | | // BigDecimal bigMax = list.stream().max(BigDecimal::compareTo).get(); |
| | | // teamIncomeMax = teamIncomeMax.subtract(bigMax); |
| | | // } |
| | | } |
| | | if(CollUtil.isNotEmpty(mallAchieveRecordList)){ |
| | | //按照小区业绩的多少排名 |
| | | List<MallAchieveRecord> collect = mallAchieveRecordList |
| | | .stream() |
| | | .sorted(Comparator.comparing(MallAchieveRecord::getAmount)) |
| | | .collect(Collectors.toList()); |
| | | |
| | | List<MallAchieveRecord> top100Performances = collect.stream() |
| | | .limit(100) |
| | | .collect(Collectors.toList()); |
| | | if(CollUtil.isNotEmpty(top100Performances)){ |
| | | for(MallAchieveRecord mallAchieveRecord : top100Performances){ |
| | | Long memberId = mallAchieveRecord.getMemberId(); |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); |
| | | BigDecimal balance = dappMemberEntity.getBalance(); |
| | | |
| | | BigDecimal cnt = balance.divide(new BigDecimal(2) , 2 ,BigDecimal.ROUND_DOWN); |
| | | dappMemberEntity.setBalance(balance.subtract(cnt)); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | DataDictionaryCustom packageScorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getType(), |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getCode() |
| | | ); |
| | | BigDecimal packageScorePrice = new BigDecimal(ObjectUtil.isEmpty(packageScorePriceDic) ? "0" : packageScorePriceDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //卖出资产乘以价格获取到预期获取的总额 |
| | | BigDecimal totalAmount = cnt.multiply(packageScorePrice).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //资产包卖出划入底池比例 |
| | | DataDictionaryCustom packageToPoorPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getType(), |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getCode() |
| | | ); |
| | | BigDecimal packageToPoorPercent = new BigDecimal(ObjectUtil.isEmpty(packageToPoorPercentDic) ? "0.1" : packageToPoorPercentDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //划入底池的金额 |
| | | BigDecimal poorAmount = totalAmount.multiply(packageToPoorPercent).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //实际获取的金额 |
| | | BigDecimal realAmount = totalAmount.subtract(poorAmount); |
| | | //生成一条资金流水 |
| | | DappFundFlowEntity scoreFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | realAmount, |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(scoreFlow); |
| | | dappWalletCoinDao.addTotalAndaddAvailableByMemberId(memberId,realAmount); |
| | | DappFundFlowEntity feeFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | poorAmount.negate(), |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(feeFlow); |
| | | |
| | | //卖出积分直接销毁。 |
| | | DataDictionaryCustom packageTotalScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getType(), |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getCode() |
| | | ); |
| | | BigDecimal avaPackageTotalScore = new BigDecimal(ObjectUtil.isEmpty(packageTotalScoreDic) ? "21000" : packageTotalScoreDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //更新USDT底池 |
| | | DataDictionaryCustom packagePoorDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_POOR.getType(), |
| | | DataDictionaryEnum.PACKAGE_POOR.getCode() |
| | | ); |
| | | BigDecimal packagePoor = new BigDecimal(ObjectUtil.isEmpty(packagePoorDic) ? "0" : packagePoorDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | BigDecimal avaPackagePoor = packagePoor.add(poorAmount); |
| | | packagePoorDic.setValue(avaPackagePoor.toString()); |
| | | dataDictionaryCustomMapper.updateById(packagePoorDic); |
| | | //计算当前价格 |
| | | BigDecimal divide = avaPackagePoor.divide(avaPackageTotalScore, 8, BigDecimal.ROUND_DOWN); |
| | | packageScorePriceDic.setValue(divide.toString()); |
| | | dataDictionaryCustomMapper.updateById(packageScorePriceDic); |
| | | } |
| | | } |
| | | |
| | | List<MallAchieveRecord> remainingUsers = mallAchieveRecordList |
| | | .stream() |
| | | .sorted(Comparator.comparing(MallAchieveRecord::getAmount).reversed()) |
| | | .skip(100) |
| | | .collect(Collectors.toList()); |
| | | if(CollUtil.isNotEmpty(remainingUsers)){ |
| | | for(MallAchieveRecord mallAchieveRecord : remainingUsers){ |
| | | Long memberId = mallAchieveRecord.getMemberId(); |
| | | DappMemberEntity dappMemberEntity = dappMemberDao.selectById(memberId); |
| | | BigDecimal balance = dappMemberEntity.getBalance(); |
| | | |
| | | BigDecimal cnt = balance; |
| | | dappMemberEntity.setBalance(balance.subtract(cnt)); |
| | | dappMemberDao.updateById(dappMemberEntity); |
| | | DataDictionaryCustom packageScorePriceDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getType(), |
| | | DataDictionaryEnum.PACKAGE_SCORE_PRICE.getCode() |
| | | ); |
| | | BigDecimal packageScorePrice = new BigDecimal(ObjectUtil.isEmpty(packageScorePriceDic) ? "0" : packageScorePriceDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //卖出资产乘以价格获取到预期获取的总额 |
| | | BigDecimal totalAmount = cnt.multiply(packageScorePrice).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //资产包卖出划入底池比例 |
| | | DataDictionaryCustom packageToPoorPercentDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getType(), |
| | | DataDictionaryEnum.PACKAGE_SALE_TO_POOR_PERCENT.getCode() |
| | | ); |
| | | BigDecimal packageToPoorPercent = new BigDecimal(ObjectUtil.isEmpty(packageToPoorPercentDic) ? "0.1" : packageToPoorPercentDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //划入底池的金额 |
| | | BigDecimal poorAmount = totalAmount.multiply(packageToPoorPercent).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //实际获取的金额 |
| | | BigDecimal realAmount = totalAmount.subtract(poorAmount); |
| | | //生成一条资金流水 |
| | | DappFundFlowEntity scoreFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | realAmount, |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(scoreFlow); |
| | | dappWalletCoinDao.addTotalAndaddAvailableByMemberId(memberId,realAmount); |
| | | DappFundFlowEntity feeFlow = new DappFundFlowEntity( |
| | | memberId, |
| | | poorAmount.negate(), |
| | | FundFlowEnum.SYSTEM_PACKAGE_SALE.getCode(), |
| | | DappFundFlowEntity.WITHDRAW_STATUS_AGREE, |
| | | BigDecimal.ZERO); |
| | | dappFundFlowDao.insert(feeFlow); |
| | | |
| | | //卖出积分回收。 |
| | | DataDictionaryCustom packageTotalScoreDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getType(), |
| | | DataDictionaryEnum.PACKAGE_TOTAL_SCORE.getCode() |
| | | ); |
| | | BigDecimal avaPackageTotalScore = new BigDecimal(ObjectUtil.isEmpty(packageTotalScoreDic) ? "21000" : packageTotalScoreDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | //更新USDT底池 |
| | | DataDictionaryCustom packagePoorDic = dataDictionaryCustomMapper.selectDicDataByTypeAndCode( |
| | | DataDictionaryEnum.PACKAGE_POOR.getType(), |
| | | DataDictionaryEnum.PACKAGE_POOR.getCode() |
| | | ); |
| | | BigDecimal packagePoor = new BigDecimal(ObjectUtil.isEmpty(packagePoorDic) ? "0" : packagePoorDic.getValue()).setScale(2, BigDecimal.ROUND_DOWN); |
| | | BigDecimal avaPackagePoor = packagePoor.add(poorAmount); |
| | | packagePoorDic.setValue(avaPackagePoor.toString()); |
| | | dataDictionaryCustomMapper.updateById(packagePoorDic); |
| | | //计算当前价格 |
| | | BigDecimal divide = avaPackagePoor.divide(avaPackageTotalScore, 8, BigDecimal.ROUND_DOWN); |
| | | packageScorePriceDic.setValue(divide.toString()); |
| | | dataDictionaryCustomMapper.updateById(packageScorePriceDic); |
| | | } |
| | | } |
| | | } |
| | | |
| | | } |
| | | return new FebsResponse().success(); |
| | | } |
| | | |
| | | @Override |
| | | public IPage<MallAddressInfo> shopAddressList(MallGoodsQueryDto queryDto) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | Page<MallAddressInfo> page = new Page<>(queryDto.getPageNow(), queryDto.getPageSize()); |
| | | queryDto.setMemberId(1L); |
| | | return dappMemberDao.selectShopAddressListInPage(queryDto, page); |
| | | } |
| | | |
| | | @Override |
| | | public FebsResponse findAllBanner() { |
| | | QueryWrapper<PlatformBanner> queryWrapper = new QueryWrapper<>(); |
| | | queryWrapper.orderByAsc("is_top"); |
| | | List<PlatformBanner> paymentMethodList = platformBannerMapper.selectList(queryWrapper); |
| | | return new FebsResponse().success().data(paymentMethodList); |
| | | } |
| | | |
| | | @Override |
| | | public void setDefaultAddress(Long id) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallAddressInfo addressInfo = mallAddressInfoMapper.selectById(id); |
| | | if (addressInfo == null) { |
| | | throw new FebsException("地址不存在"); |
| | | } |
| | | this.baseMapper.updateIsDefault(MallAddressInfo.IS_YOUR_N, memberId, null); |
| | | |
| | | this.baseMapper.updateIsDefault(MallAddressInfo.IS_YOUR_Y, memberId, id); |
| | | } |
| | | |
| | | @Override |
| | | public void confirmOrder(Long id) { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallOrderInfo orderInfo = mallOrderInfoMapper.selectById(id); |
| | | if (ObjectUtil.isEmpty(orderInfo)) { |
| | | throw new FebsException("订单不存在"); |
| | | } |
| | | |
| | | if (orderInfo.getStatus() != MallOrderInfo.STATUS_PAY) { |
| | | throw new FebsException("该状态不能确认收货"); |
| | | } |
| | | if (orderInfo.getDeliverState() != MallOrderInfo.DELIVER_STATUS_DONE) { |
| | | throw new FebsException("该状态不能确认收货"); |
| | | } |
| | | |
| | | orderInfo.setDeliverState(MallOrderInfo.DELIVER_STATUS_OVER); |
| | | mallOrderInfoMapper.updateById(orderInfo); |
| | | } |
| | | |
| | | @Override |
| | | public MallAddressInfo findAddress() { |
| | | Long memberId = LoginUserUtil.getAppUser().getId(); |
| | | MallAddressInfo mallAddressInfo = dappMemberDao.selectAddressOneByMemberId(memberId); |
| | | return mallAddressInfo; |
| | | } |
| | | |
| | | @Override |
| | | public List<PackageRecordVo> packageRecord(PackageRecordDto packageRecordDto) { |
| | | List<PackageRecordVo> packageRecordVos = new ArrayList<>(); |
| | | Integer type = packageRecordDto.getType(); |
| | | if(2 == type){ |
| | | packageRecordVos = dappMemberDao.selectPackageRecordWeekInPage(DateUtil.beginOfWeek(DateUtil.date())); |
| | | }else if(3 == type){ |
| | | packageRecordVos = dappMemberDao.selectPackageRecordMonthInPage(DateUtil.date()); |
| | | }else{ |
| | | packageRecordVos = dappMemberDao.selectPackageRecordDayInPage(DateUtil.date()); |
| | | } |
| | | if(CollUtil.isNotEmpty(packageRecordVos)){ |
| | | Integer packageNum = 0; |
| | | for(PackageRecordVo packageRecordVo : packageRecordVos){ |
| | | packageNum = packageNum + 1; |
| | | packageRecordVo.setPackageNum(packageNum); |
| | | } |
| | | } |
| | | return packageRecordVos; |
| | | } |
| | | |
| | | @Override |
| | | public List<AKLineLimitVo> packageKline() { |
| | | return dappAKlineMapper.selectListByTypeAndLimit(2, 30); |
| | | } |
| | | |
| | | public static List<List<String>> partitionList(List<String> originalList, int partitionSize) { |
| | | List<List<String>> partitionedList = new ArrayList<>(); |
| | | int size = originalList.size(); |