mirror of
https://github.com/openimsdk/open-im-server.git
synced 2026-04-30 19:14:07 +08:00
- Improve notification sender with bulk operations and fallback logic - Enhance group cache with new methods for member counts and version handling - Refactor group controller with better cache integration - Add more robust error handling and logging fix(group): optimize group cache implementation This commit refactors the GroupCacheRedis implementation to improve code organization and maintainability. The changes include: - Added proper import organization and removed unused imports - Implemented batchGetCache2 function calls for efficient data retrieval - Added comprehensive cache key management functions - Improved version tracking for group members and requests - Enhanced error handling and logging - Added batch operations for better performance - Refactored complex functions into smaller, more manageable pieces The changes focus on improving the overall structure and performance of the group cache system while maintaining backward compatibility. refactor(group): improve notification error handling and add admin context - Convert notification methods to return errors for better error propagation - Add admin context checking for bulk notifications - Enhance group info retrieval with proper error handling - Improve notification sender with fallback user information fix(group): handle nil group member map in notification Add nil check for groupMemberMap[groupInfo.GroupID] before accessing to prevent nil pointer panic. Skip iteration if map is nil. refactor(group): update group notification methods to use UserInfo struct Renamed function parameter from groupMemberUserID string to changedUserInfo *sdkws.UserInfo Updated function logic to use changedUserInfo.UserID instead of separate parameter Refactored notification methods to use consistent UserInfo struct pattern Added proper error handling for opUser retrieval Updated function signatures and internal logic for GroupMemberInfoSetNotificationBulk fix: batchGetGroupRoleLevelMemberIDs with BatchCache fix: GetGroupMemberNums BatchCache perf(group): optimize notification logic for group member operations # Conflicts: # internal/rpc/group/group.go # pkg/common/storage/cache/redis/group.go
72 lines
3.5 KiB
Go
72 lines
3.5 KiB
Go
// Copyright © 2023 OpenIM. All rights reserved.
|
|
//
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
// you may not use this file except in compliance with the License.
|
|
// You may obtain a copy of the License at
|
|
//
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
//
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
// See the License for the specific language governing permissions and
|
|
// limitations under the License.
|
|
|
|
package cache
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/common"
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model"
|
|
)
|
|
|
|
type GroupHash interface {
|
|
GetGroupHash(ctx context.Context, groupID string) (uint64, error)
|
|
}
|
|
|
|
type GroupCache interface {
|
|
BatchDeleter
|
|
CloneGroupCache() GroupCache
|
|
GetGroupsInfo(ctx context.Context, groupIDs []string) (groups []*model.Group, err error)
|
|
GetGroupInfo(ctx context.Context, groupID string) (group *model.Group, err error)
|
|
DelGroupsInfo(groupIDs ...string) GroupCache
|
|
|
|
GetGroupMembersHash(ctx context.Context, groupID string) (hashCode uint64, err error)
|
|
GetGroupMemberHashMap(ctx context.Context, groupIDs []string) (map[string]*common.GroupSimpleUserID, error)
|
|
DelGroupMembersHash(groupID string) GroupCache
|
|
|
|
GetGroupMemberIDs(ctx context.Context, groupID string) (groupMemberIDs []string, err error)
|
|
|
|
DelGroupMemberIDs(groupID string) GroupCache
|
|
|
|
GetJoinedGroupIDs(ctx context.Context, userID string) (joinedGroupIDs []string, err error)
|
|
DelJoinedGroupID(userID ...string) GroupCache
|
|
|
|
GetGroupMemberInfo(ctx context.Context, groupID, userID string) (groupMember *model.GroupMember, err error)
|
|
GetGroupMembersInfo(ctx context.Context, groupID string, userID []string) (groupMembers []*model.GroupMember, err error)
|
|
GetAllGroupMembersInfo(ctx context.Context, groupID string) (groupMembers []*model.GroupMember, err error)
|
|
FindGroupMemberUser(ctx context.Context, groupIDs []string, userID string) ([]*model.GroupMember, error)
|
|
|
|
GetGroupRoleLevelMemberIDs(ctx context.Context, groupID string, roleLevel int32) ([]string, error)
|
|
GetGroupOwner(ctx context.Context, groupID string) (*model.GroupMember, error)
|
|
GetGroupsOwner(ctx context.Context, groupIDs []string) ([]*model.GroupMember, error)
|
|
DelGroupRoleLevel(groupID string, roleLevel []int32) GroupCache
|
|
DelGroupAllRoleLevel(groupID string) GroupCache
|
|
DelGroupMembersInfo(groupID string, userID ...string) GroupCache
|
|
GetGroupRoleLevelMemberInfo(ctx context.Context, groupID string, roleLevel int32) ([]*model.GroupMember, error)
|
|
GetGroupRolesLevelMemberInfo(ctx context.Context, groupID string, roleLevels []int32) ([]*model.GroupMember, error)
|
|
GetGroupMemberNum(ctx context.Context, groupID string) (memberNum int64, err error)
|
|
GetGroupMemberNums(ctx context.Context, groupIDs []string) (memberNumMap map[string]int64, err error)
|
|
DelGroupsMemberNum(groupID ...string) GroupCache
|
|
|
|
//FindSortGroupMemberUserIDs(ctx context.Context, groupID string) ([]string, error)
|
|
//FindSortJoinGroupIDs(ctx context.Context, userID string) ([]string, error)
|
|
|
|
DelMaxGroupMemberVersion(groupIDs ...string) GroupCache
|
|
DelMaxJoinGroupVersion(userIDs ...string) GroupCache
|
|
FindMaxGroupMemberVersion(ctx context.Context, groupID string) (*model.VersionLog, error)
|
|
BatchFindMaxGroupMemberVersion(ctx context.Context, groupIDs []string) ([]*model.VersionLog, error)
|
|
FindMaxJoinGroupVersion(ctx context.Context, userID string) (*model.VersionLog, error)
|
|
}
|