mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-04-25 19:22:46 +08:00
errcode
This commit is contained in:
parent
e0d05e1fa8
commit
40470bc320
64
pkg/common/db/cache/black.go
vendored
Normal file
64
pkg/common/db/cache/black.go
vendored
Normal file
@ -0,0 +1,64 @@
|
|||||||
|
package cache
|
||||||
|
|
||||||
|
import (
|
||||||
|
"Open_IM/pkg/common/db/relation"
|
||||||
|
"Open_IM/pkg/common/tracelog"
|
||||||
|
"Open_IM/pkg/utils"
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"github.com/dtm-labs/rockscache"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
blackIDsKey = "BLACK_IDS:"
|
||||||
|
blackExpireTime = time.Second * 60 * 60 * 12
|
||||||
|
)
|
||||||
|
|
||||||
|
type BlackCache struct {
|
||||||
|
blackDB *relation.Black
|
||||||
|
expireTime time.Duration
|
||||||
|
rcClient *rockscache.Client
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewBlackCache(blackDB *relation.Black) *BlackCache {
|
||||||
|
return &BlackCache{
|
||||||
|
blackDB: nil,
|
||||||
|
expireTime: 0,
|
||||||
|
rcClient: nil,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *BlackCache) getBlackIDsKey(ownerUserID string) string {
|
||||||
|
return blackIDsKey + ownerUserID
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *BlackCache) GetBlackIDs(ctx context.Context, userID string) (blackIDs []string, err error) {
|
||||||
|
getBlackIDList := func() (string, error) {
|
||||||
|
blackIDs, err := b.blackDB.GetBlackIDs(ctx, userID)
|
||||||
|
if err != nil {
|
||||||
|
return "", utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
bytes, err := json.Marshal(blackIDs)
|
||||||
|
if err != nil {
|
||||||
|
return "", utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
return string(bytes), nil
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "userID", userID, "blackIDList", blackIDs)
|
||||||
|
}()
|
||||||
|
blackIDListStr, err := b.rcClient.Fetch(blackListCache+userID, time.Second*30*60, getBlackIDList)
|
||||||
|
if err != nil {
|
||||||
|
return nil, utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
err = json.Unmarshal([]byte(blackIDListStr), &blackIDs)
|
||||||
|
return blackIDs, utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *BlackCache) DelBlackIDListFromCache(ctx context.Context, userID string) (err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ctx", ctx)
|
||||||
|
}()
|
||||||
|
return b.rcClient.TagAsDeleted(blackListCache + userID)
|
||||||
|
}
|
65
pkg/common/db/cache/friend.go
vendored
Normal file
65
pkg/common/db/cache/friend.go
vendored
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
package cache
|
||||||
|
|
||||||
|
import (
|
||||||
|
"Open_IM/pkg/common/db/relation"
|
||||||
|
"Open_IM/pkg/common/tracelog"
|
||||||
|
"Open_IM/pkg/utils"
|
||||||
|
"context"
|
||||||
|
"encoding/json"
|
||||||
|
"github.com/dtm-labs/rockscache"
|
||||||
|
"github.com/go-redis/redis/v8"
|
||||||
|
"time"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
friendExpireTime = time.Second * 60 * 60 * 12
|
||||||
|
friendIDsKey = "FRIEND_IDS:"
|
||||||
|
)
|
||||||
|
|
||||||
|
type FriendCache struct {
|
||||||
|
friendDB *relation.Friend
|
||||||
|
expireTime time.Duration
|
||||||
|
rcClient *rockscache.Client
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewFriendCache(rdb redis.UniversalClient, friendDB *relation.Friend, options rockscache.Options) *FriendCache {
|
||||||
|
return &FriendCache{
|
||||||
|
friendDB: friendDB,
|
||||||
|
expireTime: friendExpireTime,
|
||||||
|
rcClient: rockscache.NewClient(rdb, options),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) getFriendRelationKey(ownerUserID string) string {
|
||||||
|
return friendIDsKey + ownerUserID
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) GetFriendIDs(ctx context.Context, ownerUserID string) (friendIDs []string, err error) {
|
||||||
|
getFriendIDList := func() (string, error) {
|
||||||
|
friendIDList, err := f.friendDB.GetFriendIDs(ctx, ownerUserID)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
bytes, err := json.Marshal(friendIDList)
|
||||||
|
if err != nil {
|
||||||
|
return "", utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
return string(bytes), nil
|
||||||
|
}
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID, "friendIDs", friendIDs)
|
||||||
|
}()
|
||||||
|
friendIDListStr, err := f.rcClient.Fetch(f.getFriendRelationKey(ownerUserID), f.expireTime, getFriendIDList)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
err = json.Unmarshal([]byte(friendIDListStr), &friendIDs)
|
||||||
|
return friendIDs, utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) DelFriendIDs(ctx context.Context, ownerUserID string) (err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID)
|
||||||
|
}()
|
||||||
|
return f.rcClient.TagAsDeleted(f.getFriendRelationKey(ownerUserID))
|
||||||
|
}
|
57
pkg/common/db/cache/group.go
vendored
57
pkg/common/db/cache/group.go
vendored
@ -2,6 +2,7 @@ package cache
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/constant"
|
"Open_IM/pkg/common/constant"
|
||||||
|
"Open_IM/pkg/common/db/localcache"
|
||||||
"Open_IM/pkg/common/db/relation"
|
"Open_IM/pkg/common/db/relation"
|
||||||
"Open_IM/pkg/common/db/unrelation"
|
"Open_IM/pkg/common/db/unrelation"
|
||||||
"Open_IM/pkg/common/tracelog"
|
"Open_IM/pkg/common/tracelog"
|
||||||
@ -39,18 +40,13 @@ type GroupCache struct {
|
|||||||
|
|
||||||
//local cache
|
//local cache
|
||||||
cacheGroupMtx sync.RWMutex
|
cacheGroupMtx sync.RWMutex
|
||||||
cacheGroupMemberUserIDs map[string]*GroupMemberIDsHash
|
cacheGroupMemberUserIDs map[string]*localcache.GroupMemberIDsHash
|
||||||
}
|
|
||||||
|
|
||||||
type GroupMemberIDsHash struct {
|
|
||||||
MemberListHash uint64
|
|
||||||
UserIDs []string
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewGroupCache(rdb redis.UniversalClient, groupDB *relation.Group, groupMemberDB *relation.GroupMember, groupRequestDB *relation.GroupRequest, mongoClient *unrelation.SuperGroupMgoDB, opts rockscache.Options) *GroupCache {
|
func NewGroupCache(rdb redis.UniversalClient, groupDB *relation.Group, groupMemberDB *relation.GroupMember, groupRequestDB *relation.GroupRequest, mongoClient *unrelation.SuperGroupMgoDB, opts rockscache.Options) *GroupCache {
|
||||||
return &GroupCache{rcClient: rockscache.NewClient(rdb, opts), expireTime: groupExpireTime,
|
return &GroupCache{rcClient: rockscache.NewClient(rdb, opts), expireTime: groupExpireTime,
|
||||||
group: groupDB, groupMember: groupMemberDB, groupRequest: groupRequestDB, redisClient: NewRedisClient(rdb),
|
group: groupDB, groupMember: groupMemberDB, groupRequest: groupRequestDB, redisClient: NewRedisClient(rdb),
|
||||||
mongoDB: mongoClient, cacheGroupMemberUserIDs: make(map[string]*GroupMemberIDsHash, 0),
|
mongoDB: mongoClient, cacheGroupMemberUserIDs: make(map[string]*localcache.GroupMemberIDsHash, 0),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -287,7 +283,7 @@ func (g *GroupCache) LocalGetGroupMemberIDs(ctx context.Context, groupID string)
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
g.cacheGroupMemberUserIDs[groupID] = &GroupMemberIDsHash{
|
g.cacheGroupMemberUserIDs[groupID] = &localcache.GroupMemberIDsHash{
|
||||||
MemberListHash: remoteHash,
|
MemberListHash: remoteHash,
|
||||||
UserIDs: groupMemberIDsRemote,
|
UserIDs: groupMemberIDsRemote,
|
||||||
}
|
}
|
||||||
@ -350,6 +346,51 @@ func (g *GroupCache) GetGroupMemberInfo(ctx context.Context, groupID, userID str
|
|||||||
return groupMember, utils.Wrap(err, "")
|
return groupMember, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (g *GroupCache) GetGroupMembersInfo(ctx context.Context, count, offset int32, groupID string) (groupMembers []*relation.GroupMember, err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "count", count, "offset", offset, "groupID", groupID, "groupMember", groupMembers)
|
||||||
|
}()
|
||||||
|
groupMemberIDList, err := g.GetGroupMemberIDs(ctx, groupID)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if count < 0 || offset < 0 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
var groupMemberList []*relation.GroupMember
|
||||||
|
var start, stop int32
|
||||||
|
start = offset
|
||||||
|
stop = offset + count
|
||||||
|
l := int32(len(groupMemberIDList))
|
||||||
|
if start > stop {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
if start >= l {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
if count != 0 {
|
||||||
|
if stop >= l {
|
||||||
|
stop = l
|
||||||
|
}
|
||||||
|
groupMemberIDList = groupMemberIDList[start:stop]
|
||||||
|
} else {
|
||||||
|
if l < 1000 {
|
||||||
|
stop = l
|
||||||
|
} else {
|
||||||
|
stop = 1000
|
||||||
|
}
|
||||||
|
groupMemberIDList = groupMemberIDList[start:stop]
|
||||||
|
}
|
||||||
|
for _, userID := range groupMemberIDList {
|
||||||
|
groupMember, err := g.GetGroupMemberInfo(ctx, groupID, userID)
|
||||||
|
if err != nil {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
groupMembers = append(groupMembers, groupMember)
|
||||||
|
}
|
||||||
|
return groupMemberList, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (g *GroupCache) DelGroupMemberInfo(ctx context.Context, groupID, userID string) (err error) {
|
func (g *GroupCache) DelGroupMemberInfo(ctx context.Context, groupID, userID string) (err error) {
|
||||||
defer func() {
|
defer func() {
|
||||||
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "groupID", groupID, "userID", userID)
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "groupID", groupID, "userID", userID)
|
||||||
|
4
pkg/common/db/cache/rockscache.go
vendored
4
pkg/common/db/cache/rockscache.go
vendored
@ -21,7 +21,7 @@ import (
|
|||||||
|
|
||||||
const (
|
const (
|
||||||
//userInfoCache = "USER_INFO_CACHE:"
|
//userInfoCache = "USER_INFO_CACHE:"
|
||||||
friendRelationCache = "FRIEND_RELATION_CACHE:"
|
//friendRelationCache = "FRIEND_RELATION_CACHE:"
|
||||||
blackListCache = "BLACK_LIST_CACHE:"
|
blackListCache = "BLACK_LIST_CACHE:"
|
||||||
//groupCache = "GROUP_CACHE:"
|
//groupCache = "GROUP_CACHE:"
|
||||||
//groupInfoCache = "GROUP_INFO_CACHE:"
|
//groupInfoCache = "GROUP_INFO_CACHE:"
|
||||||
@ -29,7 +29,7 @@ const (
|
|||||||
//joinedGroupListCache = "JOINED_GROUP_LIST_CACHE:"
|
//joinedGroupListCache = "JOINED_GROUP_LIST_CACHE:"
|
||||||
//groupMemberInfoCache = "GROUP_MEMBER_INFO_CACHE:"
|
//groupMemberInfoCache = "GROUP_MEMBER_INFO_CACHE:"
|
||||||
//groupAllMemberInfoCache = "GROUP_ALL_MEMBER_INFO_CACHE:"
|
//groupAllMemberInfoCache = "GROUP_ALL_MEMBER_INFO_CACHE:"
|
||||||
allFriendInfoCache = "ALL_FRIEND_INFO_CACHE:"
|
//allFriendInfoCache = "ALL_FRIEND_INFO_CACHE:"
|
||||||
//joinedSuperGroupListCache = "JOINED_SUPER_GROUP_LIST_CACHE:"
|
//joinedSuperGroupListCache = "JOINED_SUPER_GROUP_LIST_CACHE:"
|
||||||
//groupMemberListHashCache = "GROUP_MEMBER_LIST_HASH_CACHE:"
|
//groupMemberListHashCache = "GROUP_MEMBER_LIST_HASH_CACHE:"
|
||||||
//groupMemberNumCache = "GROUP_MEMBER_NUM_CACHE:"
|
//groupMemberNumCache = "GROUP_MEMBER_NUM_CACHE:"
|
||||||
|
@ -137,13 +137,13 @@ func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoClient *mongo.C
|
|||||||
groupDB := relation.NewGroupDB(db)
|
groupDB := relation.NewGroupDB(db)
|
||||||
groupMemberDB := relation.NewGroupMemberDB(db)
|
groupMemberDB := relation.NewGroupMemberDB(db)
|
||||||
groupRequestDB := relation.NewGroupRequest(db)
|
groupRequestDB := relation.NewGroupRequest(db)
|
||||||
newDB := db
|
newDB := *db
|
||||||
superGroupMgoDB := unrelation.NewSuperGroupMgoDB(mgoClient)
|
superGroupMgoDB := unrelation.NewSuperGroupMgoDB(mgoClient)
|
||||||
database := &GroupDataBase{
|
database := &GroupDataBase{
|
||||||
groupDB: groupDB,
|
groupDB: groupDB,
|
||||||
groupMemberDB: groupMemberDB,
|
groupMemberDB: groupMemberDB,
|
||||||
groupRequestDB: groupRequestDB,
|
groupRequestDB: groupRequestDB,
|
||||||
db: newDB,
|
db: &newDB,
|
||||||
cache: cache.NewGroupCache(rdb, groupDB, groupMemberDB, groupRequestDB, superGroupMgoDB, rockscache.Options{
|
cache: cache.NewGroupCache(rdb, groupDB, groupMemberDB, groupRequestDB, superGroupMgoDB, rockscache.Options{
|
||||||
RandomExpireAdjustment: 0.2,
|
RandomExpireAdjustment: 0.2,
|
||||||
DisableCacheRead: false,
|
DisableCacheRead: false,
|
||||||
|
24
pkg/common/db/localcache/localCache.go
Normal file
24
pkg/common/db/localcache/localCache.go
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
package localcache
|
||||||
|
|
||||||
|
import "google.golang.org/grpc"
|
||||||
|
|
||||||
|
type GroupLocalCache struct {
|
||||||
|
cache map[string]GroupMemberIDsHash
|
||||||
|
rpc *grpc.ClientConn
|
||||||
|
}
|
||||||
|
|
||||||
|
type GroupMemberIDsHash struct {
|
||||||
|
MemberListHash uint64
|
||||||
|
UserIDs []string
|
||||||
|
}
|
||||||
|
|
||||||
|
func NewGroupMemberIDsLocalCache(rpc *grpc.ClientConn) GroupLocalCache {
|
||||||
|
return GroupLocalCache{
|
||||||
|
cache: make(map[string]GroupMemberIDsHash, 0),
|
||||||
|
rpc: rpc,
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (g *GroupMemberIDsHash) GetGroupMemberIDs(groupID string) []string {
|
||||||
|
return []string{}
|
||||||
|
}
|
@ -20,7 +20,7 @@ type Black struct {
|
|||||||
|
|
||||||
func NewBlack(db *gorm.DB) *Black {
|
func NewBlack(db *gorm.DB) *Black {
|
||||||
var black Black
|
var black Black
|
||||||
black.DB = db
|
black.DB = db.Model(&Black{})
|
||||||
return &black
|
return &black
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -35,7 +35,7 @@ func (b *Black) Delete(ctx context.Context, blacks []*Black) (err error) {
|
|||||||
defer func() {
|
defer func() {
|
||||||
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "blacks", blacks)
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "blacks", blacks)
|
||||||
}()
|
}()
|
||||||
return utils.Wrap(GroupMemberDB.Delete(blacks).Error, "")
|
return utils.Wrap(b.DB.Delete(blacks).Error, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *Black) UpdateByMap(ctx context.Context, ownerUserID, blockUserID string, args map[string]interface{}) (err error) {
|
func (b *Black) UpdateByMap(ctx context.Context, ownerUserID, blockUserID string, args map[string]interface{}) (err error) {
|
||||||
@ -60,7 +60,15 @@ func (b *Black) Find(ctx context.Context, blacks []*Black) (blackList []*Black,
|
|||||||
for _, black := range blacks {
|
for _, black := range blacks {
|
||||||
where = append(where, []interface{}{black.OwnerUserID, black.BlockUserID})
|
where = append(where, []interface{}{black.OwnerUserID, black.BlockUserID})
|
||||||
}
|
}
|
||||||
return blackList, utils.Wrap(GroupMemberDB.Where("(owner_user_id, block_user_id) in ?", where).Find(&blackList).Error, "")
|
return blackList, utils.Wrap(b.DB.Where("(owner_user_id, block_user_id) in ?", where).Find(&blackList).Error, "")
|
||||||
|
}
|
||||||
|
|
||||||
|
func (b *Black) GetBlackIDs(ctx context.Context, ownerUserID string) (userIDs []string, err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID, "userIDs", userIDs)
|
||||||
|
}()
|
||||||
|
err = utils.Wrap(b.DB.Where("owner_user_id = ?", ownerUserID).Pluck("block_user_id", &userIDs).Error, "")
|
||||||
|
return userIDs, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (b *Black) Take(ctx context.Context, ownerUserID, blockUserID string) (black *Black, err error) {
|
func (b *Black) Take(ctx context.Context, ownerUserID, blockUserID string) (black *Black, err error) {
|
||||||
|
@ -26,7 +26,7 @@ type FriendUser struct {
|
|||||||
|
|
||||||
func NewFriendDB(db *gorm.DB) *Friend {
|
func NewFriendDB(db *gorm.DB) *Friend {
|
||||||
var friend Friend
|
var friend Friend
|
||||||
friend.DB = initModel(db, friend)
|
friend.DB = db.Model(friend)
|
||||||
return &friend
|
return &friend
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -63,7 +63,7 @@ func (f *Friend) UpdateRemark(ctx context.Context, ownerUserID, friendUserID, re
|
|||||||
defer func() {
|
defer func() {
|
||||||
tracelog.SetCtxDebug(ctx, utils.GetSelfFuncName(), err, "ownerUserID", ownerUserID, "friendUserID", friendUserID, "remark", remark)
|
tracelog.SetCtxDebug(ctx, utils.GetSelfFuncName(), err, "ownerUserID", ownerUserID, "friendUserID", friendUserID, "remark", remark)
|
||||||
}()
|
}()
|
||||||
return utils.Wrap(f.DB.Model(f).Where("owner_user_id = ? and friend_user_id = ?", ownerUserID, friendUserID).Update("remark", remark).Error, "")
|
return utils.Wrap(f.DB.Where("owner_user_id = ? and friend_user_id = ?", ownerUserID, friendUserID).Update("remark", remark).Error, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *Friend) FindOwnerUserID(ctx context.Context, ownerUserID string) (friends []*Friend, err error) {
|
func (f *Friend) FindOwnerUserID(ctx context.Context, ownerUserID string) (friends []*Friend, err error) {
|
||||||
@ -80,6 +80,17 @@ func (f *Friend) FindFriendUserID(ctx context.Context, friendUserID string) (fri
|
|||||||
return friends, utils.Wrap(f.DB.Where("friend_user_id = ?", friendUserID).Find(&friends).Error, "")
|
return friends, utils.Wrap(f.DB.Where("friend_user_id = ?", friendUserID).Find(&friends).Error, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (f *Friend) GetFriendIDs(ctx context.Context, ownerUserID string) (friendIDList []string, err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetSelfFuncName(), err, "ownerUserID", ownerUserID, "friendIDList", friendIDList)
|
||||||
|
}()
|
||||||
|
err = f.DB.Where("owner_user_id=?", ownerUserID).Pluck("friend_user_id", &friendIDList).Error
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
return friendIDList, nil
|
||||||
|
}
|
||||||
|
|
||||||
func (f *Friend) Take(ctx context.Context, ownerUserID, friendUserID string) (friend *Friend, err error) {
|
func (f *Friend) Take(ctx context.Context, ownerUserID, friendUserID string) (friend *Friend, err error) {
|
||||||
friend = &Friend{}
|
friend = &Friend{}
|
||||||
defer tracelog.SetCtxDebug(ctx, utils.GetSelfFuncName(), err, "ownerUserID", ownerUserID, "friendUserID", friendUserID, "friend", friend)
|
defer tracelog.SetCtxDebug(ctx, utils.GetSelfFuncName(), err, "ownerUserID", ownerUserID, "friendUserID", friendUserID, "friend", friend)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user