From f7543a1cc6c89ea03c0d6a0591526baf10d7934b Mon Sep 17 00:00:00 2001
From: vincentlu <t1341870251@gmail.com>
Date: 星期四, 05 二月 2026 16:37:23 +0800
Subject: [PATCH] #
---
zy-acs-manager/src/main/java/com/zy/acs/manager/system/service/impl/ConfigServiceImpl.java | 102 ++++++++++++++++++++++++++++++++++++++++-----------
1 files changed, 80 insertions(+), 22 deletions(-)
diff --git a/zy-acs-manager/src/main/java/com/zy/acs/manager/system/service/impl/ConfigServiceImpl.java b/zy-acs-manager/src/main/java/com/zy/acs/manager/system/service/impl/ConfigServiceImpl.java
index 2f65707..68de310 100644
--- a/zy-acs-manager/src/main/java/com/zy/acs/manager/system/service/impl/ConfigServiceImpl.java
+++ b/zy-acs-manager/src/main/java/com/zy/acs/manager/system/service/impl/ConfigServiceImpl.java
@@ -3,15 +3,21 @@
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import com.zy.acs.common.utils.GsonUtils;
+import com.zy.acs.framework.common.Cools;
import com.zy.acs.framework.common.DateUtils;
+import com.zy.acs.manager.manager.enums.StatusType;
import com.zy.acs.manager.system.entity.Config;
import com.zy.acs.manager.system.enums.ConfigType;
import com.zy.acs.manager.system.mapper.ConfigMapper;
import com.zy.acs.manager.system.service.ConfigService;
import org.springframework.stereotype.Service;
+import javax.annotation.PostConstruct;
+import java.math.BigDecimal;
import java.util.Date;
import java.util.List;
+import java.util.Map;
+import java.util.concurrent.ConcurrentHashMap;
/**
* Created by vincent on 8/30/2024
@@ -19,36 +25,75 @@
@Service("configService")
public class ConfigServiceImpl extends ServiceImpl<ConfigMapper, Config> implements ConfigService {
+ public static final Map<String, Config> CONFIG_CACHE = new ConcurrentHashMap<>();
+
+ @PostConstruct
+ public void init() {
+ CONFIG_CACHE.clear();
+
+ List<Config> list = this.list(new LambdaQueryWrapper<Config>().eq(Config::getStatus, StatusType.ENABLE.val));
+ for (Config config : list) {
+ if (null != config && !Cools.isEmpty(config.getFlag())) {
+ CONFIG_CACHE.put(config.getFlag(), config);
+ }
+ }
+ }
+
@Override
@SuppressWarnings("unchecked")
public <T> T getVal(String key, Class<T> clazz) {
- List<Config> list = this.list(new LambdaQueryWrapper<Config>().eq(Config::getFlag, key));
- Config config = list.stream().findFirst().orElse(null);
- if (null == config) {
+ if (Cools.isEmpty(key.trim(), clazz)) {
return null;
}
- String val = config.getVal();
- switch (ConfigType.query(config.getType())) {
- case BOOLEAN:
- if (val.equals("1") || val.trim().toUpperCase().equals("TRUE")) {
+
+ Config config = CONFIG_CACHE.get(key);
+ if (config == null) {
+ config = getOne(new LambdaQueryWrapper<Config>()
+ .eq(Config::getFlag, key)
+ .eq(Config::getStatus, StatusType.ENABLE.val), false);
+
+ if (null == config) {
+ return null;
+ }
+
+ if (!Cools.isEmpty(config.getFlag())) {
+ CONFIG_CACHE.put(config.getFlag(), config);
+ }
+ }
+
+ String raw = config.getVal();
+ String val = Cools.isEmpty(raw) ? "" : raw.trim();
+ ConfigType type = ConfigType.query(config.getType());
+ if (null == type) {
+ return null;
+ }
+ switch (type) {
+ case BOOLEAN: {
+ if ("1".equals(val) || "true".equalsIgnoreCase(val) || "yes".equalsIgnoreCase(val)) {
return (T) Boolean.TRUE;
}
return (T) Boolean.FALSE;
- case NUMBER:
- if (clazz == Integer.class) {
+ }
+ case NUMBER: {
+ if (clazz == Integer.class || clazz == int.class) {
return (T) Integer.valueOf(val);
- } else if (clazz == Short.class) {
+ } else if (clazz == Short.class || clazz == short.class) {
return (T) Short.valueOf(val);
- } else if (clazz == Long.class) {
+ } else if (clazz == Long.class || clazz == long.class) {
return (T) Long.valueOf(val);
- } else if (clazz == Double.class) {
+ } else if (clazz == Double.class || clazz == double.class) {
return (T) Double.valueOf(val);
+ } else if (clazz == Float.class || clazz == float.class) {
+ return (T) Float.valueOf(val);
+ } else if (clazz == BigDecimal.class) {
+ return (T) new BigDecimal(val);
}
- throw new UnsupportedOperationException("Unsupported type: " + clazz.getName());
+ throw new UnsupportedOperationException("Unsupported number type: " + clazz.getName());
+ }
case STRING:
- return (T) val;
+ return (T) raw;
case JSON:
- return GsonUtils.fromJson(val, clazz);
+ return GsonUtils.fromJson(raw, clazz);
case DATE:
return (T) DateUtils.convert(val);
default:
@@ -58,21 +103,35 @@
@Override
public <T> boolean setVal(String key, T val) {
- List<Config> list = this.list(new LambdaQueryWrapper<Config>().eq(Config::getFlag, key));
- Config config = list.stream().findFirst().orElse(null);
- if (config == null) {
+ if (key == null || key.trim().isEmpty()) {
return false;
}
+
+ Config config = CONFIG_CACHE.get(key);
+ if (config == null) {
+ config = getOne(new LambdaQueryWrapper<Config>()
+ .eq(Config::getFlag, key)
+ .eq(Config::getStatus, StatusType.ENABLE.val), false);
+ if (config == null) {
+ return false;
+ }
+ } else {
+ if (config.getStatus() == null || config.getStatus() != StatusType.ENABLE.val) {
+ return false;
+ }
+ }
+
ConfigType configType = ConfigType.query(config.getType());
switch (configType) {
case BOOLEAN:
if (!(val instanceof Boolean)) {
throw new IllegalArgumentException("Expected Boolean value for key: " + key);
}
- config.setVal((Boolean) val ? "TRUE" : "FALSE");
+ config.setVal(((Boolean) val) ? "TRUE" : "FALSE");
break;
case NUMBER:
- if (val instanceof Integer || val instanceof Short || val instanceof Long || val instanceof Double) {
+ if (val instanceof Integer || val instanceof Short || val instanceof Long
+ || val instanceof Double || val instanceof Float || val instanceof BigDecimal) {
config.setVal(String.valueOf(val));
} else {
throw new IllegalArgumentException("Expected a numeric value for key: " + key);
@@ -99,5 +158,4 @@
return this.updateById(config);
}
-
-}
+}
\ No newline at end of file
--
Gitblit v1.9.1