From cdcbed9af813b2a02cdc01eefa24db8bec6b51a9 Mon Sep 17 00:00:00 2001
From: yujian <yujian>
Date: 星期三, 27 三月 2019 12:17:33 +0800
Subject: [PATCH] 主分类 + 子分类 DAO改造

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/GoodsController.java |   84 ++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 81 insertions(+), 3 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/GoodsController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/GoodsController.java
index 9666c7a..cedf338 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/GoodsController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/GoodsController.java
@@ -11,6 +11,7 @@
 
 import com.yeshi.fanli.entity.accept.AcceptData;
 import com.yeshi.fanli.entity.bus.user.UserExtraTaoBaoInfo;
+import com.yeshi.fanli.entity.bus.user.UserInfo;
 import com.yeshi.fanli.entity.taobao.ClientTBPid;
 import com.yeshi.fanli.entity.taobao.PidUser;
 import com.yeshi.fanli.entity.taobao.TBPid;
@@ -18,11 +19,13 @@
 import com.yeshi.fanli.entity.taobao.TaoBaoLink;
 import com.yeshi.fanli.entity.taobao.TaoBaoUnionConfig;
 import com.yeshi.fanli.exception.taobao.TaobaoGoodsDownException;
+import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.goods.ShareGoodsService;
 import com.yeshi.fanli.service.inter.monitor.MonitorService;
 import com.yeshi.fanli.service.inter.taobao.TaoBaoUnionConfigService;
 import com.yeshi.fanli.service.inter.user.TBPidService;
 import com.yeshi.fanli.service.inter.user.UserExtraTaoBaoInfoService;
+import com.yeshi.fanli.service.inter.user.UserInfoService;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.StringUtil;
 import com.yeshi.fanli.util.factory.MonitorFactory;
@@ -49,6 +52,9 @@
 	@Resource
 	private UserExtraTaoBaoInfoService userExtraTaoBaoInfoService;
 
