From 26f7accb815f55f18f8eedfca4324700a96884ec Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 26 八月 2020 18:23:49 +0800
Subject: [PATCH] 资金验证优化

---
 fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java |  224 ++++++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 185 insertions(+), 39 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java b/fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java
index d22d934..a2e9129 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/admin/homemodule/SpecialCardAdminController.java
@@ -3,10 +3,12 @@
 import java.io.PrintWriter;
 import java.util.ArrayList;
 import java.util.List;
+import java.util.Set;
 
 import javax.annotation.Resource;
 import javax.servlet.http.HttpServletRequest;
 
+import com.yeshi.fanli.entity.accept.AdminAcceptData;
 import org.springframework.stereotype.Controller;
 import org.springframework.web.bind.annotation.RequestMapping;
 import org.springframework.web.multipart.MultipartHttpServletRequest;
@@ -15,16 +17,24 @@
 import com.google.gson.Gson;
 import com.google.gson.GsonBuilder;
 import com.google.gson.reflect.TypeToken;
+import com.yeshi.fanli.entity.AppVersionInfo;
+import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl;
+import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl.AdActivityType;
+import com.yeshi.fanli.entity.bus.homemodule.CommonShareInfo;
 import com.yeshi.fanli.entity.bus.homemodule.Special;
 import com.yeshi.fanli.entity.bus.homemodule.SpecialCard;
-import com.yeshi.fanli.exception.homemodule.FloatADException;
+import com.yeshi.fanli.exception.homemodule.SpecialCardException;
 import com.yeshi.fanli.exception.homemodule.SpecialException;
+import com.yeshi.fanli.service.inter.config.AppVersionService;
+import com.yeshi.fanli.service.inter.homemodule.AdActivityVersionControlService;
 import com.yeshi.fanli.service.inter.homemodule.SpecialCardService;
 import com.yeshi.fanli.service.inter.homemodule.SpecialService;
-import com.yeshi.fanli.tag.PageEntity;
+import com.yeshi.common.entity.PageEntity;
 import com.yeshi.fanli.util.Constant;
 import com.yeshi.fanli.util.StringUtil;
+import com.yeshi.fanli.vo.homemodule.SpecialVO;
 
+import net.sf.json.JSONArray;
 import net.sf.json.JSONObject;
 
 @Controller
@@ -37,16 +47,25 @@
 	@Resource
 	private SpecialCardService specialCardService;
 
+	@Resource
+	private AppVersionService appVersionService;
+
+	@Resource
+	private AdActivityVersionControlService adActivityVersionControlService;
+
 	/**
 	 * 淇濆瓨淇℃伅
-	 * 
+	 * @param acceptData
 	 * @param callback
-	 * @param special
+	 * @param specialCard
+	 * @param request
 	 * @param out
 	 */
+
 	@RequestMapping(value = "save")
-	public void save(String callback, SpecialCard specialCard, HttpServletRequest request, PrintWriter out) {
+	public void save(AdminAcceptData acceptData, String callback, SpecialCard specialCard, HttpServletRequest request, PrintWriter out) {
 		try {
+            specialCard.setSystem(acceptData.getSystem());
 			// 1. 鍏堝垽鏂環ttpRequest 鏄惁鍚湁鏂囦欢绫诲瀷
 			if (request instanceof MultipartHttpServletRequest) {
 				MultipartHttpServletRequest fileRequest = (MultipartHttpServletRequest) request;
@@ -54,9 +73,8 @@
 			} else {
 				specialCardService.saveObject(null, specialCard);
 			}
-
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("淇濆瓨鎴愬姛"));
-		} catch (FloatADException e) {
+		} catch (SpecialCardException e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg()));
 		} catch (Exception e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("淇濆瓨澶辫触"));
@@ -64,6 +82,31 @@
 		}
 	}
 
