From f537abe9f3646c739beaf15076246a2f71a347e9 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期四, 20 二月 2025 16:57:55 +0800
Subject: [PATCH] IOS广告增加区域屏蔽

---
 src/main/java/com/yeshi/buwan/service/imp/VideoInfoService.java |  183 ++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 162 insertions(+), 21 deletions(-)

diff --git a/src/main/java/com/yeshi/buwan/service/imp/VideoInfoService.java b/src/main/java/com/yeshi/buwan/service/imp/VideoInfoService.java
index 9607e09..fdf6028 100644
--- a/src/main/java/com/yeshi/buwan/service/imp/VideoInfoService.java
+++ b/src/main/java/com/yeshi/buwan/service/imp/VideoInfoService.java
@@ -1,32 +1,27 @@
 package com.yeshi.buwan.service.imp;
 
-import java.io.Serializable;
-import java.util.ArrayList;
-import java.util.Calendar;
-import java.util.List;
-
-import javax.annotation.Resource;
-
-import com.yeshi.buwan.util.TimeUtil;
+import com.yeshi.buwan.dao.CategoryVideoDao;
+import com.yeshi.buwan.dao.VideoInfoDao;
+import com.yeshi.buwan.domain.*;
+import com.yeshi.buwan.domain.entity.PlayUrl;
+import com.yeshi.buwan.dto.mq.VideoDataChangeMQMsg;
+import com.yeshi.buwan.util.StringUtil;
+import com.yeshi.buwan.util.mq.rabbit.RabbitmqManager;
 import com.yeshi.buwan.util.video.VideoConstant;
 import org.hibernate.HibernateException;
 import org.hibernate.SQLQuery;
 import org.hibernate.Session;
 import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.cache.annotation.Cacheable;
 import org.springframework.orm.hibernate4.HibernateCallback;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 
