From dc5be7d38446f70e6ff86df311119c32b41fe7f8 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期六, 28 十一月 2020 16:37:05 +0800 Subject: [PATCH] 大淘客搜索接口升级 --- fanli/src/main/java/com/yeshi/fanli/service/impl/help/AppPageNotificationServiceImpl.java | 120 ++++++++++++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 105 insertions(+), 15 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/help/AppPageNotificationServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/help/AppPageNotificationServiceImpl.java index 8bf81ca..024f7f2 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/help/AppPageNotificationServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/help/AppPageNotificationServiceImpl.java @@ -1,16 +1,29 @@ package com.yeshi.fanli.service.impl.help; +import java.util.ArrayList; import java.util.Date; +import java.util.HashSet; import java.util.List; +import java.util.Set; import javax.annotation.Resource; +import com.yeshi.fanli.entity.SystemEnum; import org.springframework.cache.annotation.Cacheable; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import com.yeshi.fanli.dao.mybatis.help.AppPageNotificationMapper; +import com.yeshi.fanli.entity.AppVersionInfo; import com.yeshi.fanli.entity.bus.help.AppPageNotification; +import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl; +import com.yeshi.fanli.entity.bus.homemodule.FloatAD; +import com.yeshi.fanli.entity.bus.homemodule.AdActivityVersionControl.AdActivityType; +import com.yeshi.fanli.entity.common.JumpDetailV2; +import com.yeshi.fanli.exception.banner.SwiperPictureException; +import com.yeshi.fanli.service.inter.config.AppVersionService; import com.yeshi.fanli.service.inter.help.AppPageNotificationService; +import com.yeshi.fanli.service.inter.homemodule.AdActivityVersionControlService; import com.yeshi.fanli.util.StringUtil; @Service @@ -19,16 +32,47 @@ @Resource private AppPageNotificationMapper appPageNotificationMapper; - @Override - public AppPageNotification getAppPageNotificationByType(String type) { + @Resource + private AppVersionService appVersionService; - return appPageNotificationMapper.selectByType(type); + @Resource + private AdActivityVersionControlService adActivityVersionControlService; + + @Override + public AppPageNotification getAppPageNotificationByType(String type, SystemEnum system) { + + return appPageNotificationMapper.selectByType(type,system); } - @Cacheable(value = "configCache", key = "'getValidNotificationByTypeCache-'+#type") + @Cacheable(value = "configCache", key = "'getValidNotificationByTypeCache-'+#type+'-'+ #platform+'-'+#versionCode+'-'+#system") @Override - public AppPageNotification getValidNotificationByTypeCache(String type) { - return appPageNotificationMapper.selectValidByType(type); + public AppPageNotification getValidNotificationByTypeCache(String type, String platform, Integer versionCode, SystemEnum system) { + List<AppPageNotification> recordList = appPageNotificationMapper.listValidByType(type,system); + if (recordList == null || recordList.size() == 0) + return null; + + // 杩囨护鐗堟湰 + AppVersionInfo app = appVersionService.getClientVersion(platform, versionCode,system); + if (app == null) { + return null; + } + List<Long> versionIdList = new ArrayList<>(); + versionIdList.add(app.getId()); + + List<Long> sourceIdList = new ArrayList<>(); + for (AppPageNotification an : recordList) + sourceIdList.add(an.getId()); + Set<Long> sourceIds = adActivityVersionControlService.filterSourceIdByVersion(sourceIdList, + AdActivityType.notification, versionIdList); + if (sourceIds == null || sourceIds.size() == 0) + return null; + long sourceId = sourceIds.iterator().next(); + + for (AppPageNotification record : recordList) { + if (record.getId().longValue() == sourceId) + return record; + } + return null; } @Override @@ -37,7 +81,7 @@ return; if (apn.getType() == null) throw new Exception("绫诲瀷涓虹┖"); - AppPageNotification old = getAppPageNotificationByType(apn.getType().name()); + AppPageNotification old = getAppPageNotificationByType(apn.getType().name(),apn.getSystem()); if (old != null) throw new Exception("宸插瓨鍦ㄦ敼绫诲瀷"); @@ -55,12 +99,12 @@ @Override public void updateByPrimaryKey(AppPageNotification record) { - appPageNotificationMapper.updateByPrimaryKey(record); + appPageNotificationMapper.updateByPrimaryKey(record); } - + @Override public void updateByPrimaryKeySelective(AppPageNotification record) { - appPageNotificationMapper.updateByPrimaryKeySelective(record); + appPageNotificationMapper.updateByPrimaryKeySelective(record); } @Override @@ -74,14 +118,60 @@ } @Override - public List<AppPageNotification> listQuery(long start, int count, String key, Integer show, Integer canClose) { - return appPageNotificationMapper.listQuery(start, count, key, show, canClose); + public List<AppPageNotification> listQuery(long start, int count, String key, Integer show, Integer canClose, SystemEnum system) { + return appPageNotificationMapper.listQuery(start, count, key, show, canClose,system); } @Override - public long countQuery(String key, Integer show, Integer canClose) { - return appPageNotificationMapper.countQuery(key, show, canClose); + public long countQuery(String key, Integer show, Integer canClose, SystemEnum system) { + return appPageNotificationMapper.countQuery(key, show, canClose,system); } - + @Transactional(rollbackFor = Exception.class) + @Override + public void setVersions(Long id, List<Long> versions) throws Exception { + AppPageNotification record = appPageNotificationMapper.selectByPrimaryKey(id); + if (record == null) { + throw new Exception("涓撻涓嶅瓨鍦�"); + } + + Set<Long> oldSet = new HashSet<>(); + + List<AdActivityVersionControl> versionList = adActivityVersionControlService + .listByTypeAndSourceId(AdActivityType.notification, id); + if (versionList != null) { + for (AdActivityVersionControl control : versionList) + oldSet.add(control.getVersion().getId()); + } + + Set<Long> newSet = new HashSet<>(); + for (Long version : versions) { + newSet.add(version); + } + + Set<Long> delSet = new HashSet<>(); + delSet.addAll(oldSet); + delSet.removeAll(newSet); + for (Long versionId : delSet) { + adActivityVersionControlService.deleteBySourceAndVersion(id, AdActivityType.notification, versionId); + } + + Set<Long> addSet = new HashSet<>(); + addSet.addAll(newSet); + addSet.removeAll(oldSet); + // 娣诲姞鏄犲皠 + for (Long versionId : addSet) { + AdActivityVersionControl control = new AdActivityVersionControl(); + control.setCreateTime(new Date()); + control.setSourceId(id); + control.setType(AdActivityType.notification); + control.setVersion(new AppVersionInfo(versionId)); + try { + adActivityVersionControlService.addVersionControl(control); + } catch (Exception e) { + throw new SwiperPictureException(2, e.getMessage()); + } + } + } + } -- Gitblit v1.8.0