mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-10-26 13:12:12 +08:00
* fix: GetUserReqApplicationList error when there is a disbanded group chat
* fix: error when querying some information about disbanded group
* fix: GetUserReqApplicationList dismissed group error
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* fix: the original message referenced by the pull message processing is withdrawn
* merge
* cicd: robot automated Change
* sdkws.MsgData
* user
* interface{} -> any
* user
* third
* group
* group
* group
* group
* group
* group
* conversation
* standalone mysql db model
* tx
* s3
* group
* mongo
* group
* group
* group
* group
* group
* group
* refactor: add openim mysql to mongo refactor
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* refactor: add openim mysql to mongo refactor
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* remove mysql
* remove mysql
* friend
* friend
* friend
* friend
* friend
* friend
* group
* convert
* index
* index
* all
* all
* mysql2mongo
* data conversion
* up35
* up35
* feat: add format set
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* fix: fix scripts
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
* merge main
* merge main
* Update init-config.sh
* fix: user args check
---------
Signed-off-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
Co-authored-by: withchao <withchao@users.noreply.github.com>
Co-authored-by: Xinwei Xiong(cubxxw) <3293172751nss@gmail.com>
Co-authored-by: Xinwei Xiong <3293172751@qq.com>
89 lines
2.5 KiB
Go
89 lines
2.5 KiB
Go
package grouphash
|
|
|
|
import (
|
|
"context"
|
|
"crypto/md5"
|
|
"encoding/binary"
|
|
"encoding/json"
|
|
|
|
"github.com/OpenIMSDK/protocol/group"
|
|
"github.com/OpenIMSDK/protocol/sdkws"
|
|
"github.com/OpenIMSDK/tools/utils"
|
|
)
|
|
|
|
func NewGroupHashFromGroupClient(x group.GroupClient) *GroupHash {
|
|
return &GroupHash{
|
|
getGroupAllUserIDs: func(ctx context.Context, groupID string) ([]string, error) {
|
|
resp, err := x.GetGroupMemberUserIDs(ctx, &group.GetGroupMemberUserIDsReq{GroupID: groupID})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return resp.UserIDs, nil
|
|
},
|
|
getGroupMemberInfo: func(ctx context.Context, groupID string, userIDs []string) ([]*sdkws.GroupMemberFullInfo, error) {
|
|
resp, err := x.GetGroupMembersInfo(ctx, &group.GetGroupMembersInfoReq{GroupID: groupID, UserIDs: userIDs})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return resp.Members, nil
|
|
},
|
|
}
|
|
}
|
|
|
|
func NewGroupHashFromGroupServer(x group.GroupServer) *GroupHash {
|
|
return &GroupHash{
|
|
getGroupAllUserIDs: func(ctx context.Context, groupID string) ([]string, error) {
|
|
resp, err := x.GetGroupMemberUserIDs(ctx, &group.GetGroupMemberUserIDsReq{GroupID: groupID})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return resp.UserIDs, nil
|
|
},
|
|
getGroupMemberInfo: func(ctx context.Context, groupID string, userIDs []string) ([]*sdkws.GroupMemberFullInfo, error) {
|
|
resp, err := x.GetGroupMembersInfo(ctx, &group.GetGroupMembersInfoReq{GroupID: groupID, UserIDs: userIDs})
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
return resp.Members, nil
|
|
},
|
|
}
|
|
}
|
|
|
|
type GroupHash struct {
|
|
getGroupAllUserIDs func(ctx context.Context, groupID string) ([]string, error)
|
|
getGroupMemberInfo func(ctx context.Context, groupID string, userIDs []string) ([]*sdkws.GroupMemberFullInfo, error)
|
|
}
|
|
|
|
func (gh *GroupHash) GetGroupHash(ctx context.Context, groupID string) (uint64, error) {
|
|
userIDs, err := gh.getGroupAllUserIDs(ctx, groupID)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
var members []*sdkws.GroupMemberFullInfo
|
|
if len(userIDs) > 0 {
|
|
members, err = gh.getGroupMemberInfo(ctx, groupID, userIDs)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
utils.Sort(userIDs, true)
|
|
}
|
|
memberMap := utils.SliceToMap(members, func(e *sdkws.GroupMemberFullInfo) string {
|
|
return e.UserID
|
|
})
|
|
res := make([]*sdkws.GroupMemberFullInfo, 0, len(members))
|
|
for _, userID := range userIDs {
|
|
member, ok := memberMap[userID]
|
|
if !ok {
|
|
continue
|
|
}
|
|
member.AppMangerLevel = 0
|
|
res = append(res, member)
|
|
}
|
|
data, err := json.Marshal(res)
|
|
if err != nil {
|
|
return 0, err
|
|
}
|
|
sum := md5.Sum(data)
|
|
return binary.BigEndian.Uint64(sum[:]), nil
|
|
}
|