+	
+	
+	/**
+	 * 鏌ヨ
+	 * 
+	 * @param callback
+	 * @param pageIndex
+	 * @param pageSize
+	 * @param key
+	 *            妯$硦鏌ヨ锛氳鏄庛�佹爣璇�
+	 * @param out
+	 */
+	@RequestMapping(value = "queryActivity")
+	public void queryActivity(AdminAcceptData acceptData,String callback, Integer pageIndex, Integer pageSize, String key, Integer sort,
+			  PrintWriter out) {
+		
+		List<Long> listPid = new ArrayList<Long>();
+		listPid.add(15L);
+		listPid.add(16L);
+		listPid.add(17L);
+		queryList(acceptData, callback, pageIndex, pageSize, key, sort, listPid, out);
+	}
+	
+	
+	
 	/**
 	 * 鏌ヨ
 	 * 
@@ -75,7 +118,12 @@
 	 * @param out
 	 */
 	@RequestMapping(value = "query")
-	public void query(String callback, Integer pageIndex, Integer pageSize, String key, Integer sort, PrintWriter out) {
+	public void query(AdminAcceptData acceptData,String callback, Integer pageIndex, Integer pageSize, String key, Integer sort, PrintWriter out) {
+		queryList(acceptData,callback, pageIndex, pageSize, key, sort, null, out);
+	}
+
+	public void queryList(AdminAcceptData acceptData,String callback, Integer pageIndex, Integer pageSize, String key, Integer sort,
+			List<Long> listPid, PrintWriter out) {
 
 		if (pageIndex == null || pageIndex < 1) {
 			pageIndex = 1;
@@ -86,14 +134,14 @@
 		}
 
 		try {
-			List<SpecialCard> list = specialCardService.listQuery((pageIndex - 1) * pageSize, pageSize, key, sort);
+			List<SpecialCard> list = specialCardService.listQuery((pageIndex - 1) * pageSize, pageSize, key, sort, listPid,acceptData.getSystem());
 
 			if (list == null || list.size() == 0) {
 				JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鏆傛棤鏁版嵁"));
 				return;
 			}
 
-			long count = specialCardService.countlistQuery(key);
+			long count = specialCardService.countlistQuery(key, listPid,acceptData.getSystem());
 
 			int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1);
 			PageEntity pe = new PageEntity(pageIndex, pageSize, count, totalPage);
@@ -105,16 +153,13 @@
 			JSONObject data = new JSONObject();
 			data.put("pe", pe);
 			data.put("result_list", gson.toJson(list));
-
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data));
-
 		} catch (Exception e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎿嶄綔寮傚父"));
 			e.printStackTrace();
 		}
 
 	}
-
 	/**
 	 * 鍒犻櫎
 	 * 
@@ -123,8 +168,7 @@
 	 * @param out
 	 */
 	@RequestMapping(value = "delete")
-	public void delete(String callback, String idArray, PrintWriter out) {
-
+	public void delete(AdminAcceptData acceptData,String callback, String idArray, PrintWriter out) {
 		try {
 			if (StringUtil.isNullOrEmpty(idArray)) {
 				JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璇烽�夋嫨鎿嶄綔鐨勬暟鎹�"));
@@ -139,36 +183,36 @@
 				JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鏈娴嬪埌鍒犻櫎鐨勬暟鎹�"));
 				return;
 			}
-
 			int count = specialCardService.deleteBatchByPrimaryKey(list);
-
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("鎴愬姛鍒犻櫎[" + count + "]鏉℃暟鎹�"));
-
 		} catch (Exception e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鍒犻櫎澶辫触"));
 			e.printStackTrace();
 		}
-
 	}
 
 	/**
 	 * 淇濆瓨淇℃伅
-	 * 
+	 * @param acceptData
 	 * @param callback
-	 * @param special
+	 * @param record
+	 * @param jumpType
+	 * @param extra
+	 * @param request
 	 * @param out
 	 */
 	@RequestMapping(value = "saveSpecial")
