From 651a15c78f668bef3859d9ed1bb7ad0b669d3600 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期五, 03 七月 2020 17:52:07 +0800
Subject: [PATCH] 多APP优化

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  381 ++++++++++++++++++++++++++++-------------------------
 1 files changed, 201 insertions(+), 180 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 e5a1a6f..122d373 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,27 +1,6 @@
 package com.yeshi.fanli.service.impl.user;
 
-import java.math.BigDecimal;
-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;
@@ -29,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;
@@ -56,30 +28,11 @@
 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;
@@ -89,8 +42,22 @@
 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.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 {
@@ -148,22 +115,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;
@@ -177,8 +131,8 @@
 	@Resource
 	private UserSystemCouponActivateService userSystemCouponActivateService;
 
-	@Resource(name = "producer")
-	private Producer producer;
+	@Resource
+	private RocketMQManager rocketMQManager;
 
 	@Resource
 	private UserInviteService userInviteService;
@@ -317,6 +271,96 @@
 		return userSystemCoupon;
 	}
 
+	
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public UserSystemCoupon freeCouponWinBySystem(Long uid, CouponTypeEnum typeEnum, String source, int num, boolean notify,
+			Integer expiryDay, Integer activated) throws UserSystemCouponException, Exception {
+		if (typeEnum == null || uid == null || StringUtil.isNullOrEmpty(source) || num < 1) {
+			throw new UserSystemCouponException(1, "鍙傛暟涓嶆纭�");
+		}
+
+		SystemCoupon coupon = systemCouponService.getCouponByType(typeEnum.name());
+		if (coupon == null) {
+			throw new UserSystemCouponException(1, "鍒哥被鍨嬩笉姝g‘");
+		}
+
+		// 婵�娲荤姸鎬�
+		// 鑷喘鍏嶅崟鍒搞�佽禒閫佸厤鍗曞埜鍙洿鎺ヤ娇鐢�
+		if (coupon.getType() == CouponTypeEnum.freeCouponBuy || coupon.getType() == CouponTypeEnum.freeCouponGive) {
+			activated = 1;
+		}
+
+		// 鏈夋晥鏃堕暱
+		if (expiryDay == null) {
+			if (activated == 0)
+				expiryDay = coupon.getActivateDay();
+			if (expiryDay == null || expiryDay == 0)
+				expiryDay = coupon.getExpiryDay();
+		}
+
+		// 璁$畻缁撴潫鏃ユ湡
+		Date nowTime = new Date();
+		String endDay = DateUtil.plusDay(expiryDay - 1, nowTime);
+		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+		if (endDay != null && endDay.trim().length() > 0) {
+			endDay += " 23:59:59";
+		}
+		Date endTime = format.parse(endDay);
+
+		UserSystemCoupon userSystemCoupon = null;
+		for (int i = 0; i < num; i++) {
+			UserSystemCoupon userCoupon = new UserSystemCoupon();
+			userCoupon.setUid(uid);
+			userCoupon.setSource(source);
+			userCoupon.setSystemCoupon(coupon);
+			userCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+			userCoupon.setStateActivated(activated);
+			userCoupon.setStartTime(nowTime);
+			userCoupon.setEndTime(endTime);
+			userCoupon.setCreateTime(nowTime);
+			userCoupon.setUpdateTime(nowTime);
+			userSystemCouponMapper.insertSelective(userCoupon);
+			// 闇�瑕佹縺娲诲埜
+			if (typeEnum == CouponTypeEnum.freeCoupon) {
+				userSystemCouponActivateService.addActivateRecord(userCoupon.getId());
+			}
+
+			if (num == 1) {
+				userSystemCoupon = userCoupon;
+			}
+		}
+
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				if (notify) { // 娑堟伅鎺ㄩ��
+					try {
+						userOtherMsgNotificationService.freeCouponWinMsg(uid, typeEnum.getDesc(), source, num, "鎴愬姛鑾峰緱",
+								nowTime, endTime);
+					} catch (Exception e) {
+						e.printStackTrace();
+					}
+				}
+
+				// 绂忓埄涓績绾㈢偣
+				UserInfoExtra extra = userInfoExtraService.getUserInfoExtra(uid);
+				if (extra != null) {
+					UserInfoExtra updateExtra = new UserInfoExtra();
+					updateExtra.setId(extra.getId());
+					if (extra.getCouponNews() == null) {
+						updateExtra.setCouponNews(1);
+					} else {
+						updateExtra.setCouponNews(extra.getCouponNews() + 1);
+					}
+					userInfoExtraService.updateByPrimaryKeySelective(updateExtra);
+				}
+			}
+		});
+
+		return userSystemCoupon;
+	}
+	
 	@Override
 	@Transactional(rollbackFor = Exception.class)
 	public UserSystemCoupon rewardCouponWin(Long uid, String source, int num, boolean notify, BigDecimal percent)
