2019-02-01 14:08:21 -05:00
|
|
|
// +build !confonly
|
|
|
|
|
2018-02-14 11:35:09 -05:00
|
|
|
package command
|
|
|
|
|
2020-10-04 00:41:45 -04:00
|
|
|
//go:generate go run v2ray.com/core/common/errors/errorgen
|
2018-02-14 11:35:09 -05:00
|
|
|
|
|
|
|
import (
|
2018-03-05 15:15:41 -05:00
|
|
|
"context"
|
|
|
|
|
2018-02-14 11:35:09 -05:00
|
|
|
grpc "google.golang.org/grpc"
|
|
|
|
|
|
|
|
"v2ray.com/core"
|
|
|
|
"v2ray.com/core/app/log"
|
|
|
|
"v2ray.com/core/common"
|
|
|
|
)
|
|
|
|
|
|
|
|
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
|
|
|
|
}
|
|
|
|
|
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
|
|
|
|
}))
|
|
|
|
}
|