Files
open-im-server/internal/push/logic/push_rpc_server.go
T

106 lines
3.0 KiB
Go
Raw Normal View History

2021-05-26 19:22:11 +08:00
package logic
import (
"Open_IM/pkg/common/config"
2022-05-30 17:46:06 +08:00
"Open_IM/pkg/common/constant"
2022-10-27 17:15:06 +08:00
"Open_IM/pkg/common/db"
"Open_IM/pkg/common/log"
2022-09-15 01:22:20 +08:00
promePkg "Open_IM/pkg/common/prometheus"
"Open_IM/pkg/grpc-etcdv3/getcdv3"
2022-09-12 19:32:24 +08:00
pbPush "Open_IM/pkg/proto/push"
"Open_IM/pkg/utils"
2021-05-26 19:22:11 +08:00
"context"
"net"
2022-05-07 17:05:05 +08:00
"strconv"
2021-05-26 19:22:11 +08:00
"strings"
2022-09-12 19:32:24 +08:00
2022-09-15 16:27:36 +08:00
grpcPrometheus "github.com/grpc-ecosystem/go-grpc-prometheus"
2022-09-12 19:32:24 +08:00
"google.golang.org/grpc"
2021-05-26 19:22:11 +08:00
)
type RPCServer struct {
rpcPort int
rpcRegisterName string
etcdSchema string
etcdAddr []string
}
func (r *RPCServer) Init(rpcPort int) {
r.rpcPort = rpcPort
r.rpcRegisterName = config.Config.RpcRegisterName.OpenImPushName
r.etcdSchema = config.Config.Etcd.EtcdSchema
r.etcdAddr = config.Config.Etcd.EtcdAddr
}
func (r *RPCServer) run() {
2022-05-07 17:05:05 +08:00
listenIP := ""
if config.Config.ListenIP == "" {
listenIP = "0.0.0.0"
} else {
listenIP = config.Config.ListenIP
}
address := listenIP + ":" + strconv.Itoa(r.rpcPort)
listener, err := net.Listen("tcp", address)
2021-05-26 19:22:11 +08:00
if err != nil {
2022-05-10 09:09:37 +08:00
panic("listening err:" + err.Error() + r.rpcRegisterName)
2021-05-26 19:22:11 +08:00
}
defer listener.Close()
2022-09-15 01:22:20 +08:00
var grpcOpts []grpc.ServerOption
if config.Config.Prometheus.Enable {
2022-09-15 08:45:10 +08:00
promePkg.NewGrpcRequestCounter()
promePkg.NewGrpcRequestFailedCounter()
promePkg.NewGrpcRequestSuccessCounter()
2022-09-15 16:27:36 +08:00
grpcOpts = append(grpcOpts, []grpc.ServerOption{
2022-09-15 16:39:49 +08:00
// grpc.UnaryInterceptor(promePkg.UnaryServerInterceptorProme),
2022-09-15 16:27:36 +08:00
grpc.StreamInterceptor(grpcPrometheus.StreamServerInterceptor),
grpc.UnaryInterceptor(grpcPrometheus.UnaryServerInterceptor),
}...)
2022-09-15 01:22:20 +08:00
}
srv := grpc.NewServer(grpcOpts...)
2021-05-26 19:22:11 +08:00
defer srv.GracefulStop()
pbPush.RegisterPushMsgServiceServer(srv, r)
2022-06-23 09:24:05 +08:00
rpcRegisterIP := config.Config.RpcRegisterIP
2022-05-07 17:05:05 +08:00
if config.Config.RpcRegisterIP == "" {
rpcRegisterIP, err = utils.GetLocalIP()
if err != nil {
log.Error("", "GetLocalIP failed ", err.Error())
}
}
err = getcdv3.RegisterEtcd(r.etcdSchema, strings.Join(r.etcdAddr, ","), rpcRegisterIP, r.rpcPort, r.rpcRegisterName, 10)
2021-05-26 19:22:11 +08:00
if err != nil {
2022-05-07 17:05:05 +08:00
log.Error("", "register push module rpc to etcd err", err.Error(), r.etcdSchema, strings.Join(r.etcdAddr, ","), rpcRegisterIP, r.rpcPort, r.rpcRegisterName)
2022-08-26 17:41:58 +08:00
panic(utils.Wrap(err, "register push module rpc to etcd err"))
2021-05-26 19:22:11 +08:00
}
err = srv.Serve(listener)
if err != nil {
2022-05-07 17:05:05 +08:00
log.Error("", "push module rpc start err", err.Error())
2021-05-26 19:22:11 +08:00
return
}
}
func (r *RPCServer) PushMsg(_ context.Context, pbData *pbPush.PushMsgReq) (*pbPush.PushMsgResp, error) {
//Call push module to send message to the user
2022-05-30 17:46:06 +08:00
switch pbData.MsgData.SessionType {
case constant.SuperGroupChatType:
MsgToSuperGroupUser(pbData)
default:
MsgToUser(pbData)
}
2021-05-26 19:22:11 +08:00
return &pbPush.PushMsgResp{
ResultCode: 0,
}, nil
}
2022-10-27 17:15:06 +08:00
func (r *RPCServer) DelUserPushToken(c context.Context, req *pbPush.DelUserPushTokenReq) (*pbPush.DelUserPushTokenResp, error) {
var resp pbPush.DelUserPushTokenResp
err := db.DB.DelFcmToken(req.UserID, int(req.PlatformID))
if err != nil {
errMsg := req.OperationID + " " + "SetFcmToken failed " + err.Error()
log.NewError(req.OperationID, errMsg)
resp.ErrCode = 500
resp.ErrMsg = errMsg
}
return &resp, nil
}