From 80b6cbfc9c861469146318d0b3dd5f8b8b525b8a Mon Sep 17 00:00:00 2001
From: xiejun <xiejun@vci-tech.com>
Date: 星期五, 01 十一月 2024 15:11:19 +0800
Subject: [PATCH] Revert "集成获取mdm分发通用数据格式接口集成"

---
 Source/BladeX-Tool/blade-starter-redis/src/main/java/org/springblade/core/redis/lock/BladeLockAutoConfiguration.java |  152 ++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 152 insertions(+), 0 deletions(-)

diff --git a/Source/BladeX-Tool/blade-starter-redis/src/main/java/org/springblade/core/redis/lock/BladeLockAutoConfiguration.java b/Source/BladeX-Tool/blade-starter-redis/src/main/java/org/springblade/core/redis/lock/BladeLockAutoConfiguration.java
new file mode 100644
index 0000000..848e827
--- /dev/null
+++ b/Source/BladeX-Tool/blade-starter-redis/src/main/java/org/springblade/core/redis/lock/BladeLockAutoConfiguration.java
@@ -0,0 +1,152 @@
+/*
+ *      Copyright (c) 2018-2028, DreamLu All rights reserved.
+ *
+ *  Redistribution and use in source and binary forms, with or without
+ *  modification, are permitted provided that the following conditions are met:
+ *
+ *  Redistributions of source code must retain the above copyright notice,
+ *  this list of conditions and the following disclaimer.
+ *  Redistributions in binary form must reproduce the above copyright
+ *  notice, this list of conditions and the following disclaimer in the
+ *  documentation and/or other materials provided with the distribution.
+ *  Neither the name of the dreamlu.net developer nor the names of its
+ *  contributors may be used to endorse or promote products derived from
+ *  this software without specific prior written permission.
+ *  Author: DreamLu 鍗㈡槬姊� (596392912@qq.com)
+ */
+
+package org.springblade.core.redis.lock;
+
+import org.redisson.Redisson;
+import org.redisson.api.RedissonClient;
+import org.redisson.config.*;
+import org.springblade.core.tool.utils.StringUtil;
+import org.springframework.boot.autoconfigure.AutoConfiguration;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
+import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
+import org.springframework.boot.context.properties.EnableConfigurationProperties;
+import org.springframework.context.annotation.Bean;
+
+/**
+ * 鍒嗗竷寮忛攣鑷姩鍖栭厤缃�
+ *
+ * @author L.cm
+ */
+@AutoConfiguration
+@ConditionalOnClass(RedissonClient.class)
+@EnableConfigurationProperties(BladeLockProperties.class)
+@ConditionalOnProperty(value = "blade.lock.enabled", havingValue = "true")
+public class BladeLockAutoConfiguration {
+
+	private static Config singleConfig(BladeLockProperties properties) {
+		Config config = new Config();
+		SingleServerConfig serversConfig = config.useSingleServer();
+		serversConfig.setAddress(properties.getAddress());
+		String password = properties.getPassword();
+		if (StringUtil.isNotBlank(password)) {
+			serversConfig.setPassword(password);
+		}
+		serversConfig.setDatabase(properties.getDatabase());
+		serversConfig.setConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setIdleConnectionTimeout(properties.getConnectionTimeout());
+		serversConfig.setConnectTimeout(properties.getConnectionTimeout());
+		serversConfig.setTimeout(properties.getTimeout());
+		return config;
+	}
+
+	private static Config masterSlaveConfig(BladeLockProperties properties) {
+		Config config = new Config();
+		MasterSlaveServersConfig serversConfig = config.useMasterSlaveServers();
+		serversConfig.setMasterAddress(properties.getMasterAddress());
+		serversConfig.addSlaveAddress(properties.getSlaveAddress());
+		String password = properties.getPassword();
+		if (StringUtil.isNotBlank(password)) {
+			serversConfig.setPassword(password);
+		}
+		serversConfig.setDatabase(properties.getDatabase());
+		serversConfig.setMasterConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setMasterConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setSlaveConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setSlaveConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setIdleConnectionTimeout(properties.getConnectionTimeout());
+		serversConfig.setConnectTimeout(properties.getConnectionTimeout());
+		serversConfig.setTimeout(properties.getTimeout());
+		return config;
+	}
+
+	private static Config sentinelConfig(BladeLockProperties properties) {
+		Config config = new Config();
+		SentinelServersConfig serversConfig = config.useSentinelServers();
+		serversConfig.setMasterName(properties.getMasterName());
+		serversConfig.addSentinelAddress(properties.getSentinelAddress());
+		String password = properties.getPassword();
+		if (StringUtil.isNotBlank(password)) {
+			serversConfig.setPassword(password);
+		}
+		serversConfig.setDatabase(properties.getDatabase());
+		serversConfig.setMasterConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setMasterConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setSlaveConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setSlaveConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setIdleConnectionTimeout(properties.getConnectionTimeout());
+		serversConfig.setConnectTimeout(properties.getConnectionTimeout());
+		serversConfig.setTimeout(properties.getTimeout());
+		return config;
+	}
+
+	private static Config clusterConfig(BladeLockProperties properties) {
+		Config config = new Config();
+		ClusterServersConfig serversConfig = config.useClusterServers();
+		serversConfig.addNodeAddress(properties.getNodeAddress());
+		String password = properties.getPassword();
+		if (StringUtil.isNotBlank(password)) {
+			serversConfig.setPassword(password);
+		}
+		serversConfig.setMasterConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setMasterConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setSlaveConnectionPoolSize(properties.getPoolSize());
+		serversConfig.setSlaveConnectionMinimumIdleSize(properties.getIdleSize());
+		serversConfig.setIdleConnectionTimeout(properties.getConnectionTimeout());
+		serversConfig.setConnectTimeout(properties.getConnectionTimeout());
+		serversConfig.setTimeout(properties.getTimeout());
+		return config;
+	}
+
+	@Bean
+	@ConditionalOnMissingBean
+	public RedisLockClient redisLockClient(BladeLockProperties properties) {
+		return new RedisLockClientImpl(redissonClient(properties));
+	}
+
+	@Bean
+	@ConditionalOnMissingBean
+	public RedisLockAspect redisLockAspect(RedisLockClient redisLockClient) {
+		return new RedisLockAspect(redisLockClient);
+	}
+
+	private static RedissonClient redissonClient(BladeLockProperties properties) {
+		BladeLockProperties.Mode mode = properties.getMode();
+		Config config;
+		switch (mode) {
+			case sentinel:
+				config = sentinelConfig(properties);
+				break;
+			case cluster:
+				config = clusterConfig(properties);
+				break;
+			case master:
+				config = masterSlaveConfig(properties);
+				break;
+			case single:
+				config = singleConfig(properties);
+				break;
+			default:
+				config = new Config();
+				break;
+		}
+		return Redisson.create(config);
+	}
+
+}

--
Gitblit v1.9.3