+	@Resource
+	private UserInfoService userInfoService;
+
 	/**
 	 * 鑾峰彇娣樺疂鐨勫垎浜摼鎺�
 	 * 
@@ -66,6 +72,12 @@
 			return;
 		}
 
+		UserInfo user = userInfoService.getUserByIdWithMybatis(uid);
+		if (user != null && user.getState() != UserInfo.STATE_NORMAL) {
+			out.print(JsonUtil.loadFalseResult(Constant.CODE_FORBIDDEN_USER, Constant.FORBIDDEN_USER_REASON_DESC));
+			return;
+		}
+
 		if (auctionId == null || auctionId <= 0) {
 			out.print(JsonUtil.loadFalseResult(2, "鍟嗗搧ID涓嶈兘涓虹┖"));
 			return;
@@ -74,6 +86,8 @@
 		JSONObject data = new JSONObject();
 		boolean isNative = false;
 		String pid = null;
+
+		boolean specialConvert = false;
 
 		String specialId = null;
 		// 鏌ヨ鐢ㄦ埛ID鏄惁缁戝畾浜嗕細鍛樿繍钀D
@@ -86,11 +100,18 @@
 				TaoBaoGoodsBrief goods = TaoKeApiUtil.getSimpleGoodsInfo(auctionId);
 				if (goods.getMaterialLibType() != null && goods.getMaterialLibType() == 1) {
 					isNative = true;
+					specialConvert = true;
 				} else
 					isNative = false;
 			} catch (TaobaoGoodsDownException e) {
 				out.print(JsonUtil.loadFalseResult(3, "鍟嗗搧宸蹭笅鏋�"));
 				return;
+			} catch (Exception e) {
+				try {
+					LogHelper.errorDetailInfo(e, "鑾峰彇鍟嗗搧绠�鐗堣鎯呭嚭閿�", auctionId + "");
+				} catch (Exception e1) {
+					e1.printStackTrace();
+				}
 			}
 
 			pid = Constant.TAOBAO_SPECIAL_PID_DEFAULT;
@@ -99,16 +120,25 @@
 			isNative = true;
 		}
 
+		data.put("native", isNative);
 		try {
 			int pidType = PidUser.TYPE_FANLI_ANDROID;
 			if (acceptData.getPlatform().equalsIgnoreCase("ios"))
 				pidType = PidUser.TYPE_FANLI_IOS;
 
 			TaoBaoLink taoBaoLink = null;
-			if (!StringUtil.isNullOrEmpty(specialId)) {
+			if (!StringUtil.isNullOrEmpty(specialId) && specialConvert) {
 				taoBaoLink = shareGoodsService.getTaoBaoLinkForBuyWithSpecial(uid, specialId, auctionId);
 			} else {
-				taoBaoLink = shareGoodsService.getTaoBaoLinkForBuy(uid, auctionId, pidType);
+				if (!specialConvert && !isNative) {
+					if (pidType == PidUser.TYPE_FANLI_ANDROID)
+						taoBaoLink = shareGoodsService.getTaoBaoLink(uid, auctionId,
+								tbPidService.getAndroidDefault().getPid());
+					else
+						taoBaoLink = shareGoodsService.getTaoBaoLink(uid, auctionId,
+								tbPidService.getIOSDefault().getPid());
+				} else
+					taoBaoLink = shareGoodsService.getTaoBaoLinkForBuy(uid, auctionId, pidType);
 			}
 
 			JSONObject link = new JSONObject();
@@ -133,6 +163,8 @@
 				tbPid = tbPidService.getTBPid(uid, PidUser.TYPE_FANLI_IOS);
 			}
 
+			data.put("native", isNative);
+
 			if (tbPid != null) {
 				String siteId = tbPid.getPid().split("_")[2];
 				String adzoneId = tbPid.getPid().split("_")[3];
@@ -145,8 +177,54 @@
 				out.print(JsonUtil.loadFalseResult(1, "璇锋眰澶辫触"));
 			}
 		}
-		data.put("native", isNative);
 
 	}
 
+	/**
+	 * 鏄惁鍦ㄥ弬涓庢帹骞�
+	 */
+
+	/**
+	 * 鏄惁鍦ㄥ弬涓庢帹骞�
+	 * 
+	 * @param goodsId
+	 *            -鍟嗗搧ID
+	 * @param goodsType
+	 *            -TB/JD
+	 * @param out
+	 */
+	@RequestMapping(value = "isGoodsExtend")
+	public void isGoodsExtend(AcceptData acceptData,String goodsId, String goodsType, PrintWriter out) {
+		if (StringUtil.isNullOrEmpty(goodsId)) {
+			out.print(JsonUtil.loadFalseResult(1, "鏈弬涓庢帹骞�"));
+			return;
+		}
+		if (StringUtil.isNullOrEmpty(goodsType)) {
+			out.print(JsonUtil.loadFalseResult(2, "缂哄皯goodsType"));
+			return;
+		}
+		if ("TB".equalsIgnoreCase(goodsType)) {
+			TaoBaoGoodsBrief goods = null;
+			try {
+				goods = TaoKeApiUtil.getSimpleGoodsInfo(Long.parseLong(goodsId));
+			} catch (NumberFormatException e) {
+				e.printStackTrace();
+			} catch (TaobaoGoodsDownException e) {
+				e.printStackTrace();
+			}
+
+			JSONObject data = new JSONObject();
+
+			if (goods == null) {
+				data.put("extend", false);
+				data.put("url", "https://h5.m.taobao.com/awp/core/detail.htm?id=" + goodsId);
+			} else {
+				data.put("extend", true);
+			}
+			out.print(JsonUtil.loadTrueResult(data));
+		} else {
+			out.print(JsonUtil.loadFalseResult(3, "鏆備笉鏀寔鍏朵粬鍟嗗搧绫诲瀷"));
+		}
+	}
+
 }

--
Gitblit v1.8.0