From 26b5b1a6bbbb5ff64dc2ec73cf8b11f1aa61c1c5 Mon Sep 17 00:00:00 2001 From: yujian <yujian> Date: 星期二, 14 五月 2019 11:03:25 +0800 Subject: [PATCH] Merge branch 'div_8' --- fanli/src/main/java/com/yeshi/fanli/controller/client/UserCouponController.java | 617 ++++++++++++++++++++++++++----------------------------- 1 files changed, 288 insertions(+), 329 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..3c5ac36 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,35 +1,35 @@ 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 java.util.Map; 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; import com.yeshi.fanli.entity.bus.homemodule.SwiperPicture; import com.yeshi.fanli.entity.bus.user.DeviceLotteryRecord; import com.yeshi.fanli.entity.bus.user.UserInfoExtra; -import com.yeshi.fanli.entity.bus.user.UserSystemCoupon; +import com.yeshi.fanli.entity.bus.user.UserLotteryRecord; 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.UserLotteryRecordException; import com.yeshi.fanli.exception.user.UserSystemCouponException; import com.yeshi.fanli.service.inter.config.ConfigService; import com.yeshi.fanli.service.inter.config.SystemCouponService; import com.yeshi.fanli.service.inter.homemodule.SwiperPictureService; -import com.yeshi.fanli.service.inter.hongbao.ThreeSaleSerivce; -import com.yeshi.fanli.service.inter.order.CommonOrderCountService; import com.yeshi.fanli.service.inter.order.CommonOrderService; import com.yeshi.fanli.service.inter.user.DeviceLotteryRecordService; import com.yeshi.fanli.service.inter.user.UserInfoExtraService; +import com.yeshi.fanli.service.inter.user.UserLotteryRecordService; import com.yeshi.fanli.service.inter.user.UserSystemCouponService; import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.vo.user.UserSystemCouponRecordVO; @@ -39,6 +39,7 @@ /** * 绂忓埄涓績 + * * @author Administrator * */ @@ -46,41 +47,42 @@ @RequestMapping("api/v1/user/coupon") public class UserCouponController { + @Resource(name = "taskExecutor") + private TaskExecutor executor; + @Resource private ConfigService configService; @Resource - private UserSystemCouponService UserSystemCouponService; - - @Resource - 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; + private UserSystemCouponService UserSystemCouponService; @Resource - private ThreeSaleSerivce threeSaleSerivce; + private SwiperPictureService swiperPictureService; + + @Resource + private CommonOrderService commonOrderService; + + @Resource + private DeviceLotteryRecordService deviceLotteryRecordService; + + @Resource + private UserSystemCouponService userSystemCouponService; + + @Resource + private UserInfoExtraService userInfoExtraService; + - // 鏈�澶ф娊濂栨鏁� - private static int MAX_COUNT = 5; + @Resource + private UserLotteryRecordService userLotteryRecordService; + + /** * 鐢ㄦ埛鍒稿垪琛ㄦ煡璇� + * * @param acceptData * @param page * @param uid @@ -92,31 +94,41 @@ 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 ); + boolean changeJump = false; + String version = acceptData.getVersion(); + int tversion = Integer.parseInt(version); + String platform = acceptData.getPlatform(); + if ("android".equalsIgnoreCase(platform) && tversion > 34) { + changeJump = true; + } else if (tversion > 44){ + changeJump = true; + } + long count = 0; + List<UserSystemCouponVO> resultList = UserSystemCouponService + .getUserCouponVOList((page - 1) * Constant.PAGE_SIZE, Constant.PAGE_SIZE, uid, changeJump); + 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 +136,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 +163,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 +206,10 @@ e.printStackTrace(); } } - - + /** - * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * * @param acceptData * @param page * @param uid @@ -187,7 +221,7 @@ out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); return; } - + try { UserSystemCouponService.useGoodsCoupon(uid, cid, goodId); out.print(JsonUtil.loadTrueResult("浣跨敤鎴愬姛")); @@ -198,10 +232,10 @@ e.printStackTrace(); } } - - + /** * 鐢ㄦ埛濂栧姳鍒� + * * @param acceptData * @param page * @param uid @@ -209,26 +243,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 +270,10 @@ e.printStackTrace(); } } - - + /** - * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * 鍏嶅崟鍒镐娇鐢ㄨ褰� 浠ュ強鐘舵�佷慨鏀� + * * @param acceptData * @param page * @param uid @@ -247,19 +281,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 +301,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 +328,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 +355,6 @@ e.printStackTrace(); } } - /** * 鑾峰彇鎶藉娆℃暟 @@ -331,34 +366,54 @@ */ @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(); - } + // 1銆佸凡鐧诲綍绯荤粺 + if (uid != null) { + JSONObject data = userLotteryRecordService.getLotteryCountNewbies(uid); + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); + return; + } - try { + // 2銆佹湭鐧诲綍绯荤粺 - 璁板綍璁惧 + 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); + int count = UserLotteryRecord.COUNT_NEWBIES; + if (list != null && list.size() > 0) { + count = count - list.size(); + } // 鎶藉瑙勫垯 String lotteryRule = configService.get("lottery_rule_newbies"); - + JSONObject data = new JSONObject(); data.put("count", count); data.put("rule", lotteryRule); - JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); - + } catch (UserLotteryRecordException e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); } catch (Exception e) { JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎿嶄綔澶辫触")); e.printStackTrace(); } } - - + /** * 鑾峰彇鎶藉缁撴灉 - * * @param callback * @param acceptData * @param uid @@ -368,211 +423,14 @@ public void getLotteryResult(String callback, AcceptData acceptData, Long uid, PrintWriter out) { try { - // 濂栧搧 - int count = 0; - String prize = ""; - String hasPrize = ""; - Long couponId = null; + // 1銆佸凡鐧诲綍鐢ㄦ埛鎶藉 + if (uid != null) { + Map<String, Object> map = userLotteryRecordService.executeLotteryNewbies(uid); + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(map)); + return; + } - if (uid == null) { // 鏈櫥褰� - 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; - } - 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(); - } - } - - - count = MAX_COUNT - 1 - list.size(); - - - } else { - count = MAX_COUNT - 1; - } - - // 濂栧搧 - prize = getLotteryPrize(MAX_COUNT, countPrize, list.size(), couponId); - // 鎶戒腑 - Long newCouponId = null; - if (prize != null && prize.trim().length() > 0) { - // 宸插瓨鍦ㄦ鍒� - if (hasPrize.equals(prize)) { - prize = null; - } else { - SystemCoupon coupon= systemCouponService.getCouponByType(prize); - newCouponId = coupon.getId(); - } - } - - // 鎻掑叆璁板綍 - DeviceLotteryRecord record = new DeviceLotteryRecord(); - record.setDevice(device); - record.setPlatform(platformType); - 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 ) { // 娆℃暟宸茬敤鍏� - JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(2, "鎶藉娆℃暟涓嶈冻")); - return; - } else { - count = lotteryNewbies - 1; // 鍓╀綑娆℃暟 - } - - 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); - // 鎶戒腑 - if (prize != null && prize.trim().length() > 0) { - - if (hasPrize.equals(prize)) { - prize = null; - } else { - // 鎻掑叆鍒镐俊鎭� - userSystemCouponService.insertUserCoupon(uid, prize, UserSystemCoupon.SOURCE_CHOUJIANG); - } - } - - // 鍓╀綑娆℃暟 - userInfoExtra.setLotteryNewbies(count); - userInfoExtraService.saveUserInfoExtra(userInfoExtra); - } - - if (prize == null || prize.trim().length() == 0) { - prize = "NoPrize"; - } - - JSONObject data = new JSONObject(); - data.put("count", count); - data.put("result", prize); - - JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); - - } catch (Exception e) { - JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎶藉澶辫触")); - e.printStackTrace(); - } - } - - /** - * 濂栧搧鎶藉彇 - * @param maxCount 鏈�澶ф鏁� - * @param hasPrize 鎷ユ湁濂栧搧鏁伴噺 - * @param record 宸叉娊娆℃暟 - * @param couponId 鍒竔d - * @return - */ - public String getLotteryPrize(int maxCount, int countPrize, int record, Long couponId) { - - String prize = null; - String freeCoupon = CouponTypeEnum.welfareFreeCoupon.name(); // 绂忓埄鍏嶈垂鍒� - String rebateCoupon = CouponTypeEnum.rebatePercentCoupon.name(); // 濂栧姳鍒� - - if (countPrize == 1 && record == maxCount - 1) { - // 鏈�鍚庝竴娆★細 鍙敹鍒颁竴涓鍝� - SystemCoupon systemCoupon = systemCouponService.selectByPrimaryKey(couponId); - if (systemCoupon != null) { - CouponTypeEnum type = systemCoupon.getType(); - if (type.name() == freeCoupon) { - prize = rebateCoupon; // 濂栧姳鍒� - } else { - prize = freeCoupon; // 绂忓埄鍏嶈垂鍒� - } - } else { - prize = rebateCoupon; // 濂栧姳鍒� - } - - } else if (countPrize == 0 && record == maxCount - 2) { - // 鍓�3娆℃病鏈夊鍔辨椂銆佸悗闈袱娆″繀涓� - long result = (1 + Math.round(Math.random() * (9))); - if (result <= 5) { - prize = freeCoupon; // 绂忓埄鍏嶈垂鍒� - } else { - prize = rebateCoupon; // 濂栧姳鍒� - } - - } else { // 澶т簬3娆℃満浼� - - if (countPrize < 2) { // 涓嶈冻涓や釜濂栧搧 - long result = (1 + Math.round(Math.random() * (9))); - if (result <= 3) { - 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) { // 鏈櫥褰� + // 2銆佹湭鐧诲綍鐢ㄦ埛鎶藉 int platformType = 0; String platform = acceptData.getPlatform(); if ("android".equals(platform)) { @@ -580,41 +438,142 @@ } else if ("ios".equals(platform)) { platformType = 2; } else { - throw new Exception("骞冲彴鏈夎"); + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("骞冲彴鏈夎")); + return; } - + String device = acceptData.getDevice(); if (device == null || device.trim().length() == 0) { - throw new Exception("璁惧涓嶅瓨鍦�"); + 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) { - 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; // 鍓╀綑娆℃暟 + if (list != null && list.size() >= UserLotteryRecord.COUNT_NEWBIES) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(2, "鎶藉娆℃暟涓嶈冻")); + return; } + // 璁惧鎶藉 + JSONObject data = getDevicePrize(list, device, platformType); + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); + } catch (UserLotteryRecordException e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getCode(), e.getMsg())); + } catch (Exception e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎶藉澶辫触")); + e.printStackTrace(); } + } + - return count; + /** + * 璁惧淇℃伅鎶藉-鏈櫥褰� + * @param list + * @param device + * @param platformType + * @return + */ + public JSONObject getDevicePrize(List<DeviceLotteryRecord> list, String device, int platformType) { + int count = 0; + int countPrize = 0; + Long couponId = null; + + if (list == null || list.size() == 0) { // 鎷ユ湁鎶藉鏈轰細 + count = UserLotteryRecord.COUNT_NEWBIES; + } else { + for (DeviceLotteryRecord deviceLotteryRecord : list) { + Long systemCouponId = deviceLotteryRecord.getSystemCouponId(); + if (systemCouponId != null) { + countPrize++; + couponId = systemCouponId; + } + } + count = UserLotteryRecord.COUNT_NEWBIES - list.size(); + } + + + String prize = null; + String couponType = null; + if (countPrize == 0) { + prize = userLotteryRecordService.getLotteryPrizeNewbies(count, countPrize, null); + } else if (countPrize == 1) { + if (couponId != null) { + SystemCoupon coupon = systemCouponService.selectByPrimaryKey(couponId); + couponType = coupon.getType().name(); + } + + if(couponType != null && couponType.trim().length() > 0) { + prize = userLotteryRecordService.getLotteryPrizeNewbies(count, countPrize, couponType); + } + } + + Long newCouponId = null; + if (prize == null || prize.trim().length() == 0) { + prize = "NoPrize"; + } else if (prize.equals(couponType)) { + // 宸插瓨鍦ㄦ鍒� + prize = "NoPrize"; + } else { + SystemCoupon coupon = systemCouponService.getCouponByType(prize); + if (coupon != null) { + newCouponId = coupon.getId(); + } + } + + count --; + + // 鎻掑叆璁板綍 + DeviceLotteryRecord record = new DeviceLotteryRecord(); + record.setDevice(device); + record.setPlatform(platformType); + record.setSystemCouponId(newCouponId); + record.setCreateTime(new Date()); + deviceLotteryRecordService.insertSelective(record); + + JSONObject data = new JSONObject(); + data.put("count", count); + data.put("result", prize); + + return data; + } + + + /** + * 鑾峰彇鎶藉娆℃暟- 澶╁ぉ鎶藉鍔卞埜 + * + * @param callback + * @param acceptData + * @param uid + * @param out + */ + @RequestMapping(value = "getDailyCount") + public void getDailyCount(String callback, AcceptData acceptData, Long uid, PrintWriter out) { + try { + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(userLotteryRecordService.getLotteryCountDaily(uid))); + } catch (UserLotteryRecordException e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getCode(),e.getMsg())); + } catch (Exception e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("淇℃伅鑾峰彇澶辫触")); + e.printStackTrace(); + } + } + + /** + * 鑾峰彇鎶藉缁撴灉 - 澶╁ぉ鎶藉鍔卞埜` + * @param callback + * @param acceptData + * @param uid + * @param out + */ + @RequestMapping(value = "getDailyResult") + public void getDailyResult(String callback, AcceptData acceptData, Long uid, PrintWriter out) { + try { + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(userLotteryRecordService.executeLotteryDaily(uid))); + } catch (UserLotteryRecordException e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getCode(),e.getMsg())); + } catch (Exception e) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎶藉澶辫触")); + e.printStackTrace(); + } } } -- Gitblit v1.8.0