From 6a813c0e4181b158e092fc2072ba1fdcb7ada24e Mon Sep 17 00:00:00 2001
From: 疯狂的狮子Li <15040126243@163.com>
Date: 星期四, 09 三月 2023 21:57:17 +0800
Subject: [PATCH] !304 fix 修复多租户下注册用户BUG Merge pull request !304 from Yjoioooo/5.X

---
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysConfigService.java         |    7 +++++++
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/SysRegisterController.java                    |    2 +-
 ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java |   17 +++++++++++++++++
 3 files changed, 25 insertions(+), 1 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/SysRegisterController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/SysRegisterController.java
index 21abf93..0c3ef3b 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/SysRegisterController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/SysRegisterController.java
@@ -31,7 +31,7 @@
     @SaIgnore
     @PostMapping("/register")
     public R<Void> register(@Validated @RequestBody RegisterBody user) {
-        if (!("true".equals(configService.selectConfigByKey("sys.account.registerUser")))) {
+        if (!configService.selectRegisterEnabled(user.getTenantId())) {
             return R.fail("褰撳墠绯荤粺娌℃湁寮�鍚敞鍐屽姛鑳斤紒");
         }
         registerService.register(user);
diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysConfigService.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysConfigService.java
index 46dcbc4..5e89d15 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysConfigService.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/ISysConfigService.java
@@ -34,6 +34,13 @@
     String selectConfigByKey(String configKey);
 
     /**
+     * 鑾峰彇娉ㄥ唽寮�鍏�
+     * @param tenantId 绉熸埛id
+     * @return true寮�鍚紝false鍏抽棴
+     */
+    boolean selectRegisterEnabled(String tenantId);
+
+    /**
      * 鑾峰彇楠岃瘉鐮佸紑鍏�
      *
      * @return true寮�鍚紝false鍏抽棴
diff --git a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java
index 0ae33b3..80a68a2 100644
--- a/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java
+++ b/ruoyi-modules/ruoyi-system/src/main/java/com/ruoyi/system/service/impl/SysConfigServiceImpl.java
@@ -16,6 +16,7 @@
 import com.ruoyi.common.mybatis.core.page.PageQuery;
 import com.ruoyi.common.mybatis.core.page.TableDataInfo;
 import com.ruoyi.common.redis.utils.CacheUtils;
+import com.ruoyi.common.tenant.helper.TenantHelper;
 import com.ruoyi.system.domain.SysConfig;
 import com.ruoyi.system.domain.bo.SysConfigBo;
 import com.ruoyi.system.domain.vo.SysConfigVo;
@@ -78,6 +79,22 @@
     }
 
     /**
+     * 鑾峰彇娉ㄥ唽寮�鍏�
+     * @param tenantId 绉熸埛id
+     * @return true寮�鍚紝false鍏抽棴
+     */
+    @Override
+    public boolean selectRegisterEnabled(String tenantId) {
+        SysConfig retConfig = baseMapper.selectOne(new LambdaQueryWrapper<SysConfig>()
+            .eq(SysConfig::getConfigKey, "sys.account.registerUser")
+            .eq(TenantHelper.isEnable(),SysConfig::getTenantId, tenantId));
+        if (ObjectUtil.isNull(retConfig)) {
+            return false;
+        }
+        return Convert.toBool(retConfig.getConfigValue());
+    }
+
+    /**
      * 鑾峰彇楠岃瘉鐮佸紑鍏�
      *
      * @return true寮�鍚紝false鍏抽棴

--
Gitblit v1.9.3