zrok/agent/access.go

96 lines
2.1 KiB
Go
Raw Normal View History

2024-09-13 20:40:55 +02:00
package agent
import (
2024-09-17 03:32:17 +02:00
"bytes"
"encoding/json"
"errors"
"github.com/michaelquigley/pfxlog"
2024-09-13 20:40:55 +02:00
"github.com/openziti/zrok/agent/proctree"
2024-09-17 03:32:17 +02:00
"github.com/sirupsen/logrus"
"strings"
2024-09-13 20:40:55 +02:00
)
type access struct {
2024-09-17 03:32:17 +02:00
frontendToken string
token string
2024-09-13 20:40:55 +02:00
bindAddress string
autoMode bool
autoAddress string
autoStartPort uint16
autoEndPort uint16
2024-09-13 20:40:55 +02:00
responseHeaders []string
2024-09-17 03:32:17 +02:00
process *proctree.Child
readBuffer bytes.Buffer
booted bool
bootComplete chan struct{}
bootErr error
2024-09-13 20:40:55 +02:00
2024-09-25 17:06:06 +02:00
agent *Agent
2024-09-13 20:40:55 +02:00
}
2024-09-17 03:32:17 +02:00
func (a *access) monitor() {
if err := proctree.WaitChild(a.process); err != nil {
pfxlog.ChannelLogger(a.token).Error(err)
}
2024-09-25 17:06:06 +02:00
a.agent.rmAccess <- a
2024-09-17 03:32:17 +02:00
}
func (a *access) tail(data []byte) {
defer func() {
if r := recover(); r != nil {
logrus.Errorf("recovering: %v", r)
}
}()
a.readBuffer.Write(data)
if line, err := a.readBuffer.ReadString('\n'); err == nil {
line = strings.Trim(line, "\n")
if !a.booted {
if strings.HasPrefix(line, "{") {
in := make(map[string]interface{})
if err := json.Unmarshal([]byte(line), &in); err == nil {
if v, found := in["message"]; found {
if str, ok := v.(string); ok {
if str == "boot" {
if v, found := in["frontend_token"]; found {
if str, ok := v.(string); ok {
a.frontendToken = str
}
}
if v, found := in["bind_address"]; found {
if str, ok := v.(string); ok {
a.bindAddress = str
}
}
a.booted = true
} else {
a.bootErr = errors.New(line)
}
} else {
a.bootErr = errors.New(line)
}
} else {
a.bootErr = errors.New(line)
2024-09-17 23:25:24 +02:00
}
} else {
a.bootErr = errors.New(line)
2024-09-17 23:25:24 +02:00
}
close(a.bootComplete)
2024-09-17 03:32:17 +02:00
} else {
logrus.Warn(line)
2024-09-17 03:32:17 +02:00
}
} else {
if strings.HasPrefix(line, "{") {
in := make(map[string]interface{})
if err := json.Unmarshal([]byte(line), &in); err == nil {
pfxlog.ChannelLogger(a.token).Info(in)
}
} else {
pfxlog.ChannelLogger(a.token).Info(strings.Trim(line, "\n"))
}
}
} else {
a.readBuffer.WriteString(line)
}
}