From 78f3f67d4629583b5ed5bf7ac8552344f0403ced Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期五, 23 八月 2019 17:29:36 +0800
Subject: [PATCH] 金币获取拦截修改
---
fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java | 423 +++++++++++++++++++++++++++++++++++-----------------
1 files changed, 283 insertions(+), 140 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 c941999..394ecf6 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,7 +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;
@@ -17,6 +16,8 @@
import org.yeshi.utils.DateUtil;
import com.yeshi.fanli.dao.mybatis.user.UserSystemCouponMapper;
+import com.yeshi.fanli.dto.msg.MsgOtherGiveContentDTO;
+import com.yeshi.fanli.entity.bus.msg.MsgOtherDetail.MsgTypeOtherTypeEnum;
import com.yeshi.fanli.entity.bus.user.DeviceLotteryRecord;
import com.yeshi.fanli.entity.bus.user.HongBaoV2;
import com.yeshi.fanli.entity.bus.user.Order;
@@ -62,7 +63,7 @@
import com.yeshi.fanli.util.MoneyBigDecimalUtil;
import com.yeshi.fanli.util.RedisManager;
import com.yeshi.fanli.util.StringUtil;
-import com.yeshi.fanli.util.account.UserUtil;
+import com.yeshi.fanli.util.TokenUtil;
import com.yeshi.fanli.util.factory.UserMoneyDetailFactory;
import com.yeshi.fanli.util.taobao.TaoBaoUtil;
import com.yeshi.fanli.vo.msg.ClientTextStyleVO;
@@ -190,7 +191,7 @@
@Override
@Transactional
- public void insertUserCoupon(Long uid, String couponType, String source)
+ public void insertUserCoupon(Long uid, String couponType, String source, BigDecimal percent)
throws UserSystemCouponException, Exception {
if (couponType == null || uid == null) {
@@ -198,13 +199,17 @@
}
SystemCoupon coupon = null;
- if (couponType.equals(CouponTypeEnum.welfareFreeCoupon.name())) {
- // 绂忓埄鍏嶅崟鍒�
+ if (couponType.equals(CouponTypeEnum.welfareFreeCoupon.name()) || couponType.equals(CouponTypeEnum.freeCoupon.name())) {
+ // 鍏嶅崟鍒�
coupon = systemCouponService.getCouponByType(couponType);
} else if (couponType.equals(CouponTypeEnum.rebatePercentCoupon.name())) {
// 闅忔満濂栧姳鍒�
- randomRewardCoupon(1, uid, source);
- return;
+ if (percent == null || percent.compareTo(new BigDecimal(0)) > 0) {
+ randomRewardCoupon(1, uid, source);
+ return;
+ } else {
+ coupon = systemCouponService.getCouponByTypeAndPercent(couponType, percent);
+ }
}
if (coupon == null) {
@@ -219,6 +224,8 @@
if (countSuccess == 0) {
stateActivated = 0;
}
+ } else if (coupon.getType() == CouponTypeEnum.freeCoupon) {
+ stateActivated = 0;
}
// 缁撴潫鏃ユ湡
@@ -290,8 +297,6 @@
return null;
}
- // 鏇存柊杩囨湡鍒�
- updateCounponInvalid(uid);
// 閫�鍥炲埜
sendBackTimeOutCoupon(uid);
@@ -553,8 +558,6 @@
throw new UserSystemCouponException(1, "鐢ㄦ埛鏈櫥褰�");
}
- // 鏇存柊杩囨湡鍒�
- updateCounponInvalid(uid);
// 閫�鍥炲埜
sendBackTimeOutCoupon(uid);
@@ -580,8 +583,6 @@
throw new UserSystemCouponException(1, "鍟嗗搧ID涓虹┖");
}
- // 鏇存柊杩囨湡鍒�
- updateCounponInvalid(uid);
// 閫�鍥炲埜
sendBackTimeOutCoupon(uid);
@@ -1118,9 +1119,6 @@
return;
}
- // 楠岃瘉鏄惁澶辨晥
- updateCounponInvalid(uid);
-
// 寰呮椿绂忓埄鍏嶅崟鍒�
List<UserSystemCoupon> list = userSystemCouponMapper.getCouponByTypeAndNotActivated(uid, systemCoupon.getId());
if (list == null || list.size() == 0) {
@@ -1205,25 +1203,30 @@
}
}
- @Transactional
@Override
- public void updateCounponInvalid(Long uid) {
- List<UserSystemCoupon> list = userSystemCouponMapper.getCounponNowInvalid(uid);
+ public List<UserSystemCoupon> getCounponNowInvalid(int count) {
+ return userSystemCouponMapper.getCounponNowInvalid(count);
+ }
+
+
+ @Override
+ public void updateCounponInvalid(List<UserSystemCoupon> list) {
if (list == null || list.size() == 0) {
return;
}
for (UserSystemCoupon userSystemCoupon : list) {
- // 鏇存柊鍒稿凡杩囨湡
+ UserSystemCoupon userCoupon = new UserSystemCoupon();
+ userCoupon.setUpdateTime(new Date());
userSystemCoupon.setState(UserSystemCoupon.STATE_OVERDUE);
userSystemCouponMapper.updateByPrimaryKeySelective(userSystemCoupon);
- SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
- if (systemCoupon == null) {
+ SystemCoupon baseCoupon = userSystemCoupon.getSystemCoupon();
+ if (baseCoupon == null) {
continue;
}
-
- SystemCoupon baseCoupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
+
+ baseCoupon = systemCouponService.selectByPrimaryKey(baseCoupon.getId());
if (baseCoupon == null || baseCoupon.getId() == null) {
continue;
}
@@ -1236,8 +1239,11 @@
userOtherMsgNotificationService.freeSheetCouponAlreadyOutOfDate(userSystemCoupon);
} else if (baseCoupon.getType() == CouponTypeEnum.rebatePercentCoupon) {
userOtherMsgNotificationService.rewardCouponAlreadyOutOfDate(userSystemCoupon);
+ }else if (baseCoupon.getType() == CouponTypeEnum.freeCouponBuy) {
+ userOtherMsgNotificationService.outOfDate(userSystemCoupon, MsgTypeOtherTypeEnum.freeCouponBuy);
+ } else if (baseCoupon.getType() == CouponTypeEnum.freeCouponGive) {
+ userOtherMsgNotificationService.outOfDate(userSystemCoupon, MsgTypeOtherTypeEnum.freeCouponGive);
}
-
} catch (Exception e) {
try {
LogHelper.errorDetailInfo(e);
@@ -1252,7 +1258,7 @@
@Override
public void sendBackTimeOutCoupon(Long uid) {
// 瓒呰繃10鍒嗛挓 鏈鍖归厤鐨勫埜
- List<UserSystemCouponRecord> list = userSystemCouponRecordService.getCouponByUsingTimeOut(uid,600L);
+ List<UserSystemCouponRecord> list = userSystemCouponRecordService.getCouponByUsingTimeOut(uid, 600L);
if (list == null || list.size() == 0) {
return;
}
@@ -1264,32 +1270,9 @@
userSystemCouponRecordService.updateByPrimaryKeySelective(couponRecord);
UserSystemCoupon userSystemCoupon = couponRecord.getUserSystemCoupon();
-
- int expiryDay = 15;
-
- SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
- SystemCoupon coupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
- if (coupon != null) {
- expiryDay = coupon.getExpiryDay();
- }
-
- // 缁撴潫鏃ユ湡
- Date endTime = null;
- try {
- // 浠婂ぉ鍦ㄥ唴 鍑忓幓涓�澶�
- String endDay = DateUtil.plusDay(expiryDay - 1, new Date());
- SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
- endTime = format.parse(endDay);
- } catch (ParseException e) {
- e.printStackTrace();
- }
// 鐘舵�佸垵濮嬪寲
userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
userSystemCoupon.setUseTime(null);
-
- // 鏈夋晥鏈熸椂闂撮噸鏂板畾涔�
- userSystemCoupon.setStartTime(new Date());
- userSystemCoupon.setEndTime(endTime);
userSystemCoupon.setUpdateTime(new Date());
userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
}
@@ -1376,42 +1359,50 @@
*
* @param userSystemCoupon
*/
- public void sendBackCoupon(UserSystemCoupon userSystemCoupon, UserSystemCouponRecord record) throws Exception {
-
- int expiryDay = 15;
-
- SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
- SystemCoupon coupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
- if (coupon != null) {
- expiryDay = coupon.getExpiryDay();
+ public void sendBackCoupon(UserSystemCoupon userCoupon, UserSystemCouponRecord record) throws Exception {
+ if (userCoupon == null)
+ return;
+
+ Integer state = userCoupon.getState();
+ if (state != UserSystemCoupon.STATE_IN_USE)
+ return;
+
+ Date now = new Date();
+ Date endTime = userCoupon.getEndTime();
+ if (endTime != null && endTime.getTime() < now.getTime()) {
+ // 杩囨湡
+ List<UserSystemCoupon> list = new ArrayList<UserSystemCoupon>();
+ list.add(userCoupon);
+ updateCounponInvalid(list);
+ return;
}
-
- // 缁撴潫鏃ユ湡
- Date endTime = null;
- try {
- // 浠婂ぉ鍦ㄥ唴 鍑忓幓涓�澶�
- String endDay = DateUtil.plusDay(expiryDay - 1, new Date());
- SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
- endTime = format.parse(endDay);
- } catch (ParseException e) {
- e.printStackTrace();
- }
- // 鐘舵�佸垵濮嬪寲
- userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+
+ // 閫�鍥炲埜
+ UserSystemCoupon userSystemCoupon = new UserSystemCoupon();
+ userSystemCoupon.setId(userCoupon.getId());
+ userSystemCoupon.setGive(false);
userSystemCoupon.setUseTime(null);
- // 鏈夋晥鏈熸椂闂撮噸鏂板畾涔�
- userSystemCoupon.setStartTime(new Date());
- userSystemCoupon.setEndTime(endTime);
-
+ userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
userSystemCoupon.setUpdateTime(new Date());
-
userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
-
- if (CouponTypeEnum.welfareFreeCoupon.name().equals(record.getCouponType())) {
- userOtherMsgNotificationService.welfareCouponDrawBack(userSystemCoupon, record.getOrderNo());
- } else if (CouponTypeEnum.freeCoupon.name().equals(record.getCouponType())) {
- userOtherMsgNotificationService.freeSheetCouponDrawBack(userSystemCoupon, record.getOrderNo());
+
+ // 浣跨敤璁板綍
+ if (record != null) {
+ UserSystemCouponRecord useRecordUpdate = new UserSystemCouponRecord();
+ useRecordUpdate.setId(record.getId());
+ useRecordUpdate.setState(UserSystemCouponRecord.STATE_WAIT_TIME_OUT);
+ useRecordUpdate.setUpdateTime(new Date());
+ userSystemCouponRecordService.updateByPrimaryKeySelective(useRecordUpdate);
+
+ if (CouponTypeEnum.welfareFreeCoupon.name().equals(record.getCouponType())) {
+ userOtherMsgNotificationService.welfareCouponDrawBack(userSystemCoupon, record.getOrderNo());
+ } else if (CouponTypeEnum.freeCoupon.name().equals(record.getCouponType())) {
+ userOtherMsgNotificationService.freeSheetCouponDrawBack(userSystemCoupon, record.getOrderNo());
+ } else if (CouponTypeEnum.freeCouponBuy.name().equals(record.getCouponType())) {
+ userOtherMsgNotificationService.couponDrawBack(userSystemCoupon, record.getOrderNo(), MsgTypeOtherTypeEnum.freeCouponBuy);
+ }
}
+
}
@Override
@@ -1697,8 +1688,6 @@
@Override
public List<UserSystemCouponVO> getCouponList(long start, int count, Long uid)
throws UserSystemCouponException, Exception {
- // 鏇存柊杩囨湡鍒�
- updateCounponInvalid(uid);
// 閫�鍥炲埜
sendBackTimeOutCoupon(uid);
@@ -1746,7 +1735,7 @@
userCouponVO.setCouponPicture(systemCoupon.getPicture());
}
- if (UserSystemCoupon.STATE_CAN_USE == state) {
+ if (UserSystemCoupon.STATE_CAN_USE == state || UserSystemCoupon.STATE_IN_USE == state) {
int differentDays = 0;
if (endTime != null && startTime != null) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
@@ -1822,22 +1811,54 @@
jumpBtn.put("params", jumpLink);
jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("orderList"));
}
- } else if (UserSystemCoupon.STATE_IN_USE == state) {
+ } else if (UserSystemCoupon.STATE_IN_USE == state && give) {
+ userCouponVO.setCouponEffect("璧犻�佷腑");
+ userCouponVO.setCouponRule(systemCoupon.getRemark());
+ String tips = null;
if (CouponTypeEnum.freeCouponGive == type) {
userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
+ tips = configService.get("give_free_coupon_tips");
}
- if (give && CouponTypeEnum.rebatePercentCoupon == type) {
+ if (CouponTypeEnum.rebatePercentCoupon == type) {
userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
+ tips = configService.get("give_free_coupon_tips");
}
- } else if (UserSystemCoupon.STATE_END_USE == state) {
+
+ if (!StringUtil.isNullOrEmpty(tips)) {
+ UserSystemCouponGiveRecord record = userSystemCouponGiveRecordService.getRecordByUidAndCouponId(uid, userCouponVO.getId());
+ if (record != null) {
+ TokenRecord tokenRecord = tokenRecordService.getNearByTypeAndIdentify(CouponTypeEnum.freeCoupon.name(), record.getId().toString());
+ if (tokenRecord != null && !StringUtil.isNullOrEmpty(tokenRecord.getToken())) {
+ String projectChineseName = Constant.systemCommonConfig.getProjectChineseName();
+ while(tips.contains("{APP鍚嶇О}")) {
+ tips = tips.replace("{APP鍚嶇О}", projectChineseName);
+ }
+ tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
+ userCouponVO.setGiveTips(tips);
+ }
+
+ Date endTimeGive = record.getEndTime();
+ if (endTimeGive != null) {
+ Map<String, Object> remainDays = new HashMap<String, Object>();
+ remainDays.put("content", "鍓╀綑" + DateUtil.dateDiff2(new Date(), endTimeGive) + "杩囨湡");
+ remainDays.put("fontColor", "#F14242");
+ userCouponVO.setRemainDays(remainDays);
+ }
+ }
+ }
+
+ } else if (give && UserSystemCoupon.STATE_END_USE == state) {
+ userCouponVO.setCouponRule(systemCoupon.getRemark());
if (CouponTypeEnum.freeCouponGive == type) {
userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END);
}
- if (give && CouponTypeEnum.rebatePercentCoupon == type) {
+ if (CouponTypeEnum.rebatePercentCoupon == type) {
userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END);
}
+ }else if (give && UserSystemCoupon.STATE_OVERDUE == state) {
+ userCouponVO.setCouponRule(systemCoupon.getRemark());
}
userCouponVO.setJumpBtn(jumpBtn);
}
@@ -1847,7 +1868,7 @@
@Transactional
@Override
- public String giveCoupon(Long uid, Long id) throws UserSystemCouponException {
+ public UserSystemCouponVO giveCoupon(Long uid, Long id) throws UserSystemCouponException {
UserSystemCoupon userSystemCoupon = userSystemCouponMapper.selectByPrimaryKey(id);
if (userSystemCoupon == null)
throw new UserSystemCouponException(1, "璇ュ埜宸蹭笉瀛樺湪");
@@ -1861,78 +1882,200 @@
throw new UserSystemCouponException(1, "璇ュ埜宸插け鏁�");
Integer state = userSystemCoupon.getState();
- if (state == UserSystemCoupon.STATE_OVERDUE)
- throw new UserSystemCouponException(1, "璇ュ埜宸茶繃鏈�");
-
- if (state == UserSystemCoupon.STATE_END_USE)
- throw new UserSystemCouponException(1, "璇ュ埜浣跨敤/璧犻�佹垚鍔�");
+ if (state != UserSystemCoupon.STATE_CAN_USE)
+ throw new UserSystemCouponException(1, "璇ュ埜宸茶浣跨敤鎴栬禒閫�");
CouponTypeEnum type = systemCoupon.getType();
if (type != CouponTypeEnum.freeCouponGive && type != CouponTypeEnum.rebatePercentCoupon )
throw new UserSystemCouponException(1, "璇ュ埜涓嶆敮鎸佽禒閫�");
+ String tips = null;
TokenTypeEnum tokenTypeEnum = null;
if (type == CouponTypeEnum.freeCouponGive) {
tokenTypeEnum = TokenTypeEnum.freeCoupon;
+ tips = configService.get("give_free_coupon_tips");
} else if (type == CouponTypeEnum.rebatePercentCoupon){
tokenTypeEnum = TokenTypeEnum.rebatePercentCoupon;
+ tips = configService.get("give_rebate_percent_coupon_tips");
} else {
throw new UserSystemCouponException(1, "璇ュ埜涓嶆敮鎸佽禒閫�");
}
- String token = null;
- Date nowDate = new Date();
- TokenRecord record = tokenRecordService.getNearByTypeAndIdentify(tokenTypeEnum.name(), id+"");
- if (record != null && record.getEndTime().getTime() > nowDate.getTime()) {
- token = record.getToken();
- } else {
- for (int i = 0; i < 5; i++) {
- try {
- // TODO 鍙d护鐢熸垚瑙勫垯寰呭畾
- long num = 10000 + (long) (Math.random() * 10000);
- token = UserUtil.getInviteCode(num);
-
- TokenRecord tokenRecord = new TokenRecord();
- tokenRecord.setUid(uid);
- tokenRecord.setIdentify(id+"");
- tokenRecord.setType(tokenTypeEnum);
- tokenRecord.setStartTime(nowDate);
- tokenRecord.setEndTime(DateUtil.plusDayDate(3, nowDate));
- tokenRecord.setToken(token);
- tokenRecord.setState(state);
- tokenRecordService.insertSelective(tokenRecord);
- } catch (Exception e) {
- LogHelper.errorDetailInfo(e);
- token = null;
+ if (StringUtil.isNullOrEmpty(tips))
+ throw new UserSystemCouponException(1, "tips鏁版嵁缂哄け");
+
+
+ // 鏄惁鏈�杩戠敓鎴愬彛浠ゆ湁鏁�
+ UserSystemCouponGiveRecord record = userSystemCouponGiveRecordService.getRecordByUidAndCouponId(uid, id);
+ if (record != null) {
+ TokenRecord tokenRecord = tokenRecordService.getNearByTypeAndIdentify(tokenTypeEnum.name(), id+"");
+ if (tokenRecord != null && !StringUtil.isNullOrEmpty(tokenRecord.getToken())) {
+ String projectChineseName = Constant.systemCommonConfig.getProjectChineseName();
+ while(tips.contains("{APP鍚嶇О}")) {
+ tips = tips.replace("{APP鍚嶇О}", projectChineseName);
}
+ tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
- if(!StringUtil.isNullOrEmpty(token)) {
- break;
- }
+ return createUserCouponVOo(userSystemCoupon, systemCoupon, record, tips);
}
-
- if(StringUtil.isNullOrEmpty(token))
- throw new UserSystemCouponException(1, "鍙d护鐢熸垚澶辫触");
-
- // 鎻掑叆璧犻�佽褰�
- UserSystemCouponGiveRecord giveRecord = new UserSystemCouponGiveRecord();
- giveRecord.setCouponId(id);
- giveRecord.setGiveUid(uid);
- giveRecord.setGiveTime(nowDate);
- userSystemCouponGiveRecordService.insertSelective(giveRecord);
}
- if(StringUtil.isNullOrEmpty(token))
- throw new UserSystemCouponException(1, "鍙d护鐢熸垚澶辫触");
+
+ Date nowDate = new Date();
+ // 鎻掑叆璧犻�佽褰�
+ UserSystemCouponGiveRecord giveRecord = new UserSystemCouponGiveRecord();
+ giveRecord.setCouponId(id);
+ giveRecord.setGiveUid(uid);
+ giveRecord.setGiveTime(nowDate);
+ giveRecord.setEndTime(DateUtil.plusDayDate(Constant.GIVE_DAYS, nowDate));
+ userSystemCouponGiveRecordService.insertSelective(giveRecord);
+
+ // 鍒涘缓璁板綍
+ TokenRecord tokenRecord = new TokenRecord();
+ tokenRecord.setUid(uid);
+ tokenRecord.setIdentify(giveRecord.getId()+"");
+ tokenRecord.setType(tokenTypeEnum);
+ tokenRecord.setStartTime(nowDate);
+ tokenRecord.setEndTime(DateUtil.plusDayDate(Constant.TOKEN_DAYS, nowDate));
+ tokenRecord.setState(0);
+ tokenRecordService.insertSelective(tokenRecord);
+
+ // 鍒涘缓鍙d护
+ String token = TokenUtil.createToken(tokenRecord.getId());
+ tokenRecord.setToken(token);
+ tokenRecordService.updateByPrimaryKeySelective(tokenRecord);
+
+ // 鍒哥姸鎬�
+ userSystemCoupon.setState(UserSystemCoupon.STATE_IN_USE);
+ userSystemCoupon.setGive(true);
+ userSystemCoupon.setUpdateTime(nowDate);
+ userSystemCouponMapper.updateByPrimaryKeySelective(userSystemCoupon);
+
+ // 鎻掑叆浣跨敤鍒歌褰�
+ UserSystemCouponRecord couponRecord = new UserSystemCouponRecord();
+ couponRecord.setState(UserSystemCouponRecord.STATE_GIVE_ON);
+ couponRecord.setUserSystemCoupon(userSystemCoupon);
+ couponRecord.setCouponType(type.name());
+ couponRecord.setCreateTime(nowDate);
+ couponRecord.setUpdateTime(nowDate);
+ userSystemCouponRecordService.insertSelective(couponRecord);
+
+ String projectChineseName = Constant.systemCommonConfig.getProjectChineseName();
+ while(tips.contains("{APP鍚嶇О}")) {
+ tips = tips.replace("{APP鍚嶇О}", projectChineseName);
+ }
+ tips = tips.replace("{鍙d护}", token).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
+
+ return createUserCouponVOo(userSystemCoupon, systemCoupon, giveRecord, tips);
+ }
+
+
+ private UserSystemCouponVO createUserCouponVOo(UserSystemCoupon userSystemCoupon, SystemCoupon systemCoupon,
+ UserSystemCouponGiveRecord record, String tips) {
+ UserSystemCouponVO userCouponVO = new UserSystemCouponVO();
+ userCouponVO.setId(userSystemCoupon.getId());
+ userCouponVO.setUid(userSystemCoupon.getUid());
+ userCouponVO.setSource("鏉ユ簮锛�" + userSystemCoupon.getSource());
+ userCouponVO.setCouponName(systemCoupon.getName());
+ userCouponVO.setCouponEffect("璧犻�佷腑");
+ userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
+ userCouponVO.setCouponRule(systemCoupon.getRemark());
+ userCouponVO.setCouponRuleLink(systemCoupon.getRuleLink());
+ userCouponVO.setCouponPicture(systemCoupon.getPicture());
+ userCouponVO.setGiveTips(tips);
+
+ String couponTerm = "鏈夋晥鏈燂細";
+ 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);
+ }
+ userCouponVO.setCouponTerm(couponTerm);
+
+ Map<String, Object> remainDays = new HashMap<String, Object>();
+
+ try {
+ remainDays.put("content", "鍓╀綑" + DateUtil.dateDiff2(new Date(), record.getGiveTime()) + "杩囨湡");
+ } catch (Exception e) {
+ }
+ remainDays.put("fontColor", "#F14242");
+ userCouponVO.setRemainDays(remainDays);
+
+ return userCouponVO;
+ }
- String tips = "閫佺粰浣犱竴寮犺繑鍒╁鍔卞埜蹇幓棰嗗彇鍚э紝澶嶅埗鏈潯娑堟伅[&%s&]锛屾墦寮�[杩斿埄鍒竇App棰嗗彇锛屼娇鐢ㄥ悗鍙杩斿埄鍔犲�嶃�俓r\n"
- +"----------------------------\r\n"
- + "涓嬭浇[杩斿埄鍒竇App閾炬帴:http://t.cn/2H7AXAH\r\n"
- + "PS锛氬彛浠ゅ皢浼�24灏忔椂鍐呭け鏁堬紝璇峰強鏃堕鍙栥��";
-
- tips = String.format(tips, token);
-
- return tips;
+
+ @Override
+ public void sendBackGiveCoupon(List<UserSystemCouponGiveRecord> overdueList) {
+ for (UserSystemCouponGiveRecord record: overdueList) {
+ // 鏇存柊璧犻�佽褰�
+ UserSystemCouponGiveRecord updateRecord = new UserSystemCouponGiveRecord();
+ updateRecord.setId(record.getId());
+ updateRecord.setState(UserSystemCouponGiveRecord.STATE_OVERDUE);
+ userSystemCouponGiveRecordService.updateByPrimaryKeySelective(updateRecord);
+
+ // 鏇存柊鍒镐俊鎭�
+ Long couponId = record.getCouponId();
+ if (couponId == null) {
+ continue;
+ }
+
+ // 鍒稿垪琛�
+ UserSystemCoupon userCoupon = userSystemCouponMapper.selectByPrimaryKey(couponId);
+ if (userCoupon == null)
+ continue;
+
+ Integer state = userCoupon.getState();
+ if (state != UserSystemCoupon.STATE_IN_USE)
+ return;
+
+ Date now = new Date();
+ Date endTime = userCoupon.getEndTime();
+ if (endTime != null && endTime.getTime() < now.getTime()) {
+ List<UserSystemCoupon> list = new ArrayList<UserSystemCoupon>();
+ list.add(userCoupon);
+ updateCounponInvalid(list);
+ continue;
+ }
+
+ // 閫�鍥炲埜
+ UserSystemCoupon userSystemCoupon = new UserSystemCoupon();
+ userSystemCoupon.setId(userCoupon.getId());
+ userSystemCoupon.setGive(false);
+ userSystemCoupon.setUseTime(null);
+ userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+ userSystemCoupon.setUpdateTime(new Date());
+ userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
+
+ // 浣跨敤璁板綍
+ UserSystemCouponRecord useRecord = userSystemCouponRecordService.getNearByUserCouponId(couponId);
+ if (useRecord != null) {
+ UserSystemCouponRecord useRecordUpdate = new UserSystemCouponRecord();
+ useRecordUpdate.setId(useRecord.getId());
+ useRecordUpdate.setState(UserSystemCouponRecord.STATE_WAIT_TIME_OUT);
+ useRecordUpdate.setUpdateTime(new Date());
+ userSystemCouponRecordService.updateByPrimaryKeySelective(useRecordUpdate);
+ }
+
+ SystemCoupon systemCoupon = userCoupon.getSystemCoupon();
+ if (systemCoupon != null)
+ systemCoupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
+
+ if (systemCoupon == null)
+ continue;
+
+ // 閫�鍥炴秷鎭�
+ String beiZhu = "璇峰埌鎴戠殑-绂忓埄涓績鏌ョ湅";
+ SimpleDateFormat sd = new SimpleDateFormat("yyyy.MM.dd HH:mm");
+ MsgOtherGiveContentDTO msgOther = new MsgOtherGiveContentDTO();
+ msgOther.setType(MsgOtherGiveContentDTO.TYEP_COUPON);
+ msgOther.setTitle("璧犻��" + systemCoupon.getName() + "閫�鍥�");
+ msgOther.setGiveType("浣犺禒閫佺殑"+ systemCoupon.getName() + "鏈鎴愬姛棰嗗彇");
+ msgOther.setGiveTime(sd.format(record.getGiveTime()));
+ msgOther.setReturnTime(sd.format(new Date()));
+ userOtherMsgNotificationService.tokenGiveMsg(record.getGiveUid(), beiZhu, msgOther);
+ }
}
}
--
Gitblit v1.8.0