疯狂的狮子li
2021-09-13 2af534eea471f4adb104906c7a814bcc66d4d68d
ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java
@@ -1,22 +1,20 @@
package com.ruoyi.system.service.impl;
import cn.hutool.core.convert.Convert;
import cn.hutool.core.lang.Validator;
import com.ruoyi.common.utils.StringUtils;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.ruoyi.common.annotation.DataSource;
import com.ruoyi.common.constant.Constants;
import com.ruoyi.common.constant.UserConstants;
import com.ruoyi.common.core.mybatisplus.core.ServicePlusImpl;
import com.ruoyi.common.core.page.TableDataInfo;
import com.ruoyi.common.core.redis.RedisCache;
import com.ruoyi.common.enums.DataSourceType;
import com.ruoyi.common.exception.CustomException;
import com.ruoyi.common.exception.ServiceException;
import com.ruoyi.common.utils.PageUtils;
import com.ruoyi.common.utils.RedisUtils;
import com.ruoyi.common.utils.StringUtils;
import com.ruoyi.system.domain.SysConfig;
import com.ruoyi.system.mapper.SysConfigMapper;
import com.ruoyi.system.service.ISysConfigService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import javax.annotation.PostConstruct;
@@ -33,9 +31,6 @@
@Service
public class SysConfigServiceImpl extends ServicePlusImpl<SysConfigMapper, SysConfig, SysConfig> implements ISysConfigService {
   @Autowired
   private RedisCache redisCache;
   /**
    * 项目启动时,初始化参数到缓存
    */
@@ -51,10 +46,10 @@
         .like(StringUtils.isNotBlank(config.getConfigName()), SysConfig::getConfigName, config.getConfigName())
         .eq(StringUtils.isNotBlank(config.getConfigType()), SysConfig::getConfigType, config.getConfigType())
         .like(StringUtils.isNotBlank(config.getConfigKey()), SysConfig::getConfigKey, config.getConfigKey())
         .apply(Validator.isNotEmpty(params.get("beginTime")),
         .apply(StringUtils.isNotEmpty(params.get("beginTime")),
            "date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')",
            params.get("beginTime"))
         .apply(Validator.isNotEmpty(params.get("endTime")),
         .apply(StringUtils.isNotEmpty(params.get("endTime")),
            "date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')",
            params.get("endTime"));
      return PageUtils.buildDataInfo(page(PageUtils.buildPage(), lqw));
@@ -80,14 +75,14 @@
    */
   @Override
   public String selectConfigByKey(String configKey) {
      String configValue = Convert.toStr(redisCache.getCacheObject(getCacheKey(configKey)));
      if (Validator.isNotEmpty(configValue)) {
      String configValue = Convert.toStr(RedisUtils.getCacheObject(getCacheKey(configKey)));
      if (StringUtils.isNotEmpty(configValue)) {
         return configValue;
      }
      SysConfig retConfig = baseMapper.selectOne(new LambdaQueryWrapper<SysConfig>()
         .eq(SysConfig::getConfigKey, configKey));
      if (Validator.isNotNull(retConfig)) {
         redisCache.setCacheObject(getCacheKey(configKey), retConfig.getConfigValue());
      if (StringUtils.isNotNull(retConfig)) {
         RedisUtils.setCacheObject(getCacheKey(configKey), retConfig.getConfigValue());
         return retConfig.getConfigValue();
      }
      return StringUtils.EMPTY;
@@ -120,10 +115,10 @@
         .like(StringUtils.isNotBlank(config.getConfigName()), SysConfig::getConfigName, config.getConfigName())
         .eq(StringUtils.isNotBlank(config.getConfigType()), SysConfig::getConfigType, config.getConfigType())
         .like(StringUtils.isNotBlank(config.getConfigKey()), SysConfig::getConfigKey, config.getConfigKey())
         .apply(Validator.isNotEmpty(params.get("beginTime")),
         .apply(StringUtils.isNotEmpty(params.get("beginTime")),
            "date_format(create_time,'%y%m%d') >= date_format({0},'%y%m%d')",
            params.get("beginTime"))
         .apply(Validator.isNotEmpty(params.get("endTime")),
         .apply(StringUtils.isNotEmpty(params.get("endTime")),
            "date_format(create_time,'%y%m%d') <= date_format({0},'%y%m%d')",
            params.get("endTime"));
      return baseMapper.selectList(lqw);
@@ -139,7 +134,7 @@
   public int insertConfig(SysConfig config) {
      int row = baseMapper.insert(config);
      if (row > 0) {
         redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
         RedisUtils.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
      }
      return row;
   }
@@ -154,7 +149,7 @@
   public int updateConfig(SysConfig config) {
      int row = baseMapper.updateById(config);
      if (row > 0) {
         redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
         RedisUtils.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
      }
      return row;
   }
@@ -170,9 +165,9 @@
      for (Long configId : configIds) {
         SysConfig config = selectConfigById(configId);
         if (StringUtils.equals(UserConstants.YES, config.getConfigType())) {
            throw new CustomException(String.format("内置参数【%1$s】不能删除 ", config.getConfigKey()));
            throw new ServiceException(String.format("内置参数【%1$s】不能删除 ", config.getConfigKey()));
         }
         redisCache.deleteObject(getCacheKey(config.getConfigKey()));
         RedisUtils.deleteObject(getCacheKey(config.getConfigKey()));
      }
      baseMapper.deleteBatchIds(Arrays.asList(configIds));
   }
@@ -184,7 +179,7 @@
   public void loadingConfigCache() {
      List<SysConfig> configsList = selectConfigList(new SysConfig());
      for (SysConfig config : configsList) {
         redisCache.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
         RedisUtils.setCacheObject(getCacheKey(config.getConfigKey()), config.getConfigValue());
      }
   }
@@ -193,8 +188,8 @@
    */
   @Override
   public void clearConfigCache() {
      Collection<String> keys = redisCache.keys(Constants.SYS_CONFIG_KEY + "*");
      redisCache.deleteObject(keys);
      Collection<String> keys = RedisUtils.keys(Constants.SYS_CONFIG_KEY + "*");
      RedisUtils.deleteObject(keys);
   }
   /**
@@ -214,9 +209,9 @@
    */
   @Override
   public String checkConfigKeyUnique(SysConfig config) {
      Long configId = Validator.isNull(config.getConfigId()) ? -1L : config.getConfigId();
      Long configId = StringUtils.isNull(config.getConfigId()) ? -1L : config.getConfigId();
      SysConfig info = baseMapper.selectOne(new LambdaQueryWrapper<SysConfig>().eq(SysConfig::getConfigKey, config.getConfigKey()));
      if (Validator.isNotNull(info) && info.getConfigId().longValue() != configId.longValue()) {
      if (StringUtils.isNotNull(info) && info.getConfigId().longValue() != configId.longValue()) {
         return UserConstants.NOT_UNIQUE;
      }
      return UserConstants.UNIQUE;