-	public void saveSpecial(String callback, Special record, String jumpType, HttpServletRequest request,
+	public void saveSpecial(AdminAcceptData acceptData,String callback, Special record, String jumpType, CommonShareInfo extra, HttpServletRequest request,
 			PrintWriter out) {
 		try {
 			// 1. 鍏堝垽鏂環ttpRequest 鏄惁鍚湁鏂囦欢绫诲瀷
+            record.setSystem(acceptData.getSystem());
 			if (request instanceof MultipartHttpServletRequest) {
 				MultipartHttpServletRequest fileRequest = (MultipartHttpServletRequest) request;
 				specialService.saveObject(fileRequest.getFile("file"), fileRequest.getFile("file2"),
-						fileRequest.getFile("file3"), record, jumpType);
+						fileRequest.getFile("file3"), record, jumpType, extra);
 			} else {
-				specialService.saveObject(null, null, null, record, jumpType);
+				specialService.saveObject(null, null, null, record, jumpType, extra);
 			}
 
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("淇濆瓨鎴愬姛"));
@@ -188,7 +232,7 @@
 	 * @param out
 	 */
 	@RequestMapping(value = "deleteSpecial")
-	public void deleteSpecial(String callback, String idArray, PrintWriter out) {
+	public void deleteSpecial(AdminAcceptData acceptData,String callback, String idArray, PrintWriter out) {
 
 		try {
 			if (StringUtil.isNullOrEmpty(idArray)) {
@@ -206,25 +250,21 @@
 			}
 
 			int count = specialService.deleteBatchByPrimaryKey(list);
-
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("鎴愬姛鍒犻櫎[" + count + "]鏉℃暟鎹�"));
-
 		} catch (Exception e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鍒犻櫎澶辫触"));
 			e.printStackTrace();
 		}
-
 	}
 
 	/**
 	 * 淇敼鎺掑簭
 	 * 
 	 * @param callback
-	 * @param goodsClass
 	 * @param out
 	 */
 	@RequestMapping(value = "saveSpecialOrder")
-	public void saveSpecialOrder(String callback, Long id, Integer moveType, Integer sex, PrintWriter out) {
+	public void saveSpecialOrder(AdminAcceptData acceptData,String callback, Long id, Integer moveType, Integer sex, PrintWriter out) {
 		try {
 			specialService.updateOrder(id, moveType, sex);
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("鎿嶄綔鎴愬姛"));
@@ -242,13 +282,12 @@
 	 * @param callback
 	 * @param pageIndex
 	 * @param pageSize
-	 * @param bannerId
 	 * @param out
 	 */
 	@RequestMapping(value = "querySpecial")
-	public void querySpecial(String callback, Integer pageIndex, Integer pageSize, String key, Long cardId, Integer sex,
-			PrintWriter out) {
-
+	public void querySpecial(AdminAcceptData acceptData,String callback, Integer pageIndex, Integer pageSize, String key, Long cardId, Integer sex,
+			String version, String platform, PrintWriter out) {
+		pageSize = 100;
 		if (pageIndex == null || pageIndex < 1) {
 			pageIndex = 1;
 		}
@@ -262,16 +301,53 @@
 			return;
 		}
 
+		List<AppVersionInfo> versionList = null;
+		if (!StringUtil.isNullOrEmpty(version) || !StringUtil.isNullOrEmpty(platform)) {
+			versionList = new ArrayList<>();
+			if (!StringUtil.isNullOrEmpty(version)) {
+				AppVersionInfo appVersion = appVersionService.selectByPrimaryKey(Long.parseLong(version));
+				if (appVersion != null)
+					versionList.add(appVersion);
+			} else {
+				List<AppVersionInfo> appVersionList = appVersionService.getAppVersionInfoListByPlatform(platform,acceptData.getSystem());
+				if (appVersionList != null) {
+					versionList.addAll(appVersionList);
+				}
+			}
+		}
+
 		try {
 
-			List<Special> list = specialService.listQueryByCard((pageIndex - 1) * pageSize, pageSize, cardId, key, sex);
-
+			List<SpecialVO> list = specialService.listQueryByCard((pageIndex - 1) * pageSize, pageSize, cardId, key, sex);
 			if (list == null || list.size() == 0) {
 				JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鏆傛棤鏁版嵁"));
 				return;
 			}
 
 			long count = specialService.countlistQueryByCard(cardId, key, sex);
+			// 杩囨护
+			if (versionList != null) {
+				if (versionList.size() > 0) {
+					List<Long> sourceIdList = new ArrayList<>();
+					for (SpecialVO special : list) {
+						sourceIdList.add(special.getId());
+					}
+					List<Long> versionIdList = new ArrayList<>();
+					for (AppVersionInfo versionInfo : versionList)
+						versionIdList.add(versionInfo.getId());
+					Set<Long> sets = adActivityVersionControlService.filterSourceIdByVersion(sourceIdList,
+							AdActivityType.special, versionIdList);
+					for (int i = 0; i < list.size(); i++) {
+						if (!sets.contains(list.get(i).getId())) {
+							list.remove(i--);
+						}
+					}
+					count = list.size();
+				} else {
+					list.clear();
+					count = 0;
+				}
+			}
 
 			int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1);
 			PageEntity pe = new PageEntity(pageIndex, pageSize, count, totalPage);
@@ -283,14 +359,84 @@
 			JSONObject data = new JSONObject();
 			data.put("pe", pe);
 			data.put("result_list", gson.toJson(list));
-
 			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data));
-
 		} catch (Exception e) {
 			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎿嶄綔寮傚父"));
 			e.printStackTrace();
 		}
-
 	}
 
