From c428522a1d47199b30acf4522a33c88f54180fdd Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Tue, 30 Mar 2021 21:52:45 +0800 Subject: [PATCH] 20210329 返利记录的修改 --- src/main/java/com/xcong/excoin/modules/contract/service/impl/RabbitOrderServiceImpl.java | 35 +++++++++-------- src/main/resources/mapper/contract/ContractOrderDao.xml | 9 ++++ src/main/resources/mapper/documentary/FollowTraderProfitDetailDao.xml | 13 ++++++ src/main/java/com/xcong/excoin/modules/documentary/service/impl/FollowOrderOperationServiceImpl.java | 46 +++++++++++++++++++++-- src/main/java/com/xcong/excoin/modules/documentary/common/NoticeConstant.java | 4 +- src/main/java/com/xcong/excoin/modules/contract/dao/ContractOrderDao.java | 2 + src/main/java/com/xcong/excoin/modules/documentary/dao/FollowTraderProfitDetailDao.java | 7 +++ 7 files changed, 92 insertions(+), 24 deletions(-) diff --git a/src/main/java/com/xcong/excoin/modules/contract/dao/ContractOrderDao.java b/src/main/java/com/xcong/excoin/modules/contract/dao/ContractOrderDao.java index ec49b0e..0679e99 100644 --- a/src/main/java/com/xcong/excoin/modules/contract/dao/ContractOrderDao.java +++ b/src/main/java/com/xcong/excoin/modules/contract/dao/ContractOrderDao.java @@ -35,4 +35,6 @@ public BigDecimal getBurstUsdtByMemberId(@Param("memberId") Long memberId); public List<ContractOrderEntity> selectFollowOrderListByMemberId(@Param("tradeMemberId")Long tradeMemberId); + + public String selectOrderNoByOrderIds(@Param("orderId")Long orderId); } diff --git a/src/main/java/com/xcong/excoin/modules/contract/service/impl/RabbitOrderServiceImpl.java b/src/main/java/com/xcong/excoin/modules/contract/service/impl/RabbitOrderServiceImpl.java index ac84f21..05c3810 100644 --- a/src/main/java/com/xcong/excoin/modules/contract/service/impl/RabbitOrderServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/contract/service/impl/RabbitOrderServiceImpl.java @@ -195,23 +195,24 @@ memberWalletContractDao.increaseWalletContractBalanceById(returnMoney, returnMoney, null, traderWallet.getId()); insertReturnProfitDetail(traderInfoEntity.getMemberId(), memberEntity.getId(), returnMoney, holdOrderEntity.getOrderNo()); //增加返佣提醒 - String orderNo = holdOrderEntity.getOrderNo(); - LogRecordUtils.insertFollowerNotice(traderInfoEntity.getMemberId(), - NoticeConstant.RETURN_MONEY_TITLE, - StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT, - orderNo, - holdOrderEntity.getSymbol(), - returnMoney.setScale(2, BigDecimal.ROUND_HALF_UP).toString())); - //带单返利的记录要在资产页面的其他记录 - LogRecordUtils.insertMemberAccountMoneyChange( - traderInfoEntity.getMemberId(), - StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT_MAMC, - orderNo, - holdOrderEntity.getSymbol()), - returnMoney.setScale(2, BigDecimal.ROUND_HALF_UP), - MemberWalletCoinEnum.WALLETCOINCODE.getValue(), - MemberAccountMoneyChange.STATUS_SUCCESS_INTEGER, - MemberAccountMoneyChange.TYPE_WALLET_AGENT); +// String orderNo = holdOrderEntity.getOrderNo(); +// LogRecordUtils.insertFollowerNotice(traderInfoEntity.getMemberId(), +// NoticeConstant.RETURN_MONEY_TITLE, +// StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT, +// orderNo, +// holdOrderEntity.getSymbol(), +// returnMoney.setScale(2, BigDecimal.ROUND_HALF_UP).toString())); +// //带单返利的记录要在资产页面的其他记录 +// LogRecordUtils.insertMemberAccountMoneyChange( +// traderInfoEntity.getMemberId(), +// StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT_MAMC, +// orderNo, +// holdOrderEntity.getSymbol(), +// returnMoney.setScale(2, BigDecimal.ROUND_HALF_UP).toString()), +// returnMoney.setScale(2, BigDecimal.ROUND_HALF_UP), +// MemberWalletCoinEnum.WALLETCOINCODE.getValue(), +// MemberAccountMoneyChange.STATUS_SUCCESS_INTEGER, +// MemberAccountMoneyChange.TYPE_WALLET_AGENT); } } } diff --git a/src/main/java/com/xcong/excoin/modules/documentary/common/NoticeConstant.java b/src/main/java/com/xcong/excoin/modules/documentary/common/NoticeConstant.java index 2c1c659..1e7a4c3 100644 --- a/src/main/java/com/xcong/excoin/modules/documentary/common/NoticeConstant.java +++ b/src/main/java/com/xcong/excoin/modules/documentary/common/NoticeConstant.java @@ -30,8 +30,8 @@ public static final String BOMB_ORDER_CONTENT = "因市场剧烈波动,您的{}合约已被强制平仓,交易员:{}"; - public static final String RETURN_MONEY_TITLE = "跟单-平仓返佣"; - public static final String RETURN_MONEY_CONTENT = "平仓成功,收到的合约单号为{},币种为{}的返佣金额:{}"; + public static final String RETURN_MONEY_TITLE = "跟单-平仓返利"; + public static final String RETURN_MONEY_CONTENT = "平仓成功,收到的合约{},币种{}的返利金额:{}"; public static final String RETURN_MONEY_CONTENT_MAMC = "合约{},币种{}的返利"; } diff --git a/src/main/java/com/xcong/excoin/modules/documentary/dao/FollowTraderProfitDetailDao.java b/src/main/java/com/xcong/excoin/modules/documentary/dao/FollowTraderProfitDetailDao.java index ab01a2a..6e36e67 100644 --- a/src/main/java/com/xcong/excoin/modules/documentary/dao/FollowTraderProfitDetailDao.java +++ b/src/main/java/com/xcong/excoin/modules/documentary/dao/FollowTraderProfitDetailDao.java @@ -1,8 +1,15 @@ package com.xcong.excoin.modules.documentary.dao; +import java.math.BigDecimal; +import java.util.List; + +import org.apache.ibatis.annotations.Param; + import com.baomidou.mybatisplus.core.mapper.BaseMapper; import com.xcong.excoin.modules.documentary.entity.FollowTraderProfitDetailEntity; public interface FollowTraderProfitDetailDao extends BaseMapper<FollowTraderProfitDetailEntity> { + BigDecimal selectFollowHoldOrderByFollowOrderNo(@Param("orderNos")List<String> orderNos); + } diff --git a/src/main/java/com/xcong/excoin/modules/documentary/service/impl/FollowOrderOperationServiceImpl.java b/src/main/java/com/xcong/excoin/modules/documentary/service/impl/FollowOrderOperationServiceImpl.java index f51d58b..a081a3e 100644 --- a/src/main/java/com/xcong/excoin/modules/documentary/service/impl/FollowOrderOperationServiceImpl.java +++ b/src/main/java/com/xcong/excoin/modules/documentary/service/impl/FollowOrderOperationServiceImpl.java @@ -7,9 +7,11 @@ import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.xcong.excoin.common.enumerates.CoinTypeEnum; +import com.xcong.excoin.common.enumerates.MemberWalletCoinEnum; import com.xcong.excoin.common.enumerates.RabbitPriceTypeEnum; import com.xcong.excoin.common.response.Result; import com.xcong.excoin.common.system.service.CommonService; +import com.xcong.excoin.modules.coin.entity.MemberAccountMoneyChange; import com.xcong.excoin.modules.contract.dao.ContractHoldOrderDao; import com.xcong.excoin.modules.contract.dao.ContractOrderDao; import com.xcong.excoin.modules.contract.entity.ContractEntrustOrderEntity; @@ -18,10 +20,7 @@ import com.xcong.excoin.modules.contract.mapper.ContractHoldOrderEntityMapper; import com.xcong.excoin.modules.contract.service.RabbitOrderService; import com.xcong.excoin.modules.documentary.common.NoticeConstant; -import com.xcong.excoin.modules.documentary.dao.FollowFollowerOrderRelationDao; -import com.xcong.excoin.modules.documentary.dao.FollowFollowerProfitDao; -import com.xcong.excoin.modules.documentary.dao.FollowFollowerSettingDao; -import com.xcong.excoin.modules.documentary.dao.FollowTraderInfoDao; +import com.xcong.excoin.modules.documentary.dao.*; import com.xcong.excoin.modules.documentary.entity.FollowFollowerOrderRelationEntity; import com.xcong.excoin.modules.documentary.entity.FollowFollowerProfitEntity; import com.xcong.excoin.modules.documentary.entity.FollowFollowerSettingEntity; @@ -88,6 +87,8 @@ @Autowired private FollowProducer followProducer; + @Autowired + private FollowTraderProfitDetailDao followTraderProfitDetailDao; @Override @@ -263,11 +264,48 @@ public void closingFollowOrders(String orderNo) { List<FollowFollowerOrderRelationEntity> orderRelations = followFollowerOrderRelationDao.selectFollowHoldOrderByTradeOrderNo(orderNo); if (CollUtil.isNotEmpty(orderRelations)) { + List<Long> orderIds = new ArrayList<>(); for (FollowFollowerOrderRelationEntity orderRelation : orderRelations) { List<Long> ids= new ArrayList<>(); ids.add(orderRelation.getOrderId()); + orderIds.add(orderRelation.getOrderId()); rabbitOrderService.cancelHoldOrder(ids); } + if(CollUtil.isNotEmpty(orderIds)){ + //获取对应的平仓记录单号 + List<String> orderNosList = new ArrayList<>(); + + for(Long orderId : orderIds) { + String orderNos = contractOrderDao.selectOrderNoByOrderIds(orderId); + ContractOrderEntity contractOrderEntity = contractOrderDao.selectById(orderId); + orderNosList.add(orderNos); + } + //获取总返佣 + BigDecimal totalAmount = followTraderProfitDetailDao.selectFollowHoldOrderByFollowOrderNo(orderNosList); + totalAmount = (totalAmount == null?BigDecimal.ZERO:totalAmount.setScale(2, BigDecimal.ROUND_DOWN)); + if(totalAmount.compareTo(BigDecimal.ZERO) > 0){ + //增加返佣提醒 + String symbol = contractOrderDao.selectById(orderIds.get(0)).getSymbol(); + String orderNoTrader = orderRelations.get(0).getTradeOrderNo(); + Long traderMemberId = orderRelations.get(0).getTradeMemberId(); + LogRecordUtils.insertFollowerNotice(traderMemberId, + NoticeConstant.RETURN_MONEY_TITLE, + StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT, + orderNoTrader, + symbol, + totalAmount)); + //带单返利的记录要在资产页面的其他记录 + LogRecordUtils.insertMemberAccountMoneyChange( + traderMemberId, + StrUtil.format(NoticeConstant.RETURN_MONEY_CONTENT_MAMC, + orderNoTrader, + symbol), + totalAmount, + MemberWalletCoinEnum.WALLETCOINCODE.getValue(), + MemberAccountMoneyChange.STATUS_SUCCESS_INTEGER, + MemberAccountMoneyChange.TYPE_WALLET_AGENT); + } + } } } } diff --git a/src/main/resources/mapper/contract/ContractOrderDao.xml b/src/main/resources/mapper/contract/ContractOrderDao.xml index fe6ad61..4e8d023 100644 --- a/src/main/resources/mapper/contract/ContractOrderDao.xml +++ b/src/main/resources/mapper/contract/ContractOrderDao.xml @@ -2,6 +2,15 @@ <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.xcong.excoin.modules.contract.dao.ContractOrderDao"> + <select id="selectOrderNoByOrderIds" resultType="java.lang.String"> + SELECT + order_no + FROM + contract_order + WHERE + id = #{orderId} + </select> + <select id="selectFollowOrderListByMemberId" resultType="com.xcong.excoin.modules.contract.entity.ContractOrderEntity"> SELECT * diff --git a/src/main/resources/mapper/documentary/FollowTraderProfitDetailDao.xml b/src/main/resources/mapper/documentary/FollowTraderProfitDetailDao.xml index a6e586a..c397480 100644 --- a/src/main/resources/mapper/documentary/FollowTraderProfitDetailDao.xml +++ b/src/main/resources/mapper/documentary/FollowTraderProfitDetailDao.xml @@ -1,6 +1,17 @@ <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.xcong.excoin.modules.documentary.dao.FollowTraderProfitDetailDao"> - + + <select id="selectFollowHoldOrderByFollowOrderNo" resultType="java.math.BigDecimal"> + SELECT + sum(amount) + FROM + follow_trader_profit_detail + WHERE + order_no in + <foreach collection="orderNos" item="item" index="" open="(" separator="," close=")"> + #{item} + </foreach> + </select> </mapper> \ No newline at end of file -- Gitblit v1.9.1