/
view_logs.go
45 lines (37 loc) · 1 KB
/
view_logs.go
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
package chain
import (
"github.com/baetyl/baetyl-go/v2/errors"
"github.com/baetyl/baetyl-go/v2/log"
"github.com/baetyl/baetyl-go/v2/pubsub"
v1 "github.com/baetyl/baetyl-go/v2/spec/v1"
"github.com/baetyl/baetyl/v2/ami"
)
func (c *chain) ViewLogs(opt *ami.LogsOptions) error {
c.logOpt = opt
c.processor = pubsub.NewProcessor(c.subChan, 0, &chainHandler{chain: c})
c.processor.Start()
return c.tomb.Go(c.chainReading, c.logging)
}
func (c *chain) logging() error {
c.logOpt.Name = c.debugOptions.Name
c.logOpt.Namespace = c.debugOptions.Namespace
c.logOpt.Container = c.debugOptions.Container
defer func() {
c.log.Debug("connecting close")
msg := &v1.Message{
Kind: v1.MessageCMD,
Metadata: map[string]string{
"success": "false",
"msg": "disconnect",
"token": c.token,
},
}
c.pb.Publish(c.upside, msg)
}()
err := c.ami.RemoteLogs(c.logOpt, c.pipe)
if err != nil {
c.log.Error("failed to start view logs", log.Error(err))
return errors.Trace(err)
}
return nil
}