From bb3bdeae38ee40dbdd802634b2d4549790b9aa92 Mon Sep 17 00:00:00 2001
From: yujian <yujian>
Date: 星期五, 12 四月 2019 11:39:06 +0800
Subject: [PATCH] 1.5.3 需求提交

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/RecommendController.java |  279 ++++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 210 insertions(+), 69 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/RecommendController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/RecommendController.java
index 8d8827c..550ec02 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/RecommendController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/RecommendController.java
@@ -7,8 +7,8 @@
 import java.util.Calendar;
 import java.util.Collections;
 import java.util.Date;
+import java.util.Iterator;
 import java.util.List;
-import java.util.Map;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
@@ -28,17 +28,16 @@
 import com.google.gson.JsonPrimitive;
 import com.google.gson.JsonSerializationContext;
 import com.google.gson.JsonSerializer;
-import com.yeshi.fanli.dao.mybatis.HongBaoManageMapper;
 import com.yeshi.fanli.entity.accept.AcceptData;
 import com.yeshi.fanli.entity.bus.homemodule.Special;
 import com.yeshi.fanli.entity.bus.homemodule.SuperSpecial;
 import com.yeshi.fanli.entity.bus.homemodule.SwiperPicture;
+import com.yeshi.fanli.entity.bus.lable.QualityFactory;
 import com.yeshi.fanli.entity.bus.recommend.Honest;
 import com.yeshi.fanli.entity.bus.recommend.RecommendBanner;
 import com.yeshi.fanli.entity.bus.recommend.RecommendBannerV2;
 import com.yeshi.fanli.entity.bus.recommend.RecommendSpecial;
 import com.yeshi.fanli.entity.bus.su.recommend.SuperRecommendBanner;
-import com.yeshi.fanli.entity.bus.su.recommend.SuperRecommendBannerV2;
 import com.yeshi.fanli.entity.bus.su.recommend.SuperRecommendSpecial;
 import com.yeshi.fanli.entity.bus.user.Order;
 import com.yeshi.fanli.entity.bus.user.ShamUser;
@@ -54,7 +53,6 @@
 import com.yeshi.fanli.entity.taobao.ClientTBPid;
 import com.yeshi.fanli.entity.taobao.PidUser;
 import com.yeshi.fanli.entity.taobao.SearchFilter;
-import com.yeshi.fanli.entity.taobao.TBPid;
 import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
 import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBriefExtra;
 import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
@@ -75,7 +73,6 @@
 import com.yeshi.fanli.service.inter.config.SystemConfigService;
 import com.yeshi.fanli.service.inter.goods.CollectionGoodsV2Service;
 import com.yeshi.fanli.service.inter.goods.CommonGoodsService;
-import com.yeshi.fanli.service.inter.goods.RecommendBannerService;
 import com.yeshi.fanli.service.inter.goods.ScanHistoryV2Service;
 import com.yeshi.fanli.service.inter.goods.SuperRecommendBannerService;
 import com.yeshi.fanli.service.inter.goods.SuperRecommendBannerV2Service;
@@ -86,6 +83,7 @@
 import com.yeshi.fanli.service.inter.homemodule.SuperSpecialService;
 import com.yeshi.fanli.service.inter.homemodule.SwiperPictureService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoManageService;
+import com.yeshi.fanli.service.inter.lable.QualityFlashSaleService;
 import com.yeshi.fanli.service.inter.lable.QualityGoodsService;
 import com.yeshi.fanli.service.inter.monitor.MonitorService;
 import com.yeshi.fanli.service.inter.order.OrderService;
@@ -101,11 +99,11 @@
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.RedisManager;
 import com.yeshi.fanli.util.StringUtil;
+import com.yeshi.fanli.util.TaoBaoConstant;
 import com.yeshi.fanli.util.ThreadUtil;
 import com.yeshi.fanli.util.TimeUtil;
 import com.yeshi.fanli.util.factory.MonitorFactory;
 import com.yeshi.fanli.util.taobao.TaoBaoCouponUtil;
-import com.yeshi.fanli.util.taobao.TaoBaoOrderUtil;
 import com.yeshi.fanli.util.taobao.TaoBaoUtil;
 import com.yeshi.fanli.util.taobao.TaoKeApiUtil;
 import com.yeshi.fanli.vo.user.UserSettingsVO;
