群邀请设置

pull/3727/head
hawklin2017 3 weeks ago
parent 6c1fe8fcca
commit f268d91db6

@ -170,6 +170,7 @@ func newGinRouter(ctx context.Context, client discovery.SvcDiscoveryRegistry, co
userRouterGroup.POST("/set_phone_visibility", u.SetPhoneVisibility)
userRouterGroup.POST("/set_call_accept_setting", u.SetCallAcceptSetting)
userRouterGroup.POST("/set_msg_receive_setting", u.SetMsgReceiveSetting)
userRouterGroup.POST("/set_group_invite_setting", u.SetGroupInviteSetting)
// 根据手机号精确查找用户phoneSearchVisibility=true 时遵守 phone_visibility 设置)
userRouterGroup.POST("/get_user_by_phone", u.GetUserByPhone)
// 根据昵称精确查询用户(可多结果,与 getPaginationUsers 模糊搜索不同)

@ -351,6 +351,10 @@ func (u *UserApi) SetMsgReceiveSetting(c *gin.Context) {
a2r.Call(c, user.UserClient.SetMsgReceiveSetting, u.Client)
}
func (u *UserApi) SetGroupInviteSetting(c *gin.Context) {
a2r.Call(c, user.UserClient.SetGroupInviteSetting, u.Client)
}
func (u *UserApi) GetUserByPhone(c *gin.Context) {
a2r.Call(c, user.UserClient.GetUserByPhone, u.Client)
}

@ -67,6 +67,7 @@ type groupServer struct {
msgClient *rpcli.MsgClient
conversationClient *rpcli.ConversationClient
cryptoClient *rpcli.CryptoClient
relationClient *rpcli.RelationClient
}
type Config struct {
@ -122,6 +123,10 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg
if err != nil {
return err
}
friendConn, err := client.GetConn(ctx, config.Share.RpcRegisterName.Friend)
if err != nil {
return err
}
//cryptoConn, err := client.GetConn(ctx, config.Share.RpcRegisterName.Crypto)
//if err != nil {
// return err
@ -132,6 +137,7 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg
userClient: rpcli.NewUserClient(userConn),
msgClient: rpcli.NewMsgClient(msgConn),
conversationClient: rpcli.NewConversationClient(conversationConn),
relationClient: rpcli.NewRelationClient(friendConn),
//cryptoClient: rpcli.NewCryptoClient(cryptoConn),
}
gs.db = controller.NewGroupDatabase(rdb, &config.LocalCacheConfig, groupDB, groupMemberDB, groupRequestDB, groupPinnedMsgDB, mgocli.GetTx(), grouphash.NewGroupHashFromGroupServer(&gs))
@ -457,6 +463,31 @@ func (s *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite
return nil, errs.ErrRecordNotFound.WrapMsg("user not found")
}
// 检查受邀用户的群邀请权限设置(管理员操作跳过)
if !authverify.IsAppManagerUid(ctx, s.config.Share.IMAdminUserID) {
inviterID := mcontext.GetOpUserID(ctx)
for _, userID := range req.InvitedUserIDs {
info, ok := userMap[userID]
if !ok {
continue
}
switch info.GroupInviteSetting {
case 2: // GroupInviteSettingNobody所有人不可邀请
return nil, errs.ErrNoPermission.WrapMsg("user has disabled group invitations", "userID", userID)
case 1: // GroupInviteSettingFriends仅好友可邀请
isFriend, err := s.relationClient.IsFriend(ctx, inviterID, userID)
if err != nil {
log.ZError(ctx, "InviteUserToGroup: IsFriend check failed", err,
"inviterID", inviterID, "invitedUserID", userID)
return nil, err
}
if !isFriend {
return nil, errs.ErrNoPermission.WrapMsg("user only allows friends to invite them to groups", "userID", userID)
}
}
}
}
var groupMember *model.GroupMember
var opUserID string
if !authverify.IsAppManagerUid(ctx, s.config.Share.IMAdminUserID) {

@ -393,6 +393,37 @@ func (s *userServer) SetMsgReceiveSetting(ctx context.Context, req *pbuser.SetMs
return &pbuser.SetMsgReceiveSettingResp{}, nil
}
// SetGroupInviteSetting 设置群邀请权限0=所有人可邀请1=仅好友可邀请2=所有人不可邀请)。
// 只允许本人或管理员操作。
func (s *userServer) SetGroupInviteSetting(ctx context.Context, req *pbuser.SetGroupInviteSettingReq) (*pbuser.SetGroupInviteSettingResp, error) {
if req.UserID == "" {
return nil, errs.ErrArgs.WrapMsg("userID is required")
}
if req.GroupInviteSetting < 0 || req.GroupInviteSetting > 2 {
return nil, errs.ErrArgs.WrapMsg("groupInviteSetting must be 0, 1 or 2")
}
if err := authverify.CheckAccessV3(ctx, req.UserID, s.config.Share.IMAdminUserID); err != nil {
log.ZWarn(ctx, "SetGroupInviteSetting: access denied", err,
"opUserID", mcontext.GetOpUserID(ctx), "targetUserID", req.UserID)
return nil, err
}
if _, err := s.db.FindWithError(ctx, []string{req.UserID}); err != nil {
log.ZError(ctx, "SetGroupInviteSetting: user not found or db error", err,
"opUserID", mcontext.GetOpUserID(ctx), "targetUserID", req.UserID)
return nil, err
}
if err := s.db.UpdateByMap(ctx, req.UserID, map[string]any{
"group_invite_setting": req.GroupInviteSetting,
}); err != nil {
log.ZError(ctx, "SetGroupInviteSetting: UpdateByMap failed", err,
"opUserID", mcontext.GetOpUserID(ctx), "targetUserID", req.UserID,
"groupInviteSetting", req.GroupInviteSetting)
return nil, err
}
s.friendNotificationSender.UserInfoUpdatedNotification(ctx, req.UserID)
return &pbuser.SetGroupInviteSettingResp{}, nil
}
// GetUserByPhone 根据精确手机号查询用户。
//
// phone_visibility 仅控制用户资料中手机号字段是否展示,不影响搜索本身:

@ -48,9 +48,10 @@ func UserDB2Pb(user *relationtb.User) *sdkws.UserInfo {
Phone: user.Phone,
AreaCode: user.AreaCode,
PhoneVisibility: user.PhoneVisibility,
CallAcceptSetting: user.CallAcceptSetting,
MsgReceiveSetting: user.MsgReceiveSetting,
CallRingtoneURL: user.CallRingtoneURL,
CallAcceptSetting: user.CallAcceptSetting,
MsgReceiveSetting: user.MsgReceiveSetting,
GroupInviteSetting: user.GroupInviteSetting,
CallRingtoneURL: user.CallRingtoneURL,
}
}
@ -156,6 +157,9 @@ func UserPb2DBMapEx(user *sdkws.UserInfoWithEx) map[string]any {
if user.MsgReceiveSetting != nil {
val["msg_receive_setting"] = user.MsgReceiveSetting.Value
}
if user.GroupInviteSetting != nil {
val["group_invite_setting"] = user.GroupInviteSetting.Value
}
if user.CallRingtoneURL != nil {
val["call_ringtone_url"] = user.CallRingtoneURL.Value
}

@ -42,6 +42,14 @@ const (
MsgReceiveSettingNobody int32 = 2
)
// GroupInviteSetting 群邀请权限枚举。
// 0=所有人可邀请, 1=仅好友可邀请, 2=所有人不可邀请
const (
GroupInviteSettingPublic int32 = 0
GroupInviteSettingFriends int32 = 1
GroupInviteSettingNobody int32 = 2
)
// UserStatus 用户账号状态枚举。
// 0=正常1=冻结可登录不能收发消息2=黑名单(不可登录,自动踢下线,不能收发消息)
const (
@ -66,6 +74,7 @@ type User struct {
PhoneVisibility int32 `bson:"phone_visibility"`
CallAcceptSetting int32 `bson:"call_accept_setting"`
MsgReceiveSetting int32 `bson:"msg_receive_setting"`
GroupInviteSetting int32 `bson:"group_invite_setting"`
// CallRingtoneURL 用户自定义来电铃声 URL对方来电时播放此铃声
CallRingtoneURL string `bson:"call_ringtone_url"`
// Status 账号状态0=正常1=冻结2=黑名单

@ -1 +1 @@
Subproject commit 3b211f91d0e6b98797f91ba34fa64a7b47df5645
Subproject commit de7a73dfcf97ac618dacdad970da0f3cbd7f0ac8
Loading…
Cancel
Save