command.go 1.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. package command
  2. //go:generate go run github.com/xtls/xray-core/common/errors/errorgen
  3. import (
  4. "context"
  5. "github.com/xtls/xray-core/app/log"
  6. "github.com/xtls/xray-core/common"
  7. "github.com/xtls/xray-core/common/errors"
  8. "github.com/xtls/xray-core/core"
  9. grpc "google.golang.org/grpc"
  10. )
  11. type LoggerServer struct {
  12. V *core.Instance
  13. }
  14. // RestartLogger implements LoggerService.
  15. func (s *LoggerServer) RestartLogger(ctx context.Context, request *RestartLoggerRequest) (*RestartLoggerResponse, error) {
  16. logger := s.V.GetFeature((*log.Instance)(nil))
  17. if logger == nil {
  18. return nil, errors.New("unable to get logger instance")
  19. }
  20. if err := logger.Close(); err != nil {
  21. return nil, errors.New("failed to close logger").Base(err)
  22. }
  23. if err := logger.Start(); err != nil {
  24. return nil, errors.New("failed to start logger").Base(err)
  25. }
  26. return &RestartLoggerResponse{}, nil
  27. }
  28. func (s *LoggerServer) mustEmbedUnimplementedLoggerServiceServer() {}
  29. type service struct {
  30. v *core.Instance
  31. }
  32. func (s *service) Register(server *grpc.Server) {
  33. ls := &LoggerServer{
  34. V: s.v,
  35. }
  36. RegisterLoggerServiceServer(server, ls)
  37. // For compatibility purposes
  38. vCoreDesc := LoggerService_ServiceDesc
  39. vCoreDesc.ServiceName = "v2ray.core.app.log.command.LoggerService"
  40. server.RegisterService(&vCoreDesc, ls)
  41. }
  42. func init() {
  43. common.Must(common.RegisterConfig((*Config)(nil), func(ctx context.Context, cfg interface{}) (interface{}, error) {
  44. s := core.MustFromContext(ctx)
  45. return &service{v: s}, nil
  46. }))
  47. }