From b37275dba6b782bf3bb3817c4504f6cdef1bef7c Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期四, 18 三月 2021 18:38:51 +0800
Subject: [PATCH] APP首页顶部标签兼容

---
 src/main/java/com/yeshi/buwan/service/imp/juhe/Iqiyi2ServiceImpl.java |   88 +++++++++++++++++++++++++++++++++++---------
 1 files changed, 70 insertions(+), 18 deletions(-)

diff --git a/src/main/java/com/yeshi/buwan/service/imp/juhe/Iqiyi2ServiceImpl.java b/src/main/java/com/yeshi/buwan/service/imp/juhe/Iqiyi2ServiceImpl.java
index 5eff5fd..475da62 100644
--- a/src/main/java/com/yeshi/buwan/service/imp/juhe/Iqiyi2ServiceImpl.java
+++ b/src/main/java/com/yeshi/buwan/service/imp/juhe/Iqiyi2ServiceImpl.java
@@ -6,33 +6,36 @@
 import com.yeshi.buwan.dao.video.AlbumVideoMapDao;
 import com.yeshi.buwan.domain.*;
 import com.yeshi.buwan.domain.entity.PlayUrl;
+import com.yeshi.buwan.domain.system.SystemConfig;
 import com.yeshi.buwan.domain.video.AlbumVideoMap;
 import com.yeshi.buwan.iqiyi.IqiYiNewAPI;
 import com.yeshi.buwan.iqiyi.entity.IqiyiAlbum2;
 import com.yeshi.buwan.iqiyi.entity.VideoIqiyi2;
 import com.yeshi.buwan.iqiyi.util.IqiyiUtil;
 import com.yeshi.buwan.iqiyi.util.IqiyiUtil2;
-import com.yeshi.buwan.service.imp.CategoryVideoService;
-import com.yeshi.buwan.service.imp.ResourceVideoService;
-import com.yeshi.buwan.service.imp.VideoInfoService;
-import com.yeshi.buwan.service.imp.VideoResourceService;
+import com.yeshi.buwan.query.Iqiyi2AlbumQuery;
+import com.yeshi.buwan.service.imp.*;
 import com.yeshi.buwan.service.inter.juhe.Iqiyi2Service;
+import com.yeshi.buwan.service.inter.system.SystemConfigService;
 import com.yeshi.buwan.util.StringUtil;
 import com.yeshi.buwan.util.TimeUtil;
+import com.yeshi.buwan.util.log.VideoLogFactory;
 import com.yeshi.buwan.util.mq.CMQManager;
 import com.yeshi.buwan.util.video.VideoConstant;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
 import org.springframework.stereotype.Service;
 
 import javax.annotation.Resource;
 import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Calendar;
-import java.util.Date;
-import java.util.List;
+import java.util.*;
 import java.util.regex.Pattern;
 
 @Service
 public class Iqiyi2ServiceImpl implements Iqiyi2Service {
+
+    private final Logger logger = LoggerFactory.getLogger("videoUpdate");
+
     @Resource
     private VideoIqiyi2Dao videoIqiyi2Dao;
 
@@ -57,6 +60,9 @@
     @Resource
     private VideoResourceService videoResourceService;
 
+    @Resource
+    private SystemConfigService systemConfigService;
+
     public List<VideoDetailInfo> getVideoDetailList(String videoId, int page, int pageSize) {
         //鏌ヨ涓撹緫
         VideoIqiyi2 videoIqiyi2 = videoIqiyi2Dao.selectByVideoId(Long.parseLong(videoId));
@@ -70,7 +76,10 @@
         } else {//涓撹緫
             //鍒ゆ柇period瀛楁鏄惁涓虹┖
             int sort = album.isSourceAlbum() ? IqiyiAlbum2.SORT_PERIOD : IqiyiAlbum2.SORT_ORDER;
-            List<IqiyiAlbum2> list = iqiyiAlbum2Dao.listByAid(album.getId(), sort, (page - 1) * pageSize, pageSize);
+            Iqiyi2AlbumQuery query = new Iqiyi2AlbumQuery();
+            query.setFeatureAlbumId(album.getId());
+            query.setContentType(1);
+            List<IqiyiAlbum2> list = iqiyiAlbum2Dao.listByAid(query, sort, (page - 1) * pageSize, pageSize);
             if (list != null)
                 album2List.addAll(list);
         }
@@ -102,6 +111,19 @@
         iqiyiAlbum2Dao.save(album);
     }
 
