package messageCMS import ( "Open_IM/pkg/common/config" "Open_IM/pkg/common/constant" "Open_IM/pkg/common/db" errors "Open_IM/pkg/common/http" "context" "strconv" "Open_IM/pkg/common/log" imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model" "Open_IM/pkg/grpc-etcdv3/getcdv3" pbMessageCMS "Open_IM/pkg/proto/message_cms" open_im_sdk "Open_IM/pkg/proto/sdk_ws" "Open_IM/pkg/utils" "net" "strings" "google.golang.org/grpc" ) type messageCMSServer struct { rpcPort int rpcRegisterName string etcdSchema string etcdAddr []string } func NewMessageCMSServer(port int) *messageCMSServer { log.NewPrivateLog(constant.LogFileName) return &messageCMSServer{ rpcPort: port, rpcRegisterName: config.Config.RpcRegisterName.OpenImMessageCMSName, etcdSchema: config.Config.Etcd.EtcdSchema, etcdAddr: config.Config.Etcd.EtcdAddr, } } func (s *messageCMSServer) Run() { log.NewInfo("0", "messageCMS rpc start ") listenIP := "" if config.Config.ListenIP == "" { listenIP = "0.0.0.0" } else { listenIP = config.Config.ListenIP } address := listenIP + ":" + strconv.Itoa(s.rpcPort) //listener network listener, err := net.Listen("tcp", address) if err != nil { panic("listening err:" + err.Error() + s.rpcRegisterName) } log.NewInfo("0", "listen network success, ", address, listener) defer listener.Close() //grpc server srv := grpc.NewServer() defer srv.GracefulStop() //Service registers with etcd pbMessageCMS.RegisterMessageCMSServer(srv, s) rpcRegisterIP := config.Config.RpcRegisterIP if config.Config.RpcRegisterIP == "" { rpcRegisterIP, err = utils.GetLocalIP() if err != nil { log.Error("", "GetLocalIP failed ", err.Error()) } } log.NewInfo("", "rpcRegisterIP", rpcRegisterIP) err = getcdv3.RegisterEtcd(s.etcdSchema, strings.Join(s.etcdAddr, ","), rpcRegisterIP, s.rpcPort, s.rpcRegisterName, 10) if err != nil { log.NewError("0", "RegisterEtcd failed ", err.Error()) return } err = srv.Serve(listener) if err != nil { log.NewError("0", "Serve failed ", err.Error()) return } log.NewInfo("0", "message cms rpc success") } func (s *messageCMSServer) BoradcastMessage(_ context.Context, req *pbMessageCMS.BoradcastMessageReq) (*pbMessageCMS.BoradcastMessageResp, error) { log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "BoradcastMessage", req.String()) resp := &pbMessageCMS.BoradcastMessageResp{} return resp, errors.WrapError(constant.ErrDB) } func (s *messageCMSServer) GetChatLogs(_ context.Context, req *pbMessageCMS.GetChatLogsReq) (*pbMessageCMS.GetChatLogsResp, error) { log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "GetChatLogs", req.String()) resp := &pbMessageCMS.GetChatLogsResp{} time, err := utils.TimeStringToTime(req.Date) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "time string parse error", err.Error()) } chatLog := db.ChatLog{ Content: req.Content, SendTime: time, ContentType: req.ContentType, SessionType: req.SessionType, } switch chatLog.SessionType { case constant.SingleChatType: chatLog.SendID = req.UserId case constant.GroupChatType: chatLog.RecvID = req.GroupId chatLog.SendID = req.UserId } log.NewDebug(req.OperationID, utils.GetSelfFuncName(), "chat_log: ", chatLog) nums, err := imdb.GetChatLogCount(chatLog) resp.ChatLogsNum = int32(nums) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetChatLogCount", err.Error()) } chatLogs, err := imdb.GetChatLog(chatLog, req.Pagination.PageNumber, req.Pagination.ShowNumber) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetChatLog", err.Error()) return resp, errors.WrapError(constant.ErrDB) } for _, chatLog := range chatLogs { pbChatLog := &pbMessageCMS.ChatLogs{ SessionType: chatLog.SessionType, ContentType: chatLog.ContentType, SearchContent: req.Content, WholeContent: chatLog.Content, Date: chatLog.CreateTime.String(), SenderNickName: chatLog.SenderNickname, SenderId: chatLog.SendID, } if chatLog.SenderNickname == "" { sendUser, err := imdb.GetUserByUserID(chatLog.SendID) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetUserByUserID failed", err.Error()) continue } pbChatLog.SenderNickName = sendUser.Nickname } switch chatLog.SessionType { case constant.SingleChatType: recvUser, err := imdb.GetUserByUserID(chatLog.RecvID) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetUserByUserID failed", err.Error()) continue } pbChatLog.ReciverId = recvUser.UserID pbChatLog.ReciverNickName = recvUser.Nickname case constant.GroupChatType: group, err := imdb.GetGroupById(chatLog.RecvID) if err != nil { log.NewError(req.OperationID, utils.GetSelfFuncName(), "GetGroupById failed") continue } pbChatLog.GroupId = group.GroupID pbChatLog.GroupName = group.GroupName } resp.ChatLogs = append(resp.ChatLogs, pbChatLog) } resp.Pagination = &open_im_sdk.ResponsePagination{ CurrentPage: req.Pagination.PageNumber, ShowNumber: req.Pagination.ShowNumber, } log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "resp output: ", resp.String()) return resp, nil } func (s *messageCMSServer) MassSendMessage(_ context.Context, req *pbMessageCMS.MassSendMessageReq) (*pbMessageCMS.MassSendMessageResp, error) { log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "MassSendMessage", req.String()) resp := &pbMessageCMS.MassSendMessageResp{} return resp, nil } func (s *messageCMSServer) WithdrawMessage(_ context.Context, req *pbMessageCMS.WithdrawMessageReq) (*pbMessageCMS.WithdrawMessageResp, error) { log.NewInfo(req.OperationID, utils.GetSelfFuncName(), "WithdrawMessage", req.String()) resp := &pbMessageCMS.WithdrawMessageResp{} return resp, nil }