2018-02-14 11:35:09 -05:00
|
|
|
package command
|
|
|
|
|
2021-02-16 15:31:50 -05:00
|
|
|
//go:generate go run github.com/v2fly/v2ray-core/v4/common/errors/errorgen
|
2018-02-14 11:35:09 -05:00
|
|
|
|
|
|
|
import (
|
2018-03-05 15:15:41 -05:00
|
|
|
"context"
|
2021-02-21 10:02:42 -05:00
|
|
|
"time"
|
2018-03-05 15:15:41 -05:00
|
|
|
|
2018-02-14 11:35:09 -05:00
|
|
|
grpc "google.golang.org/grpc"
|
|
|
|
|
2021-02-16 15:31:50 -05:00
|
|
|
core "github.com/v2fly/v2ray-core/v4"
|
|
|
|
"github.com/v2fly/v2ray-core/v4/app/log"
|
|
|
|
"github.com/v2fly/v2ray-core/v4/common"
|
2021-02-21 10:02:42 -05:00
|
|
|
cmlog "github.com/v2fly/v2ray-core/v4/common/log"
|
2018-02-14 11:35:09 -05:00
|
|
|
)
|
|
|
|
|
2021-02-21 10:02:42 -05:00
|
|
|
// LoggerServer is the implemention of LoggerService
|
2018-02-14 11:35:09 -05:00
|
|
|
type LoggerServer struct {
|
|
|
|
V *core.Instance
|
|
|
|
}
|
|
|
|
|
2018-05-25 17:20:24 -04:00
|
|
|
// RestartLogger implements LoggerService.
|
2018-02-14 11:35:09 -05:00
|
|
|
func (s *LoggerServer) RestartLogger(ctx context.Context, request *RestartLoggerRequest) (*RestartLoggerResponse, error) {
|
|
|
|
logger := s.V.GetFeature((*log.Instance)(nil))
|
|
|
|
if logger == nil {
|
|
|
|
return nil, newError("unable to get logger instance")
|
|
|
|
}
|
|
|
|
if err := logger.Close(); err != nil {
|
|
|
|
return nil, newError("failed to close logger").Base(err)
|
|
|
|
}
|
|
|
|
if err := logger.Start(); err != nil {
|
|
|
|
return nil, newError("failed to start logger").Base(err)
|
|
|
|
}
|
|
|
|
return &RestartLoggerResponse{}, nil
|
|
|
|
}
|
|
|
|
|
2021-02-21 10:02:42 -05:00
|
|
|
// FollowLog implements LoggerService.
|
|
|
|
func (s *LoggerServer) FollowLog(_ *FollowLogRequest, stream LoggerService_FollowLogServer) error {
|
|
|
|
logger := s.V.GetFeature((*log.Instance)(nil))
|
|
|
|
if logger == nil {
|
|
|
|
return newError("unable to get logger instance")
|
|
|
|
}
|
|
|
|
follower, ok := logger.(cmlog.Follower)
|
|
|
|
if !ok {
|
|
|
|
return newError("logger not support following")
|
|
|
|
}
|
|
|
|
var err error
|
|
|
|
f := func(msg cmlog.Message) {
|
|
|
|
err = stream.Send(&FollowLogResponse{
|
|
|
|
Message: msg.String(),
|
|
|
|
})
|
|
|
|
}
|
|
|
|
follower.AddFollower(f)
|
|
|
|
defer follower.RemoveFollower(f)
|
|
|
|
ticker := time.NewTicker(time.Second)
|
|
|
|
for {
|
|
|
|
<-ticker.C
|
|
|
|
if err != nil {
|
|
|
|
ticker.Stop()
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-24 08:10:26 -04:00
|
|
|
func (s *LoggerServer) mustEmbedUnimplementedLoggerServiceServer() {}
|
|
|
|
|
2018-02-14 11:35:09 -05:00
|
|
|
type service struct {
|
|
|
|
v *core.Instance
|
|
|
|
}
|
|
|
|
|
|
|
|
func (s *service) Register(server *grpc.Server) {
|
|
|
|
RegisterLoggerServiceServer(server, &LoggerServer{
|
|
|
|
V: s.v,
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, cfg interface{}) (interface{}, error) {
|
2018-02-21 11:05:29 -05:00
|
|
|
s := core.MustFromContext(ctx)
|
2018-02-14 11:35:09 -05:00
|
|
|
return &service{v: s}, nil
|
|
|
|
}))
|
|
|
|
}
|