@@ -427,6 +471,8 @@
 			inviteCode = userInfoExtra.getInviteCode();
 		}
 
+		SystemEnum system=userInfoService.getUserSystem(uid);
+
 		for (UserSystemCouponVO userCouponVO : listVO) {
 
 			SystemCoupon systemCoupon = userCouponVO.getSystemCoupon();
@@ -493,7 +539,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);
@@ -511,7 +557,7 @@
 
 				} else if (UserSystemCoupon.STATE_IN_USE == state) {
 					// 浣跨敤涓�
-					userCouponVO.setInUseExplain(configService.get(ConfigKeyEnum.freeCouponUsingHelp.getKey()));
+					userCouponVO.setInUseExplain(configService.getValue(ConfigKeyEnum.freeCouponUsingHelp.getKey(),system));
 				}
 			}
 
@@ -550,27 +596,24 @@
 	}
 
 	@Override
-	public List<UserSystemCouponVO> getEnableListByCouponId(Long uid, Integer activated, List<SystemCoupon> couponList)
-			throws UserSystemCouponException, Exception {
-
+	public List<UserSystemCouponVO> getEnableListByCouponId(Long uid, Integer activated, List<SystemCoupon> couponList) {
 		List<Long> listCouponId = new ArrayList<Long>();
 		for (SystemCoupon systemCoupon : couponList) {
 			listCouponId.add(systemCoupon.getId());
 		}
 
 		List<UserSystemCouponVO> listVO = userSystemCouponMapper.getEnableListByCouponId(uid, activated, listCouponId);
-
 		if (listVO == null || listVO.size() == 0) {
 			return null;
 		}
-
+		
+		SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+		SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd");
 		for (UserSystemCouponVO userCouponVO : listVO) {
-
 			SystemCoupon systemCoupon = userCouponVO.getSystemCoupon();
 			if (systemCoupon == null) {
 				continue; // 鍒镐俊鎭笉瀹屾暣
 			}
-
 			for (SystemCoupon coupon : couponList) {
 				if (coupon.getId().equals(systemCoupon.getId()) || coupon.getId() == systemCoupon.getId()) {
 					systemCoupon = coupon;
@@ -596,11 +639,15 @@
 			Date startTime = userCouponVO.getStartTime();
 			Date endTime = userCouponVO.getEndTime();
 			if (endTime != null && startTime != null) {
-				SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+				
 				couponTerm = couponTerm + sdf.format(startTime) + "-" + sdf.format(endTime);
 
-				SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd");
-				differentDays = DateUtil.daysBetween(sdf2.format(new Date()), sdf2.format(endTime)) + 1;
+			
+				try {
+					differentDays = DateUtil.daysBetween(sdf2.format(new Date()), sdf2.format(endTime)) + 1;
+				} catch (ParseException e) {
+					e.printStackTrace();
+				}
 				if (differentDays < 0) {
 					differentDays = 0;
 				}
@@ -679,6 +726,24 @@
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
+	public List<UserSystemCouponVO> getFreeCouponList(Long uid) {
+		// 杩囨湡鍒�
+		updateInvalidSate(uid);
+
+		// 閫�鍥炲埜
+		sendBackTimeOutCoupon(uid);
+
+		// 鍟嗗搧鐩稿叧鐨勫埜
+		List<SystemCoupon> couponList = systemCouponService.getGoodsCouponList();
+		if (couponList == null || couponList.size() == 0) {
+			return null;
+		}
+		return getEnableListByCouponId(uid, null, couponList);
+	}
+
+	
+	@Transactional(rollbackFor = Exception.class)
+	@Override
 	public List<UserSystemCouponVO> getGoodsCouponList(Long uid, Long auctionId)
 			throws UserSystemCouponException, Exception {
 
@@ -728,7 +793,7 @@
 
 		return list;
 	}
-
+	
 	@Override
 	public long countUsableFreeCouponForBuy(Long uid) {
 		if (uid == null)
@@ -952,6 +1017,7 @@
 		}
 
 		BigDecimal hongBao = orderVO.getHongBao();
+		
 		// 绾㈠寘鐘舵��
 		Integer hongBaoState = orderVO.getHongBaoState();
 		// 绾㈠寘绫诲瀷
@@ -964,6 +1030,11 @@
 			if (order == null)
 				throw new UserSystemCouponException(1, "璇ヨ鍗曚笉瀛樺湪");
 
+			// 浣跨敤濂栧姳鍒� 閲戦棰濋檺鍒�
+			if (hongBao.compareTo(Constant.REWARD_COUPON_LIMIT_MONEY) > 0){
+				throw new UserSystemCouponException(1, "璇ヨ鍗曚笉鑳戒娇鐢ㄥ鍔卞埜");
+			}
+			
 			/* 濂栭噾璁$畻 浠ュ強鐩稿叧绾㈠寘淇℃伅澶勭悊 */
 
 			// 杞崲鎴愬皬鏁扮偣
@@ -1100,7 +1171,7 @@
 
 		// 鏌ヨ璁板綍
 		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo,
-				UserSystemCouponRecord.STATE_SUCCESS);
+				sourceType, UserSystemCouponRecord.STATE_SUCCESS);
 		if (record == null) {
 			throw new UserSystemCouponException(1, "娌℃湁浣跨敤鍒歌褰�");
 		}
@@ -1126,6 +1197,8 @@
 		}
 
 		Long uid = userSystemCoupon.getUid();
+
+		SystemEnum system=userInfoService.getUserSystem(uid);
 
 		CommonOrderVO commonOrderVO = commonOrderService.getCommonOrderByOrderNo(userSystemCoupon.getUid(), orderNo,
 				CommonOrder.STATE_JS, sourceType);
@@ -1159,9 +1232,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));
 		}
