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