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

77 lines
2.4 KiB
Go
Raw Normal View History

2021-12-23 17:34:32 +08:00
package msg
2021-05-26 19:40:38 +08:00
import (
2023-02-23 19:15:30 +08:00
"OpenIM/internal/common/check"
2023-03-03 17:42:26 +08:00
"OpenIM/pkg/common/db/cache"
2023-02-23 19:15:30 +08:00
"OpenIM/pkg/common/db/controller"
"OpenIM/pkg/common/db/localcache"
2023-03-03 17:42:26 +08:00
"OpenIM/pkg/common/db/unrelation"
2023-03-01 15:32:26 +08:00
"OpenIM/pkg/common/prome"
2023-03-02 12:00:31 +08:00
"OpenIM/pkg/discoveryregistry"
2023-02-23 19:15:30 +08:00
"OpenIM/pkg/proto/msg"
2022-09-14 17:45:38 +08:00
"google.golang.org/grpc"
)
2023-02-10 22:10:37 +08:00
type msgServer struct {
2023-03-03 17:42:26 +08:00
RegisterCenter discoveryregistry.SvcDiscoveryRegistry
MsgDatabase controller.MsgDatabase
ExtendMsgDatabase controller.ExtendMsgDatabase
Group *check.GroupChecker
User *check.UserCheck
Conversation *check.ConversationChecker
friend *check.FriendChecker
2023-02-14 22:04:03 +08:00
*localcache.GroupLocalCache
2023-02-23 11:26:46 +08:00
black *check.BlackChecker
MessageLocker MessageLocker
2022-05-23 10:14:10 +08:00
}
2023-03-02 12:00:31 +08:00
func Start(client discoveryregistry.SvcDiscoveryRegistry, server *grpc.Server) error {
2023-03-03 17:42:26 +08:00
rdb, err := cache.NewRedis()
2023-02-14 20:01:44 +08:00
if err != nil {
return err
2021-05-26 19:40:38 +08:00
}
2023-03-03 17:42:26 +08:00
mongo, err := unrelation.NewMongo()
if err != nil {
2023-02-14 20:01:44 +08:00
return err
}
2023-03-03 17:42:26 +08:00
cacheModel := cache.NewCacheModel(rdb)
msgDocModel := unrelation.NewMsgMongoDriver(mongo.GetDatabase())
extendMsgModel := unrelation.NewExtendMsgSetMongoDriver(mongo.GetDatabase())
extendMsgDatabase := controller.NewExtendMsgDatabase(extendMsgModel)
msgDatabase := controller.NewMsgDatabase(msgDocModel, cacheModel)
2023-02-14 20:01:44 +08:00
s := &msgServer{
2023-03-03 17:42:26 +08:00
Conversation: check.NewConversationChecker(client),
User: check.NewUserCheck(client),
Group: check.NewGroupChecker(client),
MsgDatabase: msgDatabase,
ExtendMsgDatabase: extendMsgDatabase,
RegisterCenter: client,
GroupLocalCache: localcache.NewGroupLocalCache(client),
black: check.NewBlackChecker(client),
friend: check.NewFriendChecker(client),
2023-03-03 18:08:26 +08:00
MessageLocker: NewLockerMessage(cacheModel),
2023-02-14 20:01:44 +08:00
}
s.initPrometheus()
msg.RegisterMsgServer(server, s)
return nil
2021-05-26 19:40:38 +08:00
}
2023-02-14 20:01:44 +08:00
func (m *msgServer) initPrometheus() {
2023-03-01 15:32:26 +08:00
prome.NewMsgPullFromRedisSuccessCounter()
prome.NewMsgPullFromRedisFailedCounter()
prome.NewMsgPullFromMongoSuccessCounter()
prome.NewMsgPullFromMongoFailedCounter()
prome.NewSingleChatMsgRecvSuccessCounter()
prome.NewGroupChatMsgRecvSuccessCounter()
prome.NewWorkSuperGroupChatMsgRecvSuccessCounter()
prome.NewSingleChatMsgProcessSuccessCounter()
prome.NewSingleChatMsgProcessFailedCounter()
prome.NewGroupChatMsgProcessSuccessCounter()
prome.NewGroupChatMsgProcessFailedCounter()
prome.NewWorkSuperGroupChatMsgProcessSuccessCounter()
prome.NewWorkSuperGroupChatMsgProcessFailedCounter()
2022-09-14 17:45:38 +08:00
}