From 56e258fa6c23469ea825f6b11d458df9ba577e9f Mon Sep 17 00:00:00 2001 From: yujian <yujian> Date: 星期五, 01 三月 2019 14:38:50 +0800 Subject: [PATCH] Merge branch 'div' --- fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java | 362 ++++++++++++++++++++++++++------------------------- 1 files changed, 182 insertions(+), 180 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java index 683afc5..6cc19ba 100644 --- a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java +++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java @@ -1,17 +1,16 @@ package com.yeshi.fanli.controller.client; import java.io.PrintWriter; -import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import javax.annotation.Resource; +import org.springframework.core.task.TaskExecutor; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; -import org.yeshi.utils.DateUtil; import org.yeshi.utils.JsonUtil; import com.yeshi.fanli.entity.accept.AcceptData; @@ -21,6 +20,7 @@ import com.yeshi.fanli.entity.bus.user.UserSystemCoupon; import com.yeshi.fanli.entity.system.SystemCoupon; import com.yeshi.fanli.entity.system.SystemCoupon.CouponTypeEnum; +import com.yeshi.fanli.exception.user.UserInfoExtraException; import com.yeshi.fanli.exception.user.UserSystemCouponException; import com.yeshi.fanli.service.inter.config.ConfigService; import com.yeshi.fanli.service.inter.config.SystemCouponService; @@ -39,12 +39,16 @@ /** * 绂忓埄涓績 + * * @author Administrator * */ @Controller @RequestMapping("api/v1/user/coupon") public class UserCouponController { + + @Resource(name = "taskExecutor") + private TaskExecutor executor; @Resource private ConfigService configService; @@ -53,34 +57,35 @@ private UserSystemCouponService UserSystemCouponService; @Resource - private SwiperPictureService swiperPictureService; - + private SwiperPictureService swiperPictureService; + @Resource private CommonOrderService commonOrderService; - + @Resource private DeviceLotteryRecordService deviceLotteryRecordService; - + @Resource private SystemCouponService systemCouponService; - + @Resource private UserSystemCouponService userSystemCouponService; - + @Resource private UserInfoExtraService userInfoExtraService; - + @Resource private CommonOrderCountService commonOrderCountService; @Resource private ThreeSaleSerivce threeSaleSerivce; - + // 鏈�澶ф娊濂栨鏁� private static int MAX_COUNT = 5; - + /** * 鐢ㄦ埛鍒稿垪琛ㄦ煡璇� + * * @param acceptData * @param page * @param uid @@ -92,31 +97,31 @@ out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { if (page == null || page < 1) { page = 1; } - + // 绂忓埄涓績鍥剧墖 - String topPicture = null; - if(page == 1) { + String topPicture = null; + if (page == 1) { List<SwiperPicture> listswiper = swiperPictureService.getByBannerCard("welfare_top"); if (listswiper != null && listswiper.size() > 0) { topPicture = listswiper.get(0).getSrc(); } } - + long count = 0; - List<UserSystemCouponVO> resultList = UserSystemCouponService.getUserCouponVOList((page - 1) * Constant.PAGE_SIZE, - Constant.PAGE_SIZE, uid ); - + List<UserSystemCouponVO> resultList = UserSystemCouponService + .getUserCouponVOList((page - 1) * Constant.PAGE_SIZE, Constant.PAGE_SIZE, uid); + if (resultList != null && resultList.size() > 0) { count = UserSystemCouponService.countUserCouponList(uid); } else if (resultList == null) { resultList = new ArrayList<UserSystemCouponVO>(); } - + JSONObject data = new JSONObject(); data.put("topPicture", topPicture); data.put("count", count); @@ -124,6 +129,26 @@ out.print(JsonUtil.loadTrueResult(data)); + // 鏇存柊绂忓埄涓績鏈鏁伴噺 + if (page == 1) { + executor.execute(new Runnable() { + @Override + public void run() { + UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid); + // 鏈鍒告槸鍚﹀ぇ浜�0 + if (userInfoExtra != null && userInfoExtra.getCouponNews() > 0) { + userInfoExtra.setCouponNews(0); + try { + userInfoExtraService.saveUserInfoExtra(userInfoExtra); + } catch (UserInfoExtraException e) { + e.printStackTrace(); + } + } + + } + }); + } + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -131,40 +156,42 @@ e.printStackTrace(); } } - + /** * 鐢ㄦ埛濂栧姳鍒� + * * @param acceptData * @param page * @param uid + * @param auctionId 鍟嗗搧id * @param out */ @RequestMapping(value = "getGoodsCouponList", method = RequestMethod.POST) - public void getGoodsCouponList(AcceptData acceptData, Long uid, PrintWriter out) { + public void getGoodsCouponList(AcceptData acceptData, Long uid, Long auctionId, PrintWriter out) { if (uid == null) { out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { - List<UserSystemCouponVO> resultList = UserSystemCouponService.getGoodsCouponList(uid); - - if (resultList == null ) { - resultList =new ArrayList<UserSystemCouponVO>(); + List<UserSystemCouponVO> resultList = UserSystemCouponService.getGoodsCouponList(uid, auctionId); + + if (resultList == null) { + resultList = new ArrayList<UserSystemCouponVO>(); } - + JSONObject dataTip = new JSONObject(); dataTip.put("content", configService.get("free_coupon_tip")); dataTip.put("fontColor", "#F14242"); - + JSONObject data = new JSONObject(); data.put("helpLink", configService.get("free_coupon_help")); data.put("tip", dataTip); data.put("count", resultList.size()); data.put("result_list", JsonUtil.getApiCommonGson().toJson(resultList)); - + out.print(JsonUtil.loadTrueResult(data)); - + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -172,10 +199,10 @@ e.printStackTrace(); } } - - + /** - * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * * @param acceptData * @param page * @param uid @@ -187,7 +214,7 @@ out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { UserSystemCouponService.useGoodsCoupon(uid, cid, goodId); out.print(JsonUtil.loadTrueResult("浣跨敤鎴愬姛")); @@ -198,10 +225,10 @@ e.printStackTrace(); } } - - + /** * 鐢ㄦ埛濂栧姳鍒� + * * @param acceptData * @param page * @param uid @@ -209,26 +236,26 @@ */ @RequestMapping(value = "getOrderCouponList", method = RequestMethod.POST) public void getOrderCouponList(AcceptData acceptData, Long uid, PrintWriter out) { - + if (uid == null) { out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { List<UserSystemCouponVO> resultList = UserSystemCouponService.getOrderCouponList(uid); - - if (resultList == null ) { - resultList =new ArrayList<UserSystemCouponVO>(); + + if (resultList == null) { + resultList = new ArrayList<UserSystemCouponVO>(); } - + JSONObject data = new JSONObject(); data.put("helpLink", configService.get("reward_coupon_help")); data.put("count", resultList.size()); data.put("result_list", JsonUtil.getApiCommonGson().toJson(resultList)); - + out.print(JsonUtil.loadTrueResult(data)); - + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -236,10 +263,10 @@ e.printStackTrace(); } } - - + /** - * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * * @param acceptData * @param page * @param uid @@ -247,19 +274,19 @@ */ @RequestMapping(value = "useRewardCoupon", method = RequestMethod.POST) public void useRewardCoupon(AcceptData acceptData, Long uid, Long cid, String orderNo, PrintWriter out) { - + if (uid == null) { out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { UserSystemCouponService.useOrderCoupon(uid, cid, orderNo); - + JSONObject data = commonOrderService.getRewardJumpInfo(orderNo); - + out.print(JsonUtil.loadTrueResult(data)); - + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -267,25 +294,26 @@ e.printStackTrace(); } } - + /** - * 璁㈠崟-濂栧姳杩涘害璇︽儏 + * 璁㈠崟-濂栧姳杩涘害璇︽儏 + * * @param acceptData - * @param orderNo 璁㈠崟鍙� + * @param orderNo 璁㈠崟鍙� * @param out */ @RequestMapping(value = "getRewardRecord", method = RequestMethod.POST) public void getRewardCounponRecord(AcceptData acceptData, String orderNo, PrintWriter out) { - + try { - + UserSystemCouponRecordVO rewardRecord = UserSystemCouponService.getRewardCouponRecord(orderNo); - + JSONObject data = new JSONObject(); data.put("rewardRecord", rewardRecord); - + out.print(JsonUtil.loadTrueResult(data)); - + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -293,25 +321,26 @@ e.printStackTrace(); } } - + /** - * 璁㈠崟-濂栧姳杩涘害璇︽儏 + * 璁㈠崟-濂栧姳杩涘害璇︽儏 + * * @param acceptData - * @param orderNo 璁㈠崟鍙� + * @param orderNo 璁㈠崟鍙� * @param out */ @RequestMapping(value = "getFreeCounponRecord", method = RequestMethod.POST) public void getFreeCounponRecord(AcceptData acceptData, String orderNo, PrintWriter out) { - + try { - + UserSystemCouponRecordVO rewardRecord = UserSystemCouponService.getFreeCouponRecord(orderNo); - + JSONObject data = new JSONObject(); data.put("frreCouponRecord", rewardRecord); - + out.print(JsonUtil.loadTrueResult(data)); - + } catch (UserSystemCouponException e) { out.print(JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { @@ -319,7 +348,6 @@ e.printStackTrace(); } } - /** * 鑾峰彇鎶藉娆℃暟 @@ -331,15 +359,55 @@ */ @RequestMapping(value = "getLotteryCount") public void getLotteryCount(String callback, AcceptData acceptData, Long uid, PrintWriter out) { - int count = 0; try { - count = getSurplusCount(acceptData, uid); - } catch (Exception e) { - JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMessage())); - e.printStackTrace(); - } + // 榛樿鏈�澶ф娊濂栨鏁� + int count = 5; - try { + if (uid == null || uid == 0) { // 鏈櫥褰� + int platformType = 0; + String platform = acceptData.getPlatform(); + if ("android".equals(platform)) { + platformType = 1; + } else if ("ios".equals(platform)) { + platformType = 2; + } else { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("骞冲彴鏈夎")); + return; + } + + String device = acceptData.getDevice(); + if (device == null || device.trim().length() == 0) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璁惧涓嶅瓨鍦�")); + return; + } + + List<DeviceLotteryRecord> list = deviceLotteryRecordService.listByPlatformAndDevice(platformType, + device); + if (list != null && list.size() > 0) { + count = count - list.size(); + } + + } else { // 宸茬櫥褰� + UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid); + if (userInfoExtra == null) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鐢ㄦ埛淇℃伅涓嶅瓨鍦�")); + return; + } + + Integer lotteryNewbies = userInfoExtra.getLotteryNewbies(); + if (lotteryNewbies == null) { // 鏈娊杩� + // 鏄惁鏈夎繃璁㈠崟锛氳繑鍒┿�佸垎浜鍗� + boolean hasOrder = commonOrderCountService.hasRebateAndShareOrder(uid); + if (hasOrder) { + count = 0; // 涓嶇畻鏂扮敤鎴� + } + userInfoExtra.setLotteryNewbies(count); + userInfoExtraService.saveUserInfoExtra(userInfoExtra); + } else { + count = lotteryNewbies; // 鍓╀綑娆℃暟 + } + } + // 鎶藉瑙勫垯 String lotteryRule = configService.get("lottery_rule_newbies"); @@ -354,8 +422,7 @@ e.printStackTrace(); } } - - + /** * 鑾峰彇鎶藉缁撴灉 * @@ -373,8 +440,8 @@ String prize = ""; String hasPrize = ""; Long couponId = null; - - if (uid == null) { // 鏈櫥褰� + + if (uid == null || uid == 0) { // 鏈櫥褰� int platformType = 0; String platform = acceptData.getPlatform(); if ("android".equals(platform)) { @@ -392,31 +459,30 @@ return; } int countPrize = 0; - + List<DeviceLotteryRecord> list = deviceLotteryRecordService.listByPlatformAndDevice(platformType, device); if (list != null && list.size() == MAX_COUNT) { // 鏃犳娊濂栨満浼� JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(2, "鎶藉娆℃暟涓嶈冻")); return; } else if (list != null && list.size() < MAX_COUNT) { // 鎷ユ湁鎶藉鏈轰細 - + for (DeviceLotteryRecord deviceLotteryRecord : list) { Long systemCouponId = deviceLotteryRecord.getSystemCouponId(); if (systemCouponId != null) { countPrize++; couponId = systemCouponId; } - - if (countPrize == 1) { - SystemCoupon coupon = systemCouponService.selectByPrimaryKey(systemCouponId); - hasPrize = coupon.getType().name(); - } + } - + if (countPrize == 1 && couponId != null) { + SystemCoupon coupon = systemCouponService.selectByPrimaryKey(couponId); + hasPrize = coupon.getType().name(); + } + count = MAX_COUNT - 1 - list.size(); - - + } else { count = MAX_COUNT - 1; } @@ -430,11 +496,11 @@ if (hasPrize.equals(prize)) { prize = null; } else { - SystemCoupon coupon= systemCouponService.getCouponByType(prize); + SystemCoupon coupon = systemCouponService.getCouponByType(prize); newCouponId = coupon.getId(); } } - + // 鎻掑叆璁板綍 DeviceLotteryRecord record = new DeviceLotteryRecord(); record.setDevice(device); @@ -442,34 +508,35 @@ record.setSystemCouponId(newCouponId); record.setCreateTime(new Date()); deviceLotteryRecordService.insertSelective(record); - + } else { // 宸茬櫥褰� UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid); if (userInfoExtra == null) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("淇℃伅涓嶆纭�")); return; } - + Integer lotteryNewbies = userInfoExtra.getLotteryNewbies(); - if (lotteryNewbies == null || lotteryNewbies < 1 ) { // 娆℃暟宸茬敤鍏� + if (lotteryNewbies == null || lotteryNewbies < 1) { // 娆℃暟宸茬敤鍏� JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(2, "鎶藉娆℃暟涓嶈冻")); return; } else { count = lotteryNewbies - 1; // 鍓╀綑娆℃暟 } - - List<UserSystemCoupon> list = userSystemCouponService.getUserCouponBySource(uid, UserSystemCoupon.SOURCE_CHOUJIANG); + + List<UserSystemCoupon> list = userSystemCouponService.getUserCouponBySource(uid, + UserSystemCoupon.SOURCE_CHOUJIANG); if (list != null && list.size() == 1) { couponId = list.get(0).getSystemCoupon().getId(); SystemCoupon coupon = systemCouponService.selectByPrimaryKey(couponId); hasPrize = coupon.getType().name(); } - + // 濂栧搧 - prize = getLotteryPrize(MAX_COUNT, list.size(), MAX_COUNT- lotteryNewbies, couponId); + prize = getLotteryPrize(MAX_COUNT, list.size(), MAX_COUNT - lotteryNewbies, couponId); // 鎶戒腑 if (prize != null && prize.trim().length() > 0) { - + if (hasPrize.equals(prize)) { prize = null; } else { @@ -477,12 +544,12 @@ userSystemCouponService.insertUserCoupon(uid, prize, UserSystemCoupon.SOURCE_CHOUJIANG); } } - + // 鍓╀綑娆℃暟 userInfoExtra.setLotteryNewbies(count); userInfoExtraService.saveUserInfoExtra(userInfoExtra); } - + if (prize == null || prize.trim().length() == 0) { prize = "NoPrize"; } @@ -498,21 +565,22 @@ e.printStackTrace(); } } - + /** * 濂栧搧鎶藉彇 - * @param maxCount 鏈�澶ф鏁� + * + * @param maxCount 鏈�澶ф鏁� * @param hasPrize 鎷ユ湁濂栧搧鏁伴噺 - * @param record 宸叉娊娆℃暟 + * @param record 宸叉娊娆℃暟 * @param couponId 鍒竔d * @return */ public String getLotteryPrize(int maxCount, int countPrize, int record, Long couponId) { - - String prize = null; + + String prize = null; String freeCoupon = CouponTypeEnum.welfareFreeCoupon.name(); // 绂忓埄鍏嶈垂鍒� - String rebateCoupon = CouponTypeEnum.rebatePercentCoupon.name(); // 濂栧姳鍒� - + String rebateCoupon = CouponTypeEnum.rebatePercentCoupon.name(); // 濂栧姳鍒� + if (countPrize == 1 && record == maxCount - 1) { // 鏈�鍚庝竴娆★細 鍙敹鍒颁竴涓鍝� SystemCoupon systemCoupon = systemCouponService.selectByPrimaryKey(couponId); @@ -526,7 +594,7 @@ } else { prize = rebateCoupon; // 濂栧姳鍒� } - + } else if (countPrize == 0 && record == maxCount - 2) { // 鍓�3娆℃病鏈夊鍔辨椂銆佸悗闈袱娆″繀涓� long result = (1 + Math.round(Math.random() * (9))); @@ -535,7 +603,7 @@ } else { prize = rebateCoupon; // 濂栧姳鍒� } - + } else { // 澶т簬3娆℃満浼� if (countPrize < 2) { // 涓嶈冻涓や釜濂栧搧 @@ -544,77 +612,11 @@ prize = freeCoupon; // 绂忓埄鍏嶈垂鍒� } else if (result <= 6) { prize = rebateCoupon; // 濂栧姳鍒� - } - } - } - - return prize; - } - - - - public static void main(String[] args) { - long result = (1 + Math.round(Math.random() * (9))); - System.out.println(result); - } - - - /** - * 鑾峰彇鎶藉缁撴灉 - * - * @param callback - * @param acceptData - * @param uid - * @param out - */ - public int getSurplusCount(AcceptData acceptData, Long uid) throws Exception { - - // 榛樿鏈�澶ф娊濂栨鏁� - int count = 5; - - if (uid == null) { // 鏈櫥褰� - int platformType = 0; - String platform = acceptData.getPlatform(); - if ("android".equals(platform)) { - platformType = 1; - } else if ("ios".equals(platform)) { - platformType = 2; - } else { - throw new Exception("骞冲彴鏈夎"); - } - - String device = acceptData.getDevice(); - if (device == null || device.trim().length() == 0) { - throw new Exception("璁惧涓嶅瓨鍦�"); - } - - List<DeviceLotteryRecord> list = deviceLotteryRecordService.listByPlatformAndDevice(platformType, device); - if (list != null && list.size() > 0) { - count = count - list.size(); - } - - } else { // 宸茬櫥褰� - UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid); - if (userInfoExtra == null) { - throw new Exception("淇℃伅涓嶆纭�"); - } - - Integer lotteryNewbies = userInfoExtra.getLotteryNewbies(); - if (lotteryNewbies == null) { // 鏈娊杩� - // 鏄惁鏈夎繃璁㈠崟锛氳繑鍒┿�佸垎浜鍗� - boolean hasOrder = commonOrderCountService.hasRebateAndShareOrder(uid); - if (hasOrder) { - count = 0; // 涓嶇畻鏂扮敤鎴� } - userInfoExtra.setLotteryNewbies(count); - userInfoExtraService.saveUserInfoExtra(userInfoExtra); - - } else { - count = lotteryNewbies; // 鍓╀綑娆℃暟 - } + } } - return count; + return prize; } } -- Gitblit v1.8.0