From 7e7db2fa55a9a3af46d4fd8ede0dee147f101d64 Mon Sep 17 00:00:00 2001 From: yujian <yujian@163.com> Date: 星期六, 09 五月 2020 21:41:27 +0800 Subject: [PATCH] 2.1需求 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java | 290 +++++++++++++++++++++++++++++++++------------------------ 1 files changed, 166 insertions(+), 124 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java index 4423789..6947f30 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/vip/UserVIPInfoServiceImpl.java @@ -1,6 +1,5 @@ package com.yeshi.fanli.service.impl.user.vip; -import java.util.ArrayList; import java.util.Date; import java.util.HashMap; import java.util.List; @@ -12,42 +11,40 @@ import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; +import com.aliyun.openservices.ons.api.Message; +import com.aliyun.openservices.ons.api.Producer; import com.yeshi.fanli.dao.mybatis.user.vip.UserVIPInfoMapper; -import com.yeshi.fanli.dto.msg.MsgAccountVipDTO; -import com.yeshi.fanli.dto.msg.MsgOtherSystemGiveDTO; -import com.yeshi.fanli.entity.bus.msg.MsgAccountDetail; -import com.yeshi.fanli.entity.bus.msg.MsgAccountDetail.MsgTypeAccountTypeEnum; -import com.yeshi.fanli.entity.bus.msg.MsgOtherDetail.MsgTypeOtherTypeEnum; -import com.yeshi.fanli.entity.bus.user.HongBaoV2; +import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum; +import com.yeshi.fanli.dto.mq.user.body.UserLevelChangedMQMsg; +import com.yeshi.fanli.entity.bus.user.ThreeSale; import com.yeshi.fanli.entity.bus.user.UserInfo; -import com.yeshi.fanli.entity.bus.user.UserInfoExtra; import com.yeshi.fanli.entity.bus.user.UserInviteValidNum; -import com.yeshi.fanli.entity.bus.user.UserSystemCoupon; +import com.yeshi.fanli.entity.bus.user.vip.UserLevelEnum; +import com.yeshi.fanli.entity.bus.user.vip.UserLevelUpgradedNotify; import com.yeshi.fanli.entity.bus.user.vip.UserVIPInfo; import com.yeshi.fanli.entity.bus.user.vip.UserVIPPreInfo; -import com.yeshi.fanli.entity.system.SystemCoupon.CouponTypeEnum; -import com.yeshi.fanli.exception.msg.MsgAccountDetailException; +import com.yeshi.fanli.entity.common.Config; +import com.yeshi.fanli.entity.system.ConfigKeyEnum; import com.yeshi.fanli.exception.user.vip.UserVIPInfoException; +import com.yeshi.fanli.exception.user.vip.UserVIPPreInfoException; +import com.yeshi.fanli.log.LogHelper; import com.yeshi.fanli.service.inter.config.ConfigService; import com.yeshi.fanli.service.inter.count.HongBaoV2CountService; -import com.yeshi.fanli.service.inter.msg.UserOtherMsgNotificationService; -import com.yeshi.fanli.service.inter.shop.BanLiShopOrderService; -import com.yeshi.fanli.service.inter.user.UserInfoExtraService; import com.yeshi.fanli.service.inter.user.UserInfoService; -import com.yeshi.fanli.service.inter.user.UserInviteSeparateService; -import com.yeshi.fanli.service.inter.user.UserSystemCouponService; -import com.yeshi.fanli.service.inter.user.integral.IntegralDetailService; import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce; +import com.yeshi.fanli.service.inter.user.invite.UserInviteMsgNotificationService; import com.yeshi.fanli.service.inter.user.invite.UserInviteValidNumService; -import com.yeshi.fanli.service.inter.user.msg.MsgAccountDetailService; +import com.yeshi.fanli.service.inter.user.msg.UserAccountMsgNotificationService; +import com.yeshi.fanli.service.inter.user.vip.UserLevelUpgradedNotifyService; import com.yeshi.fanli.service.inter.user.vip.UserVIPInfoService; import com.yeshi.fanli.service.inter.user.vip.UserVIPPreInfoService; import com.yeshi.fanli.service.inter.user.vip.UserVipConfigService; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.StringUtil; -import com.yeshi.fanli.vo.msg.ClientTextStyleVO; -import com.yeshi.fanli.vo.msg.CommonMsgItemVO; -import com.yeshi.fanli.vo.msg.CommonMsgItemVOFactory; +import com.yeshi.fanli.util.TimeUtil; +import com.yeshi.fanli.util.email.MailSenderUtil; +import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory; +import com.yeshi.fanli.util.rocketmq.MQTopicName; @Service public class UserVIPInfoServiceImpl implements UserVIPInfoService { @@ -59,9 +56,6 @@ private UserInfoService userInfoService; @Resource - private UserInfoExtraService userInfoExtraService; - - @Resource private UserVipConfigService userVipConfigService; @Lazy @@ -69,35 +63,28 @@ private HongBaoV2CountService hongBaoV2CountService; @Resource - private IntegralDetailService integralDetailService; - - @Resource - private BanLiShopOrderService banLiShopOrderService; - - @Resource - private UserOtherMsgNotificationService userOtherMsgNotificationService; - - @Resource private ThreeSaleSerivce threeSaleSerivce; - - @Resource - private UserInviteSeparateService userInviteSeparateService; - - @Resource - private ConfigService configService; - - @Lazy - @Resource - private UserSystemCouponService userSystemCouponService; @Resource private UserVIPPreInfoService userVIPPreInfoService; @Resource - private MsgAccountDetailService msgAccountDetailService; - + private UserAccountMsgNotificationService userAccountMsgNotificationService; + @Resource private UserInviteValidNumService userInviteValidNumService; + + @Resource + private UserLevelUpgradedNotifyService userLevelUpgradedNotifyService; + + @Resource + private UserInviteMsgNotificationService userInviteMsgNotificationService; + + @Resource(name = "producer") + private Producer producer; + + @Resource + private ConfigService configService; @Override @Transactional(rollbackFor = Exception.class) @@ -114,7 +101,6 @@ info.setCreateTime(new Date()); userVIPInfoMapper.insert(info); } - @Override public boolean isVIP(Long uid) { @@ -157,7 +143,6 @@ return map; } - @Override public List<UserVIPInfo> listQuery(int page, int count, String key, Integer state) { return userVIPInfoMapper.listQuery((page - 1) * count, count, key, state); @@ -168,7 +153,6 @@ return userVIPInfoMapper.countQuery(key, state); } - @Transactional(rollbackFor = Exception.class) @Override public void applyVIP(Long uid) throws UserVIPInfoException { @@ -177,19 +161,19 @@ throw new UserVIPInfoException(1, "璇峰厛鍗囩骇涓洪珮绾т細鍛�"); } - if (!verifyVip(uid)) + int verifyResult = verifyVip(uid); + if (verifyResult <= 0) throw new UserVIPInfoException(1, "涓嶆弧瓒冲崌绾ф潯浠�"); UserVIPInfo userInfo = userVIPInfoMapper.selectByPrimaryKeyForUpdate(uid); if (userInfo == null) { userInfo = new UserVIPInfo(); userInfo.setId(uid); - // 娣诲姞璁板綍 addUserVIPInfo(userInfo); } if (userInfo.getState() != UserVIPInfo.STATE_INVALID) - throw new UserVIPInfoException(2, "宸茬粡鐢宠杩�"); + throw new UserVIPInfoException(2, "绯荤粺宸叉敹鍒颁綘鐨勮秴绾т細鍛樺崌绾х敵璇凤紝灏嗕細灏藉揩瀹屾垚瀹℃牳"); UserVIPInfo info = new UserVIPInfo(); info.setId(userInfo.getId()); @@ -197,19 +181,21 @@ info.setState(UserVIPInfo.STATE_VERIFING); info.setUpdateTime(new Date()); userVIPInfoMapper.updateByPrimaryKeySelective(info); - - MsgAccountDetail detail = new MsgAccountDetail(); - detail.setTitle("灏婃暚鐨勯珮绾т細鍛橈紝绯荤粺宸叉敹鍒颁綘鐨勮秴绾т細鍛樺崌绾х敵璇凤紝姝e湪鍙楃悊涓�"); - detail.setBeiZhu("濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇"); - detail.setRead(false); - detail.setCreateTime(new Date()); - detail.setUser(new UserInfo(uid)); - detail.setContent("鎴戜滑灏嗕細鍦�48灏忔椂鍐呭畬鎴愬鏍�"); - detail.setType(MsgTypeAccountTypeEnum.vipApply); + // 鍙戦�侀偖浠堕�氱煡 try { - msgAccountDetailService.addMsgAccountDetail(detail); - } catch (MsgAccountDetailException e) { - e.printStackTrace(); + Config config = configService.getConfig(ConfigKeyEnum.extractCodeEmailFrom.getKey()); + String[] sts = config.getValue().split(","); + String account = sts[0]; + String pwd = sts[1]; + + String msg = String.format("鐢ㄦ埛ID:%s 鐢宠瓒呯骇浼氬憳", uid + ""); + String email = userVipConfigService.getValueByKey("apply_vip_email"); + String[] emails = email.split(","); + for (String e : emails) { + MailSenderUtil.sendEmail(e, account, pwd, msg, msg); + } + } catch (Exception e) { + LogHelper.errorDetailInfo(e); } } @@ -229,51 +215,65 @@ throw new UserVIPInfoException(1, "璇ョ敤鎴疯繕涓嶆槸楂樼骇浼氬憳"); } - if (!verifyVip(uid)) + int verifyVipResult = verifyVip(uid); + + if (verifyVipResult <= 0) throw new UserVIPInfoException(1, "绯荤粺楠岃瘉锛氫笉婊¤冻鍗囩骇鏉′欢"); - // 棰濆淇℃伅 - UserInfoExtra userInfoExtra = userInfoExtraService.getByUidForUpdate(uid); - if (userInfoExtra == null) - throw new UserVIPInfoException(1, "鐢ㄦ埛淇℃伅涓嶅瓨鍦�"); - + Date upgradeTime = new Date(); // 閫氳繃瓒呯骇浼氬憳 UserVIPInfo info = new UserVIPInfo(); info.setId(userVIPInfo.getId()); - info.setSuccessTime(new Date()); + info.setSuccessTime(upgradeTime); info.setState(UserVIPInfo.STATE_SUCCESS); - info.setUpdateTime(new Date()); + info.setUpdateTime(upgradeTime); userVIPInfoMapper.updateByPrimaryKeySelective(info); + UserVIPPreInfo preInfo = new UserVIPPreInfo(); + preInfo.setCreateTime(new Date()); + preInfo.setProcess(UserLevelEnum.superVIP.getLevel()); + preInfo.setSourceType(verifyVipResult); + preInfo.setUid(uid); + try { - // 璧犻�佸厤鍗曞埜 - String giveCoupon = userVipConfigService.getValueByKey("vip_pre_10_gift_givefree_coupon"); - if (!StringUtil.isNullOrEmpty(giveCoupon)) { - int num = Integer.parseInt(giveCoupon); - for (int i = 0; i < num; i++) { - userSystemCouponService.insertUserCoupon(uid, CouponTypeEnum.freeCouponGive.name(), - UserSystemCoupon.SOURCE_SYSTEM_PUSH, null, false); - } - - // 娑堟伅 - List<CommonMsgItemVO> listMsg = new ArrayList<>(); - listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("鐘� 鎬�", ClientTextStyleVO.COLOR_TITLE), - new ClientTextStyleVO("鎭枩浣狅紒鎴愬姛鍗囩骇涓鸿秴绾т細鍛�", ClientTextStyleVO.COLOR_CONTENT))); - listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("濂� 鍔�", ClientTextStyleVO.COLOR_TITLE), - new ClientTextStyleVO("鑾峰緱璧犻�佸厤鍗曞埜" + num +"寮�", ClientTextStyleVO.COLOR_CONTENT))); - listMsg.add(CommonMsgItemVOFactory.createMsgItemVO(new ClientTextStyleVO("澶� 娉�", ClientTextStyleVO.COLOR_TITLE), - new ClientTextStyleVO("璇︽儏鏌ョ湅锛屽搴斾細鍛樻潈鐩�", ClientTextStyleVO.COLOR_CONTENT))); - userOtherMsgNotificationService.createMsgOtherDetail(uid, listMsg, MsgTypeOtherTypeEnum.vipUpgradeReward); + userVIPPreInfoService.addUserVIPPreInfo(preInfo); + } catch (UserVIPPreInfoException e1) { + throw new UserVIPInfoException(100, "鍗囩骇澶辫触"); + } + + // 鍗囩骇寮规鎻愮ず + UserLevelUpgradedNotify notify = new UserLevelUpgradedNotify(); + notify.setUid(uid); + notify.setFromLevel(UserLevelEnum.highVIP); + notify.setToLevel(UserLevelEnum.superVIP); + notify.setValid(true); + notify.setCreateTime(new Date()); + userLevelUpgradedNotifyService.addUserLevelUpgradedNotify(notify); + + try { + // 鍗囩骇娑堟伅 + UserVIPPreInfo pre1 = userVIPPreInfoService.getVipByProcess(uid, UserVIPPreInfo.PROCESS_2); + userAccountMsgNotificationService.vipUpgradeSuccess(uid, + TimeUtil.getDayDifferenceCount(pre1.getCreateTime(), new Date())); + + // 鐩存帴绮変笣鍗囩骇鎻愰啋 + ThreeSale threeSale = threeSaleSerivce.getMyBoss(uid); + if (threeSale != null) { + Long bossId = threeSale.getBoss().getId(); + UserInfo userInfo = userInfoService.selectByPKey(uid); + userInviteMsgNotificationService.fansUpgrade(bossId, "瓒呯骇浼氬憳", userInfo.getNickName(), getPassItem(uid), + upgradeTime); } } catch (Exception e) { - throw new UserVIPInfoException(1, "鍒歌禒閫佸け璐�"); + e.printStackTrace(); } - - // 娑堟伅 - MsgAccountVipDTO msgDto = new MsgAccountVipDTO(); - msgDto.setStatus("宸插皢浣犵殑璐︽埛鐢遍珮绾т細鍛樺崌绾т负瓒呯骇浼氬憳"); - msgDto.setEquity("浠庢敹鍒版湰娑堟伅璧凤紝浣犲皢鑾峰緱鍏ㄩ儴瓒呯骇浼氬憳鏉冪泭"); - msgAccountDetailService.addMsgVIP(uid, "鎭枩浣狅紒缁忎汉宸ュ鏍镐綘婊¤冻鍗囩骇瓒呯骇浼氬憳鏉′欢", "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgDto); + + if (!Constant.IS_TEST) { + UserLevelChangedMQMsg msg = new UserLevelChangedMQMsg(uid, UserLevelEnum.highVIP, UserLevelEnum.superVIP, + new Date()); + Message message = MQMsgBodyFactory.create(MQTopicName.TOPIC_USER, UserTopicTagEnum.userLevelChanged, msg); + producer.send(message); + } } /** @@ -281,14 +281,9 @@ * @param uid * @return */ - private boolean verifyVip(Long uid) { - // 鑷喘璁㈠崟 - long doneZiGou = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY, - HongBaoV2.TYPE_ZIGOU); - // 鍒嗕韩璁㈠崟 - long doneShare = hongBaoV2CountService.counOrderByUidAndOrderType(uid, Constant.VIP_ORDER_PAY, - HongBaoV2.TYPE_SHARE_GOODS); - + private String getPassItem(Long uid) { + // 鑷喘 + 鍒嗕韩璁㈠崟 + long doneOrder = hongBaoV2CountService.countMyDirectOrderByCashArrival(uid, Constant.VIP_ORDER_PAY); // 鏈夋晥绮変笣 int doneFirst = 0; int doneSecond = 0; @@ -298,34 +293,79 @@ doneSecond = userInviteValidNum.getNumSecond() == null ? 0 : userInviteValidNum.getNumSecond(); } - long limitZiGou = 0; - String zigou = userVipConfigService.getValueByKey("vip_pre_10_zigou_order_count"); + long limitOrder = 0; + String zigou = userVipConfigService.getValueByKey("vip_pre_10_order_count"); if (!StringUtil.isNullOrEmpty(zigou)) { - limitZiGou = Long.parseLong(zigou); + limitOrder = Long.parseLong(zigou); } - - long limitShare = 0; - String share = userVipConfigService.getValueByKey("vip_pre_10_share_order_count"); - if (!StringUtil.isNullOrEmpty(share)) { - limitShare = Long.parseLong(share); - } - + long limitFirst = 0; String first = userVipConfigService.getValueByKey("vip_pre_10_first_level_team_count"); if (!StringUtil.isNullOrEmpty(first)) { limitFirst = Long.parseLong(first); } - + long limitSecond = 0; String second = userVipConfigService.getValueByKey("vip_pre_10_second_level_team_count"); if (!StringUtil.isNullOrEmpty(second)) { limitSecond = Long.parseLong(second); } - - if (doneZiGou >= limitZiGou || doneShare >= limitShare || (doneFirst >= limitFirst && doneSecond >= limitSecond)) { - return true; + + String item = ""; + if (doneOrder >= limitOrder) { + item = "杩斿埄+鍒嗕韩璁㈠崟"; + } else if (doneFirst >= limitFirst && doneSecond >= limitSecond) { + item = "鐩存帴+闂存帴绮変笣"; } - return false; + return item; + } + + /** + * 楠岃瘉鏄惁绗﹀悎VIP + * @Title: verifyVip + * @Description: + * @param uid + * @return 0-涓嶇鍚� 1-璁㈠崟 2-鍥㈤槦 + * int 杩斿洖绫诲瀷 + * @throws + */ + private int verifyVip(Long uid) { + // 鑷喘 + 鍒嗕韩璁㈠崟 + long doneOrder = hongBaoV2CountService.countMyDirectOrderByCashArrival(uid, Constant.VIP_ORDER_PAY); + // 鏈夋晥绮変笣 + int doneFirst = 0; + int doneSecond = 0; + UserInviteValidNum userInviteValidNum = userInviteValidNumService.selectByPrimaryKey(uid); + if (userInviteValidNum != null) { + doneFirst = userInviteValidNum.getNumFirst() == null ? 0 : userInviteValidNum.getNumFirst(); + doneSecond = userInviteValidNum.getNumSecond() == null ? 0 : userInviteValidNum.getNumSecond(); + } + long limitOrder = 0; + String zigou = userVipConfigService.getValueByKey("vip_pre_10_order_count"); + if (!StringUtil.isNullOrEmpty(zigou)) { + limitOrder = Long.parseLong(zigou); + } + + long limitFirst = 0; + String first = userVipConfigService.getValueByKey("vip_pre_10_first_level_team_count"); + if (!StringUtil.isNullOrEmpty(first)) { + limitFirst = Long.parseLong(first); + } + + long limitSecond = 0; + String second = userVipConfigService.getValueByKey("vip_pre_10_second_level_team_count"); + if (!StringUtil.isNullOrEmpty(second)) { + limitSecond = Long.parseLong(second); + } + + if (doneOrder >= limitOrder) { + return UserVIPPreInfo.SOURCE_TYPE_ORDER; + } + + if ((doneFirst >= limitFirst && doneSecond >= limitSecond)) + + return UserVIPPreInfo.SOURCE_TYPE_TEAM; + return 0; } @Transactional(rollbackFor = Exception.class) @@ -343,13 +383,15 @@ info.setId(userInfo.getId()); info.setState(UserVIPInfo.STATE_INVALID); info.setUpdateTime(new Date()); + info.setBeiZhu(reason); userVIPInfoMapper.updateByPrimaryKeySelective(info); - // 娑堟伅 - MsgAccountVipDTO msgDto = new MsgAccountVipDTO(); - msgDto.setStatus("浣犵殑璐﹀彿浠嶆槸楂樼骇浼氬憳"); - msgDto.setReason(reason); - msgAccountDetailService.addMsgVIP(uid, "寰堟姳姝夛紒缁忎汉宸ュ鏍镐綘鏈弧瓒虫垨涓嶇鍚堝崌绾ц秴绾т細鍛樼殑鏉′欢", "濡傛湁鐤戦棶璇疯仈绯绘垜鐨�-浜哄伐瀹㈡湇", msgDto); + userAccountMsgNotificationService.vipUpgradeFail(uid, reason); + } + + @Override + public void deleteByPrimaryKey(Long id) { + userVIPInfoMapper.deleteByPrimaryKey(id); } } -- Gitblit v1.8.0