From dc5be7d38446f70e6ff86df311119c32b41fe7f8 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期六, 28 十一月 2020 16:37:05 +0800 Subject: [PATCH] 大淘客搜索接口升级 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java | 159 ++++++++++++++++++++-------------------------------- 1 files changed, 62 insertions(+), 97 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java index c4abba5..8275f3a 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java @@ -1,28 +1,6 @@ package com.yeshi.fanli.service.impl.user; -import java.math.BigDecimal; -import java.text.ParseException; -import java.text.SimpleDateFormat; -import java.util.ArrayList; -import java.util.Date; -import java.util.HashMap; -import java.util.List; -import java.util.Map; - -import javax.annotation.Resource; - -import org.springframework.context.annotation.Lazy; -import org.springframework.core.task.TaskExecutor; -import org.springframework.jdbc.datasource.DataSourceTransactionManager; -import org.springframework.scheduling.annotation.Async; -import org.springframework.stereotype.Service; -import org.springframework.transaction.annotation.Transactional; -import org.springframework.transaction.support.DefaultTransactionDefinition; -import org.yeshi.utils.DateUtil; -import org.yeshi.utils.entity.DateInfo; - import com.aliyun.openservices.ons.api.Message; -import com.aliyun.openservices.ons.api.Producer; import com.aliyun.openservices.ons.api.SendResult; import com.aliyun.openservices.ons.api.transaction.LocalTransactionExecuter; import com.aliyun.openservices.ons.api.transaction.TransactionProducer; @@ -30,17 +8,10 @@ import com.yeshi.fanli.dao.mybatis.user.UserSystemCouponMapper; import com.yeshi.fanli.dto.mq.user.UserTopicTagEnum; import com.yeshi.fanli.dto.mq.user.body.UserSystemCouponUseMQMsg; +import com.yeshi.fanli.entity.SystemEnum; import com.yeshi.fanli.entity.accept.AcceptData; -import com.yeshi.fanli.entity.bus.user.HongBaoV2; -import com.yeshi.fanli.entity.bus.user.Order; -import com.yeshi.fanli.entity.bus.user.TokenRecord; +import com.yeshi.fanli.entity.bus.user.*; import com.yeshi.fanli.entity.bus.user.TokenRecord.TokenTypeEnum; -import com.yeshi.fanli.entity.bus.user.UserInfo; -import com.yeshi.fanli.entity.bus.user.UserInfoExtra; -import com.yeshi.fanli.entity.bus.user.UserSystemCoupon; -import com.yeshi.fanli.entity.bus.user.UserSystemCouponActivate; -import com.yeshi.fanli.entity.bus.user.UserSystemCouponGiveRecord; -import com.yeshi.fanli.entity.bus.user.UserSystemCouponRecord; import com.yeshi.fanli.entity.common.JumpDetailV2; import com.yeshi.fanli.entity.money.UserMoneyDetail; import com.yeshi.fanli.entity.order.CommonOrder; @@ -48,7 +19,7 @@ import com.yeshi.fanli.entity.system.ConfigKeyEnum; import com.yeshi.fanli.entity.system.SystemCoupon; import com.yeshi.fanli.entity.system.SystemCoupon.CouponTypeEnum; -import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief; +import com.yeshi.goods.facade.entity.taobao.TaoBaoGoodsBrief; import com.yeshi.fanli.exception.user.UserSystemCouponException; import com.yeshi.fanli.log.LogHelper; import com.yeshi.fanli.service.inter.common.JumpDetailV2Service; @@ -57,41 +28,38 @@ import com.yeshi.fanli.service.inter.money.UserMoneyDetailService; import com.yeshi.fanli.service.inter.money.msg.UserMoneyMsgNotificationService; import com.yeshi.fanli.service.inter.msg.UserOtherMsgNotificationService; -import com.yeshi.fanli.service.inter.order.CommonOrderCountService; -import com.yeshi.fanli.service.inter.order.CommonOrderService; -import com.yeshi.fanli.service.inter.order.HongBaoOrderService; -import com.yeshi.fanli.service.inter.order.HongBaoV2Service; -import com.yeshi.fanli.service.inter.order.OrderHongBaoMapService; -import com.yeshi.fanli.service.inter.order.OrderService; -import com.yeshi.fanli.service.inter.push.PushCouponRecordService; -import com.yeshi.fanli.service.inter.push.PushCouponService; -import com.yeshi.fanli.service.inter.user.TokenRecordService; -import com.yeshi.fanli.service.inter.user.UserInfoExtraService; -import com.yeshi.fanli.service.inter.user.UserInfoService; -import com.yeshi.fanli.service.inter.user.UserSystemCouponActivateService; -import com.yeshi.fanli.service.inter.user.UserSystemCouponGiveRecordService; -import com.yeshi.fanli.service.inter.user.UserSystemCouponRecordService; -import com.yeshi.fanli.service.inter.user.UserSystemCouponService; -import com.yeshi.fanli.service.inter.user.invite.ThreeSaleSerivce; +import com.yeshi.fanli.service.inter.order.*; +import com.yeshi.fanli.service.inter.user.*; import com.yeshi.fanli.service.inter.user.invite.UserInviteService; -import com.yeshi.fanli.util.Constant; -import com.yeshi.fanli.util.MoneyBigDecimalUtil; -import com.yeshi.fanli.util.RedisManager; -import com.yeshi.fanli.util.StringUtil; -import com.yeshi.fanli.util.TimeUtil; -import com.yeshi.fanli.util.TokenUtil; -import com.yeshi.fanli.util.VersionUtil; +import com.yeshi.fanli.service.manger.msg.RocketMQManager; +import com.yeshi.fanli.util.*; import com.yeshi.fanli.util.annotation.RequestSerializableByKeyService; import com.yeshi.fanli.util.factory.UserMoneyDetailFactory; import com.yeshi.fanli.util.rocketmq.MQMsgBodyFactory; import com.yeshi.fanli.util.rocketmq.MQTopicName; import com.yeshi.fanli.util.taobao.TaoBaoUtil; -import com.yeshi.fanli.vo.msg.ClientTextStyleVO; +import com.yeshi.common.vo.ClientTextStyleVO; import com.yeshi.fanli.vo.order.CommonOrderVO; import com.yeshi.fanli.vo.user.UserSystemCouponRecordVO; import com.yeshi.fanli.vo.user.UserSystemCouponVO; - import net.sf.json.JSONObject; +import org.springframework.context.annotation.Lazy; +import org.springframework.core.task.TaskExecutor; +import org.springframework.jdbc.datasource.DataSourceTransactionManager; +import org.springframework.scheduling.annotation.Async; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import org.springframework.transaction.support.DefaultTransactionDefinition; +import org.yeshi.utils.DateUtil; +import org.yeshi.utils.MoneyBigDecimalUtil; +import org.yeshi.utils.TimeUtil; +import org.yeshi.utils.entity.DateInfo; + +import javax.annotation.Resource; +import java.math.BigDecimal; +import java.text.ParseException; +import java.text.SimpleDateFormat; +import java.util.*; @Service public class UserSystemCouponServiceImpl implements UserSystemCouponService { @@ -149,22 +117,9 @@ @Resource private UserInfoExtraService userInfoExtraService; - @Resource - private ThreeSaleSerivce threeSaleSerivce; @Resource private UserOtherMsgNotificationService userOtherMsgNotificationService; - - @Lazy - @Resource - private CommonOrderCountService commonOrderCountService; - - @Resource - @Lazy - private PushCouponService pushCouponService; - - @Resource - private PushCouponRecordService pushCouponRecordService; @Resource private TokenRecordService tokenRecordService; @@ -178,8 +133,8 @@ @Resource private UserSystemCouponActivateService userSystemCouponActivateService; - @Resource(name = "producer") - private Producer producer; + @Resource + private RocketMQManager rocketMQManager; @Resource private UserInviteService userInviteService; @@ -518,6 +473,8 @@ inviteCode = userInfoExtra.getInviteCode(); } + SystemEnum system=userInfoService.getUserSystem(uid); + for (UserSystemCouponVO userCouponVO : listVO) { SystemCoupon systemCoupon = userCouponVO.getSystemCoupon(); @@ -584,7 +541,7 @@ // 鍏嶅崟鍒搞�� 绂忓埄鍏嶅崟鍒� // 鍏嶅崟鍟嗗搧鍒楄〃 - jumpLink.put("url", configService.get(ConfigKeyEnum.freeGoodsList.getKey())); + jumpLink.put("url", configService.getValue(ConfigKeyEnum.freeGoodsList.getKey(),system)); jumpBtn = new HashMap<String, Object>(); jumpBtn.put("params", jumpLink); @@ -602,7 +559,7 @@ } else if (UserSystemCoupon.STATE_IN_USE == state) { // 浣跨敤涓� - userCouponVO.setInUseExplain(configService.get(ConfigKeyEnum.freeCouponUsingHelp.getKey())); + userCouponVO.setInUseExplain(configService.getValue(ConfigKeyEnum.freeCouponUsingHelp.getKey(),system)); } } @@ -1243,6 +1200,8 @@ Long uid = userSystemCoupon.getUid(); + SystemEnum system=userInfoService.getUserSystem(uid); + CommonOrderVO commonOrderVO = commonOrderService.getCommonOrderByOrderNo(userSystemCoupon.getUid(), orderNo, CommonOrder.STATE_JS, sourceType); @@ -1275,9 +1234,8 @@ userRecordVO.setJumpWelfare(jumpWelfare); // 璺宠浆濂栧姳鍒歌鍒� - userRecordVO.setRuleLink(configService.get(ConfigKeyEnum.rewardCouponHelp.getKey())); - - String rewardCouponRemark = configService.get(ConfigKeyEnum.rewardCouponRemark.getKey()); + userRecordVO.setRuleLink(configService.getValue(ConfigKeyEnum.rewardCouponHelp.getKey(),system)); + String rewardCouponRemark = configService.getValue(ConfigKeyEnum.rewardCouponRemark.getKey(),system); if (rewardCouponRemark != null && rewardCouponRemark.trim().length() > 0) { userRecordVO.setRemark(JSONObject.fromObject(rewardCouponRemark)); } @@ -1314,6 +1272,8 @@ throw new UserSystemCouponException(1, "鏈壘鍒板埜鍩烘湰淇℃伅"); } + SystemEnum system=userInfoService.getUserSystem(userSystemCoupon.getUid()); + // 璁㈠崟 CommonOrderVO orderVO = commonOrderService.getCommonOrderByOrderNo(userSystemCoupon.getUid(), orderNo, null, sourceType); @@ -1336,7 +1296,7 @@ String progressMsg = ""; String progressColor = ""; // 璺宠浆濂栧姳鍒歌鍒� - userRecordVO.setRuleLink(configService.get(ConfigKeyEnum.freeCouponHelp.getKey())); + userRecordVO.setRuleLink(configService.getValue(ConfigKeyEnum.freeCouponHelp.getKey(),system)); // 杩涘害锛� 1 鐏拌壊 2 绾㈣壊 3 缁胯壊 String progressState1 = "3"; @@ -1374,7 +1334,7 @@ jumpDetail = jumpDetailV2Service.getByTypeCache("welfareCore"); - rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponBackRemark.getKey()); + rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponBackRemark.getKey(),system); } else if (UserSystemCouponRecord.STATE_FAIL_DRAWBACK == stateRecord) { // 閫�娆� @@ -1393,7 +1353,7 @@ jumpDetail = jumpDetailV2Service.getByTypeCache("welfareCore"); - rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponBackRemark.getKey()); + rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponBackRemark.getKey(),system); } else if (UserSystemCouponRecord.STATE_FREE_ON == stateRecord) { // 鍏嶅崟涓� @@ -1407,7 +1367,7 @@ progressMsg = "鍏嶅崟鍙戣捣锛岀瓑寰呮敹璐�"; } - rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponRemark.getKey()); + rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponRemark.getKey(),system); } else if (UserSystemCouponRecord.STATE_SUCCESS == stateRecord) { // 鍏嶅崟鎴愬姛 @@ -1429,7 +1389,7 @@ jumpDetail = jumpDetailV2Service.getByTypeCache("capitalDetails"); - rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponRemark.getKey()); + rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponRemark.getKey(),system); } userRecordVO.setProgressState(progressState); userRecordVO.setPayMoney(payMoney); @@ -1674,6 +1634,8 @@ return listVO; } + SystemEnum system=userInfoService.getUserSystem(uid); + // 鏄惁婵�娲婚個璇风爜 String inviteCode = null; UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid); @@ -1755,7 +1717,7 @@ // 缁熻寰呮縺娲绘暟閲� if (VersionUtil.greaterThan_2_0_2(acceptData.getPlatform(), acceptData.getVersion())) { int activateCount = userSystemCouponActivateService.getActivateCount(userCouponVO.getId()); - String activateNum = configService.get(ConfigKeyEnum.freeCouponActivateNum.getKey()); + String activateNum = configService.getValue(ConfigKeyEnum.freeCouponActivateNum.getKey(),system); userCouponVO.setCouponEffect( "(" + activateCount + "/" + Integer.parseInt(activateNum) + ")寰呮縺娲�"); } @@ -1793,7 +1755,7 @@ userCouponVO.setState(UserSystemCoupon.STATE_GIVE_ONLY); } else if (CouponTypeEnum.freeCoupon == type || CouponTypeEnum.welfareFreeCoupon == type || CouponTypeEnum.freeCouponBuy == type) { - jumpLink.put("url", configService.get(ConfigKeyEnum.freeGoodsList.getKey())); + jumpLink.put("url", configService.getValue(ConfigKeyEnum.freeGoodsList.getKey(),system)); jumpBtn = new HashMap<String, Object>(); jumpBtn.put("params", jumpLink); jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("web")); @@ -1821,13 +1783,13 @@ TokenTypeEnum tokenType = null; if (CouponTypeEnum.freeCouponGive == type) { userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN); - tips = configService.get(ConfigKeyEnum.giveFreeCouponTips.getKey()); + tips = configService.getValue(ConfigKeyEnum.giveFreeCouponTips.getKey(),system); tokenType = TokenTypeEnum.freeCoupon; } if (CouponTypeEnum.rebatePercentCoupon == type) { userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN); - tips = configService.get(ConfigKeyEnum.giveRebatePercentCouponTips.getKey()); + tips = configService.getValue(ConfigKeyEnum.giveRebatePercentCouponTips.getKey(),system); tokenType = TokenTypeEnum.rebatePercentCoupon; } @@ -1843,7 +1805,7 @@ tips = tips.replace("{APP鍚嶇О}", projectChineseName); } tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", - configService.get(ConfigKeyEnum.appDownLink.getKey())); + configService.getValue(ConfigKeyEnum.appDownLink.getKey(),system)); userCouponVO.setGiveTips(tips); } @@ -1925,14 +1887,16 @@ if (type != CouponTypeEnum.freeCouponGive && type != CouponTypeEnum.rebatePercentCoupon) throw new UserSystemCouponException(1, "璇ュ埜涓嶆敮鎸佽禒閫�"); + SystemEnum system=userInfoService.getUserSystem(uid); + String tips = null; TokenTypeEnum tokenTypeEnum = null; if (type == CouponTypeEnum.freeCouponGive) { tokenTypeEnum = TokenTypeEnum.freeCoupon; - tips = configService.get(ConfigKeyEnum.giveFreeCouponTips.getKey()); + tips = configService.getValue(ConfigKeyEnum.giveFreeCouponTips.getKey(),system); } else if (type == CouponTypeEnum.rebatePercentCoupon) { tokenTypeEnum = TokenTypeEnum.rebatePercentCoupon; - tips = configService.get(ConfigKeyEnum.giveRebatePercentCouponTips.getKey()); + tips = configService.getValue(ConfigKeyEnum.giveRebatePercentCouponTips.getKey(),system); } else { throw new UserSystemCouponException(1, "璇ュ埜涓嶆敮鎸佽禒閫�"); } @@ -1950,7 +1914,7 @@ tips = tips.replace("{APP鍚嶇О}", projectChineseName); } tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", - configService.get(ConfigKeyEnum.appDownLink.getKey())); + configService.getValue(ConfigKeyEnum.appDownLink.getKey(),system)); return createUserCouponVOo(userSystemCoupon, systemCoupon, record, tips); } @@ -2000,7 +1964,7 @@ while (tips.contains("{APP鍚嶇О}")) { tips = tips.replace("{APP鍚嶇О}", projectChineseName); } - tips = tips.replace("{鍙d护}", token).replace("{涓嬭浇閾炬帴}", configService.get(ConfigKeyEnum.appDownLink.getKey())); + tips = tips.replace("{鍙d护}", token).replace("{涓嬭浇閾炬帴}", configService.getValue(ConfigKeyEnum.appDownLink.getKey(),system)); UserSystemCouponVO couponVO = createUserCouponVOo(userSystemCoupon, systemCoupon, giveRecord, tips); @@ -2009,9 +1973,8 @@ msg.setCouponType(type.name()); Message message = MQMsgBodyFactory.create(MQTopicName.TOPIC_USER, UserTopicTagEnum.systemCouponDrawback, msg); // 寤惰繜涓�鍒嗛挓 - message.setStartDeliverTime(endTime.getTime() + 1000 * 60); try { - producer.send(message); + rocketMQManager.sendNormalMsg(message,1000 * 60L, null); } catch (Exception e) { throw new UserSystemCouponException(1, "鍒涘缓璧犻�佷俊鎭け璐�"); } @@ -2102,8 +2065,9 @@ /** * 閫�鍥炲埜 鍒濆鏁版嵁 - * - * @param userSystemCoupon + * @param userCoupon + * @param record + * @throws Exception */ public void sendBackCoupon(UserSystemCoupon userCoupon, UserSystemCouponRecord record) throws Exception { if (userCoupon == null) @@ -2469,9 +2433,11 @@ } } + SystemEnum system=userInfoService.getUserSystem(uid); + // 婵�娲绘暟閲� boolean result = false; - int limitNum = Integer.parseInt(configService.get(ConfigKeyEnum.freeCouponActivateNum.getKey())); + int limitNum = Integer.parseInt(configService.getValue(ConfigKeyEnum.freeCouponActivateNum.getKey(),system)); Integer state = couponActivate.getState(); int count = couponActivate.getCount(); @@ -2505,7 +2471,6 @@ * 婵�娲诲埜 * * @param coupon - * @param activateNum */ @Transactional private void activateFreeCoupon(UserSystemCoupon coupon, int limitNum) { -- Gitblit v1.8.0