|
@@ -1,18 +1,15 @@
|
|
|
package com.vber.common.tenant.helper;
|
|
package com.vber.common.tenant.helper;
|
|
|
|
|
|
|
|
-import cn.dev33.satoken.context.SaHolder;
|
|
|
|
|
import cn.dev33.satoken.stp.StpUtil;
|
|
import cn.dev33.satoken.stp.StpUtil;
|
|
|
import cn.hutool.core.convert.Convert;
|
|
import cn.hutool.core.convert.Convert;
|
|
|
import com.alibaba.ttl.TransmittableThreadLocal;
|
|
import com.alibaba.ttl.TransmittableThreadLocal;
|
|
|
import com.baomidou.mybatisplus.core.plugins.IgnoreStrategy;
|
|
import com.baomidou.mybatisplus.core.plugins.IgnoreStrategy;
|
|
|
import com.baomidou.mybatisplus.core.plugins.InterceptorIgnoreHelper;
|
|
import com.baomidou.mybatisplus.core.plugins.InterceptorIgnoreHelper;
|
|
|
import com.vber.common.core.constant.GlobalConstants;
|
|
import com.vber.common.core.constant.GlobalConstants;
|
|
|
-import com.vber.common.core.utils.ServletUtils;
|
|
|
|
|
import com.vber.common.core.utils.SpringUtils;
|
|
import com.vber.common.core.utils.SpringUtils;
|
|
|
import com.vber.common.core.utils.StringUtils;
|
|
import com.vber.common.core.utils.StringUtils;
|
|
|
import com.vber.common.redis.utils.RedisUtils;
|
|
import com.vber.common.redis.utils.RedisUtils;
|
|
|
import com.vber.common.satoken.utils.LoginHelper;
|
|
import com.vber.common.satoken.utils.LoginHelper;
|
|
|
-import jakarta.servlet.http.HttpServletRequest;
|
|
|
|
|
import lombok.AccessLevel;
|
|
import lombok.AccessLevel;
|
|
|
import lombok.NoArgsConstructor;
|
|
import lombok.NoArgsConstructor;
|
|
|
import lombok.extern.slf4j.Slf4j;
|
|
import lombok.extern.slf4j.Slf4j;
|
|
@@ -90,35 +87,43 @@ public class TenantHelper {
|
|
|
if (!isEnable()) {
|
|
if (!isEnable()) {
|
|
|
return null;
|
|
return null;
|
|
|
}
|
|
}
|
|
|
- if (notLogin()) {
|
|
|
|
|
|
|
+ if (isNotLogin()) {
|
|
|
return TEMP_DYNAMIC_TENANT.get();
|
|
return TEMP_DYNAMIC_TENANT.get();
|
|
|
}
|
|
}
|
|
|
- String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
|
|
|
- String tenantId = (String) SaHolder.getStorage().get(cacheKey);
|
|
|
|
|
|
|
+ // 如果线程内有值 优先返回
|
|
|
|
|
+ String tenantId = TEMP_DYNAMIC_TENANT.get();
|
|
|
if (StringUtils.isNotBlank(tenantId)) {
|
|
if (StringUtils.isNotBlank(tenantId)) {
|
|
|
return tenantId;
|
|
return tenantId;
|
|
|
}
|
|
}
|
|
|
|
|
+ String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
|
tenantId = RedisUtils.getCacheObject(cacheKey);
|
|
tenantId = RedisUtils.getCacheObject(cacheKey);
|
|
|
- SaHolder.getStorage().set(cacheKey, tenantId);
|
|
|
|
|
return tenantId;
|
|
return tenantId;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
|
- * 设置动态租户(一直有效 需要手动清理)
|
|
|
|
|
|
|
+ * 设置动态租户
|
|
|
* <p>
|
|
* <p>
|
|
|
* 如果为未登录状态下 那么只在当前线程内生效
|
|
* 如果为未登录状态下 那么只在当前线程内生效
|
|
|
*/
|
|
*/
|
|
|
public static void setDynamic(String tenantId) {
|
|
public static void setDynamic(String tenantId) {
|
|
|
|
|
+ setDynamic(tenantId, false);
|
|
|
|
|
+ }
|
|
|
|
|
+
|
|
|
|
|
+ /**
|
|
|
|
|
+ * 设置动态租户
|
|
|
|
|
+ * <p>
|
|
|
|
|
+ * 如果为未登录状态下 那么只在当前线程内生效
|
|
|
|
|
+ */
|
|
|
|
|
+ public static void setDynamic(String tenantId, boolean isGlobal) {
|
|
|
if (!isEnable()) {
|
|
if (!isEnable()) {
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
- if (notLogin()) {
|
|
|
|
|
|
|
+ if (isNotLogin() || !isGlobal) {
|
|
|
TEMP_DYNAMIC_TENANT.set(tenantId);
|
|
TEMP_DYNAMIC_TENANT.set(tenantId);
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
|
RedisUtils.setCacheObject(cacheKey, tenantId);
|
|
RedisUtils.setCacheObject(cacheKey, tenantId);
|
|
|
- SaHolder.getStorage().set(cacheKey, tenantId);
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -128,13 +133,12 @@ public class TenantHelper {
|
|
|
if (!isEnable()) {
|
|
if (!isEnable()) {
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
- if (notLogin()) {
|
|
|
|
|
|
|
+ if (isNotLogin()) {
|
|
|
TEMP_DYNAMIC_TENANT.remove();
|
|
TEMP_DYNAMIC_TENANT.remove();
|
|
|
return;
|
|
return;
|
|
|
}
|
|
}
|
|
|
String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
String cacheKey = DYNAMIC_TENANT_KEY + ":" + LoginHelper.getUserId();
|
|
|
RedisUtils.deleteObject(cacheKey);
|
|
RedisUtils.deleteObject(cacheKey);
|
|
|
- SaHolder.getStorage().delete(cacheKey);
|
|
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
/**
|
|
@@ -173,12 +177,8 @@ public class TenantHelper {
|
|
|
return null;
|
|
return null;
|
|
|
}
|
|
}
|
|
|
String tenantId = "";
|
|
String tenantId = "";
|
|
|
- // 请求头获取的租户id优先级最高
|
|
|
|
|
- HttpServletRequest request = ServletUtils.getRequest();
|
|
|
|
|
- if (request != null) {
|
|
|
|
|
- tenantId = request.getHeader(GlobalConstants.TENANT_ID_HEADER);
|
|
|
|
|
- }
|
|
|
|
|
- // 其次动态租户优先
|
|
|
|
|
|
|
+
|
|
|
|
|
+ // 动态租户优先
|
|
|
if (StringUtils.isBlank(tenantId)) {
|
|
if (StringUtils.isBlank(tenantId)) {
|
|
|
tenantId = TenantHelper.getDynamic();
|
|
tenantId = TenantHelper.getDynamic();
|
|
|
}
|
|
}
|
|
@@ -188,7 +188,8 @@ public class TenantHelper {
|
|
|
return tenantId;
|
|
return tenantId;
|
|
|
}
|
|
}
|
|
|
|
|
|
|
|
- private static boolean notLogin() {
|
|
|
|
|
|
|
+
|
|
|
|
|
+ private static boolean isNotLogin() {
|
|
|
try {
|
|
try {
|
|
|
StpUtil.checkLogin();
|
|
StpUtil.checkLogin();
|
|
|
return false;
|
|
return false;
|