mirror of
https://github.com/openimsdk/open-im-server.git
synced 2025-05-21 20:32:32 +08:00
* pb * fix: Modifying other fields while setting IsPrivateChat does not take effect * fix: quote message error revoke * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * refactoring scheduled tasks * upgrading pkg tools * fix * fix * optimize log output * feat: support GetLastMessage * feat: support GetLastMessage * feat: s3 switch * feat: s3 switch * fix: GetUsersOnline * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: SendBusinessNotification supported configuration parameters * feat: seq conversion failed without exiting * fix: DeleteDoc crash * fix: fill send time * fix: fill send time * fix: crash caused by withdrawing messages from users who have left the group * fix: user msg timestamp * seq read config * seq read config * fix: the source message of the reference is withdrawn, and the referenced message is deleted * feat: optimize the default notification.yml * fix: shouldPushOffline * fix: the sorting is wrong after canceling the administrator in group settings * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * feat: Sending messages supports returning fields modified by webhook * fix: oss specifies content-type when uploading * fix: the version number contains a line break * fix: the version number contains a line break * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * feat: GetConversationsHasReadAndMaxSeq support pinned * fix: transferring the group owner to a muted member, incremental version error * feat: unified conversion code * feat: update gomake * fix: in standalone mode, the user online status is wrong * fix: add permission check * fix: add permission check (cherry picked from commit 748d783d36fc3f1e4eacaee64203b10e8e2b8744) # Conflicts: # internal/rpc/conversation/conversation.go # internal/rpc/group/cache.go # internal/rpc/group/statistics.go # internal/rpc/msg/send.go
86 lines
2.8 KiB
Go
86 lines
2.8 KiB
Go
package conversation
|
|
|
|
import (
|
|
"context"
|
|
|
|
dbModel "github.com/openimsdk/open-im-server/v3/pkg/common/storage/model"
|
|
"github.com/openimsdk/protocol/conversation"
|
|
)
|
|
|
|
func UpdateConversationsMap(ctx context.Context, req *conversation.SetConversationsReq) (m map[string]any, conversation dbModel.Conversation, err error) {
|
|
m = make(map[string]any)
|
|
|
|
conversation.ConversationID = req.Conversation.ConversationID
|
|
conversation.ConversationType = req.Conversation.ConversationType
|
|
conversation.UserID = req.Conversation.UserID
|
|
conversation.GroupID = req.Conversation.GroupID
|
|
|
|
if req.Conversation.RecvMsgOpt != nil {
|
|
conversation.RecvMsgOpt = req.Conversation.RecvMsgOpt.Value
|
|
m["recv_msg_opt"] = req.Conversation.RecvMsgOpt.Value
|
|
}
|
|
|
|
if req.Conversation.AttachedInfo != nil {
|
|
conversation.AttachedInfo = req.Conversation.AttachedInfo.Value
|
|
m["attached_info"] = req.Conversation.AttachedInfo.Value
|
|
}
|
|
|
|
if req.Conversation.Ex != nil {
|
|
conversation.Ex = req.Conversation.Ex.Value
|
|
m["ex"] = req.Conversation.Ex.Value
|
|
}
|
|
if req.Conversation.IsPinned != nil {
|
|
conversation.IsPinned = req.Conversation.IsPinned.Value
|
|
m["is_pinned"] = req.Conversation.IsPinned.Value
|
|
}
|
|
if req.Conversation.GroupAtType != nil {
|
|
conversation.GroupAtType = req.Conversation.GroupAtType.Value
|
|
m["group_at_type"] = req.Conversation.GroupAtType.Value
|
|
}
|
|
if req.Conversation.MsgDestructTime != nil {
|
|
conversation.MsgDestructTime = req.Conversation.MsgDestructTime.Value
|
|
m["msg_destruct_time"] = req.Conversation.MsgDestructTime.Value
|
|
}
|
|
if req.Conversation.IsMsgDestruct != nil {
|
|
conversation.IsMsgDestruct = req.Conversation.IsMsgDestruct.Value
|
|
m["is_msg_destruct"] = req.Conversation.IsMsgDestruct.Value
|
|
}
|
|
if req.Conversation.BurnDuration != nil {
|
|
conversation.BurnDuration = req.Conversation.BurnDuration.Value
|
|
m["burn_duration"] = req.Conversation.BurnDuration.Value
|
|
}
|
|
|
|
return m, conversation, nil
|
|
}
|
|
|
|
func UserUpdateCheckMap(ctx context.Context, userID string, req *conversation.ConversationReq, conversation *dbModel.Conversation) (unequal bool) {
|
|
unequal = false
|
|
|
|
if req.RecvMsgOpt != nil && conversation.RecvMsgOpt != req.RecvMsgOpt.Value {
|
|
unequal = true
|
|
}
|
|
if req.AttachedInfo != nil && conversation.AttachedInfo != req.AttachedInfo.Value {
|
|
unequal = true
|
|
}
|
|
if req.Ex != nil && conversation.Ex != req.Ex.Value {
|
|
unequal = true
|
|
}
|
|
if req.IsPinned != nil && conversation.IsPinned != req.IsPinned.Value {
|
|
unequal = true
|
|
}
|
|
if req.GroupAtType != nil && conversation.GroupAtType != req.GroupAtType.Value {
|
|
unequal = true
|
|
}
|
|
if req.MsgDestructTime != nil && conversation.MsgDestructTime != req.MsgDestructTime.Value {
|
|
unequal = true
|
|
}
|
|
if req.IsMsgDestruct != nil && conversation.IsMsgDestruct != req.IsMsgDestruct.Value {
|
|
unequal = true
|
|
}
|
|
if req.BurnDuration != nil && conversation.BurnDuration != req.BurnDuration.Value {
|
|
unequal = true
|
|
}
|
|
|
|
return unequal
|
|
}
|