+	/**
+	 * 璁剧疆鐗堟湰
+	 * @param acceptData
+	 * @param callback
+	 * @param id
+	 * @param versions
+	 * @param out
+	 */
+	@RequestMapping(value = "setVersions")
+	public void setVersions(AdminAcceptData acceptData,String callback, Long id, String versions, PrintWriter out) {
+		JSONArray versionArray = JSONArray.fromObject(versions);
+		List<Long> versionIds = new ArrayList<>();
+		for (int i = 0; i < versionArray.size(); i++) {
+			Long version = versionArray.optLong(i);
+			versionIds.add(version);
+		}
+		try {
+			specialService.setVersions(id, versionIds);
+			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(""));
+		} catch (Exception e) {
+			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMessage()));
+		}
+	}
+
+	@RequestMapping(value = "getVersions")
+	public void getVersions(AdminAcceptData acceptData,String callback, Long id, PrintWriter out) {
+		List<AdActivityVersionControl> list = adActivityVersionControlService
+				.listByTypeAndSourceId(AdActivityType.special, id);
+
+		List<Long> versionList = new ArrayList<>();
+		if (list != null)
+			for (AdActivityVersionControl control : list)
+				versionList.add(control.getVersion().getId());
+		JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(versionList));
+	}
+
+	/**
+	 * 淇敼鐘舵��
+	 * @param callback
+	 * @param id
+	 * @param out
+	 */
+	@RequestMapping(value = "switchStateCard")
+	public void switchStateCard(AdminAcceptData acceptData,String callback, Long id, PrintWriter out) {
+		try {
+			specialCardService.switchState(id);
+			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("鎿嶄綔鎴愬姛"));
+		} catch (SpecialCardException e) {
+			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg()));
+		} catch (Exception e) {
+			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎿嶄綔澶辫触"));
+			e.printStackTrace();
+		}
+	}
+	
+	/**
+	 * 淇敼鐘舵��
+	 * @param callback
+	 * @param id
+	 * @param out
+	 */
+	@RequestMapping(value = "switchState")
+	public void switchState(AdminAcceptData acceptData,String callback, Long id, PrintWriter out) {
+		try {
+			specialService.switchState(id);
+			JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult("鎿嶄綔鎴愬姛"));
+		} catch (SpecialException e) {
+			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(e.getMsg()));
+		} catch (Exception e) {
+			JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鎿嶄綔澶辫触"));
+			e.printStackTrace();
+		}
+	}
 }

--
Gitblit v1.8.0