| | |
| | | import com.ruoyi.common.utils.JsonUtils; |
| | | import com.ruoyi.common.utils.StringUtils; |
| | | import com.ruoyi.common.utils.redis.RedisUtils; |
| | | import com.ruoyi.common.utils.spring.SpringUtils; |
| | | import com.ruoyi.oss.constant.OssConstant; |
| | | import com.ruoyi.oss.enumd.OssEnumd; |
| | | import com.ruoyi.oss.core.OssClient; |
| | | import com.ruoyi.oss.exception.OssException; |
| | | import com.ruoyi.oss.properties.OssProperties; |
| | | import com.ruoyi.oss.service.IOssStrategy; |
| | | import com.ruoyi.oss.service.abstractd.AbstractOssStrategy; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | |
| | | import java.util.Map; |
| | | import java.util.concurrent.ConcurrentHashMap; |
| | | |
| | | /** |
| | | * 文件上传Factory |
| | |
| | | @Slf4j |
| | | public class OssFactory { |
| | | |
| | | private static final Map<String, OssClient> CLIENT_CACHE = new ConcurrentHashMap<>(); |
| | | |
| | | /** |
| | | * 初始化工厂 |
| | | */ |
| | | public static void init() { |
| | | log.info("初始化OSS工厂"); |
| | | RedisUtils.subscribe(OssConstant.CACHE_CONFIG_KEY, String.class, type -> { |
| | | AbstractOssStrategy strategy = getStrategy(type); |
| | | RedisUtils.subscribe(OssConstant.CACHE_CONFIG_KEY, String.class, configKey -> { |
| | | OssClient client = getClient(configKey); |
| | | // 未初始化不处理 |
| | | if (strategy.isInit) { |
| | | refresh(type); |
| | | log.info("订阅刷新OSS配置 => " + type); |
| | | if (client != null) { |
| | | refresh(configKey); |
| | | log.info("订阅刷新OSS配置 => " + configKey); |
| | | } |
| | | }); |
| | | } |
| | |
| | | /** |
| | | * 获取默认实例 |
| | | */ |
| | | public static IOssStrategy instance() { |
| | | public static OssClient instance() { |
| | | // 获取redis 默认类型 |
| | | String type = RedisUtils.getCacheObject(OssConstant.CACHE_CONFIG_KEY); |
| | | if (StringUtils.isEmpty(type)) { |
| | | String configKey = RedisUtils.getCacheObject(OssConstant.CACHE_CONFIG_KEY); |
| | | if (StringUtils.isEmpty(configKey)) { |
| | | throw new OssException("文件存储服务类型无法找到!"); |
| | | } |
| | | return instance(type); |
| | | return instance(configKey); |
| | | } |
| | | |
| | | /** |
| | | * 根据类型获取实例 |
| | | */ |
| | | public static IOssStrategy instance(String type) { |
| | | OssEnumd enumd = OssEnumd.find(type); |
| | | if (enumd == null) { |
| | | throw new OssException("文件存储服务类型无法找到!"); |
| | | public static OssClient instance(String configKey) { |
| | | OssClient client = getClient(configKey); |
| | | if (client == null) { |
| | | refresh(configKey); |
| | | return getClient(configKey); |
| | | } |
| | | AbstractOssStrategy strategy = getStrategy(type); |
| | | if (!strategy.isInit) { |
| | | refresh(type); |
| | | } |
| | | return strategy; |
| | | return client; |
| | | } |
| | | |
| | | private static void refresh(String type) { |
| | | Object json = RedisUtils.getCacheObject(OssConstant.SYS_OSS_KEY + type); |
| | | private static void refresh(String configKey) { |
| | | Object json = RedisUtils.getCacheObject(OssConstant.SYS_OSS_KEY + configKey); |
| | | OssProperties properties = JsonUtils.parseObject(json.toString(), OssProperties.class); |
| | | if (properties == null) { |
| | | throw new OssException("系统异常, '" + type + "'配置信息不存在!"); |
| | | throw new OssException("系统异常, '" + configKey + "'配置信息不存在!"); |
| | | } |
| | | getStrategy(type).init(properties); |
| | | CLIENT_CACHE.put(configKey, new OssClient(configKey, properties)); |
| | | } |
| | | |
| | | private static AbstractOssStrategy getStrategy(String type) { |
| | | OssEnumd enumd = OssEnumd.find(type); |
| | | return (AbstractOssStrategy) SpringUtils.getBean(enumd.getBeanClass()); |
| | | private static OssClient getClient(String configKey) { |
| | | return CLIENT_CACHE.get(configKey); |
| | | } |
| | | |
| | | } |