From 8b4ff0c55b0563b1ccb6111f1cc7a53321e72778 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=A5=9E=E5=A5=87bug=E5=9C=A8=E5=93=AA=E9=87=8C?= <35194310+WhereAreBugs@users.noreply.github.com> Date: Mon, 9 Feb 2026 19:12:21 +0800 Subject: [PATCH] bugfix(permission):fix no permission error when set group notification. (#3675) * bugfix(permission):fix no permission error when set group notification. * fix(send): add temporary admin context to solve permission problem. --- internal/rpc/group/group.go | 5 +++-- internal/rpc/msg/send.go | 3 ++- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/internal/rpc/group/group.go b/internal/rpc/group/group.go index 3ddd9cc22..778316e5c 100644 --- a/internal/rpc/group/group.go +++ b/internal/rpc/group/group.go @@ -1207,9 +1207,10 @@ func (s *groupServer) SetGroupInfoEx(ctx context.Context, req *pbgroup.SetGroupI log.ZWarn(ctx, "GetGroupMemberIDs is failed.", err) return nil, err } - + // use temp admin permission to force success. + adminCtx := mcontext.WithOpUserIDContext(ctx, s.config.Share.IMAdminUserID[0]) conversation.GroupAtType = &wrapperspb.Int32Value{Value: constant.GroupNotification} - if err := s.conversationClient.SetConversations(ctx, resp.UserIDs, conversation); err != nil { + if err := s.conversationClient.SetConversations(adminCtx, resp.UserIDs, conversation); err != nil { log.ZWarn(ctx, "SetConversations", err, "UserIDs", resp.UserIDs, "conversation", conversation) } diff --git a/internal/rpc/msg/send.go b/internal/rpc/msg/send.go index c93f18148..f9e7428dd 100644 --- a/internal/rpc/msg/send.go +++ b/internal/rpc/msg/send.go @@ -87,8 +87,9 @@ func (m *msgServer) setConversationAtInfo(nctx context.Context, msg *sdkws.MsgDa } }() + // template admin permission for next operation ctx := mcontext.NewCtx("@@@" + mcontext.GetOperationID(nctx)) - + ctx = mcontext.WithOpUserIDContext(ctx, m.config.Share.IMAdminUserID[0]) var atUserID []string conversation := &pbconversation.ConversationReq{