mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-06 04:15:46 +08:00
* feat: msg local cache * feat: msg local cache * feat: msg local cache * feat: msg local cache * feat: msg local cache * feat: msg local cache * fix: mongo * fix: mongo * fix: mongo * openim.yaml * localcache * localcache * localcache * localcache * localcache * localcache * localcache * localcache * localcache * local cache * local cache * local cache * local cache * fix: GroupApplicationAcceptedNotification * fix: GroupApplicationAcceptedNotification * fix: NotificationUserInfoUpdate * feat: cache add single-flight and timing-wheel. * feat: local cache * feat: local cache * feat: local cache * feat: cache add single-flight and timing-wheel. * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: local cache * feat: msg rpc local cache * feat: msg rpc local cache * feat: msg rpc local cache * feat: msg rpc local cache * feat: msg rpc local cache * feat: msg rpc local cache * refactor: refactor the code of push and optimization. * cicd: robot automated Change * refactor: rename cache. * merge * fix: refactor project dir avoid import cycle. * update tools * merge * feat: conversation FindRecvMsgNotNotifyUserIDs * feat: conversation FindRecvMsgNotNotifyUserIDs * feat: conversation FindRecvMsgNotNotifyUserIDs * merge * merge the latest main --------- Co-authored-by: Gordon <46924906+FGadvancer@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com>
67 lines
1.4 KiB
Go
67 lines
1.4 KiB
Go
package cache
|
|
|
|
import (
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/cachekey"
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
|
"strings"
|
|
"sync"
|
|
)
|
|
|
|
var (
|
|
once sync.Once
|
|
subscribe map[string][]string
|
|
)
|
|
|
|
func getPublishKey(topic string, key []string) []string {
|
|
if topic == "" || len(key) == 0 {
|
|
return nil
|
|
}
|
|
once.Do(func() {
|
|
list := []struct {
|
|
Local config.LocalCache
|
|
Keys []string
|
|
}{
|
|
{
|
|
Local: config.Config.LocalCache.User,
|
|
Keys: []string{cachekey.UserInfoKey, cachekey.UserGlobalRecvMsgOptKey},
|
|
},
|
|
{
|
|
Local: config.Config.LocalCache.Group,
|
|
Keys: []string{cachekey.GroupMemberIDsKey, cachekey.GroupInfoKey, cachekey.GroupMemberInfoKey},
|
|
},
|
|
{
|
|
Local: config.Config.LocalCache.Friend,
|
|
Keys: []string{cachekey.FriendIDsKey, cachekey.BlackIDsKey},
|
|
},
|
|
{
|
|
Local: config.Config.LocalCache.Conversation,
|
|
Keys: []string{cachekey.ConversationKey, cachekey.ConversationIDsKey, cachekey.ConversationNotReceiveMessageUserIDsKey},
|
|
},
|
|
}
|
|
subscribe = make(map[string][]string)
|
|
for _, v := range list {
|
|
if v.Local.Enable() {
|
|
subscribe[v.Local.Topic] = v.Keys
|
|
}
|
|
}
|
|
})
|
|
prefix, ok := subscribe[topic]
|
|
if !ok {
|
|
return nil
|
|
}
|
|
res := make([]string, 0, len(key))
|
|
for _, k := range key {
|
|
var exist bool
|
|
for _, p := range prefix {
|
|
if strings.HasPrefix(k, p) {
|
|
exist = true
|
|
break
|
|
}
|
|
}
|
|
if exist {
|
|
res = append(res, k)
|
|
}
|
|
}
|
|
return res
|
|
}
|