From ff859437dd9d18d9d7411bafc4c31038f940b9f2 Mon Sep 17 00:00:00 2001
From: zhibing.pu <393733352@qq.com>
Date: 星期五, 09 八月 2024 18:53:56 +0800
Subject: [PATCH] 添加管理员和非管理员的站点权限功能

---
 ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/PartnerServiceImpl.java |   24 ++++++++++++++++++++----
 1 files changed, 20 insertions(+), 4 deletions(-)

diff --git a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/PartnerServiceImpl.java b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/PartnerServiceImpl.java
index e89e9e0..b3fceeb 100644
--- a/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/PartnerServiceImpl.java
+++ b/ruoyi-service/ruoyi-chargingPile/src/main/java/com/ruoyi/chargingPile/service/impl/PartnerServiceImpl.java
@@ -16,6 +16,8 @@
 import com.ruoyi.common.core.web.domain.AjaxResult;
 import com.ruoyi.common.core.web.page.PageInfo;
 import com.ruoyi.common.security.utils.SecurityUtils;
+import com.ruoyi.other.api.feignClient.RoleSiteClient;
+import com.ruoyi.other.api.feignClient.UserSiteClient;
 import com.ruoyi.system.api.domain.SysRole;
 import com.ruoyi.system.api.domain.SysUser;
 import com.ruoyi.system.api.feignClient.SysRoleClient;
@@ -54,6 +56,12 @@
 	
 	@Resource
 	private TChargingPileService chargingPileService;
+	
+	@Resource
+	private UserSiteClient userSiteClient;
+	
+	@Resource
+	private RoleSiteClient roleSiteClient;
 	
 	
 	
@@ -391,16 +399,24 @@
 	 * @return
 	 */
 	@Override
-	public List<Integer> authSite(Integer partnerId, SiteMenu siteMenu) {
+	public Set<Integer> authSite(Integer partnerId, SiteMenu siteMenu) {
 		TSiteMenu one = siteMenuService.getOne(new LambdaQueryWrapper<TSiteMenu>().eq(TSiteMenu::getPath, siteMenu.getValue()).eq(TSiteMenu::getStatus, 0));
 		List<TPartnerSite> list = partnerSiteService.list(new LambdaQueryWrapper<TPartnerSite>()
 				.eq(TPartnerSite::getPartnerId, partnerId)
 				.eq(TPartnerSite::getSiteMenuId, one.getMenuId()));
 		List<Integer> collect = list.stream().map(TPartnerSite::getSiteId).collect(Collectors.toList());
-		if(collect.size() == 0){
-			collect.add(-1);
+		//获取合作商用户关联的站点数据
+		Partner partner = this.getById(partnerId);
+		SysUser sysUser = sysUserClient.queryUserByUserName(partner.getAccount()).getData();
+		List<Integer> data = userSiteClient.getSiteIds(sysUser.getUserId()).getData();
+		List<Integer> data1 = roleSiteClient.getSiteIds(sysUser.getRoleId()).getData();
+		collect.addAll(data);
+		collect.addAll(data1);
+		Set<Integer> siteIds = new HashSet<>(collect);
+		if(siteIds.size() == 0){
+			siteIds.add(-1);
 		}
-		return collect;
+		return siteIds;
 	}
 	
 	

--
Gitblit v1.7.1