2024-05-27 15:15:23 +08:00

66 lines
1.9 KiB
Go

package friend
import (
"context"
"crypto/md5"
"encoding/binary"
"encoding/json"
"github.com/openimsdk/open-im-server/v3/pkg/common/db/dataver"
"github.com/openimsdk/open-im-server/v3/pkg/common/db/table/relation"
pbfriend "github.com/openimsdk/protocol/friend"
)
func (s *friendServer) SearchFriends(ctx context.Context, req *pbfriend.SearchFriendsReq) (*pbfriend.SearchFriendsResp, error) {
//TODO implement me
panic("implement me")
}
func (s *friendServer) sortFriendUserIDsHash(userIDs []string) uint64 {
data, _ := json.Marshal(userIDs)
sum := md5.Sum(data)
return binary.BigEndian.Uint64(sum[:])
}
func (s *friendServer) IncrSyncFriends(ctx context.Context, req *pbfriend.IncrSyncFriendsReq) (*pbfriend.IncrSyncFriendsResp, error) {
var limit int
if req.Version > 0 {
limit = s.config.RpcConfig.FriendSyncCount
}
incrVer, err := s.friendDatabase.FindFriendIncrVersion(ctx, req.UserID, uint(req.Version), limit)
if err != nil {
return nil, err
}
sortUserIDs, err := s.friendDatabase.FindSortFriendUserIDs(ctx, req.UserID)
if err != nil {
return nil, err
}
if len(sortUserIDs) == 0 {
return &pbfriend.IncrSyncFriendsResp{
Version: uint64(incrVer.Version),
Full: true,
SyncCount: uint32(s.config.RpcConfig.FriendSyncCount),
}, nil
}
var changes []*relation.FriendModel
res := dataver.NewSyncResult(incrVer, sortUserIDs)
if len(res.Changes) > 0 {
changes, err = s.friendDatabase.FindFriendsWithError(ctx, req.UserID, res.Changes)
if err != nil {
return nil, err
}
}
calcHash := s.sortFriendUserIDsHash(sortUserIDs)
if calcHash == req.IdHash {
sortUserIDs = nil
}
return &pbfriend.IncrSyncFriendsResp{
Version: uint64(res.Version),
Full: res.Full,
SyncCount: uint32(s.config.RpcConfig.FriendSyncCount),
SortUserIdHash: calcHash,
SortUserIds: sortUserIDs,
DeleteUserIds: res.DeleteEID,
Changes: friendsDB2PB(changes),
}, nil
}