@@ -1178,7 +1250,7 @@
 		}
 
 		// 鏌ヨ璁板綍
-		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo, null);
+		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo,sourceType, null);
 		if (record == null) {
 			throw new UserSystemCouponException(1, "娌℃湁浣跨敤鍒歌褰�");
 		}
@@ -1197,6 +1269,8 @@
 		if (baseCoupon == null || baseCoupon.getId() == null) {
 			throw new UserSystemCouponException(1, "鏈壘鍒板埜鍩烘湰淇℃伅");
 		}
+
+		SystemEnum system=userInfoService.getUserSystem(userSystemCoupon.getUid());
 
 		// 璁㈠崟
 		CommonOrderVO orderVO = commonOrderService.getCommonOrderByOrderNo(userSystemCoupon.getUid(), orderNo, null,
@@ -1220,7 +1294,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";
@@ -1258,7 +1332,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) {
 			// 閫�娆�
@@ -1277,7 +1351,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) {
 			// 鍏嶅崟涓�
@@ -1291,7 +1365,7 @@
 				progressMsg = "鍏嶅崟鍙戣捣锛岀瓑寰呮敹璐�";
 			}
 
-			rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponRemark.getKey());
+			rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponRemark.getKey(),system);
 
 		} else if (UserSystemCouponRecord.STATE_SUCCESS == stateRecord) {
 			// 鍏嶅崟鎴愬姛
@@ -1313,7 +1387,7 @@
 
 			jumpDetail = jumpDetailV2Service.getByTypeCache("capitalDetails");
 
-			rewardCouponRemark = configService.get(ConfigKeyEnum.freeCouponRemark.getKey());
+			rewardCouponRemark = configService.getValue(ConfigKeyEnum.freeCouponRemark.getKey(),system);
 		}
 		userRecordVO.setProgressState(progressState);
 		userRecordVO.setPayMoney(payMoney);