@@ -117,8 +115,6 @@
 @RequestMapping("api/v1/user")
 public class RecommendController {
 
-	@Resource
-	private RecommendBannerService recommendService;
 
 	@Resource
 	private BusinessSystemService businessSystemService;
@@ -144,8 +140,6 @@
 	@Resource
 	private UserInfoService userInfoService;
 
-	@Resource
-	private TaoBaoOrderUtil taoBaoOrderUtil;
 
 	@Resource
 	private TaoBaoCouponService taoBaoCouponService;
@@ -158,9 +152,6 @@
 
 	@Resource
 	private CollectionGoodsV2Service collectionGoodsV2Service;
-
-	@Resource
-	private HongBaoManageMapper hongBaoManageMapper;
 
 	@Resource
 	private TaoBaoGoodsBriefService taoBaoGoodsBriefService;
@@ -221,11 +212,13 @@
 
 	@Resource
 	private UserInfoExtraService userInfoExtraService;
+	
+	@Resource
+	private QualityFlashSaleService qualityFlashSaleService;
+	
 
 	@RequestMapping(value = "getHonestList")
 	public void getHonestList(AcceptData acceptData, PrintWriter out) {
-		BusinessSystem system = businessSystemService.getBusinessSystemCache(acceptData.getPlatform(),
-				acceptData.getPackages());
 		List<Honest> honestList = null;
 		List<TaoBaoUnionConfig> configList = taoBaoUnionConfigService.getConfigByTypeCache(PidUser.TYPE_FANLI_ANDROID);
 		if ((Integer.parseInt(acceptData.getVersion()) >= 20 && "android".equalsIgnoreCase(acceptData.getPlatform()))
@@ -404,25 +397,28 @@
 		if (!"1".equals(version) && "android".equalsIgnoreCase(acceptData.getPlatform())) {
 			jumpDetail = jumpDetailService.getlastJumpDetailCache();
 		}
+		List<RecommendSpecial> recommendSpecialList = null;
+
 		List<SuperRecommendSpecial> superRecommendSpecialList = superRecommendSpecialService
 				.getSuperRecommendSpecialBySystemId(system.getId());
+		if (superRecommendSpecialList != null && superRecommendSpecialList.size() > 0) {
 
-		List<RecommendSpecial> recommendSpecialList = null;
-		for (SuperRecommendSpecial superRecommendSpecial : superRecommendSpecialList) {
-			if (recommendSpecialList == null) {
-				recommendSpecialList = new ArrayList<RecommendSpecial>();
+			recommendSpecialList = new ArrayList<RecommendSpecial>();
+
+			for (SuperRecommendSpecial superRecommendSpecial : superRecommendSpecialList) {
+				RecommendSpecial recommendSpecial = superRecommendSpecial.getRecommendSpecial();
+				if (jumpDetail != null) {
+					recommendSpecial.setJumpDetail(jumpDetail);
+				}
+				recommendSpecialList.add(recommendSpecial);
 			}
-			RecommendSpecial recommendSpecial = superRecommendSpecial.getRecommendSpecial();
-			if (jumpDetail != null) {
-				recommendSpecial.setJumpDetail(jumpDetail);
-			}
-			recommendSpecialList.add(recommendSpecial);
 		}
 
 		if (recommendSpecialList == null || recommendSpecialList.size() == 0) {
 			out.print(JsonUtil.loadFalseResult(1, "鏆傛棤鏁版嵁"));
 			return;
 		}
+
 		JSONObject data = new JSONObject();
 		data.put("count", recommendSpecialList.size());
 		Gson gson = new Gson();
@@ -569,8 +565,8 @@
 		// 鑾峰彇娣樺鍙傛暟
 		ClientTBPid clientTBPid = null;
 		if (simpleGoods.getMaterialLibType() != null && simpleGoods.getMaterialLibType() == 1) {
-			String pid = Constant.TAOBAO_SPECIAL_PID_DEFAULT;
-			clientTBPid = new ClientTBPid(Constant.TAOBAO_AUTH_APPKEY, Constant.TAOBAO_AUTH_APPSECRET,
+			String pid = TaoBaoConstant.TAOBAO_SPECIAL_PID_DEFAULT;
+			clientTBPid = new ClientTBPid(TaoBaoConstant.TAOBAO_AUTH_APPKEY, TaoBaoConstant.TAOBAO_AUTH_APPSECRET,
 					pid.split("_")[2], pid.split("_")[3]);
 		} else {
 			if (acceptData.getPlatform().equalsIgnoreCase("android")) {
@@ -971,7 +967,6 @@
 		ClientTBPid clientTBPid = null;
 		// 鐢ㄦ埛宸茬粡鐧诲綍
 		if (!StringUtil.isNullOrEmpty(uid)) {
-			TBPid tbPid = null;
 			if (acceptData.getPlatform().equalsIgnoreCase("android")) {
 				clientTBPid = tbPidService.getAndroidDefault();
 			} else {
@@ -1293,7 +1288,6 @@
 		// 浠庢帹鑽愭潵
 		if (page <= 1) {
 			array.clear();
-			Map<String, String> map = hongBaoManageService.convertMap();
 			BigDecimal proportion = manageService.getFanLiRate();
 			if (!StringUtil.isNullOrEmpty(imei) || !StringUtil.isNullOrEmpty(idfa)) {
 				long startTime = java.lang.System.currentTimeMillis();
@@ -1307,7 +1301,7 @@
 					for (TaoBaoGoodsBrief goods : result.getTaoBaoGoodsBriefs()) {
 						if (!StringUtil.isNullOrEmpty(goods.getCouponInfo()) && goods.getCouponAmount() != null
 								&& goods.getCouponAmount().compareTo(new BigDecimal("5")) >= 0
-								&& goods.getBiz30day() > 1000)
+								&& goods.getBiz30day() > 1000 && !StringUtil.isNullOrEmpty(goods.getPictUrlWhite()))
 							goodsList.add(goods);
 					}
 					try {
@@ -1335,14 +1329,12 @@
 					proportion.toString());
 			array.addAll(localArray);
 		} else {// 浠庣簿閫夊簱鏉�
-			Map<String, String> map = hongBaoManageService.convertMap();
 			BigDecimal proportion = manageService.getFanLiRate();
 			array = qualityGoodsService.getRecommendToIndex((page - 1) * pageSize, pageSize, proportion.toString());
 			if (array == null) {
 				out.print(JsonUtil.loadFalseResult("娌℃湁鏇村浜�"));
 				return;
 			}
-			long count = qualityGoodsService.countRecommendToIndex(proportion.toString());
 		}
 
 		JSONObject data = new JSONObject();
@@ -1368,26 +1360,8 @@
 		}
 
 		// 棣栭〉Banner
-		List<RecommendBannerV2> listBanner = null;
-
-		List<SuperRecommendBannerV2> listRecommendBanner = superRecommendBannerV2Service
-				.getSuperRecommendBannerV2sBySystem(system);
-
-		if (listRecommendBanner != null && listRecommendBanner.size() > 0) {
-
-			listBanner = new ArrayList<RecommendBannerV2>();
-
-			for (SuperRecommendBannerV2 superRecommendBanner : listRecommendBanner) {
-				RecommendBannerV2 recommendBanner = superRecommendBanner.getRecommendBanner();
-				// 娣樼壒浠锋殏鏃朵慨鏀�
-				if (system.getId() == 7) {
-					recommendBanner.getJumpDetail().setActivity(recommendBanner.getJumpDetail().getActivity()
-							.replace("com.yeshi.ec.rebate.myapplication", "com.yeshi.ec.taospecial"));
-				}
-
-				listBanner.add(recommendBanner);
-			}
-		}
+		List<RecommendBannerV2> listBanner = superRecommendBannerV2Service
+				.getSuperRecommendBannerV2sBySystem(system.getId());
 
 		JSONObject root = new JSONObject();
 		root.put("banner", listBanner);
@@ -1580,11 +1554,188 @@
 					root.put("invite", invite);
 			}
 		}
-
 		out.print(JsonUtil.loadTrueResult(root));
-
 	}
 
+	
+	/**
+	 * 鏂扮増鎺ㄨ崘涓撻绠$悊(1.5.3)
+	 * 
+	 * @param acceptData
+	 * @param out
+	 */
+	@RequestMapping(value = "getRecommendIndex")
+	public void getRecommendIndex(AcceptData acceptData, Long uid, PrintWriter out) {
+		try {
+			// 涓撻妯″潡
+			JSONObject root = specialService.listCacheSpecialToIndex();
+
+			// 椤堕儴杞挱鍥�
+			List<SwiperPicture> topPicList = getSwiperByCard("index_top");
+			if (topPicList == null) {
+				topPicList = new ArrayList<SwiperPicture>();
+			}
+			root.put("topPicList", JsonUtil.getApiCommonGson().toJson(topPicList));
+			
+			// 閭�璇枫�佸垎浜疆鎾浘
+			List<SwiperPicture> invitePicList = getInvitePicList(uid, acceptData);
+			if (invitePicList == null) {
+				invitePicList = new ArrayList<SwiperPicture>();
+			}
+			root.put("invitePicList", JsonUtil.getApiCommonGson().toJson(invitePicList));
+			
+			// 搴曢儴缃戦〉閾炬帴
+			String platform = acceptData.getPlatform();
+			if ("ios".equalsIgnoreCase(platform)) {
+				root.put("htmlLink", configService.get("index_html_link_ios"));
+			} 
+			
+			out.print(JsonUtil.loadTrueResult(root));
+		} catch (Exception e) {
+			out.print(JsonUtil.loadFalseResult(1, "鑾峰彇鏁版嵁澶辫触"));
+			try {
+				LogHelper.errorDetailInfo(e);
+			} catch (Exception e1) {
+				e1.printStackTrace();
+			}	
+		}
+	}
+	
+	/**
+	 * 閭�璇锋湁濂栨槸鍚﹂渶瑕佽繑鍥�
+	 * @param uid
+	 * @param acceptData
+	 * @return
+	 */
+	public List<SwiperPicture>  getInvitePicList(Long uid, AcceptData acceptData) {
+		// 濡傛灉IOS褰撳墠鐗堟湰澶勪簬瀹℃牳鐘舵�佸氨涓嶈繑鍥�
+		if ("ios".equalsIgnoreCase(acceptData.getPlatform())
+				&& configService.iosOnLining(Integer.parseInt(acceptData.getVersion()))) {
+			return null;
+		} 
+		
+		List<SwiperPicture> invitePicList = getSwiperByCard("index_invite");	
+		
+		if (uid != null) {
+			try {
+				// 鐢ㄦ埛鑷畾涔夛細涓嶇湅閭�璇锋湁濂�
+				UserSettingsVO vo = userCustomSettingsService.getMySettings(uid);
+				if (vo != null  && vo.getNoInvitationBonus() != null && vo.getNoInvitationBonus() == 1 
+						&& invitePicList != null && invitePicList.size() > 0) {
+					Iterator<SwiperPicture> iterator = invitePicList.iterator();
+					while (iterator.hasNext()) {
+						SwiperPicture swiperPicture = iterator.next();
+						JumpDetailV2 jumpDetail = swiperPicture.getJumpDetail();
+						if (jumpDetail != null && "invite".equals(jumpDetail.getType())) {
+							iterator.remove();
+						}
+					}
+				}
+			} catch (UserCustomSettingsException e) {
+				e.printStackTrace();
+			}
+		}
+		
+		return invitePicList;
+	}
+	
+	
+	public List<SwiperPicture> getSwiperByCard(String card){
+		List<SwiperPicture> swiperList = null;
+		try {
+			swiperList = swiperPictureService.getByBannerCard(card);
+		} catch (Exception e) {
+			try {
+				LogHelper.errorDetailInfo(e);
+			} catch (Exception e1) {
+				e1.printStackTrace();
+			}
+			e.printStackTrace();
+		}
+		return swiperList;
+	}
+	
+	
+	/**
+	 * 闄愭椂绉掓潃 1.5.3
+	 * 
+	 * @param acceptData
+	 * @param out
+	 */
+	@RequestMapping(value = "getSpikeGoods")
+	public void getSpikeGoods(AcceptData acceptData, PrintWriter out) {
+		
+		// 涓嬩竴娆″�掕鏃剁殑鏃堕棿
+		int type = qualityFlashSaleService.getNowType() + 1;
+		int hour = 0;
+		switch(type) {
+			case 1:
+				hour = 0;
+				break;
+			case 2:
+				hour = 9;
+				break;
+			case 3:
+				hour = 12;
+				break;
+			case 4:
+				hour = 14;
+				break;
+			case 5:
+				hour = 16;
+				break;
+			case 6:
+				hour = 20;
+				break;
+			case 7:
+				hour = 22;
+				break;
+			default:
+				break;
+		}
+		
+		Calendar nextTime = Calendar.getInstance();
+		nextTime.set(Calendar.HOUR_OF_DAY, hour);
+		nextTime.set(Calendar.MINUTE, 0);
+		nextTime.set(Calendar.SECOND, 0);
+		nextTime.set(Calendar.MILLISECOND, 0);
+		
+		JSONObject root = new JSONObject();
+		root.put("time", nextTime.getTimeInMillis());
+		
+		
+		JSONArray array = new JSONArray();
+		String cachekey = "spikeGoodsList" ;
+		String cacheValue = redisManager.getCommonString(cachekey);
+		if (!StringUtil.isNullOrEmpty(cacheValue)) {
+			array = JSONArray.fromObject(cacheValue);
+		} else {
+			BigDecimal proportion = manageService.getFanLiRate();
+			Gson gson = JsonUtil.getConvertBigDecimalToStringSubZeroBuilder(new GsonBuilder())
+					.excludeFieldsWithoutExposeAnnotation().setDateFormat("yyyy-MM-dd").create();
+			
+			// 缂撳瓨涓笉瀛樺湪
+			List<QualityFactory> listGoods = qualityGoodsService.listFlashSaleRandGoods();
+			if (listGoods == null) {
+				listGoods = new ArrayList<QualityFactory>();
+			}
+			/* 閬嶅巻鍒楄〃鏁版嵁 */
+			for (QualityFactory qualityFactory : listGoods) {
+					
+				TaoBaoGoodsBrief taoBaoGoodsBrief = qualityFactory.getTaoBaoGoodsBrief();
+				if (taoBaoGoodsBrief == null) {
+					continue;
+				}
+				array.add(gson.toJson(TaoBaoUtil.getTaoBaoGoodsBriefExtra(taoBaoGoodsBrief, proportion.toString(), null)));
+			}
+			// 缂撳瓨鍗婁釜灏忔椂
+			redisManager.cacheCommonString(cachekey, array.toString(), 60 * 30);
+		}
+		root.put("listgoods", array);
+		out.print(JsonUtil.loadTrueResult(root));
+	}
+	
+	
 	/**
 	 * 鍟嗗搧鍩烘湰璇︽儏 (1.4.0)
 	 * 
@@ -1628,21 +1779,11 @@
 		// 鑾峰彇娣樺鍙傛暟
 		ClientTBPid clientTBPid = null;
 
-		if (StringUtil.isNullOrEmpty(uid)) {
-			// 鐢ㄦ埛鏈櫥褰�
-			if (acceptData.getPlatform().equalsIgnoreCase("android")) {
-				clientTBPid = tbPidService.getAndroidDefault();
-			} else {
-				clientTBPid = tbPidService.getIOSDefault();
-			}
-
+		// 鐢ㄦ埛鏈櫥褰�
+		if (acceptData.getPlatform().equalsIgnoreCase("android")) {
+			clientTBPid = tbPidService.getAndroidDefault();
 		} else {
-			// 鐢ㄦ埛宸茬粡鐧诲綍
-			if (acceptData.getPlatform().equalsIgnoreCase("android")) {
-				clientTBPid = tbPidService.getAndroidDefault();
-			} else {
-				clientTBPid = tbPidService.getIOSDefault();
-			}
+			clientTBPid = tbPidService.getIOSDefault();
 		}
 
 		LogHelper.test("鑾峰彇PID鑰楁椂锛�" + (java.lang.System.currentTimeMillis() - startTime));
@@ -2098,8 +2239,8 @@
 		}
 
 		JSONObject data = new JSONObject();
-		data.put("listGuess", JsonUtil.getApiCommonGson().toJson(listExtra));
-		data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listQuality));
+		data.put("listQuality", JsonUtil.getApiCommonGson().toJson(listExtra));
+		data.put("listGuess", JsonUtil.getApiCommonGson().toJson(listQuality));
 
 		out.print(JsonUtil.loadTrueResult(data));
 	}

--
Gitblit v1.8.0