Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: API RPC call statistics #2398

Closed
wants to merge 151 commits into from
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
151 commits
Select commit Hold shift + click to select a range
4c3c455
fix: GroupApplicationAcceptedNotification
withchao Jan 11, 2024
f5f2cf4
Merge remote-tracking branch 'origin/main'
withchao Jan 11, 2024
ad979d4
Merge branch 'openimsdk:main' into main
withchao Jan 11, 2024
a00d77a
fix: GroupApplicationAcceptedNotification
withchao Jan 11, 2024
48ff03f
fix: NotificationUserInfoUpdate
withchao Jan 12, 2024
45859d9
Merge branch 'openimsdk:main' into main
withchao Jan 16, 2024
e3d78de
Merge branch 'openimsdk:main' into main
withchao Jan 18, 2024
c81e199
Merge branch 'openimsdk:main' into main
withchao Jan 22, 2024
4266fed
cicd: robot automated Change
withchao Jan 22, 2024
1a14191
Merge remote-tracking branch 'upstream/main'
withchao Jan 26, 2024
86d3a66
Merge branch 'openimsdk:main' into main
withchao Jan 28, 2024
1964a4b
Merge branch 'openimsdk:main' into main
withchao Jan 31, 2024
d91cde9
Merge branch 'openimsdk:main' into main
withchao Feb 5, 2024
6a05e64
Merge branch 'openimsdk:main' into main
withchao Feb 20, 2024
39a6141
Merge branch 'openimsdk:main' into main
withchao Mar 6, 2024
c2009ce
Merge branch 'openimsdk:main' into main
withchao Mar 7, 2024
34c7f22
Merge branch 'openimsdk:main' into main
withchao Mar 8, 2024
ea9c75b
Merge branch 'openimsdk:main' into main
withchao Mar 13, 2024
7b5279a
fix: component
withchao Mar 13, 2024
34daf13
fix: getConversationInfo
withchao Mar 13, 2024
65d58ae
Merge branch 'openimsdk:main' into main
withchao Mar 13, 2024
e601b5f
Merge remote-tracking branch 'upstream/main'
withchao Mar 20, 2024
5f72b1e
Merge remote-tracking branch 'origin/main'
withchao Mar 20, 2024
20dfafd
Merge branch 'openimsdk:main' into main
withchao Apr 24, 2024
dc57d38
feat: cron task
withchao Apr 25, 2024
2f13149
feat: cron task
withchao Apr 25, 2024
2e43950
feat: cron task
withchao Apr 25, 2024
7a29a85
feat: cron task
withchao Apr 26, 2024
3920c06
feat: cron task
withchao Apr 26, 2024
bed7a60
Merge branch 'openimsdk:main' into main
withchao Apr 26, 2024
f2fbf19
Merge remote-tracking branch 'refs/remotes/origin/main' into corn37
withchao Apr 26, 2024
01851df
Merge remote-tracking branch 'upstream/main'
withchao Apr 28, 2024
480ccc7
fix: minio config url recognition error
withchao Apr 28, 2024
1046323
Merge branch 'openimsdk:main' into main
withchao May 8, 2024
76c6fe8
Merge branch 'openimsdk:main' into main
withchao May 10, 2024
6b119bd
Merge branch 'openimsdk:main' into main
withchao May 17, 2024
5528e8e
new mongo
withchao May 22, 2024
c6942f0
new mongo
withchao May 22, 2024
82c6b00
new mongo
withchao May 23, 2024
a2bfc90
new mongo
withchao May 23, 2024
05cec1b
new mongo
withchao May 24, 2024
1184002
new mongo
withchao May 24, 2024
e99eaf9
new mongo
withchao May 24, 2024
2f97933
new mongo
withchao May 24, 2024
1f02bdc
friend incr sync
withchao May 27, 2024
8e37a41
friend incr sync
withchao May 27, 2024
f6131c4
friend incr sync
withchao May 29, 2024
0d57f28
friend incr sync
withchao May 29, 2024
9ba22f3
friend incr sync
withchao May 30, 2024
61740d4
Merge branch 'openimsdk:main' into main
withchao May 30, 2024
10315e9
Merge branch 'main' into list
withchao May 30, 2024
eb362da
mage
withchao May 30, 2024
0aaf8b9
optimization version log
withchao May 30, 2024
0f72de8
optimization version log
withchao May 30, 2024
cfc01bb
sync
withchao May 31, 2024
e9f4627
sync
withchao Jun 3, 2024
6363358
sync
withchao Jun 3, 2024
1b5621b
group sync
withchao Jun 3, 2024
6939352
sync option
withchao Jun 4, 2024
7e13faa
sync option
withchao Jun 4, 2024
1796c3a
refactor: replace `friend` package with `realtion`.
mo3et Jun 5, 2024
cfd07b1
Merge branch 'openimsdk:main' into list
mo3et Jun 5, 2024
7821f5f
Merge branch 'list' into list
mo3et Jun 5, 2024
e11807c
refactor: update lastest commit to relation.
mo3et Jun 5, 2024
9362169
Merge pull request #1 from mo3et/list
FGadvancer Jun 5, 2024
6285b68
sync option
withchao Jun 6, 2024
8e1d0c5
Merge remote-tracking branch 'origin/list' into list
withchao Jun 6, 2024
c5f565f
sync option
withchao Jun 6, 2024
a1523f4
sync option
withchao Jun 6, 2024
58c4c13
sync
withchao Jun 7, 2024
caebdf3
sync
withchao Jun 11, 2024
17dad5c
Merge branch 'openimsdk:main' into main
withchao Jun 12, 2024
1b10271
go.mod
withchao Jun 13, 2024
ef71d0c
seq
withchao Jun 14, 2024
904842b
update: go mod
icey-yu Jun 14, 2024
c5fa596
refactor: change incremental to full
icey-yu Jun 14, 2024
f19f6f9
feat: get full friend user ids
icey-yu Jun 14, 2024
cee1a49
feat: api and config
icey-yu Jun 14, 2024
fe4842b
seq
withchao Jun 14, 2024
1aa610c
Merge pull request #2 from icey-yu/friend-increamental
withchao Jun 14, 2024
a41c8c6
group version
withchao Jun 17, 2024
5156795
Merge branch 'openimsdk:main' into main
withchao Jun 17, 2024
c161330
Merge remote-tracking branch 'origin/list' into list
withchao Jun 17, 2024
bd4fb8a
merge
withchao Jun 17, 2024
ec40d82
Merge remote-tracking branch 'origin/main' into list
withchao Jun 17, 2024
d55d416
seq
withchao Jun 17, 2024
a2a28b4
seq
withchao Jun 18, 2024
cce382d
seq
withchao Jun 18, 2024
aff8322
fix: sort by id avoid unstable sort friends.
FGadvancer Jun 18, 2024
08cb4a9
group
withchao Jun 19, 2024
f613c6d
group
withchao Jun 19, 2024
7182298
Merge remote-tracking branch 'origin/list' into seq38
withchao Jun 19, 2024
1ee33f3
group
withchao Jun 19, 2024
924888d
fix: sort by id avoid unstable sort friends.
FGadvancer Jun 19, 2024
5006af5
fix: sort by id avoid unstable sort friends.
FGadvancer Jun 19, 2024
4f359b7
fix: sort by id avoid unstable sort friends.
FGadvancer Jun 19, 2024
4074f81
Merge branch 'refs/heads/list' into seq38
withchao Jun 19, 2024
03d4564
user version
withchao Jun 20, 2024
88c1510
Merge remote-tracking branch 'origin/list' into list
withchao Jun 20, 2024
ac9f4f6
Merge remote-tracking branch 'origin/list' into seq38
withchao Jun 20, 2024
425008a
Merge remote-tracking branch 'origin/seq38' into seq38
withchao Jun 20, 2024
2d2941a
seq
withchao Jun 20, 2024
8e3890e
seq
withchao Jun 21, 2024
9b043fe
seq user
withchao Jun 24, 2024
8f0403e
user online
withchao Jun 26, 2024
2b2a75f
implement minio expire delete.
mo3et Jun 28, 2024
8f86049
user online
withchao Jun 28, 2024
3960d28
config
withchao Jun 28, 2024
affa909
fix
withchao Jun 28, 2024
3ef62d4
fix
withchao Jun 28, 2024
dac8fba
implement minio expire delete logic.
mo3et Jun 28, 2024
3167780
online cache
withchao Jul 1, 2024
d06c323
online cache
withchao Jul 1, 2024
bf2cf42
Merge pull request #6 from mo3et/minio-cron-del
withchao Jul 1, 2024
4781cf4
Merge branch 'openimsdk:main' into main
withchao Jul 1, 2024
45b07bc
online cache
withchao Jul 1, 2024
32c5f65
online cache
withchao Jul 2, 2024
9388cb6
online cache
withchao Jul 2, 2024
28c8b78
online cache
withchao Jul 2, 2024
6e2659c
online cache
withchao Jul 2, 2024
f87ee44
online cache
withchao Jul 2, 2024
1bfaf3e
online cache
withchao Jul 2, 2024
dcd8749
online cache
withchao Jul 2, 2024
14aba3b
online cache
withchao Jul 2, 2024
3df39a8
online cache
withchao Jul 2, 2024
3306117
feat: implement scheduled delete outdated object in minio.
mo3et Jul 2, 2024
bfbfb78
Merge branch 'openimsdk:main' into main
withchao Jul 3, 2024
8d4737c
update gomake version
withchao Jul 3, 2024
0b4c802
update gomake version
withchao Jul 3, 2024
7897044
implement FindExpires pagination.
mo3et Jul 3, 2024
686ccae
remove unnesseary incr.
mo3et Jul 3, 2024
a421bd1
fix uncorrect args call.
mo3et Jul 3, 2024
c117ef8
Merge pull request #8 from mo3et/minio-cron-del
withchao Jul 3, 2024
e791cbd
online push
withchao Jul 3, 2024
006766c
online push
withchao Jul 3, 2024
fcda73f
online push
withchao Jul 4, 2024
a464750
Merge branch 'openimsdk:main' into main
withchao Jul 4, 2024
73a9265
Merge remote-tracking branch 'origin/main' into seq38
withchao Jul 4, 2024
c5cf078
resolving conflicts
withchao Jul 4, 2024
f315177
Merge branch 'seq38' into online
withchao Jul 4, 2024
a9ab9ba
resolving conflicts
withchao Jul 4, 2024
97636c4
test
withchao Jul 4, 2024
1336b83
api prommetrics
withchao Jul 4, 2024
6713986
api prommetrics
withchao Jul 4, 2024
9151b56
api prommetrics
withchao Jul 4, 2024
c1d66fa
api prommetrics
withchao Jul 4, 2024
e3ee24d
api prommetrics
withchao Jul 4, 2024
0a9b53b
rpc prommetrics
withchao Jul 5, 2024
ab84d77
Merge branch 'openimsdk:main' into main
withchao Jul 5, 2024
181107d
Merge branch 'main' into count
withchao Jul 5, 2024
2052e1c
rpc prommetrics
withchao Jul 5, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
sync option
  • Loading branch information
