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
848e861304
commit
f6cc91d7db
3
pkg/common/db/cache/black.go
vendored
3
pkg/common/db/cache/black.go
vendored
@ -2,6 +2,7 @@ package cache
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/db/relation"
|
"Open_IM/pkg/common/db/relation"
|
||||||
|
"Open_IM/pkg/common/db/table"
|
||||||
"Open_IM/pkg/common/tracelog"
|
"Open_IM/pkg/common/tracelog"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
"context"
|
"context"
|
||||||
@ -16,7 +17,7 @@ const (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type BlackCache struct {
|
type BlackCache struct {
|
||||||
blackDB *relation.Black
|
blackDB *table.BlackModel
|
||||||
expireTime time.Duration
|
expireTime time.Duration
|
||||||
rcClient *rockscache.Client
|
rcClient *rockscache.Client
|
||||||
}
|
}
|
||||||
|
1
pkg/common/db/cache/conversation.go
vendored
Normal file
1
pkg/common/db/cache/conversation.go
vendored
Normal file
@ -0,0 +1 @@
|
|||||||
|
package cache
|
78
pkg/common/db/cache/friend.go
vendored
78
pkg/common/db/cache/friend.go
vendored
@ -2,6 +2,7 @@ package cache
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/db/relation"
|
"Open_IM/pkg/common/db/relation"
|
||||||
|
"Open_IM/pkg/common/db/table"
|
||||||
"Open_IM/pkg/common/tracelog"
|
"Open_IM/pkg/common/tracelog"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
"context"
|
"context"
|
||||||
@ -12,17 +13,19 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
const (
|
const (
|
||||||
friendExpireTime = time.Second * 60 * 60 * 12
|
friendExpireTime = time.Second * 60 * 60 * 12
|
||||||
friendIDsKey = "FRIEND_IDS:"
|
friendIDsKey = "FRIEND_IDS:"
|
||||||
|
TwoWayFriendsIDsKey = "COMMON_FRIENDS_IDS:"
|
||||||
|
friendKey = "FRIEND_INFO:"
|
||||||
)
|
)
|
||||||
|
|
||||||
type FriendCache struct {
|
type FriendCache struct {
|
||||||
friendDB *relation.Friend
|
friendDB *relation.FriendGorm
|
||||||
expireTime time.Duration
|
expireTime time.Duration
|
||||||
rcClient *rockscache.Client
|
rcClient *rockscache.Client
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewFriendCache(rdb redis.UniversalClient, friendDB *relation.Friend, options rockscache.Options) *FriendCache {
|
func NewFriendCache(rdb redis.UniversalClient, friendDB *relation.FriendGorm, options rockscache.Options) *FriendCache {
|
||||||
return &FriendCache{
|
return &FriendCache{
|
||||||
friendDB: friendDB,
|
friendDB: friendDB,
|
||||||
expireTime: friendExpireTime,
|
expireTime: friendExpireTime,
|
||||||
@ -30,17 +33,25 @@ func NewFriendCache(rdb redis.UniversalClient, friendDB *relation.Friend, option
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (f *FriendCache) getFriendRelationKey(ownerUserID string) string {
|
func (f *FriendCache) getFriendIDsKey(ownerUserID string) string {
|
||||||
return friendIDsKey + ownerUserID
|
return friendIDsKey + ownerUserID
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) getTwoWayFriendsIDsKey(ownerUserID string) string {
|
||||||
|
return TwoWayFriendsIDsKey + ownerUserID
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) getFriendKey(ownerUserID, friendUserID string) string {
|
||||||
|
return friendKey + ownerUserID + "-" + friendUserID
|
||||||
|
}
|
||||||
|
|
||||||
func (f *FriendCache) GetFriendIDs(ctx context.Context, ownerUserID string) (friendIDs []string, err error) {
|
func (f *FriendCache) GetFriendIDs(ctx context.Context, ownerUserID string) (friendIDs []string, err error) {
|
||||||
getFriendIDList := func() (string, error) {
|
getFriendIDs := func() (string, error) {
|
||||||
friendIDList, err := f.friendDB.GetFriendIDs(ctx, ownerUserID)
|
friendIDs, err := f.friendDB.GetFriendIDs(ctx, ownerUserID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", err
|
return "", err
|
||||||
}
|
}
|
||||||
bytes, err := json.Marshal(friendIDList)
|
bytes, err := json.Marshal(friendIDs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", utils.Wrap(err, "")
|
return "", utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
@ -49,11 +60,11 @@ func (f *FriendCache) GetFriendIDs(ctx context.Context, ownerUserID string) (fri
|
|||||||
defer func() {
|
defer func() {
|
||||||
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID, "friendIDs", friendIDs)
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID, "friendIDs", friendIDs)
|
||||||
}()
|
}()
|
||||||
friendIDListStr, err := f.rcClient.Fetch(f.getFriendRelationKey(ownerUserID), f.expireTime, getFriendIDList)
|
friendIDsStr, err := f.rcClient.Fetch(f.getFriendIDsKey(ownerUserID), f.expireTime, getFriendIDs)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
err = json.Unmarshal([]byte(friendIDListStr), &friendIDs)
|
err = json.Unmarshal([]byte(friendIDsStr), &friendIDs)
|
||||||
return friendIDs, utils.Wrap(err, "")
|
return friendIDs, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,5 +72,50 @@ func (f *FriendCache) DelFriendIDs(ctx context.Context, ownerUserID string) (err
|
|||||||
defer func() {
|
defer func() {
|
||||||
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID)
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID)
|
||||||
}()
|
}()
|
||||||
return f.rcClient.TagAsDeleted(f.getFriendRelationKey(ownerUserID))
|
return f.rcClient.TagAsDeleted(f.getFriendIDsKey(ownerUserID))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) GetTwoWayFriendIDs(ctx context.Context, ownerUserID string) (twoWayFriendIDs []string, err error) {
|
||||||
|
friendIDs, err := f.GetFriendIDs(ctx, ownerUserID)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
for _, friendID := range friendIDs {
|
||||||
|
friendFriendID, err := f.GetFriendIDs(ctx, friendID)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
if utils.IsContain(ownerUserID, friendFriendID) {
|
||||||
|
twoWayFriendIDs = append(twoWayFriendIDs, ownerUserID)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return twoWayFriendIDs, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) DelTwoWayFriendIDs(ctx context.Context, ownerUserID string) (err error) {
|
||||||
|
defer func() {
|
||||||
|
tracelog.SetCtxDebug(ctx, utils.GetFuncName(1), err, "ownerUserID", ownerUserID)
|
||||||
|
}()
|
||||||
|
return f.rcClient.TagAsDeleted(f.getTwoWayFriendsIDsKey(ownerUserID))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (f *FriendCache) GetFriend(ctx context.Context, ownerUserID, friendUserID string) (friend *table.FriendModel, err error) {
|
||||||
|
getFriend := func() (string, error) {
|
||||||
|
friend, err = f.friendDB.Take(ctx, ownerUserID, friendUserID)
|
||||||
|
if err != nil {
|
||||||
|
return "", err
|
||||||
|
}
|
||||||
|
bytes, err := json.Marshal(friend)
|
||||||
|
if err != nil {
|
||||||
|
return "", utils.Wrap(err, "")
|
||||||
|
}
|
||||||
|
return string(bytes), nil
|
||||||
|
}
|
||||||
|
friendStr, err := f.rcClient.Fetch(f.getFriendKey(ownerUserID, friendUserID), f.expireTime, getFriend)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
friendInfo := &relation.FriendUser{}
|
||||||
|
err = json.Unmarshal([]byte(groupMemberInfoStr), groupMember)
|
||||||
|
return groupMember, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
4
pkg/common/db/cache/group.go
vendored
4
pkg/common/db/cache/group.go
vendored
@ -33,7 +33,7 @@ type GroupCache struct {
|
|||||||
group *relation.GroupGorm
|
group *relation.GroupGorm
|
||||||
groupMember *relation.GroupMemberGorm
|
groupMember *relation.GroupMemberGorm
|
||||||
groupRequest *relation.GroupRequestGorm
|
groupRequest *relation.GroupRequestGorm
|
||||||
mongoDB *unrelation.SuperGroupMgoDB
|
mongoDB *unrelation.SuperGroupMongoDriver
|
||||||
expireTime time.Duration
|
expireTime time.Duration
|
||||||
redisClient *RedisClient
|
redisClient *RedisClient
|
||||||
rcClient *rockscache.Client
|
rcClient *rockscache.Client
|
||||||
@ -43,7 +43,7 @@ type GroupCache struct {
|
|||||||
cacheGroupMemberUserIDs map[string]*localcache.GroupMemberIDsHash
|
cacheGroupMemberUserIDs map[string]*localcache.GroupMemberIDsHash
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewGroupCache(rdb redis.UniversalClient, groupDB *relation.GroupGorm, groupMemberDB *relation.GroupMemberGorm, groupRequestDB *relation.GroupRequestGorm, mongoClient *unrelation.SuperGroupMgoDB, opts rockscache.Options) *GroupCache {
|
func NewGroupCache(rdb redis.UniversalClient, groupDB *relation.GroupGorm, groupMemberDB *relation.GroupMemberGorm, groupRequestDB *relation.GroupRequestGorm, mongoClient *unrelation.SuperGroupMongoDriver, 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]*localcache.GroupMemberIDsHash, 0),
|
mongoDB: mongoClient, cacheGroupMemberUserIDs: make(map[string]*localcache.GroupMemberIDsHash, 0),
|
||||||
|
@ -180,7 +180,7 @@ type GroupDataBase struct {
|
|||||||
db *gorm.DB
|
db *gorm.DB
|
||||||
|
|
||||||
cache *cache.GroupCache
|
cache *cache.GroupCache
|
||||||
mongoDB *unrelation.SuperGroupMgoDB
|
mongoDB *unrelation.SuperGroupMongoDriver
|
||||||
}
|
}
|
||||||
|
|
||||||
func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoClient *mongo.Client) GroupDataBaseInterface {
|
func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoClient *mongo.Client) GroupDataBaseInterface {
|
||||||
@ -188,19 +188,19 @@ func newGroupDatabase(db *gorm.DB, rdb redis.UniversalClient, mgoClient *mongo.C
|
|||||||
groupMemberDB := relation.NewGroupMemberDB(db)
|
groupMemberDB := relation.NewGroupMemberDB(db)
|
||||||
groupRequestDB := relation.NewGroupRequest(db)
|
groupRequestDB := relation.NewGroupRequest(db)
|
||||||
newDB := *db
|
newDB := *db
|
||||||
superGroupMgoDB := unrelation.NewSuperGroupMgoDB(mgoClient)
|
SuperGroupMongoDriver := unrelation.NewSuperGroupMongoDriver(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, SuperGroupMongoDriver, rockscache.Options{
|
||||||
RandomExpireAdjustment: 0.2,
|
RandomExpireAdjustment: 0.2,
|
||||||
DisableCacheRead: false,
|
DisableCacheRead: false,
|
||||||
DisableCacheDelete: false,
|
DisableCacheDelete: false,
|
||||||
StrongConsistency: true,
|
StrongConsistency: true,
|
||||||
}),
|
}),
|
||||||
mongoDB: superGroupMgoDB,
|
mongoDB: SuperGroupMongoDriver,
|
||||||
}
|
}
|
||||||
return database
|
return database
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package relation
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/constant"
|
"Open_IM/pkg/common/constant"
|
||||||
|
"Open_IM/pkg/common/db/table"
|
||||||
pbMsg "Open_IM/pkg/proto/msg"
|
pbMsg "Open_IM/pkg/proto/msg"
|
||||||
server_api_params "Open_IM/pkg/proto/sdk_ws"
|
server_api_params "Open_IM/pkg/proto/sdk_ws"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
@ -10,38 +11,18 @@ import (
|
|||||||
"github.com/golang/protobuf/proto"
|
"github.com/golang/protobuf/proto"
|
||||||
"github.com/jinzhu/copier"
|
"github.com/jinzhu/copier"
|
||||||
"gorm.io/gorm"
|
"gorm.io/gorm"
|
||||||
"time"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
type ChatLog struct {
|
type ChatLogGorm struct {
|
||||||
ServerMsgID string `gorm:"column:server_msg_id;primary_key;type:char(64)" json:"serverMsgID"`
|
DB *gorm.DB
|
||||||
ClientMsgID string `gorm:"column:client_msg_id;type:char(64)" json:"clientMsgID"`
|
|
||||||
SendID string `gorm:"column:send_id;type:char(64);index:send_id,priority:2" json:"sendID"`
|
|
||||||
RecvID string `gorm:"column:recv_id;type:char(64);index:recv_id,priority:2" json:"recvID"`
|
|
||||||
SenderPlatformID int32 `gorm:"column:sender_platform_id" json:"senderPlatformID"`
|
|
||||||
SenderNickname string `gorm:"column:sender_nick_name;type:varchar(255)" json:"senderNickname"`
|
|
||||||
SenderFaceURL string `gorm:"column:sender_face_url;type:varchar(255);" json:"senderFaceURL"`
|
|
||||||
SessionType int32 `gorm:"column:session_type;index:session_type,priority:2;index:session_type_alone" json:"sessionType"`
|
|
||||||
MsgFrom int32 `gorm:"column:msg_from" json:"msgFrom"`
|
|
||||||
ContentType int32 `gorm:"column:content_type;index:content_type,priority:2;index:content_type_alone" json:"contentType"`
|
|
||||||
Content string `gorm:"column:content;type:varchar(3000)" json:"content"`
|
|
||||||
Status int32 `gorm:"column:status" json:"status"`
|
|
||||||
SendTime time.Time `gorm:"column:send_time;index:sendTime;index:content_type,priority:1;index:session_type,priority:1;index:recv_id,priority:1;index:send_id,priority:1" json:"sendTime"`
|
|
||||||
CreateTime time.Time `gorm:"column:create_time" json:"createTime"`
|
|
||||||
Ex string `gorm:"column:ex;type:varchar(1024)" json:"ex"`
|
|
||||||
DB *gorm.DB
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (ChatLog) TableName() string {
|
func NewChatLog(db *gorm.DB) *ChatLogGorm {
|
||||||
return "chat_logs"
|
return &ChatLogGorm{DB: db}
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewChatLog(db *gorm.DB) *ChatLog {
|
func (c *ChatLogGorm) Create(msg pbMsg.MsgDataToMQ) error {
|
||||||
return &ChatLog{DB: db}
|
chatLog := new(table.ChatLogModel)
|
||||||
}
|
|
||||||
|
|
||||||
func (c *ChatLog) Create(msg pbMsg.MsgDataToMQ) error {
|
|
||||||
chatLog := new(ChatLog)
|
|
||||||
copier.Copy(chatLog, msg.MsgData)
|
copier.Copy(chatLog, msg.MsgData)
|
||||||
switch msg.MsgData.SessionType {
|
switch msg.MsgData.SessionType {
|
||||||
case constant.GroupChatType, constant.SuperGroupChatType:
|
case constant.GroupChatType, constant.SuperGroupChatType:
|
||||||
@ -66,7 +47,7 @@ func (c *ChatLog) Create(msg pbMsg.MsgDataToMQ) error {
|
|||||||
return c.DB.Create(chatLog).Error
|
return c.DB.Create(chatLog).Error
|
||||||
}
|
}
|
||||||
|
|
||||||
func (c *ChatLog) GetChatLog(chatLog *ChatLog, pageNumber, showNumber int32, contentTypeList []int32) (int64, []ChatLog, error) {
|
func (c *ChatLogGorm) GetChatLog(chatLog *table.ChatLogModel, pageNumber, showNumber int32, contentTypeList []int32) (int64, []ChatLogModel, error) {
|
||||||
mdb := c.DB.Model(chatLog)
|
mdb := c.DB.Model(chatLog)
|
||||||
if chatLog.SendTime.Unix() > 0 {
|
if chatLog.SendTime.Unix() > 0 {
|
||||||
mdb = mdb.Where("send_time > ? and send_time < ?", chatLog.SendTime, chatLog.SendTime.AddDate(0, 0, 1))
|
mdb = mdb.Where("send_time > ? and send_time < ?", chatLog.SendTime, chatLog.SendTime.AddDate(0, 0, 1))
|
||||||
@ -95,7 +76,7 @@ func (c *ChatLog) GetChatLog(chatLog *ChatLog, pageNumber, showNumber int32, con
|
|||||||
if err := mdb.Count(&count).Error; err != nil {
|
if err := mdb.Count(&count).Error; err != nil {
|
||||||
return 0, nil, err
|
return 0, nil, err
|
||||||
}
|
}
|
||||||
var chatLogs []ChatLog
|
var chatLogs []table.ChatLogModel
|
||||||
mdb = mdb.Limit(int(showNumber)).Offset(int(showNumber * (pageNumber - 1)))
|
mdb = mdb.Limit(int(showNumber)).Offset(int(showNumber * (pageNumber - 1)))
|
||||||
if err := mdb.Find(&chatLogs).Error; err != nil {
|
if err := mdb.Find(&chatLogs).Error; err != nil {
|
||||||
return 0, nil, err
|
return 0, nil, err
|
||||||
|
@ -1,9 +1,15 @@
|
|||||||
package table
|
package table
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"gorm.io/gorm"
|
||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
FriendModelTableName = ""
|
||||||
|
ConversationModelTableName = ""
|
||||||
|
)
|
||||||
|
|
||||||
type FriendModel struct {
|
type FriendModel struct {
|
||||||
OwnerUserID string `gorm:"column:owner_user_id;primary_key;size:64"`
|
OwnerUserID string `gorm:"column:owner_user_id;primary_key;size:64"`
|
||||||
FriendUserID string `gorm:"column:friend_user_id;primary_key;size:64"`
|
FriendUserID string `gorm:"column:friend_user_id;primary_key;size:64"`
|
||||||
@ -13,6 +19,7 @@ type FriendModel struct {
|
|||||||
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
||||||
Ex string `gorm:"column:ex;size:1024"`
|
Ex string `gorm:"column:ex;size:1024"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type ConversationModel struct {
|
type ConversationModel struct {
|
||||||
OwnerUserID string `gorm:"column:owner_user_id;primary_key;type:char(128)" json:"OwnerUserID"`
|
OwnerUserID string `gorm:"column:owner_user_id;primary_key;type:char(128)" json:"OwnerUserID"`
|
||||||
ConversationID string `gorm:"column:conversation_id;primary_key;type:char(128)" json:"conversationID"`
|
ConversationID string `gorm:"column:conversation_id;primary_key;type:char(128)" json:"conversationID"`
|
||||||
@ -102,7 +109,6 @@ type UserModel struct {
|
|||||||
CreateTime time.Time `gorm:"column:create_time;index:create_time"`
|
CreateTime time.Time `gorm:"column:create_time;index:create_time"`
|
||||||
AppMangerLevel int32 `gorm:"column:app_manger_level"`
|
AppMangerLevel int32 `gorm:"column:app_manger_level"`
|
||||||
GlobalRecvMsgOpt int32 `gorm:"column:global_recv_msg_opt"`
|
GlobalRecvMsgOpt int32 `gorm:"column:global_recv_msg_opt"`
|
||||||
status int32 `gorm:"column:status"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type BlackModel struct {
|
type BlackModel struct {
|
||||||
@ -113,3 +119,22 @@ type BlackModel struct {
|
|||||||
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
OperatorUserID string `gorm:"column:operator_user_id;size:64"`
|
||||||
Ex string `gorm:"column:ex;size:1024"`
|
Ex string `gorm:"column:ex;size:1024"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ChatLogModel struct {
|
||||||
|
ServerMsgID string `gorm:"column:server_msg_id;primary_key;type:char(64)" json:"serverMsgID"`
|
||||||
|
ClientMsgID string `gorm:"column:client_msg_id;type:char(64)" json:"clientMsgID"`
|
||||||
|
SendID string `gorm:"column:send_id;type:char(64);index:send_id,priority:2" json:"sendID"`
|
||||||
|
RecvID string `gorm:"column:recv_id;type:char(64);index:recv_id,priority:2" json:"recvID"`
|
||||||
|
SenderPlatformID int32 `gorm:"column:sender_platform_id" json:"senderPlatformID"`
|
||||||
|
SenderNickname string `gorm:"column:sender_nick_name;type:varchar(255)" json:"senderNickname"`
|
||||||
|
SenderFaceURL string `gorm:"column:sender_face_url;type:varchar(255);" json:"senderFaceURL"`
|
||||||
|
SessionType int32 `gorm:"column:session_type;index:session_type,priority:2;index:session_type_alone" json:"sessionType"`
|
||||||
|
MsgFrom int32 `gorm:"column:msg_from" json:"msgFrom"`
|
||||||
|
ContentType int32 `gorm:"column:content_type;index:content_type,priority:2;index:content_type_alone" json:"contentType"`
|
||||||
|
Content string `gorm:"column:content;type:varchar(3000)" json:"content"`
|
||||||
|
Status int32 `gorm:"column:status" json:"status"`
|
||||||
|
SendTime time.Time `gorm:"column:send_time;index:sendTime;index:content_type,priority:1;index:session_type,priority:1;index:recv_id,priority:1;index:send_id,priority:1" json:"sendTime"`
|
||||||
|
CreateTime time.Time `gorm:"column:create_time" json:"createTime"`
|
||||||
|
Ex string `gorm:"column:ex;type:varchar(1024)" json:"ex"`
|
||||||
|
DB *gorm.DB
|
||||||
|
}
|
||||||
|
@ -1,48 +1,84 @@
|
|||||||
package table
|
package table
|
||||||
|
|
||||||
type SuperGroup struct {
|
import (
|
||||||
|
"strconv"
|
||||||
|
"strings"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
CSuperGroup = "super_group"
|
||||||
|
CUserToSuperGroup = "user_to_super_group"
|
||||||
|
CTag = "tag"
|
||||||
|
CSendLog = "send_log"
|
||||||
|
CWorkMoment = "work_moment"
|
||||||
|
CExtendMsgSet = "extend_msgs"
|
||||||
|
|
||||||
|
ExtendMsgMaxNum = 100
|
||||||
|
)
|
||||||
|
|
||||||
|
type SuperGroupModel struct {
|
||||||
GroupID string `bson:"group_id" json:"groupID"`
|
GroupID string `bson:"group_id" json:"groupID"`
|
||||||
MemberIDList []string `bson:"member_id_list" json:"memberIDList"`
|
MemberIDList []string `bson:"member_id_list" json:"memberIDList"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type UserToSuperGroup struct {
|
func (SuperGroupModel) TableName() string {
|
||||||
|
return CSuperGroup
|
||||||
|
}
|
||||||
|
|
||||||
|
type UserToSuperGroupModel struct {
|
||||||
UserID string `bson:"user_id" json:"userID"`
|
UserID string `bson:"user_id" json:"userID"`
|
||||||
GroupIDList []string `bson:"group_id_list" json:"groupIDList"`
|
GroupIDList []string `bson:"group_id_list" json:"groupIDList"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type Tag struct {
|
func (UserToSuperGroupModel) TableName() string {
|
||||||
|
return CUserToSuperGroup
|
||||||
|
}
|
||||||
|
|
||||||
|
type TagModel struct {
|
||||||
UserID string `bson:"user_id"`
|
UserID string `bson:"user_id"`
|
||||||
TagID string `bson:"tag_id"`
|
TagID string `bson:"tag_id"`
|
||||||
TagName string `bson:"tag_name"`
|
TagName string `bson:"tag_name"`
|
||||||
UserList []string `bson:"user_list"`
|
UserList []string `bson:"user_list"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type CommonUser struct {
|
func (TagModel) TableName() string {
|
||||||
|
return CTag
|
||||||
|
}
|
||||||
|
|
||||||
|
type CommonUserModel struct {
|
||||||
UserID string `bson:"user_id"`
|
UserID string `bson:"user_id"`
|
||||||
UserName string `bson:"user_name"`
|
UserName string `bson:"user_name"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type TagSendLog struct {
|
type TagSendLogModel struct {
|
||||||
UserList []CommonUser `bson:"tag_list"`
|
UserList []CommonUserModel `bson:"tag_list"`
|
||||||
SendID string `bson:"send_id"`
|
SendID string `bson:"send_id"`
|
||||||
SenderPlatformID int32 `bson:"sender_platform_id"`
|
SenderPlatformID int32 `bson:"sender_platform_id"`
|
||||||
Content string `bson:"content"`
|
Content string `bson:"content"`
|
||||||
SendTime int64 `bson:"send_time"`
|
SendTime int64 `bson:"send_time"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (TagSendLogModel) TableName() string {
|
||||||
|
return CSendLog
|
||||||
}
|
}
|
||||||
|
|
||||||
type WorkMoment struct {
|
type WorkMoment struct {
|
||||||
WorkMomentID string `bson:"work_moment_id"`
|
WorkMomentID string `bson:"work_moment_id"`
|
||||||
UserID string `bson:"user_id"`
|
UserID string `bson:"user_id"`
|
||||||
UserName string `bson:"user_name"`
|
UserName string `bson:"user_name"`
|
||||||
FaceURL string `bson:"face_url"`
|
FaceURL string `bson:"face_url"`
|
||||||
Content string `bson:"content"`
|
Content string `bson:"content"`
|
||||||
LikeUserList []*CommonUser `bson:"like_user_list"`
|
LikeUserList []*CommonUserModel `bson:"like_user_list"`
|
||||||
AtUserList []*CommonUser `bson:"at_user_list"`
|
AtUserList []*CommonUserModel `bson:"at_user_list"`
|
||||||
PermissionUserList []*CommonUser `bson:"permission_user_list"`
|
PermissionUserList []*CommonUserModel `bson:"permission_user_list"`
|
||||||
Comments []*CommonUser `bson:"comments"`
|
Comments []*CommonUserModel `bson:"comments"`
|
||||||
PermissionUserIDList []string `bson:"permission_user_id_list"`
|
PermissionUserIDList []string `bson:"permission_user_id_list"`
|
||||||
Permission int32 `bson:"permission"`
|
Permission int32 `bson:"permission"`
|
||||||
CreateTime int32 `bson:"create_time"`
|
CreateTime int32 `bson:"create_time"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (WorkMoment) TableName() string {
|
||||||
|
return CWorkMoment
|
||||||
}
|
}
|
||||||
|
|
||||||
type Comment struct {
|
type Comment struct {
|
||||||
@ -54,3 +90,44 @@ type Comment struct {
|
|||||||
Content string `bson:"content" json:"content"`
|
Content string `bson:"content" json:"content"`
|
||||||
CreateTime int32 `bson:"create_time" json:"create_time"`
|
CreateTime int32 `bson:"create_time" json:"create_time"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type ExtendMsgSet struct {
|
||||||
|
SourceID string `bson:"source_id" json:"sourceID"`
|
||||||
|
SessionType int32 `bson:"session_type" json:"sessionType"`
|
||||||
|
ExtendMsgs map[string]ExtendMsg `bson:"extend_msgs" json:"extendMsgs"`
|
||||||
|
ExtendMsgNum int32 `bson:"extend_msg_num" json:"extendMsgNum"`
|
||||||
|
CreateTime int64 `bson:"create_time" json:"createTime"` // this block's create time
|
||||||
|
MaxMsgUpdateTime int64 `bson:"max_msg_update_time" json:"maxMsgUpdateTime"` // index find msg
|
||||||
|
}
|
||||||
|
|
||||||
|
type KeyValue struct {
|
||||||
|
TypeKey string `bson:"type_key" json:"typeKey"`
|
||||||
|
Value string `bson:"value" json:"value"`
|
||||||
|
LatestUpdateTime int64 `bson:"latest_update_time" json:"latestUpdateTime"`
|
||||||
|
}
|
||||||
|
|
||||||
|
type ExtendMsg struct {
|
||||||
|
ReactionExtensionList map[string]KeyValue `bson:"reaction_extension_list" json:"reactionExtensionList"`
|
||||||
|
ClientMsgID string `bson:"client_msg_id" json:"clientMsgID"`
|
||||||
|
MsgFirstModifyTime int64 `bson:"msg_first_modify_time" json:"msgFirstModifyTime"` // this extendMsg create time
|
||||||
|
AttachedInfo string `bson:"attached_info" json:"attachedInfo"`
|
||||||
|
Ex string `bson:"ex" json:"ex"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ExtendMsgSet) TableName() string {
|
||||||
|
return CExtendMsgSet
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ExtendMsgSet) GetExtendMsgMaxNum() int32 {
|
||||||
|
return ExtendMsgMaxNum
|
||||||
|
}
|
||||||
|
|
||||||
|
func (ExtendMsgSet) GetSourceID(ID string, index int32) string {
|
||||||
|
return ID + ":" + strconv.Itoa(int(index))
|
||||||
|
}
|
||||||
|
|
||||||
|
func (e *ExtendMsgSet) SplitSourceIDAndGetIndex() int32 {
|
||||||
|
l := strings.Split(e.SourceID, ":")
|
||||||
|
index, _ := strconv.Atoi(l[len(l)-1])
|
||||||
|
return int32(index)
|
||||||
|
}
|
||||||
|
@ -1,67 +1,29 @@
|
|||||||
package unrelation
|
package unrelation
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/config"
|
"Open_IM/pkg/common/db/table"
|
||||||
"Open_IM/pkg/common/db"
|
|
||||||
server_api_params "Open_IM/pkg/proto/sdk_ws"
|
server_api_params "Open_IM/pkg/proto/sdk_ws"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
"context"
|
"context"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"go.mongodb.org/mongo-driver/bson"
|
||||||
"go.mongodb.org/mongo-driver/bson/primitive"
|
"go.mongodb.org/mongo-driver/bson/primitive"
|
||||||
"go.mongodb.org/mongo-driver/mongo"
|
"go.mongodb.org/mongo-driver/mongo"
|
||||||
"go.mongodb.org/mongo-driver/mongo/options"
|
"go.mongodb.org/mongo-driver/mongo/options"
|
||||||
"strconv"
|
|
||||||
"strings"
|
|
||||||
"time"
|
|
||||||
|
|
||||||
"go.mongodb.org/mongo-driver/bson"
|
|
||||||
)
|
)
|
||||||
|
|
||||||
const cExtendMsgSet = "extend_msgs"
|
type ExtendMsgSetMongoDriver struct {
|
||||||
const MaxNum = 100
|
mgoDB *mongo.Database
|
||||||
|
ExtendMsgSetCollection *mongo.Collection
|
||||||
type ExtendMsgSet struct {
|
|
||||||
SourceID string `bson:"source_id" json:"sourceID"`
|
|
||||||
SessionType int32 `bson:"session_type" json:"sessionType"`
|
|
||||||
ExtendMsgs map[string]ExtendMsg `bson:"extend_msgs" json:"extendMsgs"`
|
|
||||||
ExtendMsgNum int32 `bson:"extend_msg_num" json:"extendMsgNum"`
|
|
||||||
CreateTime int64 `bson:"create_time" json:"createTime"` // this block's create time
|
|
||||||
MaxMsgUpdateTime int64 `bson:"max_msg_update_time" json:"maxMsgUpdateTime"` // index find msg
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type KeyValue struct {
|
func NewExtendMsgSetMongoDriver(mgoDB *mongo.Database) *ExtendMsgSetMongoDriver {
|
||||||
TypeKey string `bson:"type_key" json:"typeKey"`
|
return &ExtendMsgSetMongoDriver{mgoDB: mgoDB, ExtendMsgSetCollection: mgoDB.Collection(table.CExtendMsgSet)}
|
||||||
Value string `bson:"value" json:"value"`
|
|
||||||
LatestUpdateTime int64 `bson:"latest_update_time" json:"latestUpdateTime"`
|
|
||||||
}
|
}
|
||||||
|
|
||||||
type ExtendMsg struct {
|
func (e *ExtendMsgSetMongoDriver) CreateExtendMsgSet(ctx context.Context, set *table.ExtendMsgSet) error {
|
||||||
ReactionExtensionList map[string]KeyValue `bson:"reaction_extension_list" json:"reactionExtensionList"`
|
_, err := e.ExtendMsgSetCollection.InsertOne(ctx, set)
|
||||||
ClientMsgID string `bson:"client_msg_id" json:"clientMsgID"`
|
|
||||||
MsgFirstModifyTime int64 `bson:"msg_first_modify_time" json:"msgFirstModifyTime"` // this extendMsg create time
|
|
||||||
AttachedInfo string `bson:"attached_info" json:"attachedInfo"`
|
|
||||||
Ex string `bson:"ex" json:"ex"`
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetExtendMsgMaxNum() int32 {
|
|
||||||
return MaxNum
|
|
||||||
}
|
|
||||||
|
|
||||||
func GetExtendMsgSourceID(ID string, index int32) string {
|
|
||||||
return ID + ":" + strconv.Itoa(int(index))
|
|
||||||
}
|
|
||||||
|
|
||||||
func SplitSourceIDAndGetIndex(sourceID string) int32 {
|
|
||||||
l := strings.Split(sourceID, ":")
|
|
||||||
index, _ := strconv.Atoi(l[len(l)-1])
|
|
||||||
return int32(index)
|
|
||||||
}
|
|
||||||
|
|
||||||
func (d *db.DataBases) CreateExtendMsgSet(set *ExtendMsgSet) error {
|
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
_, err := c.InsertOne(ctx, set)
|
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -69,9 +31,7 @@ type GetAllExtendMsgSetOpts struct {
|
|||||||
ExcludeExtendMsgs bool
|
ExcludeExtendMsgs bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *db.DataBases) GetAllExtendMsgSet(ID string, opts *GetAllExtendMsgSetOpts) (sets []*ExtendMsgSet, err error) {
|
func (e *ExtendMsgSetMongoDriver) GetAllExtendMsgSet(ctx context.Context, ID string, opts *GetAllExtendMsgSetOpts) (sets []*table.ExtendMsgSet, err error) {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
regex := fmt.Sprintf("^%s", ID)
|
regex := fmt.Sprintf("^%s", ID)
|
||||||
var findOpts *options.FindOptions
|
var findOpts *options.FindOptions
|
||||||
if opts != nil {
|
if opts != nil {
|
||||||
@ -80,7 +40,7 @@ func (d *db.DataBases) GetAllExtendMsgSet(ID string, opts *GetAllExtendMsgSetOpt
|
|||||||
findOpts.SetProjection(bson.M{"extend_msgs": 0})
|
findOpts.SetProjection(bson.M{"extend_msgs": 0})
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cursor, err := c.Find(ctx, bson.M{"uid": primitive.Regex{Pattern: regex}}, findOpts)
|
cursor, err := e.ExtendMsgSetCollection.Find(ctx, bson.M{"uid": primitive.Regex{Pattern: regex}}, findOpts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, utils.Wrap(err, "")
|
return nil, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
@ -91,20 +51,19 @@ func (d *db.DataBases) GetAllExtendMsgSet(ID string, opts *GetAllExtendMsgSetOpt
|
|||||||
return sets, nil
|
return sets, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *db.DataBases) GetExtendMsgSet(ctx context.Context, sourceID string, sessionType int32, maxMsgUpdateTime int64, c *mongo.Collection) (*ExtendMsgSet, error) {
|
func (e *ExtendMsgSetMongoDriver) GetExtendMsgSet(ctx context.Context, sourceID string, sessionType int32, maxMsgUpdateTime int64) (*table.ExtendMsgSet, error) {
|
||||||
regex := fmt.Sprintf("^%s", sourceID)
|
|
||||||
var err error
|
var err error
|
||||||
findOpts := options.Find().SetLimit(1).SetSkip(0).SetSort(bson.M{"source_id": -1}).SetProjection(bson.M{"extend_msgs": 0})
|
findOpts := options.Find().SetLimit(1).SetSkip(0).SetSort(bson.M{"source_id": -1}).SetProjection(bson.M{"extend_msgs": 0})
|
||||||
// update newest
|
// update newest
|
||||||
find := bson.M{"source_id": primitive.Regex{Pattern: regex}, "session_type": sessionType}
|
find := bson.M{"source_id": primitive.Regex{Pattern: fmt.Sprintf("^%s", sourceID)}, "session_type": sessionType}
|
||||||
if maxMsgUpdateTime > 0 {
|
if maxMsgUpdateTime > 0 {
|
||||||
find["max_msg_update_time"] = maxMsgUpdateTime
|
find["max_msg_update_time"] = maxMsgUpdateTime
|
||||||
}
|
}
|
||||||
result, err := c.Find(ctx, find, findOpts)
|
result, err := e.ExtendMsgSetCollection.Find(ctx, find, findOpts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, utils.Wrap(err, "")
|
return nil, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
var setList []ExtendMsgSet
|
var setList []table.ExtendMsgSet
|
||||||
if err := result.All(ctx, &setList); err != nil {
|
if err := result.All(ctx, &setList); err != nil {
|
||||||
return nil, utils.Wrap(err, "")
|
return nil, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
@ -115,36 +74,32 @@ func (d *db.DataBases) GetExtendMsgSet(ctx context.Context, sourceID string, ses
|
|||||||
}
|
}
|
||||||
|
|
||||||
// first modify msg
|
// first modify msg
|
||||||
func (d *db.DataBases) InsertExtendMsg(sourceID string, sessionType int32, msg *ExtendMsg) error {
|
func (e *ExtendMsgSetMongoDriver) InsertExtendMsg(ctx context.Context, sourceID string, sessionType int32, msg *table.ExtendMsg) error {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
set, err := e.GetExtendMsgSet(ctx, sourceID, sessionType, 0)
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
set, err := d.GetExtendMsgSet(ctx, sourceID, sessionType, 0, c)
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return utils.Wrap(err, "")
|
return utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
if set == nil || set.ExtendMsgNum >= GetExtendMsgMaxNum() {
|
if set == nil || set.ExtendMsgNum >= set.GetExtendMsgMaxNum() {
|
||||||
var index int32
|
var index int32
|
||||||
if set != nil {
|
if set != nil {
|
||||||
index = SplitSourceIDAndGetIndex(set.SourceID)
|
index = set.SplitSourceIDAndGetIndex()
|
||||||
}
|
}
|
||||||
err = d.CreateExtendMsgSet(&ExtendMsgSet{
|
err = e.CreateExtendMsgSet(ctx, &table.ExtendMsgSet{
|
||||||
SourceID: GetExtendMsgSourceID(sourceID, index),
|
SourceID: set.GetSourceID(sourceID, index),
|
||||||
SessionType: sessionType,
|
SessionType: sessionType,
|
||||||
ExtendMsgs: map[string]ExtendMsg{msg.ClientMsgID: *msg},
|
ExtendMsgs: map[string]table.ExtendMsg{msg.ClientMsgID: *msg},
|
||||||
ExtendMsgNum: 1,
|
ExtendMsgNum: 1,
|
||||||
CreateTime: msg.MsgFirstModifyTime,
|
CreateTime: msg.MsgFirstModifyTime,
|
||||||
MaxMsgUpdateTime: msg.MsgFirstModifyTime,
|
MaxMsgUpdateTime: msg.MsgFirstModifyTime,
|
||||||
})
|
})
|
||||||
} else {
|
} else {
|
||||||
_, err = c.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$set": bson.M{"max_msg_update_time": msg.MsgFirstModifyTime, "$inc": bson.M{"extend_msg_num": 1}, fmt.Sprintf("extend_msgs.%s", msg.ClientMsgID): msg}})
|
_, err = e.ExtendMsgSetCollection.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$set": bson.M{"max_msg_update_time": msg.MsgFirstModifyTime, "$inc": bson.M{"extend_msg_num": 1}, fmt.Sprintf("extend_msgs.%s", msg.ClientMsgID): msg}})
|
||||||
}
|
}
|
||||||
return utils.Wrap(err, "")
|
return utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
// insert or update
|
// insert or update
|
||||||
func (d *db.DataBases) InsertOrUpdateReactionExtendMsgSet(sourceID string, sessionType int32, clientMsgID string, msgFirstModifyTime int64, reactionExtensionList map[string]*server_api_params.KeyValue) error {
|
func (e *ExtendMsgSetMongoDriver) InsertOrUpdateReactionExtendMsgSet(ctx context.Context, sourceID string, sessionType int32, clientMsgID string, msgFirstModifyTime int64, reactionExtensionList map[string]*server_api_params.KeyValue) error {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
var updateBson = bson.M{}
|
var updateBson = bson.M{}
|
||||||
for _, v := range reactionExtensionList {
|
for _, v := range reactionExtensionList {
|
||||||
updateBson[fmt.Sprintf("extend_msgs.%s.%s", clientMsgID, v.TypeKey)] = v
|
updateBson[fmt.Sprintf("extend_msgs.%s.%s", clientMsgID, v.TypeKey)] = v
|
||||||
@ -153,46 +108,42 @@ func (d *db.DataBases) InsertOrUpdateReactionExtendMsgSet(sourceID string, sessi
|
|||||||
opt := &options.UpdateOptions{
|
opt := &options.UpdateOptions{
|
||||||
Upsert: &upsert,
|
Upsert: &upsert,
|
||||||
}
|
}
|
||||||
set, err := d.GetExtendMsgSet(ctx, sourceID, sessionType, msgFirstModifyTime, c)
|
set, err := e.GetExtendMsgSet(ctx, sourceID, sessionType, msgFirstModifyTime)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return utils.Wrap(err, "")
|
return utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
if set == nil {
|
if set == nil {
|
||||||
return errors.New(fmt.Sprintf("sourceID %s has no set", sourceID))
|
return errors.New(fmt.Sprintf("sourceID %s has no set", sourceID))
|
||||||
}
|
}
|
||||||
_, err = c.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$set": updateBson}, opt)
|
_, err = e.ExtendMsgSetCollection.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$set": updateBson}, opt)
|
||||||
return utils.Wrap(err, "")
|
return utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
// delete TypeKey
|
// delete TypeKey
|
||||||
func (d *db.DataBases) DeleteReactionExtendMsgSet(sourceID string, sessionType int32, clientMsgID string, msgFirstModifyTime int64, reactionExtensionList map[string]*server_api_params.KeyValue) error {
|
func (e *ExtendMsgSetMongoDriver) DeleteReactionExtendMsgSet(ctx context.Context, sourceID string, sessionType int32, clientMsgID string, msgFirstModifyTime int64, reactionExtensionList map[string]*server_api_params.KeyValue) error {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
var updateBson = bson.M{}
|
var updateBson = bson.M{}
|
||||||
for _, v := range reactionExtensionList {
|
for _, v := range reactionExtensionList {
|
||||||
updateBson[fmt.Sprintf("extend_msgs.%s.%s", clientMsgID, v.TypeKey)] = ""
|
updateBson[fmt.Sprintf("extend_msgs.%s.%s", clientMsgID, v.TypeKey)] = ""
|
||||||
}
|
}
|
||||||
set, err := d.GetExtendMsgSet(ctx, sourceID, sessionType, msgFirstModifyTime, c)
|
set, err := e.GetExtendMsgSet(ctx, sourceID, sessionType, msgFirstModifyTime)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return utils.Wrap(err, "")
|
return utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
if set == nil {
|
if set == nil {
|
||||||
return errors.New(fmt.Sprintf("sourceID %s has no set", sourceID))
|
return errors.New(fmt.Sprintf("sourceID %s has no set", sourceID))
|
||||||
}
|
}
|
||||||
_, err = c.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$unset": updateBson})
|
_, err = e.ExtendMsgSetCollection.UpdateOne(ctx, bson.M{"source_id": set.SourceID, "session_type": sessionType}, bson.M{"$unset": updateBson})
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (d *db.DataBases) GetExtendMsg(sourceID string, sessionType int32, clientMsgID string, maxMsgUpdateTime int64) (extendMsg *ExtendMsg, err error) {
|
func (e *ExtendMsgSetMongoDriver) GetExtendMsg(ctx context.Context, sourceID string, sessionType int32, clientMsgID string, maxMsgUpdateTime int64) (extendMsg *table.ExtendMsg, err error) {
|
||||||
ctx, _ := context.WithTimeout(context.Background(), time.Duration(config.Config.Mongo.DBTimeout)*time.Second)
|
|
||||||
c := d.mongoClient.Database(config.Config.Mongo.DBDatabase).Collection(cExtendMsgSet)
|
|
||||||
findOpts := options.Find().SetLimit(1).SetSkip(0).SetSort(bson.M{"source_id": -1}).SetProjection(bson.M{fmt.Sprintf("extend_msgs.%s", clientMsgID): 1})
|
findOpts := options.Find().SetLimit(1).SetSkip(0).SetSort(bson.M{"source_id": -1}).SetProjection(bson.M{fmt.Sprintf("extend_msgs.%s", clientMsgID): 1})
|
||||||
regex := fmt.Sprintf("^%s", sourceID)
|
regex := fmt.Sprintf("^%s", sourceID)
|
||||||
result, err := c.Find(ctx, bson.M{"source_id": primitive.Regex{Pattern: regex}, "session_type": sessionType, "max_msg_update_time": bson.M{"$lte": maxMsgUpdateTime}}, findOpts)
|
result, err := e.ExtendMsgSetCollection.Find(ctx, bson.M{"source_id": primitive.Regex{Pattern: regex}, "session_type": sessionType, "max_msg_update_time": bson.M{"$lte": maxMsgUpdateTime}}, findOpts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, utils.Wrap(err, "")
|
return nil, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
var setList []ExtendMsgSet
|
var setList []table.ExtendMsgSet
|
||||||
if err := result.All(ctx, &setList); err != nil {
|
if err := result.All(ctx, &setList); err != nil {
|
||||||
return nil, utils.Wrap(err, "")
|
return nil, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
@ -2,6 +2,7 @@ package unrelation
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"Open_IM/pkg/common/config"
|
"Open_IM/pkg/common/config"
|
||||||
|
"Open_IM/pkg/common/db/table"
|
||||||
"Open_IM/pkg/utils"
|
"Open_IM/pkg/utils"
|
||||||
"context"
|
"context"
|
||||||
"fmt"
|
"fmt"
|
||||||
@ -13,7 +14,7 @@ import (
|
|||||||
)
|
)
|
||||||
|
|
||||||
type Mongo struct {
|
type Mongo struct {
|
||||||
DB *mongo.Client
|
db *mongo.Client
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) InitMongo() {
|
func (m *Mongo) InitMongo() {
|
||||||
@ -53,22 +54,22 @@ func (m *Mongo) InitMongo() {
|
|||||||
panic(err.Error() + " mongo.Connect failed " + uri)
|
panic(err.Error() + " mongo.Connect failed " + uri)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
m.DB = mongoClient
|
m.db = mongoClient
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) GetClient() *mongo.Client {
|
func (m *Mongo) GetClient() *mongo.Client {
|
||||||
return m.DB
|
return m.db
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) CreateTagIndex() {
|
func (m *Mongo) CreateTagIndex() {
|
||||||
if err := m.createMongoIndex(cSendLog, false, "send_id", "-send_time"); err != nil {
|
if err := m.createMongoIndex(table.CSendLog, false, "send_id", "-send_time"); err != nil {
|
||||||
panic(err.Error() + " index create failed " + cSendLog + " send_id, -send_time")
|
panic(err.Error() + " index create failed " + table.CSendLog + " send_id, -send_time")
|
||||||
}
|
}
|
||||||
if err := m.createMongoIndex(cTag, false, "user_id", "-create_time"); err != nil {
|
if err := m.createMongoIndex(table.CTag, false, "user_id", "-create_time"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cTag + " user_id, -create_time")
|
panic(err.Error() + "index create failed " + table.CTag + " user_id, -create_time")
|
||||||
}
|
}
|
||||||
if err := m.createMongoIndex(cTag, true, "tag_id"); err != nil {
|
if err := m.createMongoIndex(table.CTag, true, "tag_id"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cTag + " tag_id")
|
panic(err.Error() + "index create failed " + table.CTag + " tag_id")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -79,32 +80,37 @@ func (m *Mongo) CreateMsgIndex() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) CreateSuperGroupIndex() {
|
func (m *Mongo) CreateSuperGroupIndex() {
|
||||||
if err := m.createMongoIndex(cSuperGroup, true, "group_id"); err != nil {
|
if err := m.createMongoIndex(table.CSuperGroup, true, "group_id"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cTag + " group_id")
|
panic(err.Error() + "index create failed " + table.CTag + " group_id")
|
||||||
}
|
}
|
||||||
if err := m.createMongoIndex(cUserToSuperGroup, true, "user_id"); err != nil {
|
if err := m.createMongoIndex(table.CUserToSuperGroup, true, "user_id"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cTag + "user_id")
|
panic(err.Error() + "index create failed " + table.CTag + "user_id")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) CreateWorkMomentIndex() {
|
func (m *Mongo) CreateWorkMomentIndex() {
|
||||||
if err := m.createMongoIndex(cWorkMoment, true, "-create_time", "work_moment_id"); err != nil {
|
if err := m.createMongoIndex(table.CWorkMoment, true, "-create_time", "work_moment_id"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cWorkMoment + " -create_time, work_moment_id")
|
panic(err.Error() + "index create failed " + table.CWorkMoment + " -create_time, work_moment_id")
|
||||||
}
|
}
|
||||||
if err := m.createMongoIndex(cWorkMoment, true, "work_moment_id"); err != nil {
|
if err := m.createMongoIndex(table.CWorkMoment, true, "work_moment_id"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cWorkMoment + " work_moment_id ")
|
panic(err.Error() + "index create failed " + table.CWorkMoment + " work_moment_id ")
|
||||||
}
|
}
|
||||||
if err := m.createMongoIndex(cWorkMoment, false, "user_id", "-create_time"); err != nil {
|
if err := m.createMongoIndex(table.CWorkMoment, false, "user_id", "-create_time"); err != nil {
|
||||||
panic(err.Error() + "index create failed " + cWorkMoment + "user_id, -create_time")
|
panic(err.Error() + "index create failed " + table.CWorkMoment + "user_id, -create_time")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Mongo) CreateExtendMsgSetIndex() {
|
||||||
|
if err := m.createMongoIndex(table.CExtendMsgSet, true, "-create_time", "work_moment_id"); err != nil {
|
||||||
|
panic(err.Error() + "index create failed " + table.CWorkMoment + " -create_time, work_moment_id")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *Mongo) createMongoIndex(collection string, isUnique bool, keys ...string) error {
|
func (m *Mongo) createMongoIndex(collection string, isUnique bool, keys ...string) error {
|
||||||
db := m.DB.Database(config.Config.Mongo.DBDatabase).Collection(collection)
|
db := m.db.Database(config.Config.Mongo.DBDatabase).Collection(collection)
|
||||||
opts := options.CreateIndexes().SetMaxTime(10 * time.Second)
|
opts := options.CreateIndexes().SetMaxTime(10 * time.Second)
|
||||||
indexView := db.Indexes()
|
indexView := db.Indexes()
|
||||||
keysDoc := bsonx.Doc{}
|
keysDoc := bsonx.Doc{}
|
||||||
|
|
||||||
// create composite indexes
|
// create composite indexes
|
||||||
for _, key := range keys {
|
for _, key := range keys {
|
||||||
if strings.HasPrefix(key, "-") {
|
if strings.HasPrefix(key, "-") {
|
||||||
|
@ -12,23 +12,19 @@ import (
|
|||||||
"time"
|
"time"
|
||||||
)
|
)
|
||||||
|
|
||||||
const cTag = "tag"
|
type OfficeMongoDriver struct {
|
||||||
const cSendLog = "send_log"
|
|
||||||
const cWorkMoment = "work_moment"
|
|
||||||
|
|
||||||
type OfficeMgoDB struct {
|
|
||||||
mgoDB *mongo.Database
|
mgoDB *mongo.Database
|
||||||
TagCollection *mongo.Collection
|
TagCollection *mongo.Collection
|
||||||
TagSendLogCollection *mongo.Collection
|
TagSendLogCollection *mongo.Collection
|
||||||
WorkMomentCollection *mongo.Collection
|
WorkMomentCollection *mongo.Collection
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewOfficeMgoDB(mgoDB *mongo.Database) *OfficeMgoDB {
|
func NewOfficeMongoDriver(mgoDB *mongo.Database) *OfficeMongoDriver {
|
||||||
return &OfficeMgoDB{mgoDB: mgoDB, TagCollection: mgoDB.Collection(cTag), TagSendLogCollection: mgoDB.Collection(cSendLog), WorkMomentCollection: mgoDB.Collection(cSendLog)}
|
return &OfficeMongoDriver{mgoDB: mgoDB, TagCollection: mgoDB.Collection(table.CTag), TagSendLogCollection: mgoDB.Collection(table.CSendLog), WorkMomentCollection: mgoDB.Collection(table.CSendLog)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetUserTags(ctx context.Context, userID string) ([]table.Tag, error) {
|
func (db *OfficeMongoDriver) GetUserTags(ctx context.Context, userID string) ([]table.TagModel, error) {
|
||||||
var tags []table.Tag
|
var tags []table.TagModel
|
||||||
cursor, err := db.TagCollection.Find(ctx, bson.M{"user_id": userID})
|
cursor, err := db.TagCollection.Find(ctx, bson.M{"user_id": userID})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return tags, err
|
return tags, err
|
||||||
@ -39,9 +35,9 @@ func (db *OfficeMgoDB) GetUserTags(ctx context.Context, userID string) ([]table.
|
|||||||
return tags, nil
|
return tags, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) CreateTag(ctx context.Context, userID, tagName string, userList []string) error {
|
func (db *OfficeMongoDriver) CreateTag(ctx context.Context, userID, tagName string, userList []string) error {
|
||||||
tagID := generateTagID(tagName, userID)
|
tagID := generateTagID(tagName, userID)
|
||||||
tag := table.Tag{
|
tag := table.TagModel{
|
||||||
UserID: userID,
|
UserID: userID,
|
||||||
TagID: tagID,
|
TagID: tagID,
|
||||||
TagName: tagName,
|
TagName: tagName,
|
||||||
@ -51,19 +47,19 @@ func (db *OfficeMgoDB) CreateTag(ctx context.Context, userID, tagName string, us
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetTagByID(ctx context.Context, userID, tagID string) (table.Tag, error) {
|
func (db *OfficeMongoDriver) GetTagByID(ctx context.Context, userID, tagID string) (table.TagModel, error) {
|
||||||
var tag table.Tag
|
var tag table.TagModel
|
||||||
err := db.TagCollection.FindOne(ctx, bson.M{"user_id": userID, "tag_id": tagID}).Decode(&tag)
|
err := db.TagCollection.FindOne(ctx, bson.M{"user_id": userID, "tag_id": tagID}).Decode(&tag)
|
||||||
return tag, err
|
return tag, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) DeleteTag(ctx context.Context, userID, tagID string) error {
|
func (db *OfficeMongoDriver) DeleteTag(ctx context.Context, userID, tagID string) error {
|
||||||
_, err := db.TagCollection.DeleteOne(ctx, bson.M{"user_id": userID, "tag_id": tagID})
|
_, err := db.TagCollection.DeleteOne(ctx, bson.M{"user_id": userID, "tag_id": tagID})
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) SetTag(ctx context.Context, userID, tagID, newName string, increaseUserIDList []string, reduceUserIDList []string) error {
|
func (db *OfficeMongoDriver) SetTag(ctx context.Context, userID, tagID, newName string, increaseUserIDList []string, reduceUserIDList []string) error {
|
||||||
var tag table.Tag
|
var tag table.TagModel
|
||||||
if err := db.TagCollection.FindOne(ctx, bson.M{"tag_id": tagID, "user_id": userID}).Decode(&tag); err != nil {
|
if err := db.TagCollection.FindOne(ctx, bson.M{"tag_id": tagID, "user_id": userID}).Decode(&tag); err != nil {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
@ -95,19 +91,19 @@ func (db *OfficeMgoDB) SetTag(ctx context.Context, userID, tagID, newName string
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetUserIDListByTagID(ctx context.Context, userID, tagID string) ([]string, error) {
|
func (db *OfficeMongoDriver) GetUserIDListByTagID(ctx context.Context, userID, tagID string) ([]string, error) {
|
||||||
var tag table.Tag
|
var tag table.TagModel
|
||||||
err := db.TagCollection.FindOne(ctx, bson.M{"user_id": userID, "tag_id": tagID}).Decode(&tag)
|
err := db.TagCollection.FindOne(ctx, bson.M{"user_id": userID, "tag_id": tagID}).Decode(&tag)
|
||||||
return tag.UserList, err
|
return tag.UserList, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) SaveTagSendLog(ctx context.Context, tagSendLog *table.TagSendLog) error {
|
func (db *OfficeMongoDriver) SaveTagSendLog(ctx context.Context, tagSendLog *table.TagSendLogModel) error {
|
||||||
_, err := db.TagSendLogCollection.InsertOne(ctx, tagSendLog)
|
_, err := db.TagSendLogCollection.InsertOne(ctx, tagSendLog)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetTagSendLogs(ctx context.Context, userID string, showNumber, pageNumber int32) ([]table.TagSendLog, error) {
|
func (db *OfficeMongoDriver) GetTagSendLogs(ctx context.Context, userID string, showNumber, pageNumber int32) ([]table.TagSendLogModel, error) {
|
||||||
var tagSendLogs []table.TagSendLog
|
var tagSendLogs []table.TagSendLogModel
|
||||||
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"send_time": -1})
|
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"send_time": -1})
|
||||||
cursor, err := db.TagSendLogCollection.Find(ctx, bson.M{"send_id": userID}, findOpts)
|
cursor, err := db.TagSendLogCollection.Find(ctx, bson.M{"send_id": userID}, findOpts)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -117,7 +113,7 @@ func (db *OfficeMgoDB) GetTagSendLogs(ctx context.Context, userID string, showNu
|
|||||||
return tagSendLogs, err
|
return tagSendLogs, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) CreateOneWorkMoment(ctx context.Context, workMoment *table.WorkMoment) error {
|
func (db *OfficeMongoDriver) CreateOneWorkMoment(ctx context.Context, workMoment *table.WorkMoment) error {
|
||||||
workMomentID := generateWorkMomentID(workMoment.UserID)
|
workMomentID := generateWorkMomentID(workMoment.UserID)
|
||||||
workMoment.WorkMomentID = workMomentID
|
workMoment.WorkMomentID = workMomentID
|
||||||
workMoment.CreateTime = int32(time.Now().Unix())
|
workMoment.CreateTime = int32(time.Now().Unix())
|
||||||
@ -125,12 +121,12 @@ func (db *OfficeMgoDB) CreateOneWorkMoment(ctx context.Context, workMoment *tabl
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) DeleteOneWorkMoment(ctx context.Context, workMomentID string) error {
|
func (db *OfficeMongoDriver) DeleteOneWorkMoment(ctx context.Context, workMomentID string) error {
|
||||||
_, err := db.WorkMomentCollection.DeleteOne(ctx, bson.M{"work_moment_id": workMomentID})
|
_, err := db.WorkMomentCollection.DeleteOne(ctx, bson.M{"work_moment_id": workMomentID})
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) DeleteComment(ctx context.Context, workMomentID, contentID, opUserID string) error {
|
func (db *OfficeMongoDriver) DeleteComment(ctx context.Context, workMomentID, contentID, opUserID string) error {
|
||||||
_, err := db.WorkMomentCollection.UpdateOne(ctx, bson.D{{"work_moment_id", workMomentID},
|
_, err := db.WorkMomentCollection.UpdateOne(ctx, bson.D{{"work_moment_id", workMomentID},
|
||||||
{"$or", bson.A{
|
{"$or", bson.A{
|
||||||
bson.D{{"user_id", opUserID}},
|
bson.D{{"user_id", opUserID}},
|
||||||
@ -140,13 +136,13 @@ func (db *OfficeMgoDB) DeleteComment(ctx context.Context, workMomentID, contentI
|
|||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetWorkMomentByID(ctx context.Context, workMomentID string) (*table.WorkMoment, error) {
|
func (db *OfficeMongoDriver) GetWorkMomentByID(ctx context.Context, workMomentID string) (*table.WorkMoment, error) {
|
||||||
workMoment := &table.WorkMoment{}
|
workMoment := &table.WorkMoment{}
|
||||||
err := db.WorkMomentCollection.FindOne(ctx, bson.M{"work_moment_id": workMomentID}).Decode(workMoment)
|
err := db.WorkMomentCollection.FindOne(ctx, bson.M{"work_moment_id": workMomentID}).Decode(workMoment)
|
||||||
return workMoment, err
|
return workMoment, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) LikeOneWorkMoment(ctx context.Context, likeUserID, userName, workMomentID string) (*table.WorkMoment, bool, error) {
|
func (db *OfficeMongoDriver) LikeOneWorkMoment(ctx context.Context, likeUserID, userName, workMomentID string) (*table.WorkMoment, bool, error) {
|
||||||
workMoment, err := db.GetWorkMomentByID(ctx, workMomentID)
|
workMoment, err := db.GetWorkMomentByID(ctx, workMomentID)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, false, err
|
return nil, false, err
|
||||||
@ -159,24 +155,24 @@ func (db *OfficeMgoDB) LikeOneWorkMoment(ctx context.Context, likeUserID, userNa
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if !isAlreadyLike {
|
if !isAlreadyLike {
|
||||||
workMoment.LikeUserList = append(workMoment.LikeUserList, &table.CommonUser{UserID: likeUserID, UserName: userName})
|
workMoment.LikeUserList = append(workMoment.LikeUserList, &table.CommonUserModel{UserID: likeUserID, UserName: userName})
|
||||||
}
|
}
|
||||||
_, err = db.WorkMomentCollection.UpdateOne(ctx, bson.M{"work_moment_id": workMomentID}, bson.M{"$set": bson.M{"like_user_list": workMoment.LikeUserList}})
|
_, err = db.WorkMomentCollection.UpdateOne(ctx, bson.M{"work_moment_id": workMomentID}, bson.M{"$set": bson.M{"like_user_list": workMoment.LikeUserList}})
|
||||||
return workMoment, !isAlreadyLike, err
|
return workMoment, !isAlreadyLike, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) SetUserWorkMomentsLevel(ctx context.Context, userID string, level int32) error {
|
func (db *OfficeMongoDriver) SetUserWorkMomentsLevel(ctx context.Context, userID string, level int32) error {
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) CommentOneWorkMoment(ctx context.Context, comment *table.Comment, workMomentID string) (table.WorkMoment, error) {
|
func (db *OfficeMongoDriver) CommentOneWorkMoment(ctx context.Context, comment *table.Comment, workMomentID string) (table.WorkMoment, error) {
|
||||||
comment.ContentID = generateWorkMomentCommentID(workMomentID)
|
comment.ContentID = generateWorkMomentCommentID(workMomentID)
|
||||||
var workMoment table.WorkMoment
|
var workMoment table.WorkMoment
|
||||||
err := db.WorkMomentCollection.FindOneAndUpdate(ctx, bson.M{"work_moment_id": workMomentID}, bson.M{"$push": bson.M{"comments": comment}}).Decode(&workMoment)
|
err := db.WorkMomentCollection.FindOneAndUpdate(ctx, bson.M{"work_moment_id": workMomentID}, bson.M{"$push": bson.M{"comments": comment}}).Decode(&workMoment)
|
||||||
return workMoment, err
|
return workMoment, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetUserSelfWorkMoments(ctx context.Context, userID string, showNumber, pageNumber int32) ([]table.WorkMoment, error) {
|
func (db *OfficeMongoDriver) GetUserSelfWorkMoments(ctx context.Context, userID string, showNumber, pageNumber int32) ([]table.WorkMoment, error) {
|
||||||
var workMomentList []table.WorkMoment
|
var workMomentList []table.WorkMoment
|
||||||
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
||||||
result, err := db.WorkMomentCollection.Find(ctx, bson.M{"user_id": userID}, findOpts)
|
result, err := db.WorkMomentCollection.Find(ctx, bson.M{"user_id": userID}, findOpts)
|
||||||
@ -187,7 +183,7 @@ func (db *OfficeMgoDB) GetUserSelfWorkMoments(ctx context.Context, userID string
|
|||||||
return workMomentList, err
|
return workMomentList, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetUserWorkMoments(ctx context.Context, opUserID, userID string, showNumber, pageNumber int32, friendIDList []string) ([]table.WorkMoment, error) {
|
func (db *OfficeMongoDriver) GetUserWorkMoments(ctx context.Context, opUserID, userID string, showNumber, pageNumber int32, friendIDList []string) ([]table.WorkMoment, error) {
|
||||||
var workMomentList []table.WorkMoment
|
var workMomentList []table.WorkMoment
|
||||||
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
||||||
result, err := db.WorkMomentCollection.Find(ctx, bson.D{ // 等价条件: select * from
|
result, err := db.WorkMomentCollection.Find(ctx, bson.D{ // 等价条件: select * from
|
||||||
@ -205,8 +201,8 @@ func (db *OfficeMgoDB) GetUserWorkMoments(ctx context.Context, opUserID, userID
|
|||||||
return workMomentList, err
|
return workMomentList, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *OfficeMgoDB) GetUserFriendWorkMoments(ctx context.Context, showNumber, pageNumber int32, userID string, friendIDList []string) ([]WorkMoment, error) {
|
func (db *OfficeMongoDriver) GetUserFriendWorkMoments(ctx context.Context, showNumber, pageNumber int32, userID string, friendIDList []string) ([]table.WorkMoment, error) {
|
||||||
var workMomentList []WorkMoment
|
var workMomentList []table.WorkMoment
|
||||||
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
findOpts := options.Find().SetLimit(int64(showNumber)).SetSkip(int64(showNumber) * (int64(pageNumber) - 1)).SetSort(bson.M{"create_time": -1})
|
||||||
var filter bson.D
|
var filter bson.D
|
||||||
permissionFilter := bson.D{
|
permissionFilter := bson.D{
|
||||||
|
@ -11,25 +11,20 @@ import (
|
|||||||
"go.mongodb.org/mongo-driver/mongo/readconcern"
|
"go.mongodb.org/mongo-driver/mongo/readconcern"
|
||||||
)
|
)
|
||||||
|
|
||||||
const (
|
type SuperGroupMongoDriver struct {
|
||||||
cSuperGroup = "super_group"
|
|
||||||
cUserToSuperGroup = "user_to_super_group"
|
|
||||||
)
|
|
||||||
|
|
||||||
type SuperGroupMgoDB struct {
|
|
||||||
MgoClient *mongo.Client
|
MgoClient *mongo.Client
|
||||||
MgoDB *mongo.Database
|
MgoDB *mongo.Database
|
||||||
superGroupCollection *mongo.Collection
|
superGroupCollection *mongo.Collection
|
||||||
userToSuperGroupCollection *mongo.Collection
|
userToSuperGroupCollection *mongo.Collection
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewSuperGroupMgoDB(mgoClient *mongo.Client) *SuperGroupMgoDB {
|
func NewSuperGroupMongoDriver(mgoClient *mongo.Client) *SuperGroupMongoDriver {
|
||||||
mgoDB := mgoClient.Database(config.Config.Mongo.DBDatabase)
|
mgoDB := mgoClient.Database(config.Config.Mongo.DBDatabase)
|
||||||
return &SuperGroupMgoDB{MgoDB: mgoDB, MgoClient: mgoClient, superGroupCollection: mgoDB.Collection(cSuperGroup), userToSuperGroupCollection: mgoDB.Collection(cUserToSuperGroup)}
|
return &SuperGroupMongoDriver{MgoDB: mgoDB, MgoClient: mgoClient, superGroupCollection: mgoDB.Collection(table.CSuperGroup), userToSuperGroupCollection: mgoDB.Collection(table.CUserToSuperGroup)}
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) CreateSuperGroup(sCtx mongo.SessionContext, groupID string, initMemberIDList []string) error {
|
func (db *SuperGroupMongoDriver) CreateSuperGroup(sCtx mongo.SessionContext, groupID string, initMemberIDList []string) error {
|
||||||
superGroup := table.SuperGroup{
|
superGroup := table.SuperGroupModel{
|
||||||
GroupID: groupID,
|
GroupID: groupID,
|
||||||
MemberIDList: initMemberIDList,
|
MemberIDList: initMemberIDList,
|
||||||
}
|
}
|
||||||
@ -51,13 +46,13 @@ func (db *SuperGroupMgoDB) CreateSuperGroup(sCtx mongo.SessionContext, groupID s
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) GetSuperGroup(ctx context.Context, groupID string) (*table.SuperGroup, error) {
|
func (db *SuperGroupMongoDriver) GetSuperGroup(ctx context.Context, groupID string) (*table.SuperGroupModel, error) {
|
||||||
superGroup := table.SuperGroup{}
|
superGroup := table.SuperGroupModel{}
|
||||||
err := db.superGroupCollection.FindOne(ctx, bson.M{"group_id": groupID}).Decode(&superGroup)
|
err := db.superGroupCollection.FindOne(ctx, bson.M{"group_id": groupID}).Decode(&superGroup)
|
||||||
return &superGroup, err
|
return &superGroup, err
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) AddUserToSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
func (db *SuperGroupMongoDriver) AddUserToSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$addToSet": bson.M{"member_id_list": bson.M{"$each": userIDList}}})
|
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$addToSet": bson.M{"member_id_list": bson.M{"$each": userIDList}}})
|
||||||
@ -80,7 +75,7 @@ func (db *SuperGroupMgoDB) AddUserToSuperGroup(ctx context.Context, groupID stri
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) RemoverUserFromSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
func (db *SuperGroupMongoDriver) RemoverUserFromSuperGroup(ctx context.Context, groupID string, userIDList []string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$pull": bson.M{"member_id_list": bson.M{"$in": userIDList}}})
|
_, err := db.superGroupCollection.UpdateOne(sCtx, bson.M{"group_id": groupID}, bson.M{"$pull": bson.M{"member_id_list": bson.M{"$in": userIDList}}})
|
||||||
@ -97,16 +92,16 @@ func (db *SuperGroupMgoDB) RemoverUserFromSuperGroup(ctx context.Context, groupI
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) GetSuperGroupByUserID(ctx context.Context, userID string) (*table.UserToSuperGroup, error) {
|
func (db *SuperGroupMongoDriver) GetSuperGroupByUserID(ctx context.Context, userID string) (*table.UserToSuperGroupModel, error) {
|
||||||
var user table.UserToSuperGroup
|
var user table.UserToSuperGroupModel
|
||||||
err := db.userToSuperGroupCollection.FindOne(ctx, bson.M{"user_id": userID}).Decode(&user)
|
err := db.userToSuperGroupCollection.FindOne(ctx, bson.M{"user_id": userID}).Decode(&user)
|
||||||
return &user, utils.Wrap(err, "")
|
return &user, utils.Wrap(err, "")
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) DeleteSuperGroup(ctx context.Context, groupID string) error {
|
func (db *SuperGroupMongoDriver) DeleteSuperGroup(ctx context.Context, groupID string) error {
|
||||||
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
opts := options.Session().SetDefaultReadConcern(readconcern.Majority())
|
||||||
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
return db.MgoDB.Client().UseSessionWithOptions(ctx, opts, func(sCtx mongo.SessionContext) error {
|
||||||
superGroup := &table.SuperGroup{}
|
superGroup := &table.SuperGroupModel{}
|
||||||
_, err := db.superGroupCollection.DeleteOne(sCtx, bson.M{"group_id": groupID})
|
_, err := db.superGroupCollection.DeleteOne(sCtx, bson.M{"group_id": groupID})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
_ = sCtx.AbortTransaction(ctx)
|
_ = sCtx.AbortTransaction(ctx)
|
||||||
@ -120,7 +115,7 @@ func (db *SuperGroupMgoDB) DeleteSuperGroup(ctx context.Context, groupID string)
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
func (db *SuperGroupMgoDB) RemoveGroupFromUser(sCtx context.Context, groupID string, userIDList []string) error {
|
func (db *SuperGroupMongoDriver) RemoveGroupFromUser(sCtx context.Context, groupID string, userIDList []string) error {
|
||||||
_, err := db.userToSuperGroupCollection.UpdateOne(sCtx, bson.M{"user_id": bson.M{"$in": userIDList}}, bson.M{"$pull": bson.M{"group_id_list": groupID}})
|
_, err := db.userToSuperGroupCollection.UpdateOne(sCtx, bson.M{"user_id": bson.M{"$in": userIDList}}, bson.M{"$pull": bson.M{"group_id_list": groupID}})
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user