Files
open-im-server/internal/rpc/msg/callback.go
T

150 lines
5.6 KiB
Go
Raw Normal View History

2022-02-28 17:57:03 +08:00
package msg
import (
cbApi "Open_IM/pkg/call_back_struct"
"Open_IM/pkg/common/config"
"Open_IM/pkg/common/constant"
"Open_IM/pkg/common/http"
"Open_IM/pkg/common/log"
pbChat "Open_IM/pkg/proto/chat"
"Open_IM/pkg/utils"
)
func callbackBeforeSendSingleMsg(msg *pbChat.SendMsgReq) (canSend bool, err error) {
2022-03-02 19:07:17 +08:00
if !config.Config.Callback.CallbackbeforeSendSingleMsg.Enable {
2022-02-28 17:57:03 +08:00
return true, nil
}
2022-03-03 16:23:59 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), msg)
2022-02-28 17:57:03 +08:00
req := cbApi.CallbackBeforeSendSingleMsgReq{CommonCallbackReq:cbApi.CommonCallbackReq{
2022-03-03 16:41:17 +08:00
CallbackCommand: constant.CallbackBeforeSendSingleMsgCommand,
2022-02-28 17:57:03 +08:00
}}
resp := &cbApi.CallbackBeforeSendSingleMsgResp{CommonCallbackResp:cbApi.CommonCallbackResp{
}}
utils.CopyStructFields(req, msg.MsgData)
2022-03-03 14:42:50 +08:00
req.Content = string(msg.MsgData.Content)
2022-03-03 16:50:06 +08:00
defer log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), req, *resp)
2022-03-02 19:07:17 +08:00
if err := http.PostReturn(config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackbeforeSendSingleMsg.CallbackTimeOut); err != nil{
if !config.Config.Callback.CallbackbeforeSendSingleMsg.CallbackFailedContinue {
return false, err
}
2022-03-03 14:42:50 +08:00
} else {
2022-03-03 16:41:17 +08:00
if resp.ActionCode == constant.ActionForbidden && resp.ErrCode == constant.CallbackHandleSuccess {
2022-03-03 14:42:50 +08:00
return false, nil
}
2022-02-28 17:57:03 +08:00
}
return true, nil
}
func callbackAfterSendSingleMsg(msg *pbChat.SendMsgReq) error {
2022-03-02 19:07:17 +08:00
if !config.Config.Callback.CallbackAfterSendSingleMsg.Enable {
2022-02-28 17:57:03 +08:00
return nil
}
2022-03-03 16:23:59 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), msg)
2022-03-03 16:41:17 +08:00
req := cbApi.CallbackAfterSendSingleMsgReq{CommonCallbackReq: cbApi.CommonCallbackReq{CallbackCommand:constant.CallbackAfterSendSingleMsgCommand}}
2022-02-28 17:57:03 +08:00
resp := &cbApi.CallbackAfterSendSingleMsgResp{CommonCallbackResp: cbApi.CommonCallbackResp{}}
utils.CopyStructFields(req, msg.MsgData)
2022-03-03 14:42:50 +08:00
req.Content = string(msg.MsgData.Content)
2022-03-03 16:50:06 +08:00
defer log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), req, *resp)
2022-03-02 19:07:17 +08:00
if err := http.PostReturn(config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackAfterSendSingleMsg.CallbackTimeOut); err != nil{
2022-02-28 17:57:03 +08:00
return err
}
return nil
}
func callbackBeforeSendGroupMsg(msg *pbChat.SendMsgReq) (canSend bool, err error) {
2022-03-02 19:07:17 +08:00
if !config.Config.Callback.CallbackBeforeSendGroupMsg.Enable {
2022-02-28 17:57:03 +08:00
return true, nil
}
2022-03-03 16:23:59 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), msg)
2022-03-03 16:41:17 +08:00
req := cbApi.CallbackBeforeSendSingleMsgReq{CommonCallbackReq: cbApi.CommonCallbackReq{CallbackCommand:constant.CallbackBeforeSendGroupMsgCommand}}
2022-02-28 17:57:03 +08:00
resp := &cbApi.CallbackBeforeSendGroupMsgResp{CommonCallbackResp: cbApi.CommonCallbackResp{}}
utils.CopyStructFields(req, msg.MsgData)
2022-03-03 14:42:50 +08:00
req.Content = string(msg.MsgData.Content)
2022-03-03 16:50:06 +08:00
defer log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), req, *resp)
2022-03-02 19:07:17 +08:00
if err := http.PostReturn(config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackBeforeSendGroupMsg.CallbackTimeOut); err != nil {
if !config.Config.Callback.CallbackBeforeSendGroupMsg.CallbackFailedContinue {
return false, nil
}
2022-03-03 14:18:28 +08:00
} else {
2022-03-03 16:41:17 +08:00
if resp.ActionCode == constant.ActionForbidden && resp.ErrCode == constant.CallbackHandleSuccess {
2022-03-03 14:18:28 +08:00
return false, nil
}
2022-02-28 17:57:03 +08:00
}
return true, nil
}
func callbackAfterSendGroupMsg(msg *pbChat.SendMsgReq) error {
2022-03-02 19:07:17 +08:00
if !config.Config.Callback.CallbackAfterSendGroupMsg.Enable {
2022-02-28 17:57:03 +08:00
return nil
}
2022-03-03 16:23:59 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), msg)
2022-03-03 17:53:37 +08:00
req := cbApi.CallbackAfterSendGroupMsgReq{
CommonCallbackReq: cbApi.CommonCallbackReq{
CallbackCommand:constant.CallbackAfterSendGroupMsgCommand,
ServerMsgID: msg.MsgData.ServerMsgID,
ClientMsgID: msg.MsgData.ClientMsgID,
OperationID: msg.OperationID,
},
GroupMsg: cbApi.GroupMsg{
Msg: cbApi.Msg{
SendID: msg.MsgData.
},
GroupID: msg.MsgData.GroupID,
}
}
2022-03-02 19:07:17 +08:00
resp := &cbApi.CallbackAfterSendGroupMsgResp{CommonCallbackResp: cbApi.CommonCallbackResp{}}
2022-03-03 17:53:37 +08:00
//utils.CopyStructFields(req, msg.MsgData)
2022-03-03 14:42:50 +08:00
req.Content = string(msg.MsgData.Content)
2022-03-03 16:50:06 +08:00
defer log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), req, *resp)
2022-03-02 19:07:17 +08:00
if err := http.PostReturn(config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackAfterSendGroupMsg.CallbackTimeOut); err != nil {
return err
}
2022-02-28 17:57:03 +08:00
return nil
}
func callBackWordFilter(msg *pbChat.SendMsgReq) (canSend bool, err error) {
if !config.Config.Callback.CallbackWordFilter.Enable || msg.MsgData.ContentType != constant.Text {
return true, nil
}
2022-03-03 16:23:59 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), msg)
2022-03-03 17:53:37 +08:00
//req := cbApi.CallbackWordFilterReq{
// CommonCallbackReq: cbApi.CommonCallbackReq{
// CallbackCommand: constant.CallbackWordFilterCommand,
// ServerMsgID: msg.MsgData.ServerMsgID,
// ClientMsgID: msg.MsgData.ClientMsgID,
// OperationID: msg.OperationID,
// },
// Content: string(msg.MsgData.Content),
//}
req := cbApi.CallbackWordFilterReq{
CommonCallbackReq: cbApi.CommonCallbackReq{},
}
utils.CopyStructFields(req.CommonCallbackReq, msg.MsgData)
2022-03-02 19:07:17 +08:00
resp := &cbApi.CallbackWordFilterResp{CommonCallbackResp: cbApi.CommonCallbackResp{}}
2022-03-03 17:53:37 +08:00
//utils.CopyStructFields(&req., msg.MsgData)
2022-03-03 16:47:03 +08:00
defer log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), req, *resp)
2022-03-03 16:08:46 +08:00
if err := http.PostReturn(config.Config.Callback.CallbackUrl, req, resp, config.Config.Callback.CallbackWordFilter.CallbackTimeOut); err != nil {
2022-03-02 19:07:17 +08:00
if !config.Config.Callback.CallbackWordFilter.CallbackFailedContinue {
2022-03-03 16:08:46 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), "config disable, stop this operation")
2022-03-02 19:07:17 +08:00
return false, err
}
2022-03-03 14:18:28 +08:00
} else {
2022-03-03 16:41:17 +08:00
if resp.ActionCode == constant.ActionForbidden && resp.ErrCode == constant.CallbackHandleSuccess {
2022-03-03 14:18:28 +08:00
return false, nil
}
2022-03-03 14:42:50 +08:00
msg.MsgData.Content = []byte(resp.Content)
2022-03-03 16:50:06 +08:00
log.NewDebug(msg.OperationID, utils.GetSelfFuncName(), string(msg.MsgData.Content))
2022-03-02 19:07:17 +08:00
}
2022-02-28 17:57:03 +08:00
return true, nil
}