From 2a593ddac16e06f1ff55edca22ea568f07b068ba Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期五, 02 四月 2021 19:15:18 +0800
Subject: [PATCH] 3.9.0bug修改

---
 src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java |  200 +++++++++++++++++++++++++++++++++++++++++++-------
 1 files changed, 172 insertions(+), 28 deletions(-)

diff --git a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
index f6e8171..6b5a106 100644
--- a/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
+++ b/src/main/java/com/yeshi/buwan/controller/parser/ConfigParser.java
@@ -1,6 +1,8 @@
 package com.yeshi.buwan.controller.parser;
 
 import java.io.PrintWriter;
+import java.lang.reflect.Type;
+import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 
@@ -8,21 +10,27 @@
 import javax.servlet.http.HttpServletRequest;
 
 import com.google.gson.GsonBuilder;
-import com.yeshi.buwan.domain.Config;
-import com.yeshi.buwan.domain.DetailSystem;
+import com.google.gson.annotations.Expose;
+import com.google.gson.reflect.TypeToken;
+import com.yeshi.buwan.domain.system.DetailSystem;
 import com.yeshi.buwan.domain.recommend.FloatAD;
+import com.yeshi.buwan.dto.config.ADShieldIPConfig;
+import com.yeshi.buwan.dto.log.BaseLog;
 import com.yeshi.buwan.log.LogHelper;
 import com.yeshi.buwan.service.imp.SystemService;
 import com.yeshi.buwan.service.inter.ad.FloatADService;
+import com.yeshi.buwan.service.manager.IPManager;
 import com.yeshi.buwan.util.IPUtil;
 import com.yeshi.buwan.util.StringUtil;
+import com.yeshi.buwan.util.log.LoggerUtil;
+import com.yeshi.buwan.util.log.UserActiveLogFactory;
 import com.yeshi.buwan.vo.AcceptData;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Controller;
 
 import com.google.gson.Gson;
-import com.yeshi.buwan.service.imp.ConfigService;
+import com.yeshi.buwan.service.imp.DetailSystemConfigService;
 import com.yeshi.buwan.util.JsonUtil;
 
 import net.sf.json.JSONObject;
