log.go 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. package api
  2. import (
  3. "io"
  4. "log"
  5. logService "github.com/v2fly/v2ray-core/v4/app/log/command"
  6. "github.com/v2fly/v2ray-core/v4/main/commands/base"
  7. )
  8. var cmdLog = &base.Command{
  9. CustomFlags: true,
  10. UsageLine: "{{.Exec}} api log [--server=127.0.0.1:8080]",
  11. Short: "log operations",
  12. Long: `
  13. Follow and print logs from v2ray.
  14. > It ignores -timeout flag while following logs
  15. Arguments:
  16. -restart
  17. Restart the logger
  18. -s, -server <server:port>
  19. The API server address. Default 127.0.0.1:8080
  20. -t, -timeout <seconds>
  21. Timeout seconds to call API. Default 3
  22. Example:
  23. {{.Exec}} {{.LongName}}
  24. {{.Exec}} {{.LongName}} --restart
  25. `,
  26. Run: executeRestartLogger,
  27. }
  28. func executeRestartLogger(cmd *base.Command, args []string) {
  29. var restart bool
  30. cmd.Flag.BoolVar(&restart, "restart", false, "")
  31. setSharedFlags(cmd)
  32. cmd.Flag.Parse(args)
  33. if restart {
  34. restartLogger()
  35. return
  36. }
  37. followLogger()
  38. }
  39. func restartLogger() {
  40. conn, ctx, close := dialAPIServer()
  41. defer close()
  42. client := logService.NewLoggerServiceClient(conn)
  43. r := &logService.RestartLoggerRequest{}
  44. _, err := client.RestartLogger(ctx, r)
  45. if err != nil {
  46. base.Fatalf("failed to restart logger: %s", err)
  47. }
  48. }
  49. func followLogger() {
  50. conn, ctx, close := dialAPIServerWithoutTimeout()
  51. defer close()
  52. client := logService.NewLoggerServiceClient(conn)
  53. r := &logService.FollowLogRequest{}
  54. stream, err := client.FollowLog(ctx, r)
  55. if err != nil {
  56. base.Fatalf("failed to follow logger: %s", err)
  57. }
  58. for {
  59. resp, err := stream.Recv()
  60. if err == io.EOF {
  61. break
  62. }
  63. if err != nil {
  64. base.Fatalf("failed to fetch log: %s", err)
  65. }
  66. log.Print(resp.Message)
  67. }
  68. }