From 035dae7be5cf8a7a4a13cecb5dc9cde9fcda07e6 Mon Sep 17 00:00:00 2001 From: xiangpei <xiangpei@timesnew.cn> Date: 星期一, 17 二月 2025 10:29:52 +0800 Subject: [PATCH] 独立删除逻辑 --- ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/sync/deleteSync.java | 61 ++++++++++++++++++------------ 1 files changed, 37 insertions(+), 24 deletions(-) diff --git a/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/sync/deleteSync.java b/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/sync/deleteSync.java index 98334b1..1c7da6c 100644 --- a/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/sync/deleteSync.java +++ b/ruoyi-modules/ruoyi-system/src/main/java/org/dromara/system/sync/deleteSync.java @@ -1,10 +1,18 @@ package org.dromara.system.sync; +import com.baomidou.mybatisplus.core.conditions.Wrapper; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper; +import lombok.extern.slf4j.Slf4j; +import org.apache.http.HttpResponse; +import org.dromara.common.mybatis.core.domain.BaseEntity; +import org.dromara.common.oss.core.OssClient; +import org.dromara.common.oss.factory.OssFactory; import org.dromara.system.domain.SysOss; import org.dromara.system.domain.properties.Boundary; import org.dromara.system.domain.vo.SysOssVo; import org.dromara.system.mapper.SysOssMapper; +import org.dromara.system.service.ISysOssService; import org.dromara.system.uitil.HttpUtils; import org.springframework.scheduling.annotation.Scheduled; import org.springframework.stereotype.Component; @@ -12,45 +20,50 @@ import java.io.IOException; import java.time.LocalDateTime; import java.util.List; +import java.util.Objects; +@Slf4j @Component public class deleteSync { - private final SysOssMapper baseMapper; + private final ISysOssService ossService; + private final SysOssMapper ossMapper; private final Boundary boundary; - public deleteSync(SysOssMapper baseMapper, Boundary boundary) { - this.baseMapper = baseMapper; + public deleteSync(ISysOssService ossService, SysOssMapper ossMapper, Boundary boundary) { + this.ossService = ossService; + this.ossMapper = ossMapper; this.boundary = boundary; } +// @Scheduled(cron = "0 */10 * * * ?") +// public void remove() throws IOException { +// log.error("鍚屾鍒犻櫎......"); +// List<SysOss> list = new LambdaQueryChainWrapper<>(baseMapper) +// .le(SysOss::getCreateTime, LocalDateTime.now().minusDays(1L)) +// .list(); +// if (list.size() == 0) +// return; +// +// for (SysOss vo : list) { +// OssClient storage = OssFactory.instance(vo.getService()); +// storage.delete(vo.getUrl()); +// HttpResponse httpResponse = HttpUtils.sendDeleteRequest(this.boundary.getVideo() + "/resource/synchronization/delete", +// String.valueOf(vo.getOssId())); +// if (httpResponse.getStatusLine().getStatusCode() == 200) { +// baseMapper.deleteId(vo.getOssId()); +// } +// } +// } @Scheduled(cron = "0 */10 * * * ?") public void remove() throws IOException { - System.out.println("鍚屾鍒犻櫎......"); - List<Long> ids = baseMapper.getWillDeleted(LocalDateTime.now().minusDays(1)); - + System.out.println("self delete......"); + List<Long> ids = ossMapper.getWillDeleted(LocalDateTime.now().minusDays(1)); if (ids.size() == 0) { return; } - for (Long ossId : ids) { - HttpUtils.sendDeleteRequest(boundary.getVideo() + "/resource/synchronization/delete", - String.valueOf(ossId)); - } + ossService.deleteByIds(ids); } - /** - * 姣忓皬鏃跺垹闄�30澶╀箣鍓嶇殑鏂囦欢淇℃伅锛岀‘淇濅笂闈㈢殑瀹氭椂浠诲姟涓嶄細鍥犱负鍋滅數鍏虫満绛夊師鍥犲鑷存枃浠舵湭琚垹闄� - * - * @throws IOException - */ - @Scheduled(cron = "0 0 * * * ?") - public void removeOssTable() throws IOException { - System.out.println("姣忓皬鏃跺畾鏃跺垹闄よ秴杩�30澶╃殑鏁版嵁搴撴枃浠朵俊鎭�......"); - List<Long> ids = baseMapper.getWillDeleted(LocalDateTime.now().minusDays(30)); - if (ids.size() == 0) { - return; - } - baseMapper.deleteBatchIds(ids); - } } -- Gitblit v1.8.0