withchao committed Jun 4, 2024
commit 693935237a87a5a46d7aa8e76aac4a370c918569
62 changes: 10 additions & 52 deletions internal/rpc/friend/sync.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,23 +62,22 @@ func (s *friendServer) GetIncrementalFriends(ctx context.Context, req *pbfriend.
return nil, err
}
opt := incrversion.Option[*pbfriend.FriendInfo, pbfriend.GetIncrementalFriendsResp]{
VersionID: req.VersionID,
Version: func() (*model.VersionLog, error) {
return s.friendDatabase.FindFriendIncrVersion(ctx, req.UserID, uint(req.Version), incrversion.Limit(s.config.RpcConfig.FriendSyncCount, req.Version))
},
AllID: func() ([]string, error) {
return s.friendDatabase.FindSortFriendUserIDs(ctx, req.UserID)
},
Find: func(ids []string) ([]*pbfriend.FriendInfo, error) {
Ctx: ctx,
VersionKey: req.UserID,
VersionID: req.VersionID,
VersionNumber: req.Version,
SyncLimit: s.config.RpcConfig.FriendSyncCount,
Version: s.friendDatabase.FindFriendIncrVersion,
CacheMaxVersion: s.friendDatabase.FindMaxFriendVersionCache,
SortID: s.friendDatabase.FindSortFriendUserIDs,
Find: func(ctx context.Context, ids []string) ([]*pbfriend.FriendInfo, error) {
friends, err := s.friendDatabase.FindFriendsWithError(ctx, req.UserID, ids)
if err != nil {
return nil, err
}
return friendsDB2PB(friends), nil
},
ID: func(elem *pbfriend.FriendInfo) string {
return elem.FriendUserID
},
ID: func(elem *pbfriend.FriendInfo) string { return elem.FriendUserID },
Resp: func(version *model.VersionLog, delIDs []string, list []*pbfriend.FriendInfo, full bool) *pbfriend.GetIncrementalFriendsResp {
return &pbfriend.GetIncrementalFriendsResp{
VersionID: version.ID.Hex(),
Expand All @@ -92,44 +91,3 @@ func (s *friendServer) GetIncrementalFriends(ctx context.Context, req *pbfriend.
}
return opt.Build()
}

//func (s *friendServer) GetIncrementalFriends(ctx context.Context, req *pbfriend.GetIncrementalFriendsReq) (*pbfriend.GetIncrementalFriendsResp, error) {
// if err := authverify.CheckAccessV3(ctx, req.UserID, s.config.Share.IMAdminUserID); err != nil {
// return nil, err
// }
// 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
// }
// var (
// deleteUserIDs []string
// changeUserIDs []string
// )
// if incrVer.Full() {
// changeUserIDs, err = s.friendDatabase.FindSortFriendUserIDs(ctx, req.UserID)
// if err != nil {
// return nil, err
// }
// } else {
// deleteUserIDs, changeUserIDs = incrVer.DeleteAndChangeIDs()
// }
// var friends []*model.Friend
// if len(changeUserIDs) > 0 {
// friends, err = s.friendDatabase.FindFriendsWithError(ctx, req.UserID, changeUserIDs)
// if err != nil {
// return nil, err
// }
// }
// return &pbfriend.GetIncrementalFriendsResp{
// Version: uint64(incrVer.Version),
// VersionID: incrVer.ID.Hex(),
// Full: incrVer.Full(),
// SyncCount: uint32(s.config.RpcConfig.FriendSyncCount),
// DeleteUserIds: deleteUserIDs,
// Changes: friendsDB2PB(friends),
// }, nil
//}
44 changes: 20 additions & 24 deletions internal/rpc/group/sync.go
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,18 @@ func (s *groupServer) SearchGroupMember(ctx context.Context, req *pbgroup.Search

func (s *groupServer) GetIncrementalGroupMember(ctx context.Context, req *pbgroup.GetIncrementalGroupMemberReq) (*pbgroup.GetIncrementalGroupMemberResp, error) {
opt := incrversion.Option[*sdkws.GroupMemberFullInfo, pbgroup.GetIncrementalGroupMemberResp]{
VersionID: req.VersionID,
Version: func() (*model.VersionLog, error) {
return s.db.FindMemberIncrVersion(ctx, req.GroupID, uint(req.Version), incrversion.Limit(s.config.RpcConfig.GroupSyncCount, req.Version))
},
AllID: func() ([]string, error) {
return s.db.FindSortGroupMemberUserIDs(ctx, req.GroupID)
},
Find: func(ids []string) ([]*sdkws.GroupMemberFullInfo, error) {
Ctx: ctx,
VersionKey: req.GroupID,
VersionID: req.VersionID,
VersionNumber: req.Version,
SyncLimit: s.config.RpcConfig.GroupSyncCount,
Version: s.db.FindMemberIncrVersion,
CacheMaxVersion: s.db.FindMaxGroupMemberVersionCache,
SortID: s.db.FindSortGroupMemberUserIDs,
Find: func(ctx context.Context, ids []string) ([]*sdkws.GroupMemberFullInfo, error) {
return s.getGroupMembersInfo(ctx, req.GroupID, ids)
},
ID: func(elem *sdkws.GroupMemberFullInfo) string {
return elem.UserID
},
ID: func(elem *sdkws.GroupMemberFullInfo) string { return elem.UserID },
Resp: func(version *model.VersionLog, delIDs []string, list []*sdkws.GroupMemberFullInfo, full bool) *pbgroup.GetIncrementalGroupMemberResp {
return &pbgroup.GetIncrementalGroupMemberResp{
VersionID: version.ID.Hex(),
Expand All @@ -48,19 +47,16 @@ func (s *groupServer) GetIncrementalJoinGroup(ctx context.Context, req *pbgroup.
return nil, err
}
opt := incrversion.Option[*sdkws.GroupInfo, pbgroup.GetIncrementalJoinGroupResp]{
VersionID: req.VersionID,
Version: func() (*model.VersionLog, error) {
return s.db.FindJoinIncrVersion(ctx, req.UserID, uint(req.Version), incrversion.Limit(s.config.RpcConfig.GroupSyncCount, req.Version))
},
AllID: func() ([]string, error) {
return s.db.FindSortJoinGroupIDs(ctx, req.UserID)
},
Find: func(ids []string) ([]*sdkws.GroupInfo, error) {
return s.getGroupsInfo(ctx, ids)
},
ID: func(elem *sdkws.GroupInfo) string {
return elem.GroupID
},
Ctx: ctx,
VersionKey: req.UserID,
VersionID: req.VersionID,
VersionNumber: req.Version,
SyncLimit: s.config.RpcConfig.GroupSyncCount,
Version: s.db.FindJoinIncrVersion,
CacheMaxVersion: s.db.FindMaxJoinGroupVersionCache,
SortID: s.db.FindSortJoinGroupIDs,
Find: s.getGroupsInfo,
ID: func(elem *sdkws.GroupInfo) string { return elem.GroupID },
Resp: func(version *model.VersionLog, delIDs []string, list []*sdkws.GroupInfo, full bool) *pbgroup.GetIncrementalJoinGroupResp {
return &pbgroup.GetIncrementalJoinGroupResp{
VersionID: version.ID.Hex(),
Expand Down
131 changes: 116 additions & 15 deletions internal/rpc/incrversion/option.go
Original file line number Diff line number Diff line change
@@ -1,38 +1,139 @@
package incrversion

import (
"context"
"fmt"
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model"
"github.com/openimsdk/tools/errs"
"github.com/openimsdk/tools/utils/datautil"
"go.mongodb.org/mongo-driver/bson/primitive"
)

func Limit(maxSync int, version uint64) int {
if version == 0 {
return 0
//func Limit(maxSync int, version uint64) int {
// if version == 0 {
// return 0
// }
// return maxSync
//}

const (
tagQuery = iota + 1
tagFull
tageEqual
)

type Option[A, B any] struct {
Ctx context.Context
VersionKey string
VersionID string
VersionNumber uint64
SyncLimit int
CacheMaxVersion func(ctx context.Context, dId string) (*model.VersionLog, error)
Version func(ctx context.Context, dId string, version uint, limit int) (*model.VersionLog, error)
SortID func(ctx context.Context, dId string) ([]string, error)
Find func(ctx context.Context, ids []string) ([]A, error)
ID func(elem A) string
Resp func(version *model.VersionLog, delIDs []string, list []A, full bool) *B
}

func (o *Option[A, B]) newError(msg string) error {
return errs.ErrInternalServer.WrapMsg(msg)
}

func (o *Option[A, B]) check() error {
if o.Ctx == nil {
return o.newError("opt ctx is nil")
}
return maxSync
if o.VersionKey == "" {
return o.newError("versionKey is empty")
}
if o.SyncLimit <= 0 {
return o.newError("invalid synchronization quantity")
}
if o.Version == nil {
return o.newError("func version is nil")
}
if o.SortID == nil {
return o.newError("func allID is nil")
}
if o.Find == nil {
return o.newError("func find is nil")
}
if o.ID == nil {
return o.newError("func id is nil")
}
if o.Resp == nil {
return o.newError("func resp is nil")
}
return nil
}

type Option[A, B any] struct {
VersionID string
Version func() (*model.VersionLog, error)
AllID func() ([]string, error)
Find func(ids []string) ([]A, error)
ID func(elem A) string
Resp func(version *model.VersionLog, delIDs []string, list []A, full bool) *B
func (o *Option[A, B]) validVersion() bool {
objID, err := primitive.ObjectIDFromHex(o.VersionID)
return err == nil && (!objID.IsZero()) && o.VersionNumber > 0
}

func (o *Option[A, B]) equalID(objID primitive.ObjectID) bool {
return o.VersionID == objID.Hex()
}

func (o *Option[A, B]) getVersion(tag *int) (*model.VersionLog, error) {
if o.CacheMaxVersion == nil {
if o.validVersion() {
*tag = tagQuery
return o.Version(o.Ctx, o.VersionKey, uint(o.VersionNumber), o.SyncLimit)
}
*tag = tagFull
return o.Version(o.Ctx, o.VersionKey, 0, 0)
} else {
cache, err := o.CacheMaxVersion(o.Ctx, o.VersionKey)
if err != nil {
return nil, err
}
if !o.validVersion() {
*tag = tagFull
return cache, nil
}
if !o.equalID(cache.ID) {
*tag = tagFull
return cache, nil
}
if o.VersionNumber == uint64(cache.Version) {
*tag = tageEqual
return cache, nil
}
*tag = tagQuery
return o.Version(o.Ctx, o.VersionKey, uint(o.VersionNumber), o.SyncLimit)
}
}

func (o *Option[A, B]) Build() (*B, error) {
version, err := o.Version()
if err := o.check(); err != nil {
return nil, err
}
var tag int
version, err := o.getVersion(&tag)
if err != nil {
return nil, err
}
var full bool
switch tag {
case tagQuery:
full = version.ID.Hex() != o.VersionID || uint64(version.Version) < o.VersionNumber || len(version.Logs) != version.LogLen
case tagFull:
full = true
case tageEqual:
full = false
default:
panic(fmt.Errorf("undefined tag %d", tag))
}
var (
deleteIDs []string
changeIDs []string
)
full := o.VersionID != version.ID.Hex() || version.Full()
//full := o.VersionID != version.ID.Hex() || version.Full()
if full {
changeIDs, err = o.AllID()
changeIDs, err = o.SortID(o.Ctx, o.VersionKey)
if err != nil {
return nil, err
}
Expand All @@ -41,7 +142,7 @@ func (o *Option[A, B]) Build() (*B, error) {
}
var list []A
if len(changeIDs) > 0 {
list, err = o.Find(changeIDs)
list, err = o.Find(o.Ctx, changeIDs)
if err != nil {
return nil, err
}
Expand Down
23 changes: 13 additions & 10 deletions pkg/common/storage/cache/cachekey/friend.go
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,13 @@

package cachekey

import "strconv"

const (
FriendIDsKey = "FRIEND_IDS:"
TwoWayFriendsIDsKey = "COMMON_FRIENDS_IDS:"
FriendKey = "FRIEND_INFO:"
IsFriendKey = "IS_FRIEND:" // local cache key
FriendSyncSortUserIDsKey = "FRIEND_SYNC_SORT_USER_IDS:"
FriendIDsKey = "FRIEND_IDS:"
TwoWayFriendsIDsKey = "COMMON_FRIENDS_IDS:"
FriendKey = "FRIEND_INFO:"
IsFriendKey = "IS_FRIEND:" // local cache key
//FriendSyncSortUserIDsKey = "FRIEND_SYNC_SORT_USER_IDS:"
FriendMaxVersionKey = "FRIEND_MAX_VERSION:"
)

func GetFriendIDsKey(ownerUserID string) string {
Expand All @@ -36,10 +35,14 @@ func GetFriendKey(ownerUserID, friendUserID string) string {
return FriendKey + ownerUserID + "-" + friendUserID
}

func GetFriendMaxVersionKey(ownerUserID string) string {
return FriendMaxVersionKey + ownerUserID
}

func GetIsFriendKey(possibleFriendUserID, userID string) string {
return IsFriendKey + possibleFriendUserID + "-" + userID
}

func GetFriendSyncSortUserIDsKey(ownerUserID string, count int) string {
return FriendSyncSortUserIDsKey + strconv.Itoa(count) + ":" + ownerUserID
}
//func GetFriendSyncSortUserIDsKey(ownerUserID string, count int) string {
// return FriendSyncSortUserIDsKey + strconv.Itoa(count) + ":" + ownerUserID
//}
10 changes: 10 additions & 0 deletions pkg/common/storage/cache/cachekey/group.go
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@ const (
JoinedGroupsKey = "JOIN_GROUPS_KEY:"
GroupMemberNumKey = "GROUP_MEMBER_NUM_CACHE:"
GroupRoleLevelMemberIDsKey = "GROUP_ROLE_LEVEL_MEMBER_IDS:"
GroupMemberMaxVersionKey = "GROUP_MEMBER_MAX_VERSION:"
GroupJoinMaxVersionKey = "GROUP_JOIN_MAX_VERSION:"
)

func GetGroupInfoKey(groupID string) string {
Expand Down Expand Up @@ -57,3 +59,11 @@ func GetGroupMemberNumKey(groupID string) string {
func GetGroupRoleLevelMemberIDsKey(groupID string, roleLevel int32) string {
return GroupRoleLevelMemberIDsKey + groupID + "-" + strconv.Itoa(int(roleLevel))
}

func GetGroupMemberMaxVersionKey(groupID string) string {
return GroupMemberMaxVersionKey + groupID
}

func GetJoinGroupMaxVersionKey(userID string) string {
return GroupJoinMaxVersionKey + userID
}
8 changes: 6 additions & 2 deletions pkg/common/storage/cache/friend.go
Original file line number Diff line number Diff line change
Expand Up @@ -35,9 +35,13 @@ type FriendCache interface {

DelOwner(friendUserID string, ownerUserIDs []string) FriendCache

DelSortFriendUserIDs(ownerUserIDs ...string) FriendCache
DelMaxFriendVersion(ownerUserIDs ...string) FriendCache

//DelSortFriendUserIDs(ownerUserIDs ...string) FriendCache

FindSortFriendUserIDs(ctx context.Context, ownerUserID string) ([]string, error)

FindFriendIncrVersion(ctx context.Context, ownerUserID string, version uint, limit int) (*relationtb.VersionLog, error)
//FindFriendIncrVersion(ctx context.Context, ownerUserID string, version uint, limit int) (*relationtb.VersionLog, error)

FindMaxFriendVersion(ctx context.Context, ownerUserID string) (*relationtb.VersionLog, error)
}
5 changes: 5 additions & 0 deletions pkg/common/storage/cache/group.go
Original file line number Diff line number Diff line change
Expand Up @@ -62,4 +62,9 @@ type GroupCache interface {

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)
FindMaxJoinGroupVersion(ctx context.Context, userID string) (*model.VersionLog, error)
}
Loading