Files
open-im-server/internal/api/msg/send_msg.go
T

104 lines
3.8 KiB
Go
Raw Normal View History

2022-07-20 21:26:52 +08:00
package msg
2021-05-26 19:15:25 +08:00
import (
"Open_IM/pkg/common/config"
"Open_IM/pkg/common/log"
2022-07-20 21:26:52 +08:00
pbChat "Open_IM/pkg/proto/msg"
2022-01-18 09:25:41 +08:00
open_im_sdk "Open_IM/pkg/proto/sdk_ws"
2021-05-26 19:15:25 +08:00
"context"
"Open_IM/pkg/grpc-etcdv3/getcdv3"
2021-05-26 19:15:25 +08:00
"github.com/gin-gonic/gin"
"net/http"
"strings"
)
type paramsUserSendMsg struct {
2021-12-23 19:37:41 +08:00
SenderPlatformID int32 `json:"senderPlatformID" binding:"required"`
SendID string `json:"sendID" binding:"required"`
SenderNickName string `json:"senderNickName"`
SenderFaceURL string `json:"senderFaceUrl"`
OperationID string `json:"operationID" binding:"required"`
Data struct {
SessionType int32 `json:"sessionType" binding:"required"`
MsgFrom int32 `json:"msgFrom" binding:"required"`
ContentType int32 `json:"contentType" binding:"required"`
RecvID string `json:"recvID" `
GroupID string `json:"groupID" `
ForceList []string `json:"forceList"`
Content []byte `json:"content" binding:"required"`
Options map[string]bool `json:"options" `
ClientMsgID string `json:"clientMsgID" binding:"required"`
CreateTime int64 `json:"createTime" binding:"required"`
OffLineInfo *open_im_sdk.OfflinePushInfo `json:"offlineInfo" `
2021-05-26 19:15:25 +08:00
}
}
2021-12-23 17:34:32 +08:00
func newUserSendMsgReq(token string, params *paramsUserSendMsg) *pbChat.SendMsgReq {
pbData := pbChat.SendMsgReq{
2021-12-23 19:37:41 +08:00
Token: token,
OperationID: params.OperationID,
MsgData: &open_im_sdk.MsgData{
SendID: params.SendID,
RecvID: params.Data.RecvID,
GroupID: params.Data.GroupID,
ClientMsgID: params.Data.ClientMsgID,
SenderPlatformID: params.SenderPlatformID,
2021-12-28 10:59:01 +08:00
SenderNickname: params.SenderNickName,
2021-12-23 19:37:41 +08:00
SenderFaceURL: params.SenderFaceURL,
SessionType: params.Data.SessionType,
MsgFrom: params.Data.MsgFrom,
ContentType: params.Data.ContentType,
Content: params.Data.Content,
CreateTime: params.Data.CreateTime,
Options: params.Data.Options,
OfflinePushInfo: params.Data.OffLineInfo,
},
2021-05-26 19:15:25 +08:00
}
return &pbData
}
2021-12-23 19:37:41 +08:00
func SendMsg(c *gin.Context) {
2021-05-26 19:15:25 +08:00
params := paramsUserSendMsg{}
if err := c.BindJSON(&params); err != nil {
c.JSON(http.StatusBadRequest, gin.H{"errCode": 400, "errMsg": err.Error()})
2022-05-10 09:09:37 +08:00
log.Error("0", "BindJSON failed ", err.Error())
2021-05-26 19:15:25 +08:00
return
}
token := c.Request.Header.Get("token")
2022-05-10 09:09:37 +08:00
log.NewInfo(params.OperationID, "api call success to sendMsgReq", params)
2021-05-26 19:15:25 +08:00
pbData := newUserSendMsgReq(token, &params)
2022-06-16 15:19:39 +08:00
log.Info(params.OperationID, "", "api SendMsg call start..., [data: %s]", pbData.String())
2021-05-26 19:15:25 +08:00
2022-08-17 12:12:54 +08:00
etcdConn := getcdv3.GetDefaultConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImMsgName, params.OperationID)
2022-06-16 15:19:39 +08:00
if etcdConn == nil {
2022-08-17 12:12:54 +08:00
errMsg := params.OperationID + "getcdv3.GetDefaultConn == nil"
2022-06-16 15:19:39 +08:00
log.NewError(params.OperationID, errMsg)
c.JSON(http.StatusInternalServerError, gin.H{"errCode": 500, "errMsg": errMsg})
return
}
2022-07-20 21:26:52 +08:00
client := pbChat.NewMsgClient(etcdConn)
2021-05-26 19:15:25 +08:00
2022-09-21 18:44:21 +08:00
log.Info(params.OperationID, "", "api SendMsg call, api call rpc...")
2021-05-26 19:15:25 +08:00
2021-12-23 17:34:32 +08:00
reply, err := client.SendMsg(context.Background(), pbData)
2021-12-08 17:44:16 +08:00
if err != nil {
2021-12-23 17:34:32 +08:00
log.NewError(params.OperationID, "SendMsg rpc failed, ", params, err.Error())
c.JSON(http.StatusBadRequest, gin.H{"errCode": 401, "errMsg": "SendMsg rpc failed, " + err.Error()})
2021-12-08 17:44:16 +08:00
return
}
2022-06-16 15:19:39 +08:00
log.Info(params.OperationID, "", "api SendMsg call end..., [data: %s] [reply: %s]", pbData.String(), reply.String())
2021-05-26 19:15:25 +08:00
c.JSON(http.StatusOK, gin.H{
2021-12-23 19:37:41 +08:00
"errCode": reply.ErrCode,
"errMsg": reply.ErrMsg,
2021-05-26 19:15:25 +08:00
"data": gin.H{
"clientMsgID": reply.ClientMsgID,
"serverMsgID": reply.ServerMsgID,
2021-06-28 15:26:31 +08:00
"sendTime": reply.SendTime,
2021-05-26 19:15:25 +08:00
},
})
}