mirror of
https://github.com/openimsdk/open-im-server.git
synced 2026-05-03 16:45:59 +08:00
505ce8aad1
* 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 748d783d36)
# Conflicts:
# internal/rpc/conversation/conversation.go
# internal/rpc/group/cache.go
# internal/rpc/group/statistics.go
# internal/rpc/msg/send.go
118 lines
4.8 KiB
Go
118 lines
4.8 KiB
Go
package conversation
|
|
|
|
import (
|
|
"context"
|
|
|
|
"github.com/openimsdk/open-im-server/v3/pkg/callbackstruct"
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/config"
|
|
dbModel "github.com/openimsdk/open-im-server/v3/pkg/common/storage/model"
|
|
"github.com/openimsdk/open-im-server/v3/pkg/common/webhook"
|
|
"github.com/openimsdk/tools/utils/datautil"
|
|
)
|
|
|
|
func (c *conversationServer) webhookBeforeCreateSingleChatConversations(ctx context.Context, before *config.BeforeConfig, req *dbModel.Conversation) error {
|
|
return webhook.WithCondition(ctx, before, func(ctx context.Context) error {
|
|
cbReq := &callbackstruct.CallbackBeforeCreateSingleChatConversationsReq{
|
|
CallbackCommand: callbackstruct.CallbackBeforeCreateSingleChatConversationsCommand,
|
|
OwnerUserID: req.OwnerUserID,
|
|
ConversationID: req.ConversationID,
|
|
ConversationType: req.ConversationType,
|
|
UserID: req.UserID,
|
|
RecvMsgOpt: req.RecvMsgOpt,
|
|
IsPinned: req.IsPinned,
|
|
IsPrivateChat: req.IsPrivateChat,
|
|
BurnDuration: req.BurnDuration,
|
|
GroupAtType: req.GroupAtType,
|
|
AttachedInfo: req.AttachedInfo,
|
|
Ex: req.Ex,
|
|
}
|
|
|
|
resp := &callbackstruct.CallbackBeforeCreateSingleChatConversationsResp{}
|
|
|
|
if err := c.webhookClient.SyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, resp, before); err != nil {
|
|
return err
|
|
}
|
|
|
|
datautil.NotNilReplace(&req.RecvMsgOpt, resp.RecvMsgOpt)
|
|
datautil.NotNilReplace(&req.IsPinned, resp.IsPinned)
|
|
datautil.NotNilReplace(&req.IsPrivateChat, resp.IsPrivateChat)
|
|
datautil.NotNilReplace(&req.BurnDuration, resp.BurnDuration)
|
|
datautil.NotNilReplace(&req.GroupAtType, resp.GroupAtType)
|
|
datautil.NotNilReplace(&req.AttachedInfo, resp.AttachedInfo)
|
|
datautil.NotNilReplace(&req.Ex, resp.Ex)
|
|
return nil
|
|
})
|
|
}
|
|
|
|
func (c *conversationServer) webhookAfterCreateSingleChatConversations(ctx context.Context, after *config.AfterConfig, req *dbModel.Conversation) error {
|
|
cbReq := &callbackstruct.CallbackAfterCreateSingleChatConversationsReq{
|
|
CallbackCommand: callbackstruct.CallbackAfterCreateSingleChatConversationsCommand,
|
|
OwnerUserID: req.OwnerUserID,
|
|
ConversationID: req.ConversationID,
|
|
ConversationType: req.ConversationType,
|
|
UserID: req.UserID,
|
|
RecvMsgOpt: req.RecvMsgOpt,
|
|
IsPinned: req.IsPinned,
|
|
IsPrivateChat: req.IsPrivateChat,
|
|
BurnDuration: req.BurnDuration,
|
|
GroupAtType: req.GroupAtType,
|
|
AttachedInfo: req.AttachedInfo,
|
|
Ex: req.Ex,
|
|
}
|
|
|
|
c.webhookClient.AsyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, &callbackstruct.CallbackAfterCreateSingleChatConversationsResp{}, after)
|
|
return nil
|
|
}
|
|
|
|
func (c *conversationServer) webhookBeforeCreateGroupChatConversations(ctx context.Context, before *config.BeforeConfig, req *dbModel.Conversation) error {
|
|
return webhook.WithCondition(ctx, before, func(ctx context.Context) error {
|
|
cbReq := &callbackstruct.CallbackBeforeCreateGroupChatConversationsReq{
|
|
CallbackCommand: callbackstruct.CallbackBeforeCreateGroupChatConversationsCommand,
|
|
ConversationID: req.ConversationID,
|
|
ConversationType: req.ConversationType,
|
|
GroupID: req.GroupID,
|
|
RecvMsgOpt: req.RecvMsgOpt,
|
|
IsPinned: req.IsPinned,
|
|
IsPrivateChat: req.IsPrivateChat,
|
|
BurnDuration: req.BurnDuration,
|
|
GroupAtType: req.GroupAtType,
|
|
AttachedInfo: req.AttachedInfo,
|
|
Ex: req.Ex,
|
|
}
|
|
|
|
resp := &callbackstruct.CallbackBeforeCreateGroupChatConversationsResp{}
|
|
|
|
if err := c.webhookClient.SyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, resp, before); err != nil {
|
|
return err
|
|
}
|
|
|
|
datautil.NotNilReplace(&req.RecvMsgOpt, resp.RecvMsgOpt)
|
|
datautil.NotNilReplace(&req.IsPinned, resp.IsPinned)
|
|
datautil.NotNilReplace(&req.IsPrivateChat, resp.IsPrivateChat)
|
|
datautil.NotNilReplace(&req.BurnDuration, resp.BurnDuration)
|
|
datautil.NotNilReplace(&req.GroupAtType, resp.GroupAtType)
|
|
datautil.NotNilReplace(&req.AttachedInfo, resp.AttachedInfo)
|
|
datautil.NotNilReplace(&req.Ex, resp.Ex)
|
|
return nil
|
|
})
|
|
}
|
|
|
|
func (c *conversationServer) webhookAfterCreateGroupChatConversations(ctx context.Context, after *config.AfterConfig, req *dbModel.Conversation) error {
|
|
cbReq := &callbackstruct.CallbackAfterCreateGroupChatConversationsReq{
|
|
CallbackCommand: callbackstruct.CallbackAfterCreateGroupChatConversationsCommand,
|
|
ConversationID: req.ConversationID,
|
|
ConversationType: req.ConversationType,
|
|
GroupID: req.GroupID,
|
|
RecvMsgOpt: req.RecvMsgOpt,
|
|
IsPinned: req.IsPinned,
|
|
IsPrivateChat: req.IsPrivateChat,
|
|
BurnDuration: req.BurnDuration,
|
|
GroupAtType: req.GroupAtType,
|
|
AttachedInfo: req.AttachedInfo,
|
|
Ex: req.Ex,
|
|
}
|
|
|
|
c.webhookClient.AsyncPost(ctx, cbReq.GetCallbackCommand(), cbReq, &callbackstruct.CallbackAfterCreateGroupChatConversationsResp{}, after)
|
|
return nil
|
|
}
|