@@ -30,73 +38,199 @@
 @Controller
 public class ConfigParser {
 
+
     Logger logger = LoggerFactory.getLogger(ConfigParser.class);
     @Resource
-    private ConfigService configService;
+    private DetailSystemConfigService configService;
     @Resource
     private SystemService systemService;
 
     @Resource
     private FloatADService floatADService;
 
-    public String getAdShowType(String key, String channel, int version, Map<String, String> map) {
+    @Resource
+    private IPManager ipManager;
+
+
+    public ADConfig getAdShowType(String key, String channel, int version, Map<String, String> map) {
         String splash = map.get(key);
         JSONObject jsonObject = JSONObject.fromObject(splash);
-        ADConfig splashAD = null;
+        if (jsonObject == null || jsonObject.isEmpty())
+            return null;
+        ADConfig adConfig = null;
         channel = channel.toLowerCase();
-        if (jsonObject.optJSONObject(channel) == null) {
+        if (jsonObject == null || jsonObject.optJSONObject(channel) == null) {
             // 榛樿涓哄簲鐢ㄥ疂
             channel = "qq";
         }
-        String adType = "";
-        splashAD = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
-        if (version >= splashAD.getVersion()) {
-            adType = "";
-        } else {
-            adType = splashAD.getType();
+        adConfig = new Gson().fromJson(jsonObject.optJSONObject(channel).toString(), ADConfig.class);
+        if (version >= adConfig.getVersion()) {
+            adConfig = null;
         }
 
-        return adType;
+        return adConfig;
+    }
+
+    /**
+     * 灞忚斀鎵�鏈夌殑骞垮憡
+     *
+     * @param channel
+     * @param version
+     * @param shieldInfo
+     * @param ip
+     * @return
+     */
+    private boolean shieldAllAd(String channel, Integer version, String shieldInfo, String ip) {
+        if (StringUtil.isNullOrEmpty(shieldInfo)) {
+            return false;
+        }
+        Type type = new TypeToken<List<ADShieldIPConfig>>() {
+        }.getType();
+        List<ADShieldIPConfig> list = new Gson().fromJson(shieldInfo, type);
+        Map<String, ADShieldIPConfig.IPShieldRule> map = new HashMap<>();
+        for (ADShieldIPConfig config : list) {
+            map.put(config.getChannel().toLowerCase(), config.getRule());
+        }
+        if (map.get(channel.toLowerCase()) != null) {
+            ADShieldIPConfig.IPShieldRule rule = map.get(channel.toLowerCase());
+            if (version >= rule.getVersion()) {
+                //璇锋眰
+                IPUtil.IPInfo ipInfo = null;
+                try {
+                    ipInfo = ipManager.getIPInfo(ip);
+                } catch (Exception e) {
+                    e.printStackTrace();
+                }
+                if (ipInfo != null) {
+                    //鍏堝垽鏂渷
+                    if (!StringUtil.isNullOrEmpty(rule.getProvince())) {
+                        if (ipInfo.getProvince() != null && ipInfo.getProvince().contains(rule.getProvince())) {
+                            if (!StringUtil.isNullOrEmpty(rule.getCity())) {//鍚屾椂鍒ゆ柇鐪佸拰甯�
+                                if (ipInfo.getCity() != null && ipInfo.getCity().contains(rule.getCity())) {
+                                    return true;
+                                }
+                            } else {
+                                //鍙垽鏂渷
+                                return true;
+                            }
+                        }
+                    } else if (!StringUtil.isNullOrEmpty(rule.getCity())) {
+                        //鍙垽鏂競
+                        if (ipInfo.getCity() != null && ipInfo.getCity().contains(rule.getCity())) {
+                            return true;
+                        }
+                    }
+                }
+            }
+        }
+        return false;
     }
 
     public void getConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
+        LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createAppSplash(new BaseLog(acceptData, "")));
         DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
         Map<String, String> map = configService.getConfigAsMap(detailSystem, acceptData.getVersion());
         JSONObject data = new JSONObject();
         JSONObject ad = new JSONObject();
+        JSONObject adNew = new JSONObject();
 
         String ip = IPUtil.getRemotIP(request);
-        String splash = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
+        //浼氬憳閾炬帴
+        String vipLink = map.get("vip_link");
+        data.put("vipLink", vipLink);
+
+        ADConfig splashConfig = getAdShowType("ad_splash_config", acceptData.getChannel(), acceptData.getVersion(), map);
 
 
         //寮�灞忕殑鍦板尯灞忚斀瑙勫垯
-        String shieldProvince = map.get("shield_province");
-        if (!StringUtil.isNullOrEmpty(shieldProvince)) {
-            JSONObject json = JSONObject.fromObject(shieldProvince);
+        String shieldInfo = map.get("shield_province");
+        boolean hiddenSplash = false;
+        if (!StringUtil.isNullOrEmpty(shieldInfo)) {
+            JSONObject json = JSONObject.fromObject(shieldInfo);
             //鑾峰彇娓犻亾闇�瑕佸睆钄界殑鍩庡競
             String province = json.optString(acceptData.getChannel().toLowerCase());
-            if (!StringUtil.isNullOrEmpty(splash) && !StringUtil.isNullOrEmpty(province)) {
-                String pro = IPUtil.getIPProvince(ip);
-                LogHelper.print("鍩庡競灞忚斀锛�" + ip + ":" + pro);
-                if (pro != null && pro.contains(province)) {//灞忚斀IP
-                    splash = "";
-                    LogHelper.print("鍩庡競灞忚斀:" + pro);
+            if (splashConfig != null && !StringUtil.isNullOrEmpty(province)) {
+
+                IPUtil.IPInfo ipInfo = null;
+                try {
+                    ipInfo = ipManager.getIPInfo(ip);
+                } catch (Exception e) {
+                    e.printStackTrace();
+                }
+                if (ipInfo != null && ipInfo.getProvince().contains(province)) {//灞忚斀IP
+                    hiddenSplash = true;
+                    LogHelper.print("鍩庡競灞忚斀:" + province);
                 }
             }
         }
+        //骞垮憡鍏ㄩ儴灞忚斀鍖哄煙
+        String shieldAdLocationInfo = map.get("shield_ad_ip_location");
+        boolean hiddenAll = shieldAllAd(acceptData.getChannel(), acceptData.getVersion(), shieldAdLocationInfo, ip);
 
+
+        if (hiddenSplash)
+            splashConfig = null;
+
+        String splash = "";
+        if (splashConfig != null)
+            splash = splashConfig.getType();
+
+        Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
+
+        if (hiddenAll)
+            splashConfig = null;
         //寮�灞�
         ad.put("splash", splash);
+        adNew.put("splash", gson.toJson(splashConfig));
 
 
+        ADConfig adConfig = null;
         //瑙嗛鍓嶈创
-        ad.put("videoPlayPre", getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map));
+        adConfig = getAdShowType("ad_play_video_pre", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        ad.put("videoPlayPre", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoPlayPre", gson.toJson(adConfig));
         //APP閫�鍑�
-        ad.put("exitApp", getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map));
+        adConfig = getAdShowType("ad_exit_app", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        ad.put("exitApp", adConfig == null ? "" : adConfig.getType());
+        adNew.put("exitApp", gson.toJson(adConfig));
         //鍏ㄥ睆骞垮憡鎺у埗
-        ad.put("videoDetailFullVideo", getAdShowType("ad_video_detail_full_video", acceptData.getChannel(), acceptData.getVersion(), map));
+        adConfig = getAdShowType("ad_video_detail_full_video", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        ad.put("videoDetailFullVideo", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoDetailFullVideo", gson.toJson(adConfig));
+        //鎼滅储椤靛箍鍛婃帶鍒�
+        adConfig = getAdShowType("ad_video_search", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        ad.put("videoSearch", adConfig == null ? "" : adConfig.getType());
+        adNew.put("videoSearch", gson.toJson(adConfig));
+
+        //pptv鍏嶅箍鍛婃縺鍔辫棰�
+        adConfig = getAdShowType("pptv_no_ad_reward", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        adNew.put("pptvNoAdReward", gson.toJson(adConfig));
+
+        //鐑惎鍔ㄥ紑灞�
+        adConfig = getAdShowType("ad_splash_hot_start", acceptData.getChannel(), acceptData.getVersion(), map);
+        if (hiddenAll)
+            adConfig = null;
+        adNew.put("splashHotStart", gson.toJson(adConfig));
+
 
         data.put("ad", ad);
+        data.put("adNew", adNew);
+        //PPTV鍏嶅箍鍛婃潈鐩婃椂闀�,鏆傛椂璁剧疆涓�3灏忔椂
+        data.put("pptvNoAdRewardHour", 3);
+        //璁剧疆缃戦〉鍔犻�熷煙鍚�
+        data.put("webSpeedUpHost", map.get("web_speed_up_host"));
+        data.put("minePageBanner", map.get("mine_page_banner"));
+
         out.print(JsonUtil.loadTrueJson(data.toString()));
     }
 
@@ -109,7 +243,7 @@
      * @param out
      */
     public void getHomeConfig(AcceptData acceptData, HttpServletRequest request, PrintWriter out) {
-        DetailSystem detailSystem = systemService.getDetailSystemByPackage(acceptData.getPackageName());
+        LoggerUtil.getUserActiveLogger().info(UserActiveLogFactory.createAppMainPage(new BaseLog(acceptData, "")));
         List<FloatAD> adList = floatADService.listShowAD(1, 1);
         Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation().create();
         JSONObject data = new JSONObject();
@@ -123,7 +257,10 @@
 
     class ADConfig {
         int version;
+        @Expose
         String type;
+        @Expose
+        String pid;
 
         public int getVersion() {
             return version;
@@ -141,6 +278,13 @@
             this.type = type;
         }
 
+        public String getPid() {
+            return pid;
+        }
+
+        public void setPid(String pid) {
+            this.pid = pid;
+        }
     }
 
 }

--
Gitblit v1.8.0