From e847891c4f6f12cee5e764f8c1fad001496b9740 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Mon, 09 Aug 2021 16:30:21 +0800 Subject: [PATCH] Merge branch 'score-shop' of http://120.27.238.55:7000/r/xzx into score-shop --- gc-core/src/main/java/com/xzx/gc/entity/ScoreDetails.java | 5 gc-order/src/main/java/com/xzx/gc/order/mapper/UserShareInfoMapper.java | 2 gc-user/src/main/resources/mapper/user/ScoreDetailsMapper.xml | 5 gc-order/src/main/resources/mapper/order/JhyOrderMapper.xml | 5 gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java | 96 ++++++++++++ gc-order/src/main/java/com/xzx/gc/order/mapper/AccountMapper.java | 2 gc-user/src/main/java/com/xzx/gc/user/mapper/AccountMapper.java | 2 gc-core/src/main/java/com/xzx/gc/common/constant/CommonEnum.java | 7 gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java | 107 +++++++++++++ gc-user/src/main/resources/mapper/user/AccountMapper.xml | 5 gc-order/src/main/resources/mapper/order/AccountMapper.xml | 5 gc-user/src/main/java/com/xzx/gc/user/mapper/ScoreDetailsMapper.java | 7 gc-order/src/main/java/com/xzx/gc/order/mapper/JhyOrderMapper.java | 2 gc-order/src/main/resources/mapper/order/RedPaperRuleMapper.xml | 4 gc-order/src/main/java/com/xzx/gc/order/mapper/OrderMapper.java | 2 gc-order/src/main/resources/mapper/order/OrderMapper.xml | 5 gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml | 4 gc-order/src/main/resources/mapper/order/UserShareInfoMapper.xml | 4 gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java | 4 gc-order/src/main/java/com/xzx/gc/order/mapper/RedPaperRuleMapper.java | 2 gc-order/src/main/java/com/xzx/gc/order/service/JhyOrderService.java | 153 ++++++++++-------- gc-user/src/main/java/com/xzx/gc/user/controller/ApiDistribController.java | 7 gc-order/src/main/java/com/xzx/gc/order/service/OrderService.java | 5 gc-user/src/main/java/com/xzx/gc/user/service/UserLoginService.java | 5 24 files changed, 375 insertions(+), 70 deletions(-) diff --git a/gc-core/src/main/java/com/xzx/gc/common/constant/CommonEnum.java b/gc-core/src/main/java/com/xzx/gc/common/constant/CommonEnum.java index f599b83..8be4562 100644 --- a/gc-core/src/main/java/com/xzx/gc/common/constant/CommonEnum.java +++ b/gc-core/src/main/java/com/xzx/gc/common/constant/CommonEnum.java @@ -98,7 +98,12 @@ 首单后返利数量("order_num_first"), 返利固定积分("regular_point"), 返利环保币比例("regular_money_percent"), - 完成数量后返积分("point_reward") + 完成数量后返积分("point_reward"), + + 推荐首单奖励("first_score"), + 朋友圈分享奖励("share_score"), + 朋友圈分享限次("share_score_time"), + 邀请奖励("register_score") ;//枚举结束 private String value; diff --git a/gc-core/src/main/java/com/xzx/gc/entity/ScoreDetails.java b/gc-core/src/main/java/com/xzx/gc/entity/ScoreDetails.java index c074a03..a604357 100644 --- a/gc-core/src/main/java/com/xzx/gc/entity/ScoreDetails.java +++ b/gc-core/src/main/java/com/xzx/gc/entity/ScoreDetails.java @@ -16,7 +16,7 @@ //用户ID private String userId; - //交易类型 1-用户充值2-集物员支付3-用户兑换所得4-用户消费5-消费退回6-管理员充值7-其他 + //交易类型 1-用户充值2-集物员支付3-用户兑换所得4-用户消费5-消费退回6-管理员充值7-其他 8-邀请后首单返利 9-分享朋友圈 10-邀请奖励 private Integer type; public static final Integer SCORE_TYPE_USER_RECHARGE = 1; public static final Integer SCORE_TYPE_PAY = 2; @@ -25,6 +25,9 @@ public static final Integer SCORE_TYPE_SHOPPING_RETURN = 5; public static final Integer SCORE_TYPE_ADMIN_RECHARGE = 6; public static final Integer SCORE_TYPE_OTHER = 7; + public static final Integer SCORE_TYPE_INVITE_FIRST_ORDER = 8; + public static final Integer SCORE_TYPE_SHARE_MOMENTS = 9; + public static final Integer SCORE_TYPE_INVITE = 10; //原始积分 private BigDecimal originalScore; diff --git a/gc-order/src/main/java/com/xzx/gc/order/mapper/AccountMapper.java b/gc-order/src/main/java/com/xzx/gc/order/mapper/AccountMapper.java index a55558e..745da6d 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/mapper/AccountMapper.java +++ b/gc-order/src/main/java/com/xzx/gc/order/mapper/AccountMapper.java @@ -36,4 +36,6 @@ void updateUserAccount(@Param("accountId") String accountId, @Param("money") String money, @Param("overdraftLimit") String overdraftLimit); AccountInfo selectAccountInfoByUserId(@Param("userId") String userId); + + AccountInfo selectAccountInfoByPhone(@Param("phone") String phone); } diff --git a/gc-order/src/main/java/com/xzx/gc/order/mapper/JhyOrderMapper.java b/gc-order/src/main/java/com/xzx/gc/order/mapper/JhyOrderMapper.java index cbe3cad..6f1dd8f 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/mapper/JhyOrderMapper.java +++ b/gc-order/src/main/java/com/xzx/gc/order/mapper/JhyOrderMapper.java @@ -19,4 +19,6 @@ List<JhyStatusCountVo> selectOrderStatusCount(@Param("type") Integer type, @Param("userId") String userId); List<JhyOrder> selectJhyOrderListByStatus(@Param("list") List<String> list, @Param("userId") String userId); + + List<JhyOrder> selectJhyOrderNoWaitAndCancel(@Param("userId") String userId); } diff --git a/gc-order/src/main/java/com/xzx/gc/order/mapper/OrderMapper.java b/gc-order/src/main/java/com/xzx/gc/order/mapper/OrderMapper.java index 6f923e1..4ed2f82 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/mapper/OrderMapper.java +++ b/gc-order/src/main/java/com/xzx/gc/order/mapper/OrderMapper.java @@ -221,5 +221,7 @@ List<OrderInfo> findListOrderReceiveTime(@Param("receiver")String receiver); + List<OrderInfo> selectOrderNoWaitAndCancel(@Param("userId") String userId); + } diff --git a/gc-order/src/main/java/com/xzx/gc/order/mapper/RedPaperRuleMapper.java b/gc-order/src/main/java/com/xzx/gc/order/mapper/RedPaperRuleMapper.java index 4b3a103..ced5a20 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/mapper/RedPaperRuleMapper.java +++ b/gc-order/src/main/java/com/xzx/gc/order/mapper/RedPaperRuleMapper.java @@ -59,4 +59,6 @@ List<XzxUserRedpaperRuleModel> queryRoyalty(@Param("partnerIds")List<String> partnerIds, @Param("partnerId")String partnerId); RedPaperRule selectDistribRule(); + + List<RedPaperRule> selectRuleByType(@Param("type") Integer type); } \ No newline at end of file diff --git a/gc-order/src/main/java/com/xzx/gc/order/mapper/UserShareInfoMapper.java b/gc-order/src/main/java/com/xzx/gc/order/mapper/UserShareInfoMapper.java index fb4e188..09fa8a5 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/mapper/UserShareInfoMapper.java +++ b/gc-order/src/main/java/com/xzx/gc/order/mapper/UserShareInfoMapper.java @@ -26,6 +26,8 @@ List<Map<String, Object>> queryPackageGoods(@Param("packageId") String packageId, @Param("partnerId") String partnerId); + UserShareInfo selectUserShareInfoByInvited(@Param("phone") String phone); + } diff --git a/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java b/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java index 6c4b284..65b15db 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java +++ b/gc-order/src/main/java/com/xzx/gc/order/service/DistribService.java @@ -44,7 +44,17 @@ private UserMapper userMapper; @Autowired private ScoreDetailsMapper scoreDetailsMapper; + @Autowired + private UserShareInfoMapper userShareInfoMapper; + @Autowired + private OrderMapper orderMapper; + /** + * 团长积分/环保币返利规则 + * + * @param orderId + * @param userId + */ public void distribRecord(Long orderId, String userId) { UserHeadRelate userHeadRelate = userHeadRelateMapper.selectRelateByUserId(userId); if (userHeadRelate == null) { @@ -160,6 +170,92 @@ sysMessageMapper.insert(sysMessage); } + /** + * 普通用户邀请用户并下单返利规则 + * + */ + public void inviteAddOrderScore(String userId, String orderId) { + UserInfo userInfo = userMapper.selectByPrimaryKey(userId); + UserShareInfo userShareInfo = userShareInfoMapper.selectUserShareInfoByInvited(userInfo.getMobilePhone()); + + if (userShareInfo == null) { + return; + } + + // 查询当前用户邀请人信息,判断是否为团长,如果是团长,则不返利 + AccountInfo accountInfo = accountMapper.selectAccountInfoByPhone(userShareInfo.getMobilePhone()); + if (AccountInfo.IS_HEAD_Y.equals(accountInfo.getIsHead())) { + log.info("邀请人为团长, 不执行返利"); + return; + } + + if (AccountInfo.IS_PROHIBIT_Y.equals(accountInfo.getIsProhibit())) { + return; + } + + List<RedPaperRule> rules = redPaperRuleMapper.selectRuleByType(10); + if (CollUtil.isEmpty(rules)) { + log.info("没有具体规则"); + return; + } + + RedPaperRule rule = rules.get(0); + if (rule.getStatus() == 0) { + log.info("规则被禁用, 不执行返利"); + return; + } + + List<OrderInfo> riderOrders = orderMapper.selectOrderNoWaitAndCancel(userId); + int riderCnt = 0; + if (CollUtil.isNotEmpty(riderOrders)) { + riderCnt = riderOrders.size(); + } + + List<JhyOrder> jhyOrders = jhyOrderMapper.selectJhyOrderNoWaitAndCancel(userId); + int jhyCnt = 0; + if (CollUtil.isNotEmpty(jhyOrders)) { + jhyCnt = jhyOrders.size(); + } + + // 仅首单返利 + if (jhyCnt + riderCnt > 1) { + return; + } + + String value = getRuleValue(rule, CommonEnum.推荐首单奖励.getValue()); + BigDecimal returnScore = BigDecimal.ZERO; + if (StrUtil.isNotBlank(value)) { + returnScore = new BigDecimal(value); + } + + BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO; + accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, BigDecimal.ROUND_DOWN).toString()); + accountMapper.updateByPrimaryKey(accountInfo); + + if (returnScore.compareTo(BigDecimal.ZERO) > 0) { + ScoreDetails scoreDetails = new ScoreDetails(); + scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore())); + scoreDetails.setOriginalScore(collectScore); + scoreDetails.setChangeScore(returnScore); + scoreDetails.setCreatedTime(new Date()); + scoreDetails.setType(ScoreDetails.SCORE_TYPE_INVITE_FIRST_ORDER); + scoreDetails.setUserId(accountInfo.getUserId()); + scoreDetails.setOrderNo(orderId.toString()); + scoreDetailsMapper.insert(scoreDetails); + } + + SysMessage sysMessage = new SysMessage(); + sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss")); + sysMessage.setCreateUserId(accountInfo.getUserId()); + sysMessage.setUserId(accountInfo.getUserId()); + sysMessage.setMessageType("4"); + sysMessage.setMessageSubTypeName("返利消息"); + sysMessage.setMessage("收到用户:" + userInfo.getMobilePhone().replaceAll("(\\w{3})\\w*(\\w{4})", "$1****$2") + "的订单返利, 积分:" + returnScore); + sysMessage.setFlag("2"); + sysMessageMapper.insert(sysMessage); + + } + private String getRuleValue(RedPaperRule redPaperRule, String key) { List<String> rules = StrUtil.split(redPaperRule.getSharingProfitType(), ','); List<String> values = StrUtil.split(redPaperRule.getShareRatio(), ','); diff --git a/gc-order/src/main/java/com/xzx/gc/order/service/JhyOrderService.java b/gc-order/src/main/java/com/xzx/gc/order/service/JhyOrderService.java index d47e691..24719d6 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/service/JhyOrderService.java +++ b/gc-order/src/main/java/com/xzx/gc/order/service/JhyOrderService.java @@ -7,9 +7,11 @@ import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; import com.xzx.gc.common.constant.Constants; +import com.xzx.gc.common.constant.RedisKeyConstant; import com.xzx.gc.common.exception.RestException; import com.xzx.gc.common.utils.IdUtils; import com.xzx.gc.common.utils.LocationUtils; +import com.xzx.gc.common.utils.RedisUtil; import com.xzx.gc.entity.*; import com.xzx.gc.order.dto.AddJhyOrderDto; import com.xzx.gc.order.dto.JhyOrderConfirmDto; @@ -59,6 +61,9 @@ @Autowired private DistribService distribService; + + @Autowired + private RedisUtil redisUtil; public void addJhyOrder(AddJhyOrderDto orderDto) { JhyInfo jhyInfo = jhyInfoMapper.selectJhyInfoByUserId(orderDto.getUserId()); @@ -200,74 +205,90 @@ } public void confirmOrder(JhyOrderConfirmDto confirmDto) { - JhyInfo jhyInfo = jhyInfoMapper.selectJhyInfoByUserId(confirmDto.getUserId()); - if (jhyInfo == null || !JhyInfo.CHECK_PASS.equals(jhyInfo.getStatus())) { - throw new RestException(-3, "不是集物员"); + String key = RedisKeyConstant.ORDER_PAY + confirmDto.getOrderId(); + if (redisUtil.setnx(key, "0")) { + try { + JhyInfo jhyInfo = jhyInfoMapper.selectJhyInfoByUserId(confirmDto.getUserId()); + if (jhyInfo == null || !JhyInfo.CHECK_PASS.equals(jhyInfo.getStatus())) { + throw new RestException(-3, "不是集物员"); + } + + jhyOrderItemsMapper.deleteItemsByOrderId(confirmDto.getOrderId()); + + BigDecimal totalScore = BigDecimal.ZERO; + for (JhyOrderConfirmItemsDto item : confirmDto.getItems()) { + BigDecimal weight = StrUtil.isNotBlank(item.getWeight()) ? new BigDecimal(item.getWeight()) : BigDecimal.ZERO; + SysEnvironmentalInfo environmentalInfo = environmentalInfoMapper.selectByPrimaryKey(item.getId()); + + JhyOrderItems orderItems = new JhyOrderItems(); + orderItems.setOrderId(confirmDto.getOrderId()); + orderItems.setPicture(environmentalInfo.getPicture()); + orderItems.setItemType(item.getId()); + orderItems.setTitle(environmentalInfo.getTitle()); + orderItems.setPrice(new BigDecimal(environmentalInfo.getPrice())); + BigDecimal total = orderItems.getPrice().multiply(BigDecimal.valueOf(40)).multiply(weight); + orderItems.setScore(total.setScale(0, BigDecimal.ROUND_DOWN).toString()); + orderItems.setWeight(weight); + jhyOrderItemsMapper.insert(orderItems); + + totalScore = totalScore.add(total); + } + + JhyOrder order = jhyOrderMapper.selectByPrimaryKey(confirmDto.getOrderId()); + AccountInfo jhyAccount = accountMapper.selectAccountInfoByUserId(order.getJhyId()); + BigDecimal collectScore = StrUtil.isNotBlank(jhyAccount.getCollectScore()) ? new BigDecimal(jhyAccount.getCollectScore()) : BigDecimal.ZERO; + if (totalScore.compareTo(collectScore) > 0) { + throw new RestException(-3, "剩余积分不足"); + } + + order.setStatus(JhyOrder.ORDER_STATUS_CONFIRM); + order.setReceivingTime(new Date()); + jhyOrderMapper.updateByPrimaryKey(order); + + BigDecimal jhyScore = StrUtil.isBlank(jhyAccount.getCollectScore()) ? BigDecimal.ZERO : new BigDecimal(jhyAccount.getCollectScore()); + ScoreDetails jhyScoreDetail = new ScoreDetails(); + jhyScoreDetail.setOrderNo(order.getOrderNo()); + jhyScoreDetail.setUserId(order.getJhyId()); + jhyScoreDetail.setType(ScoreDetails.SCORE_TYPE_PAY); + jhyScoreDetail.setChangeScore(totalScore.negate().setScale( 0, BigDecimal.ROUND_DOWN )); + jhyScoreDetail.setOriginalScore(jhyScore.setScale( 0, BigDecimal.ROUND_DOWN )); + jhyScoreDetail.setCurrentScore(jhyScore.subtract(totalScore).setScale( 0, BigDecimal.ROUND_DOWN )); + jhyScoreDetail.setCreatedTime(new Date()); + scoreDetailsMapper.insert(jhyScoreDetail); + + jhyAccount.setCollectScore(jhyScore.subtract(totalScore).setScale( 0, BigDecimal.ROUND_DOWN ).toString()); + accountMapper.updateByPrimaryKey(jhyAccount); + + AccountInfo userAccount = accountMapper.selectAccountInfoByUserId(order.getUserId()); + BigDecimal userScore = StrUtil.isBlank(userAccount.getCollectScore()) ? BigDecimal.ZERO : new BigDecimal(userAccount.getCollectScore()); + ScoreDetails userScoreDetail = new ScoreDetails(); + userScoreDetail.setOrderNo(order.getOrderNo()); + // userScoreDetail.setUserId(order.getJhyId()); + userScoreDetail.setUserId(order.getUserId()); + userScoreDetail.setType(ScoreDetails.SCORE_TYPE_EXCHANGE); + userScoreDetail.setChangeScore(totalScore.setScale( 0, BigDecimal.ROUND_DOWN )); + userScoreDetail.setOriginalScore(userScore.setScale( 0, BigDecimal.ROUND_DOWN )); + userScoreDetail.setCurrentScore(userScore.add(totalScore).setScale( 0, BigDecimal.ROUND_DOWN )); + userScoreDetail.setCreatedTime(new Date()); + scoreDetailsMapper.insert(userScoreDetail); + + userAccount.setCollectScore(userScore.add(totalScore).setScale( 0, BigDecimal.ROUND_DOWN ).toString()); + accountMapper.updateByPrimaryKey(userAccount); + + // 团长返利 + distribService.distribRecord(order.getId(), order.getUserId()); + // 推荐返利 + distribService.inviteAddOrderScore(order.getUserId(), order.getId().toString()); + } catch (Exception e) { + log.error("异常", e); + throw new RestException("支付失败"); + } finally { + redisUtil.del(key); + } + } else { + throw new RestException("支付中"); } - jhyOrderItemsMapper.deleteItemsByOrderId(confirmDto.getOrderId()); - - BigDecimal totalScore = BigDecimal.ZERO; - for (JhyOrderConfirmItemsDto item : confirmDto.getItems()) { - BigDecimal weight = StrUtil.isNotBlank(item.getWeight()) ? new BigDecimal(item.getWeight()) : BigDecimal.ZERO; - SysEnvironmentalInfo environmentalInfo = environmentalInfoMapper.selectByPrimaryKey(item.getId()); - - JhyOrderItems orderItems = new JhyOrderItems(); - orderItems.setOrderId(confirmDto.getOrderId()); - orderItems.setPicture(environmentalInfo.getPicture()); - orderItems.setItemType(item.getId()); - orderItems.setTitle(environmentalInfo.getTitle()); - orderItems.setPrice(new BigDecimal(environmentalInfo.getPrice())); - BigDecimal total = orderItems.getPrice().multiply(BigDecimal.valueOf(40)).multiply(weight); - orderItems.setScore(total.setScale(0, BigDecimal.ROUND_DOWN).toString()); - orderItems.setWeight(weight); - jhyOrderItemsMapper.insert(orderItems); - - totalScore = totalScore.add(total); - } - - JhyOrder order = jhyOrderMapper.selectByPrimaryKey(confirmDto.getOrderId()); - AccountInfo jhyAccount = accountMapper.selectAccountInfoByUserId(order.getJhyId()); - BigDecimal collectScore = StrUtil.isNotBlank(jhyAccount.getCollectScore()) ? new BigDecimal(jhyAccount.getCollectScore()) : BigDecimal.ZERO; - if (totalScore.compareTo(collectScore) > 0) { - throw new RestException(-3, "剩余积分不足"); - } - - order.setStatus(JhyOrder.ORDER_STATUS_CONFIRM); - order.setReceivingTime(new Date()); - jhyOrderMapper.updateByPrimaryKey(order); - - BigDecimal jhyScore = StrUtil.isBlank(jhyAccount.getCollectScore()) ? BigDecimal.ZERO : new BigDecimal(jhyAccount.getCollectScore()); - ScoreDetails jhyScoreDetail = new ScoreDetails(); - jhyScoreDetail.setOrderNo(order.getOrderNo()); - jhyScoreDetail.setUserId(order.getJhyId()); - jhyScoreDetail.setType(ScoreDetails.SCORE_TYPE_PAY); - jhyScoreDetail.setChangeScore(totalScore.negate().setScale( 0, BigDecimal.ROUND_DOWN )); - jhyScoreDetail.setOriginalScore(jhyScore.setScale( 0, BigDecimal.ROUND_DOWN )); - jhyScoreDetail.setCurrentScore(jhyScore.subtract(totalScore).setScale( 0, BigDecimal.ROUND_DOWN )); - jhyScoreDetail.setCreatedTime(new Date()); - scoreDetailsMapper.insert(jhyScoreDetail); - - jhyAccount.setCollectScore(jhyScore.subtract(totalScore).setScale( 0, BigDecimal.ROUND_DOWN ).toString()); - accountMapper.updateByPrimaryKey(jhyAccount); - - AccountInfo userAccount = accountMapper.selectAccountInfoByUserId(order.getUserId()); - BigDecimal userScore = StrUtil.isBlank(userAccount.getCollectScore()) ? BigDecimal.ZERO : new BigDecimal(userAccount.getCollectScore()); - ScoreDetails userScoreDetail = new ScoreDetails(); - userScoreDetail.setOrderNo(order.getOrderNo()); -// userScoreDetail.setUserId(order.getJhyId()); - userScoreDetail.setUserId(order.getUserId()); - userScoreDetail.setType(ScoreDetails.SCORE_TYPE_EXCHANGE); - userScoreDetail.setChangeScore(totalScore.setScale( 0, BigDecimal.ROUND_DOWN )); - userScoreDetail.setOriginalScore(userScore.setScale( 0, BigDecimal.ROUND_DOWN )); - userScoreDetail.setCurrentScore(userScore.add(totalScore).setScale( 0, BigDecimal.ROUND_DOWN )); - userScoreDetail.setCreatedTime(new Date()); - scoreDetailsMapper.insert(userScoreDetail); - - userAccount.setCollectScore(userScore.add(totalScore).setScale( 0, BigDecimal.ROUND_DOWN ).toString()); - accountMapper.updateByPrimaryKey(userAccount); - - distribService.distribRecord(order.getId(), order.getUserId()); } public Map<Integer, Integer> orderStatusCount(Integer type, String userId) { diff --git a/gc-order/src/main/java/com/xzx/gc/order/service/OrderService.java b/gc-order/src/main/java/com/xzx/gc/order/service/OrderService.java index 2948fdc..940ca37 100644 --- a/gc-order/src/main/java/com/xzx/gc/order/service/OrderService.java +++ b/gc-order/src/main/java/com/xzx/gc/order/service/OrderService.java @@ -226,6 +226,8 @@ @Autowired private OrderHomeApplianceService orderHomeApplianceService; + @Autowired + private DistribService distribService; @@ -1150,6 +1152,7 @@ traceIds = getTrace(orderInfoReq); } + distribService.inviteAddOrderScore(orderInfoReq.getCreateUserId(), orderId); } } } catch (RestException e) { @@ -3291,6 +3294,8 @@ //更新账户余额 accountService.updateMoneyByUserId(receiver, Convert.toBigDecimal(payMoney.toString())); + + distribService.inviteAddOrderScore(createUserId, orderId); return Result.success(byUserId.getAccountName()); } catch (Exception e) { ExceptionUtils.err("支付失败", e); diff --git a/gc-order/src/main/resources/mapper/order/AccountMapper.xml b/gc-order/src/main/resources/mapper/order/AccountMapper.xml index 3fa509e..42c68ad 100644 --- a/gc-order/src/main/resources/mapper/order/AccountMapper.xml +++ b/gc-order/src/main/resources/mapper/order/AccountMapper.xml @@ -92,4 +92,9 @@ <select id="selectAccountInfoByUserId" resultType="com.xzx.gc.entity.AccountInfo"> select * from xzx_account_info where user_id=#{userId} </select> + + <select id="selectAccountInfoByPhone" resultType="com.xzx.gc.entity.AccountInfo"> + select a.* from xzx_account_info a, xzx_user_info b + where a.user_id=b.user_id and b.mobile_phone=#{phone} + </select> </mapper> diff --git a/gc-order/src/main/resources/mapper/order/JhyOrderMapper.xml b/gc-order/src/main/resources/mapper/order/JhyOrderMapper.xml index c4f1b8c..480e24e 100644 --- a/gc-order/src/main/resources/mapper/order/JhyOrderMapper.xml +++ b/gc-order/src/main/resources/mapper/order/JhyOrderMapper.xml @@ -79,4 +79,9 @@ #{id} </foreach> </select> + + <select id="selectJhyOrderNoWaitAndCancel" resultType="com.xzx.gc.entity.JhyOrder"> + select * from xzx_jhy_order + where status not in (1, 2, 5) and user_id=#{userId} + </select> </mapper> \ No newline at end of file diff --git a/gc-order/src/main/resources/mapper/order/OrderMapper.xml b/gc-order/src/main/resources/mapper/order/OrderMapper.xml index fd519bd..20093e6 100644 --- a/gc-order/src/main/resources/mapper/order/OrderMapper.xml +++ b/gc-order/src/main/resources/mapper/order/OrderMapper.xml @@ -1523,5 +1523,8 @@ b.receive_time ASC </select> - + <select id="selectOrderNoWaitAndCancel" resultType="com.xzx.gc.entity.OrderInfo"> + select * from xzx_order_info + where order_status not in ('1', '2', '6') and create_user_id=#{userId} + </select> </mapper> diff --git a/gc-order/src/main/resources/mapper/order/RedPaperRuleMapper.xml b/gc-order/src/main/resources/mapper/order/RedPaperRuleMapper.xml index 1ff327e..9be1d93 100644 --- a/gc-order/src/main/resources/mapper/order/RedPaperRuleMapper.xml +++ b/gc-order/src/main/resources/mapper/order/RedPaperRuleMapper.xml @@ -321,4 +321,8 @@ <select id="selectDistribRule" resultType="com.xzx.gc.entity.RedPaperRule"> select * from xzx_user_redpaper_rule where rule_type=9 </select> + + <select id="selectRuleByType" resultType="com.xzx.gc.entity.RedPaperRule"> + select * from xzx_user_redpaper_rule where rule_type=#{type} + </select> </mapper> \ No newline at end of file diff --git a/gc-order/src/main/resources/mapper/order/UserShareInfoMapper.xml b/gc-order/src/main/resources/mapper/order/UserShareInfoMapper.xml index e1f1ed2..50b7299 100644 --- a/gc-order/src/main/resources/mapper/order/UserShareInfoMapper.xml +++ b/gc-order/src/main/resources/mapper/order/UserShareInfoMapper.xml @@ -165,5 +165,7 @@ </if> </select> - + <select id="selectUserShareInfoByInvited" resultType="com.xzx.gc.entity.UserShareInfo"> + select * from xzx_user_share_info where register_mobile_phone=#{phone}; + </select> </mapper> diff --git a/gc-user/src/main/java/com/xzx/gc/user/controller/ApiDistribController.java b/gc-user/src/main/java/com/xzx/gc/user/controller/ApiDistribController.java index 25e1a5f..8bb8d95 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/controller/ApiDistribController.java +++ b/gc-user/src/main/java/com/xzx/gc/user/controller/ApiDistribController.java @@ -70,4 +70,11 @@ return JsonResult.success(distribService.findHeadTeamListInPage(headTeamDto)); } + @ApiOperation("分享到朋友圈") + @PostMapping(value = "/distrib/shareMoments") + public JsonResult<String> shareMoments(HttpServletRequest request) { + distribService.shareToMoments(getUserId(request)); + return JsonResult.success("分享成功"); + } + } diff --git a/gc-user/src/main/java/com/xzx/gc/user/mapper/AccountMapper.java b/gc-user/src/main/java/com/xzx/gc/user/mapper/AccountMapper.java index 6c0335f..c8c6f09 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/mapper/AccountMapper.java +++ b/gc-user/src/main/java/com/xzx/gc/user/mapper/AccountMapper.java @@ -78,5 +78,7 @@ String selectJDSLExportByHeadUserId(@Param("accountId")String id, @Param("record")ExportDistribDataListDto distribDataListDto); List<AccountInfo> selectAccountInfoByIds(@Param("list") List<String> list); + + AccountInfo selectAccountInfoByPhone(@Param("phone") String phone); } diff --git a/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java b/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java index 95d9dc8..9de084f 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java +++ b/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java @@ -4,9 +4,13 @@ import com.xzx.gc.util.GcMapper; import org.apache.ibatis.annotations.Param; +import java.util.List; + public interface RedPaperRuleMapper extends GcMapper<RedPaperRule> { RedPaperRule getOne(@Param("now") String now, @Param("ruleType") String ruleType, @Param("partnerId") String partnerId); RedPaperRule selectByRuleName(@Param("ruleStr")String ruleStr); + + List<RedPaperRule> selectByRuleType(@Param("type") String type); } \ No newline at end of file diff --git a/gc-user/src/main/java/com/xzx/gc/user/mapper/ScoreDetailsMapper.java b/gc-user/src/main/java/com/xzx/gc/user/mapper/ScoreDetailsMapper.java new file mode 100644 index 0000000..ac7d554 --- /dev/null +++ b/gc-user/src/main/java/com/xzx/gc/user/mapper/ScoreDetailsMapper.java @@ -0,0 +1,7 @@ +package com.xzx.gc.user.mapper; + +import com.xzx.gc.entity.ScoreDetails; +import com.xzx.gc.util.GcMapper; + +public interface ScoreDetailsMapper extends GcMapper<ScoreDetails> { +} diff --git a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java index 598264b..10489b6 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java +++ b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java @@ -6,7 +6,9 @@ import cn.hutool.core.date.DateUtil; import com.github.pagehelper.PageHelper; import com.github.pagehelper.PageInfo; +import com.xzx.gc.common.constant.CommonEnum; import com.xzx.gc.common.exception.RestException; +import com.xzx.gc.common.utils.RedisUtil; import com.xzx.gc.common.utils.StringUtils; import com.xzx.gc.entity.*; import com.xzx.gc.user.dto.*; @@ -30,6 +32,7 @@ import javax.annotation.Resource; import java.math.BigDecimal; +import java.math.RoundingMode; import java.util.HashMap; import java.util.List; @@ -55,6 +58,10 @@ private UserShareInfoMapper userShareInfoMapper; @Autowired private SysMessageMapper sysMessageMapper; + @Autowired + private RedisUtil redisUtil; + @Autowired + private ScoreDetailsMapper scoreDetailsMapper; public ViewSettingVo viewSetting(String ruleStr) { ViewSettingVo viewSettingVo = new ViewSettingVo(); @@ -468,4 +475,104 @@ redPaperRuleMapper.updateByPrimaryKey(redPaperRule); } } + + public void shareToMoments(String userId) { + List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10"); + if (CollUtil.isEmpty(redPaperRules)) { + return; + } + + RedPaperRule rule = redPaperRules.get(0); + String shareTimes = getRuleValue(rule, CommonEnum.朋友圈分享限次.getValue()); + + String shareScore = getRuleValue(rule, CommonEnum.朋友圈分享奖励.getValue()); + String key = "moments:times:" + userId; + Integer times = redisUtil.getAsInt("moments:times:" + userId); + times = times == null ? 1 : times + 1; + + if (StrUtil.isNotBlank(shareTimes)) { + if (times > Integer.parseInt(shareTimes)) { + throw new RestException("达到24小时内最大分享次数"); + } + + if (StrUtil.isBlank(shareScore)) { + return; + } + + AccountInfo accountInfo = accountMapper.selectOneByUserId(userId); + BigDecimal returnScore = new BigDecimal(shareScore); + BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO; + accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString()); + accountMapper.updateByPrimaryKey(accountInfo); + + ScoreDetails scoreDetails = new ScoreDetails(); + scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore())); + scoreDetails.setOriginalScore(collectScore); + scoreDetails.setChangeScore(returnScore); + scoreDetails.setCreatedTime(new Date()); + scoreDetails.setType(ScoreDetails.SCORE_TYPE_SHARE_MOMENTS); + scoreDetails.setUserId(accountInfo.getUserId()); + scoreDetailsMapper.insert(scoreDetails); + + SysMessage sysMessage = new SysMessage(); + sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss")); + sysMessage.setCreateUserId(accountInfo.getUserId()); + sysMessage.setUserId(accountInfo.getUserId()); + sysMessage.setMessageType("4"); + sysMessage.setMessageSubTypeName("朋友圈分享"); + sysMessage.setMessage("朋友圈分享, 积分:" + returnScore); + sysMessage.setFlag("2"); + sysMessageMapper.insert(sysMessage); + + redisUtil.setex(key, times.toString(), 84400); + } + } + + public void inviteAward(String phone) { + AccountInfo accountInfo = accountMapper.selectAccountInfoByPhone(phone); + + List<RedPaperRule> redPaperRules = redPaperRuleMapper.selectByRuleType("10"); + if (CollUtil.isEmpty(redPaperRules)) { + return; + } + + RedPaperRule rule = redPaperRules.get(0); + String invite = getRuleValue(rule, CommonEnum.邀请奖励.getValue()); + + if (StrUtil.isBlank(invite)) { + return; + } + + BigDecimal returnScore = new BigDecimal(invite); + BigDecimal collectScore = StrUtil.isNotBlank(accountInfo.getCollectScore()) ? new BigDecimal(accountInfo.getCollectScore()) : BigDecimal.ZERO; + accountInfo.setCollectScore(collectScore.add(returnScore).setScale(0, RoundingMode.DOWN).toString()); + accountMapper.updateByPrimaryKey(accountInfo); + + ScoreDetails scoreDetails = new ScoreDetails(); + scoreDetails.setCurrentScore(new BigDecimal(accountInfo.getCollectScore())); + scoreDetails.setOriginalScore(collectScore); + scoreDetails.setChangeScore(returnScore); + scoreDetails.setCreatedTime(new Date()); + scoreDetails.setType(ScoreDetails.SCORE_TYPE_INVITE); + scoreDetails.setUserId(accountInfo.getUserId()); + scoreDetailsMapper.insert(scoreDetails); + + SysMessage sysMessage = new SysMessage(); + sysMessage.setCreateTime(DateUtil.format(new Date(), "yyyy-MM-dd HH:mm:ss")); + sysMessage.setCreateUserId(accountInfo.getUserId()); + sysMessage.setUserId(accountInfo.getUserId()); + sysMessage.setMessageType("4"); + sysMessage.setMessageSubTypeName("邀请奖励"); + sysMessage.setMessage("邀请奖励, 积分:" + returnScore); + sysMessage.setFlag("2"); + sysMessageMapper.insert(sysMessage); + } + + private String getRuleValue(RedPaperRule redPaperRule, String key) { + List<String> rules = StrUtil.split(redPaperRule.getSharingProfitType(), ','); + List<String> values = StrUtil.split(redPaperRule.getShareRatio(), ','); + + int i = rules.indexOf(key); + return values.get(i); + } } diff --git a/gc-user/src/main/java/com/xzx/gc/user/service/UserLoginService.java b/gc-user/src/main/java/com/xzx/gc/user/service/UserLoginService.java index 50c4e8c..de58a69 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/service/UserLoginService.java +++ b/gc-user/src/main/java/com/xzx/gc/user/service/UserLoginService.java @@ -93,6 +93,8 @@ @Autowired private AccountService accountService; + @Autowired + private DistribService distribService; @@ -166,6 +168,7 @@ public int login(UserReq userReq) { + log.info("邀请人手机号:{}", userReq.getRegisterMobilePhone()); int notCheckLoginFlag = userReq.getNotCheckLoginFlag(); if(StringUtils.isBlank(userReq.getOpenId())){ return -4; @@ -246,6 +249,8 @@ userShareInfo.setRegisterTime(DateUtil.now()); userShareInfoMapper.insertSelective(userShareInfo); log.info("用户绑定成功,邀请人:{},被邀请人:{}", userShareInfo.getMobilePhone(), userShareInfo.getRegisterMobilePhone()); + + distribService.inviteAward(userShareInfo.getMobilePhone()); }else{ log.warn("邀请人:{}不是普通用户",userShareInfo.getMobilePhone()); } diff --git a/gc-user/src/main/resources/mapper/user/AccountMapper.xml b/gc-user/src/main/resources/mapper/user/AccountMapper.xml index e30a1fb..a417c05 100644 --- a/gc-user/src/main/resources/mapper/user/AccountMapper.xml +++ b/gc-user/src/main/resources/mapper/user/AccountMapper.xml @@ -554,4 +554,9 @@ #{id} </foreach> </select> + + <select id="selectAccountInfoByPhone" resultType="com.xzx.gc.entity.AccountInfo"> + select a.* from xzx_account_info a, xzx_user_info b + where a.user_id=b.user_id and b.mobile_phone=#{phone} + </select> </mapper> diff --git a/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml b/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml index 6bcc8b1..f7f71ef 100644 --- a/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml +++ b/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml @@ -21,4 +21,8 @@ <select id="selectByRuleName" resultType="com.xzx.gc.entity.RedPaperRule"> select * from xzx_user_redpaper_rule where rule_name = #{ruleStr} </select> + + <select id="selectByRuleType" resultType="com.xzx.gc.entity.RedPaperRule"> + select * from xzx_user_redpaper_rule where rule_type=#{type} + </select> </mapper> \ No newline at end of file diff --git a/gc-user/src/main/resources/mapper/user/ScoreDetailsMapper.xml b/gc-user/src/main/resources/mapper/user/ScoreDetailsMapper.xml new file mode 100644 index 0000000..ece4dde --- /dev/null +++ b/gc-user/src/main/resources/mapper/user/ScoreDetailsMapper.xml @@ -0,0 +1,5 @@ +<?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.xzx.gc.user.mapper.ScoreDetailsMapper"> + +</mapper> \ No newline at end of file -- Gitblit v1.9.1