-import com.yeshi.buwan.dao.CategoryVideoDao;
-import com.yeshi.buwan.dao.VideoInfoDao;
-import com.yeshi.buwan.domain.CategoryVideo;
-import com.yeshi.buwan.domain.ResourceVideo;
-import com.yeshi.buwan.domain.VideoDetailInfo;
-import com.yeshi.buwan.domain.VideoInfo;
-import com.yeshi.buwan.domain.VideoResource;
-import com.yeshi.buwan.domain.VideoType;
-import com.yeshi.buwan.domain.VideoUrl;
-import com.yeshi.buwan.domain.entity.PlayUrl;
+import javax.annotation.Resource;
+import java.io.Serializable;
+import java.util.ArrayList;
+import java.util.Arrays;
+import java.util.List;
 
 @Service
 public class VideoInfoService {
@@ -43,9 +38,24 @@
     @Resource
     private VideoResourceService videoResourceService;
 
+    @Resource
+    private ClearService clearService;
+
+    @Resource
+    private RabbitmqManager rabbitmqManager;
+
+
+
+    @Transactional
     public VideoInfo getVideoInfo(String vid) {
         return videoInfoDao.find(VideoInfo.class, vid);
     }
+
+    @Cacheable(value = "videoCache", key = "'getVideoInfoDetail-'+#vid")
+    public VideoInfo getVideoInfoCache(String vid) {
+        return videoInfoDao.find(VideoInfo.class, vid);
+    }
+
 
     @SuppressWarnings("unchecked")
     public List<VideoInfo> simpleRandomVideoList(final int i) {
@@ -73,12 +83,14 @@
     }
 
     @Transactional
-    public void save(VideoInfo videoInfo) {
+    public void saveWithCategoryAndResource(VideoInfo videoInfo) {
         videoInfoDao.save(videoInfo);
+        rabbitmqManager.addVideoDataChanged(new VideoDataChangeMQMsg(VideoDataChangeMQMsg.TYPE_VIDEO_INFO, videoInfo.getId(), VideoDataChangeMQMsg.ACTION_ADD));
         CategoryVideo ca = new CategoryVideo();
         ca.setVideo(videoInfo);
         ca.setVideoType(videoInfo.getVideoType());
         categoryVideoDao.create(ca);
+       rabbitmqManager.addVideoDataChanged(new VideoDataChangeMQMsg(VideoDataChangeMQMsg.TYPE_VIDEO_CATEGORY, videoInfo.getId(), VideoDataChangeMQMsg.ACTION_ADD));
         List<VideoResource> resourceList = videoInfo.getResourceList();
         ResourceVideo rs = null;
         for (VideoResource videoResource : resourceList) {
@@ -87,6 +99,21 @@
             rs.setVideo(videoInfo);
             resourceVideoService.save(rs);
         }
+        rabbitmqManager.addVideoDataChanged(new VideoDataChangeMQMsg(VideoDataChangeMQMsg.TYPE_VIDEO_RESOURCE, videoInfo.getId(), VideoDataChangeMQMsg.ACTION_ADD));
+    }
+
+
+    @Transactional
+    public Serializable save(VideoInfo videoInfo) {
+        Serializable id = videoInfoDao.save(videoInfo);
+        rabbitmqManager.addVideoDataChanged(new VideoDataChangeMQMsg(VideoDataChangeMQMsg.TYPE_VIDEO_INFO, videoInfo.getId(), VideoDataChangeMQMsg.ACTION_ADD));
+        return id;
+    }
+
+    @Transactional
+    public void update(VideoInfo videoInfo) {
+        videoInfoDao.update(videoInfo);
+        rabbitmqManager.addVideoDataChanged(new VideoDataChangeMQMsg(VideoDataChangeMQMsg.TYPE_VIDEO_INFO, videoInfo.getId(), VideoDataChangeMQMsg.ACTION_UPDATE));
     }
 
     public List<VideoDetailInfo> getVideoDetailList(String videoid, VideoResource vr, int page, int pageSize) {
@@ -137,12 +164,12 @@
 
 
     /**
-     * 鏄惁瀛樺湪鐩稿悓鐨勮棰�
+     * 鏄惁瀛樺湪鐩稿悓鐨勮棰�(鏍规嵁鍚嶇О涓庝笂鏄犳椂闂�)
      *
      * @param newVideoInfo
      * @return
      */
-    public VideoInfo getExistSameVideo(VideoInfo newVideoInfo) {
+    public VideoInfo getExistSameVideoWithTime(VideoInfo newVideoInfo) {
         int year = Integer.parseInt(newVideoInfo.getYear());
         List<VideoInfo> list = videoInfoDao.listByName(newVideoInfo.getName(), 0, 5);
         if (list != null && list.size() > 0)
@@ -184,10 +211,62 @@
     }
 
 
+    /**
+     * 鏍规嵁鍚嶇О涓庝富婕�
+     *
+     * @param newVideoInfo
+     * @return
+     */
+    public VideoInfo getExistSameVideoWithDirector(VideoInfo newVideoInfo) {
+        List<VideoInfo> list = videoInfoDao.listByName(newVideoInfo.getName(), 0, 5);
+        if (list != null && list.size() > 0) {
+            if (VideoConstant.isMainCategory(newVideoInfo.getVideoType().getId())) {
+                for (int i = 0; i < list.size(); i++) {
+                    VideoInfo vi = list.get(i);
+                    if (getSameDirectorOrActorCount(vi.getDirector(), newVideoInfo.getDirector()) > 0 || getSameDirectorOrActorCount(vi.getMainActor(), newVideoInfo.getMainActor()) > 0) {
+//                        if (getSameDirectorOrActorCount(vi.getMainActor(), newVideoInfo.getMainActor()) > 0) {
+                        //涓诲垎绫讳竴鏍�
+                        if (vi.getVideoType() != null && newVideoInfo.getVideoType() != null && vi.getVideoType().getId() == newVideoInfo.getVideoType().getId())
+                            return list.get(i);
+//                        }
+                    }
+                }
+            } else {
+                return list.get(0);
+            }
+        }
+        return null;
+    }
+
+    private int getSameDirectorOrActorCount(String d1, String d2) {
+        if (!StringUtil.isNullOrEmpty(d1) && !StringUtil.isNullOrEmpty(d2)) {
+            List<String> d1List = new ArrayList<>();
+            if (d1.contains("/")) {
+                d1List.addAll(Arrays.asList(d1.trim().split("/")));
+            } else {
+                d1List.addAll(Arrays.asList(d1.trim().split(" ")));
+            }
+
+            List<String> d2List = new ArrayList<>();
+            if (d2.contains("/"))
+                d2List.addAll(Arrays.asList(d2.trim().split("/")));
+            else
+                d2List.addAll(Arrays.asList(d2.trim().split(" ")));
+
+            d1List.retainAll(d2List);
+
+            return d1List.size();
+        }
+
+        return 0;
+    }
+
+
     public List<VideoInfo> listByVideoIds(List<String> videoIds) {
         return videoInfoDao.listByVideoIds(videoIds);
     }
 
+    @Transactional
     public void hiddenVideo(String id) {
         VideoInfo videoInfo = videoInfoDao.find(VideoInfo.class, id);
         if (videoInfo != null && "1".equalsIgnoreCase(videoInfo.getShow())) {
@@ -202,4 +281,66 @@
         videoInfoDao.statisticVideoExtraInfo(videoId);
     }
 
+    /**
+     * 鍒楄〃鏌ヨ
+     *
+     * @param query
+     * @return
+     */
+    public List<VideoInfo> list(VideoInfoDao.DaoQuery query) {
+        return videoInfoDao.list(query);
+    }
+
+    public long count(VideoInfoDao.DaoQuery query) {
+        return videoInfoDao.count(query);
+    }
+
+
+    public void updateVideoInfo(VideoInfo videoInfo) {
+        VideoInfo oldVideo = videoInfoDao.find(VideoInfo.class, videoInfo.getId());
+        if (oldVideo == null)
+            return;
+
+        videoInfoDao.updateSelective(videoInfo);
+        //鏄惁闇�瑕佹洿鏂版悳绱㈠紩鎿�
+        boolean needUpdateSolr = false;
+        //tag鍙樺寲
+        if (videoInfo.getTag() != null && !videoInfo.getTag().equalsIgnoreCase(oldVideo.getTag())) {
+            needUpdateSolr = true;
+        }
+
+        //鍚嶇О鍙樺寲
+        if (videoInfo.getName() != null && !videoInfo.getName().equalsIgnoreCase(oldVideo.getName())) {
+            needUpdateSolr = true;
+        }
+
+        //picture鍙樺寲
+        if (videoInfo.getHpicture() != null && !videoInfo.getHpicture().equalsIgnoreCase(oldVideo.getHpicture())) {
+            needUpdateSolr = true;
+        }
+        if (videoInfo.getVpicture() != null && !videoInfo.getVpicture().equalsIgnoreCase(oldVideo.getVpicture())) {
+            needUpdateSolr = true;
+        }
+
+        if (videoInfo.getPicture() != null && !videoInfo.getPicture().equalsIgnoreCase(oldVideo.getPicture())) {
+            needUpdateSolr = true;
+        }
+
+        //瑙嗛绫诲瀷鍙戠敓鍙樺寲
+        if (videoInfo.getVideoType() != null && (oldVideo.getVideoType() == null || videoInfo.getVideoType().getId() != oldVideo.getVideoType().getId())) {
+            needUpdateSolr = true;
+        }
+
+        //鏄惁鏄剧ず
+        if (videoInfo.getShow() != null && !videoInfo.getShow().equalsIgnoreCase(oldVideo.getShow())) {
+            needUpdateSolr = true;
+        }
+
+        if (needUpdateSolr) {
+            rabbitmqManager.addSolrMsg(videoInfo.getId());
+        }
+
+
+    }
+
 }

--
Gitblit v1.8.0