+    public boolean isUnNormalUpdateVideoName(String name) {
+        SystemConfig config = systemConfigService.getConfigByKeyCache("iqiyi_update_video_name");
+        if (config != null) {
+            String[] sts = config.getValue().split(",");
+            List<String> list = new ArrayList<>();
+            for (String st : sts) {
+                list.add(st.trim());
+            }
+            return list.contains(name.trim());
+        }
+        return false;
+    }
+
     @Override
     public void addToVideoInfo(IqiyiAlbum2 album) {
         if (album.getFeatureAlbumId() > 0L && album.getChannelId() != IqiYiNewAPI.TYPE_DIANYING) {
@@ -127,16 +149,17 @@
                 return;
         }
 
-        if (album.getChannelId() != 1) {
+
+        if (album.getChannelId() != 1 && !isUnNormalUpdateVideoName(album.getName())) {
             //鏍囬涓彧鑳藉寘鍚腑鑻辨枃涓庢暟瀛�
-            String regx = "^[(\\u4e00-\\u9fa5)( )a-zA-Z0-9]+$";
+            String regx = "^[(\\u4e00-\\u9fa5)(锛�)( )a-zA-Z0-9]+$";
             if (!Pattern.matches(regx, album.getName())) {
                 return;
             }
         }
 
         //杩囨护鏌愪簺鐭墖涓庡奖璇�
-        if (album.getName().contains("銆�"))
+        if (album.getName().contains("銆�") && !isUnNormalUpdateVideoName(album.getName()))
             return;
 
         //绌虹數瑙嗗墽鎴栬�呮槸绌哄姩婕垯杩斿洖
@@ -145,6 +168,7 @@
                 return;
         }
 
+        logger.info(VideoLogFactory.createAddToVideoLog(album));
 
         VideoInfo newVideoInfo = convertAlbumToVideoInfo(album);
         VideoIqiyi2 videoIqiyi2 = videoIqiyi2Dao.selectByIqiyiId(album.getId());
@@ -153,7 +177,7 @@
             if (videoInfo == null)
                 return;
             newVideoInfo.setId(videoInfo.getId());
-            if (!newVideoInfo.getTag().equalsIgnoreCase(videoInfo.getTag())) {
+            if (!newVideoInfo.getTag().equalsIgnoreCase(videoInfo.getTag()) || newVideoInfo.getVideocount() != videoInfo.getVideocount()) {
                 newVideoInfo.setCreatetime(videoInfo.getCreatetime());
                 //鏇存柊淇℃伅tag淇℃伅
                 videoInfo.setLatestHpicture(newVideoInfo.getLatestHpicture());
@@ -165,11 +189,12 @@
                 videoInfo.setVpicture(newVideoInfo.getVpicture());
                 videoInfo.setShow(newVideoInfo.getShow());
                 videoInfo.setVideoType(newVideoInfo.getVideoType());
+                videoInfo.setUpdatetime(newVideoInfo.getUpdatetime());
                 videoInfoDao.update(videoInfo);
             }
         } else {//瑙嗛涓嶅瓨鍦�
             //鍒ゆ柇2涓棰戝疄浣撴槸鍚︿负鍚屼竴瑙嗛
-            VideoInfo oldVideo = videoInfoService.getExistSameVideo(newVideoInfo);
+            VideoInfo oldVideo = videoInfoService.getExistSameVideoWithTime(newVideoInfo);
             if (oldVideo == null) {
                 //娣诲姞瑙嗛
                 Serializable id = videoInfoDao.save(newVideoInfo);
@@ -186,11 +211,13 @@
                 oldVideo.setVpicture(newVideoInfo.getVpicture());
                 oldVideo.setShow(newVideoInfo.getShow());
                 oldVideo.setVideoType(newVideoInfo.getVideoType());
+                oldVideo.setUpdatetime(newVideoInfo.getUpdatetime());
                 videoInfoDao.update(oldVideo);
             }
 
             //鍔犲叆涓撹緫瑙嗛鏄犲皠
             AlbumVideoMap map = new AlbumVideoMap();
+            map.setId(newVideoInfo.getId());
             map.setCreateTime(new Date());
             map.setVideoId(newVideoInfo.getId());
             map.setRootVideoType(newVideoInfo.getVideoType().getId());
@@ -310,11 +337,11 @@
                 video.setLatestVpicture(IqiyiUtil.getVPicture(album2.getImageUrl()));
             }
         }
+        long videoCount = iqiyiAlbum2Dao.countVideoByAid(album.getId());
+        if (videoCount == 0L)
+            videoCount = 1;
 
-        if (album.getTvQipuIds() != null && album.getTvQipuIds().size() > 0)
-            video.setVideocount(album.getTvQipuIds().size());
-        else
-            video.setVideocount(1);
+        video.setVideocount((int) videoCount);
 
         video.setUpdatetime(System.currentTimeMillis() + "");
 
@@ -326,4 +353,29 @@
     public IqiyiAlbum2 selectAlbumById(Long id) {
         return iqiyiAlbum2Dao.get(id);
     }
+
+    @Override
+    public long countById(Long id) {
+        return iqiyiAlbum2Dao.countById(id);
+    }
+
+    @Override
+    public void deleteByAid(long id) {
+        long count = iqiyiAlbum2Dao.countById(id);
+        if (count > 0) {
+            iqiyiAlbum2Dao.delete(id);
+        }
+        VideoIqiyi2 bean = videoIqiyi2Dao.selectByIqiyiId(id);
+        if (bean != null) {
+            videoIqiyi2Dao.delete(bean.getVideoId());
+            //鍒犻櫎璧勬簮
+            resourceVideoService.delete(bean.getVideoId() + "", IqiyiUtil2.RESOURCE_ID + "");
+        }
+
+    }
+
+    @Override
+    public List<IqiyiAlbum2> listByIds(List<Long> idsList) {
+        return iqiyiAlbum2Dao.listByIds(idsList);
+    }
 }

--
Gitblit v1.8.0