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

100 lines
3.6 KiB
Go
Raw Normal View History

2021-05-26 19:15:25 +08:00
package apiChat
import (
"Open_IM/pkg/common/config"
"Open_IM/pkg/common/log"
2021-10-11 22:42:10 +08:00
pbChat "Open_IM/pkg/proto/chat"
2021-12-23 19:37:41 +08:00
"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()})
log.ErrorByKv("json unmarshal err", "", "err", err.Error(), "data", c.PostForm("data"))
return
}
token := c.Request.Header.Get("token")
log.InfoByKv("api call success to sendMsgReq", params.OperationID, "Parameters", params)
2021-05-26 19:15:25 +08:00
pbData := newUserSendMsgReq(token, &params)
2021-12-23 17:34:32 +08:00
log.Info("", "", "api SendMsg call start..., [data: %s]", pbData.String())
2021-05-26 19:15:25 +08:00
etcdConn := getcdv3.GetConn(config.Config.Etcd.EtcdSchema, strings.Join(config.Config.Etcd.EtcdAddr, ","), config.Config.RpcRegisterName.OpenImOfflineMessageName)
client := pbChat.NewChatClient(etcdConn)
2021-12-23 17:34:32 +08:00
log.Info("", "", "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
}
2021-12-23 17:34:32 +08:00
log.Info("", "", "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
},
})
}