| | |
| | | package com.yeshi.fanli.service.impl.config; |
| | | |
| | | import javax.annotation.Resource; |
| | | |
| | | import com.ks.lib.common.exception.ParamsException; |
| | | import com.yeshi.fanli.dao.mybatis.SystemConfigMapper; |
| | | import com.yeshi.fanli.entity.SystemEnum; |
| | | import com.yeshi.fanli.entity.config.SystemConfigKeyEnum; |
| | | import com.yeshi.fanli.entity.system.SystemConfig; |
| | | import com.yeshi.fanli.service.inter.config.SystemConfigService; |
| | | import org.springframework.cache.annotation.Cacheable; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import com.yeshi.fanli.dao.mybatis.SystemConfigMapper; |
| | | import com.yeshi.fanli.entity.system.BusinessSystem; |
| | | import com.yeshi.fanli.entity.system.SystemConfig; |
| | | import com.yeshi.fanli.exception.NotExistObjectException; |
| | | import com.yeshi.fanli.service.inter.config.SystemConfigService; |
| | | import javax.annotation.Resource; |
| | | |
| | | @Service |
| | | public class SystemConfigServiceImpl implements SystemConfigService{ |
| | | public class SystemConfigServiceImpl implements SystemConfigService { |
| | | |
| | | @Resource |
| | | private SystemConfigMapper systemConfigMapper; |
| | | |
| | | @Resource |
| | | private SystemConfigMapper systemConfigMapper; |
| | | |
| | | @Cacheable(value={"childSystemCache"}, key="#p0") |
| | | public String get(String sigkey) throws NotExistObjectException { |
| | | SystemConfig systemConfig = systemConfigMapper.getByKey(sigkey); |
| | | if(systemConfig == null ){ |
| | | throw new NotExistObjectException("不存在该参数"); |
| | | } |
| | | return systemConfig.getValue(); |
| | | } |
| | | |
| | | |
| | | @Cacheable(value={"childSystemCache"}, key="#p0+#system.id") |
| | | public String get(String key, BusinessSystem system) { |
| | | if(system==null || system.getId()==0){ |
| | | return ""; |
| | | } |
| | | SystemConfig systemConfig = systemConfigMapper.getByKeyAndSystemId(key, system.getId()); |
| | | if(systemConfig != null){; |
| | | return systemConfig.getValue(); |
| | | } |
| | | return ""; |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public void save(SystemConfig systemConfig) throws ParamsException { |
| | | |
| | | if (systemConfig == null || systemConfig.getSystem() == null || systemConfig.getKey() == null) { |
| | | throw new ParamsException(1, "参数不完整"); |
| | | } |
| | | |
| | | |
| | | SystemConfig old = getConfig(SystemConfigKeyEnum.valueOf(systemConfig.getKey()), systemConfig.getSystem()); |
| | | if (old != null) { |
| | | SystemConfig update = new SystemConfig(); |
| | | update.setId(old.getId()); |
| | | update.setValue(systemConfig.getValue()); |
| | | update.setUpdatetime(System.currentTimeMillis()); |
| | | systemConfigMapper.updateByPrimaryKeySelective(update); |
| | | } else { |
| | | if (systemConfig.getUpdatetime() == null) { |
| | | systemConfig.setUpdatetime(System.currentTimeMillis()); |
| | | } |
| | | systemConfigMapper.insertSelective(systemConfig); |
| | | } |
| | | } |
| | | |
| | | |
| | | @Override |
| | | public SystemConfig getConfig(SystemConfigKeyEnum key, SystemEnum system) { |
| | | return systemConfigMapper.selectByKeyAndSystem(key.name(), system); |
| | | } |
| | | |
| | | |
| | | @Cacheable(value = "systemConfig", key = "'getConfig-'+#key+'-'+#system") |
| | | @Override |
| | | public SystemConfig getConfigCache(SystemConfigKeyEnum key, SystemEnum system) { |
| | | return getConfig(key, system); |
| | | } |
| | | |
| | | @Cacheable(value = "systemConfig", key = "'getValue-'+#key+'-'+#system") |
| | | @Override |
| | | public String getValueCache(SystemConfigKeyEnum key, SystemEnum system) { |
| | | SystemConfig config = getConfig(key, system); |
| | | if (config == null) { |
| | | return null; |
| | | } |
| | | return config.getValue(); |
| | | } |
| | | } |