log.go 1.8 KB

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