From 705f8c7c71890a1cef93b26d800d840622e99de3 Mon Sep 17 00:00:00 2001 From: zhangshuai Date: Fri, 18 Oct 2024 17:54:28 +0800 Subject: [PATCH] =?UTF-8?q?fix:ASW-107=20=E4=BF=AE=E5=A4=8D=20member=20?= =?UTF-8?q?=E4=BF=AE=E6=94=B9=E6=97=B6=20member=20=E8=A2=AB=E6=B8=85?= =?UTF-8?q?=E7=A9=BA?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../impl/WorkspaceMemberServiceImpl.java | 20 ++++++++++++++++--- 1 file changed, 17 insertions(+), 3 deletions(-) diff --git a/src/main/java/net/geedge/asw/module/workspace/service/impl/WorkspaceMemberServiceImpl.java b/src/main/java/net/geedge/asw/module/workspace/service/impl/WorkspaceMemberServiceImpl.java index 161d904..f80a5e3 100644 --- a/src/main/java/net/geedge/asw/module/workspace/service/impl/WorkspaceMemberServiceImpl.java +++ b/src/main/java/net/geedge/asw/module/workspace/service/impl/WorkspaceMemberServiceImpl.java @@ -2,6 +2,7 @@ package net.geedge.asw.module.workspace.service.impl; import cn.dev33.satoken.stp.StpUtil; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import net.geedge.asw.common.util.ASWException; import net.geedge.asw.common.util.RCode; @@ -50,9 +51,22 @@ public class WorkspaceMemberServiceImpl extends ServiceImpl updateMember(String workspaceId, List memberList) { - validateInfo(workspaceId, memberList); - workspaceMemberService.remove(new LambdaQueryWrapper().eq(WorkspaceMemberEntity::getWorkspaceId, workspaceId)); - workspaceMemberService.saveBatch(memberList); + List list = this.list(new LambdaQueryWrapper().eq(WorkspaceMemberEntity::getWorkspaceId, workspaceId)); + List userIds = list.stream().map(x -> x.getUserId()).toList(); + for (WorkspaceMemberEntity member : memberList) { + String userId = member.getUserId(); + if (!userIds.contains(userId)) { + this.update(new LambdaUpdateWrapper() + .eq(WorkspaceMemberEntity::getUserId, userId) + .eq(WorkspaceMemberEntity::getWorkspaceId, workspaceId) + .set(WorkspaceMemberEntity::getRoleId, member.getRoleId())); + }else { + member.setWorkspaceId(workspaceId); + member.setCreateTimestamp(System.currentTimeMillis()); + member.setCreateUserId(StpUtil.getLoginIdAsString()); + this.save(member); + } + } Map params = T.MapUtil.builder("workspaceId", workspaceId).build(); List memberEntityList = workspaceMemberService.queryList(params); return memberEntityList;