Files
open-im-server/pkg/common/storage/cache/redis/user.go
T

106 lines
3.0 KiB
Go
Raw Normal View History

package redis
2023-06-30 09:45:02 +08:00
import (
"context"
"time"
2023-06-30 09:45:02 +08:00
"github.com/dtm-labs/rockscache"
2024-03-10 10:24:20 +08:00
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache"
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/cachekey"
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database"
"github.com/openimsdk/open-im-server/v3/pkg/common/storage/model"
2024-03-05 10:51:55 +08:00
"github.com/redis/go-redis/v9"
2023-06-30 09:45:02 +08:00
)
const (
2024-04-19 22:23:08 +08:00
userExpireTime = time.Second * 60 * 60 * 12
2023-07-28 17:54:29 +08:00
userOlineStatusExpireTime = time.Second * 60 * 60 * 24
2023-08-03 09:44:10 +08:00
statusMod = 501
2023-06-30 09:45:02 +08:00
)
type UserCacheRedis struct {
cache.BatchDeleter
rdb redis.UniversalClient
userDB database.User
2023-06-30 09:45:02 +08:00
expireTime time.Duration
rcClient *rocksCacheClient
2023-06-30 09:45:02 +08:00
}
func NewUserCacheRedis(rdb redis.UniversalClient, localCache *config.LocalCache, userDB database.User, options *rockscache.Options) cache.UserCache {
rc := newRocksCacheClient(rdb)
2023-06-30 09:45:02 +08:00
return &UserCacheRedis{
BatchDeleter: rc.GetBatchDeleter(localCache.User.Topic),
rdb: rdb,
userDB: userDB,
expireTime: userExpireTime,
rcClient: rc,
2023-06-30 09:45:02 +08:00
}
}
2024-07-16 10:46:21 +08:00
func (u *UserCacheRedis) getUserID(user *model.User) string {
return user.UserID
}
func (u *UserCacheRedis) CloneUserCache() cache.UserCache {
2023-06-30 09:45:02 +08:00
return &UserCacheRedis{
BatchDeleter: u.BatchDeleter.Clone(),
rdb: u.rdb,
userDB: u.userDB,
expireTime: u.expireTime,
rcClient: u.rcClient,
2023-06-30 09:45:02 +08:00
}
}
func (u *UserCacheRedis) getUserInfoKey(userID string) string {
return cachekey.GetUserInfoKey(userID)
2023-06-30 09:45:02 +08:00
}
func (u *UserCacheRedis) getUserGlobalRecvMsgOptKey(userID string) string {
return cachekey.GetUserGlobalRecvMsgOptKey(userID)
2023-06-30 09:45:02 +08:00
}
func (u *UserCacheRedis) GetUserInfo(ctx context.Context, userID string) (userInfo *model.User, err error) {
return getCache(ctx, u.rcClient, u.getUserInfoKey(userID), u.expireTime, func(ctx context.Context) (*model.User, error) {
return u.userDB.Take(ctx, userID)
})
2023-06-30 09:45:02 +08:00
}
func (u *UserCacheRedis) GetUsersInfo(ctx context.Context, userIDs []string) ([]*model.User, error) {
2024-07-16 10:46:21 +08:00
return batchGetCache2(ctx, u.rcClient, u.expireTime, userIDs, u.getUserInfoKey, u.getUserID, u.userDB.Find)
2023-06-30 09:45:02 +08:00
}
func (u *UserCacheRedis) DelUsersInfo(userIDs ...string) cache.UserCache {
2023-10-23 16:24:55 +08:00
keys := make([]string, 0, len(userIDs))
2023-06-30 09:45:02 +08:00
for _, userID := range userIDs {
keys = append(keys, u.getUserInfoKey(userID))
}
cache := u.CloneUserCache()
2023-06-30 09:45:02 +08:00
cache.AddKeys(keys...)
2023-10-23 16:24:55 +08:00
2023-06-30 09:45:02 +08:00
return cache
}
func (u *UserCacheRedis) GetUserGlobalRecvMsgOpt(ctx context.Context, userID string) (opt int, err error) {
2023-07-03 16:29:22 +08:00
return getCache(
ctx,
u.rcClient,
u.getUserGlobalRecvMsgOptKey(userID),
u.expireTime,
func(ctx context.Context) (int, error) {
return u.userDB.GetUserGlobalRecvMsgOpt(ctx, userID)
},
)
2023-06-30 09:45:02 +08:00
}
func (u *UserCacheRedis) DelUsersGlobalRecvMsgOpt(userIDs ...string) cache.UserCache {
2023-10-23 16:24:55 +08:00
keys := make([]string, 0, len(userIDs))
2023-06-30 09:45:02 +08:00
for _, userID := range userIDs {
keys = append(keys, u.getUserGlobalRecvMsgOptKey(userID))
}
cache := u.CloneUserCache()
2023-06-30 09:45:02 +08:00
cache.AddKeys(keys...)
2023-07-28 17:54:29 +08:00
2023-10-23 16:24:55 +08:00
return cache
2023-07-28 17:54:29 +08:00
}