@@ -1374,18 +1448,16 @@
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
-	public void updateStateByDrawback(String orderNo) throws Exception {
+	public void updateStateByDrawback(String orderNo, Integer sourceType) throws Exception {
 
 		if (orderNo == null || orderNo.trim().length() == 0) {
 			return;
 		}
 
-		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo, null);
+		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo,sourceType, null);
 		if (record == null) {
 			return;
 		}
-
-		record.setOrderNo(orderNo);
 		record.setUpdateTime(new Date());
 		record.setState(UserSystemCouponRecord.STATE_FAIL_DRAWBACK);
 		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
@@ -1396,18 +1468,15 @@
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
-	public void updateStateByArrivalAccount(String orderNo) throws Exception {
-
+	public void updateStateByArrivalAccount(String orderNo, Integer sourceType) throws Exception {
 		if (orderNo == null || orderNo.trim().length() == 0) {
 			return;
 		}
 
-		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo, 2);
+		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo,sourceType, 2);
 		if (record == null) {
 			return;
 		}
-
-		record.setOrderNo(orderNo);
 		record.setUpdateTime(new Date());
 		record.setState(UserSystemCouponRecord.STATE_SUCCESS);
 		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
@@ -1420,15 +1489,13 @@
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
-	public boolean updateCouponRecordUsed(Long uid, String orderNo, BigDecimal payment, Long auctionId)
+	public boolean updateCouponRecordUsed(Long uid, String orderNo, BigDecimal payment, Long gId,Integer sourceType)
 			throws Exception {
-
-		boolean isfree = false;
-
-		if (uid == null || payment == null || auctionId == null || orderNo == null || orderNo.trim().length() == 0) {
+		if (uid == null || payment == null || gId == null || orderNo == null || orderNo.trim().length() == 0) {
 			throw new Exception("浼犻�掑弬鏁颁笉鑳戒负绌�");
 		}
-
+		
+		boolean isfree = false;
 		// 鏌ヨ绛夊緟鍖归厤鐨勫埜璁板綍
 		List<UserSystemCouponRecord> list = userSystemCouponRecordService.getRecordByState(uid,
 				UserSystemCouponRecord.STATE_WAIT);
@@ -1442,7 +1509,11 @@
 
 		for (UserSystemCouponRecord userSystemCouponRecord : list) {
 			Long goodId = userSystemCouponRecord.getGoodId();
-			if (auctionId.equals(goodId)) {
+			Integer goodSource = userSystemCouponRecord.getGoodSource();
+			if (goodSource == null)
+				continue;
+				
+			if (gId.equals(goodId) && goodSource == sourceType) {
 				matching = true; // 鍖归厤鎴愬姛
 				record = userSystemCouponRecord;
 				break;
@@ -1451,7 +1522,7 @@
 
 		// 鍟嗗搧鍖归厤鎴愬姛
 		if (matching) {
-
+			record.setGoodSource(sourceType);
 			record.setOrderNo(orderNo);
 			record.setUpdateTime(new Date());
 
@@ -1541,62 +1612,6 @@
 		}
 	}
 
-	@Override
-	@Transactional(rollbackFor = Exception.class)
-	public void exchangeCoupon(Long uid, String couponType, String source, BigDecimal percent)
-			throws UserSystemCouponException, Exception {
-		if (couponType == null || uid == null) {
-			throw new UserSystemCouponException(1, "鍙傛暟涓嶆纭�");
-		}
-
-		SystemCoupon coupon = null;
-		if (couponType.equals(CouponTypeEnum.rebatePercentCoupon.name())) {
-			coupon = systemCouponService.getCouponByTypeAndPercent(couponType, percent);
-		} else {
-			coupon = systemCouponService.getCouponByType(couponType);
-		}
-
-		if (coupon == null) {
-			throw new UserSystemCouponException(1, "鍒哥被鍨嬩笉姝g‘");
-		}
-
-		int stateActivated = 1;
-		if (couponType == CouponTypeEnum.freeCoupon.name()) {
-			stateActivated = 0; //
-		} else if (couponType == CouponTypeEnum.welfareFreeCoupon.name()
-				&& threeSaleSerivce.countSuccessFirstTeam(uid) <= 0) {
-			stateActivated = 0; // 鏃犱笅绾ч槦鍛� --寰呮縺娲�
-		}
-
-		Integer expiryDay = null;
-		if (stateActivated == 0)
-			expiryDay = coupon.getActivateDay();
-
-		if (expiryDay == null || expiryDay == 0)
-			expiryDay = coupon.getExpiryDay();
-
-		// 璁$畻缁撴潫鏃ユ湡锛氫粖澶╁湪鍐� 鍑忓幓涓�澶�
-		String endDay = DateUtil.plusDay(expiryDay - 1, new Date());
-		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
-		if (endDay != null && endDay.trim().length() > 0) {
-			endDay += " 23:59:59";
-		}
-		Date endTime = format.parse(endDay);
-
-		UserSystemCoupon userCoupon = new UserSystemCoupon();
-		userCoupon.setUid(uid);
-		userCoupon.setSource(source);
-		userCoupon.setSystemCoupon(coupon);
-		userCoupon.setStateActivated(stateActivated);
-		userCoupon.setStartTime(new Date());
-		userCoupon.setEndTime(endTime);
-		userCoupon.setGive(false);
-		userCoupon.setCreateTime(new Date());
-		userCoupon.setUpdateTime(new Date());
-		userCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
-
-		insertSelective(userCoupon);
-	}
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
@@ -1616,6 +1631,8 @@
 		if (listVO == null || listVO.size() == 0) {
 			return listVO;
 		}
+
+		SystemEnum system=userInfoService.getUserSystem(uid);
 
 		// 鏄惁婵�娲婚個璇风爜
 		String inviteCode = null;
@@ -1698,7 +1715,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) + ")寰呮縺娲�");
 						}
@@ -1736,7 +1753,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"));
@@ -1764,13 +1781,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;
 				}
 
@@ -1786,7 +1803,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);
 						}
 
@@ -1868,14 +1885,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, "璇ュ埜涓嶆敮鎸佽禒閫�");
 		}
@@ -1893,7 +1912,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);
 			}
@@ -1943,7 +1962,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);
 
@@ -1952,9 +1971,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, "鍒涘缓璧犻�佷俊鎭け璐�");
 		}
@@ -2045,8 +2063,9 @@
 
 	/**
 	 * 閫�鍥炲埜 鍒濆鏁版嵁
-	 * 
-	 * @param userSystemCoupon
+	 * @param userCoupon
+	 * @param record
+	 * @throws Exception
 	 */
 	public void sendBackCoupon(UserSystemCoupon userCoupon, UserSystemCouponRecord record) throws Exception {
 		if (userCoupon == null)
@@ -2412,9 +2431,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();
@@ -2448,7 +2469,6 @@
 	 * 婵�娲诲埜
 	 * 
 	 * @param coupon
-	 * @param activateNum
 	 */
 	@Transactional
 	private void activateFreeCoupon(UserSystemCoupon coupon, int limitNum) {
@@ -2487,4 +2507,5 @@
 		}
 	}
 
+
 }

--
Gitblit v1.8.0