mirror of
https://github.com/openziti/zrok.git
synced 2025-01-18 20:08:21 +01:00
94 lines
2.5 KiB
Go
94 lines
2.5 KiB
Go
package agent
|
|
|
|
import (
|
|
"context"
|
|
"errors"
|
|
"fmt"
|
|
"github.com/openziti/zrok/agent/agentGrpc"
|
|
"github.com/openziti/zrok/agent/proctree"
|
|
"github.com/openziti/zrok/cmd/zrok/subordinate"
|
|
"github.com/openziti/zrok/environment"
|
|
"github.com/sirupsen/logrus"
|
|
"os"
|
|
)
|
|
|
|
func (i *agentGrpcImpl) AccessPrivate(_ context.Context, req *agentGrpc.AccessPrivateRequest) (*agentGrpc.AccessPrivateResponse, error) {
|
|
root, err := environment.LoadRoot()
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
if !root.IsEnabled() {
|
|
return nil, errors.New("unable to load environment; did you 'zrok enable'?")
|
|
}
|
|
|
|
accCmd := []string{os.Args[0], "access", "private", "--subordinate", "-b", req.BindAddress, req.Token}
|
|
if req.AutoMode {
|
|
accCmd = append(accCmd, "--auto", "--auto-address", req.AutoAddress, "--auto-start-port", fmt.Sprintf("%v", req.AutoStartPort))
|
|
accCmd = append(accCmd, "--auto-end-port", fmt.Sprintf("%v", req.AutoEndPort))
|
|
}
|
|
logrus.Info(accCmd)
|
|
|
|
acc := &access{
|
|
token: req.Token,
|
|
bindAddress: req.BindAddress,
|
|
autoMode: req.AutoMode,
|
|
autoAddress: req.AutoAddress,
|
|
autoStartPort: uint16(req.AutoStartPort),
|
|
autoEndPort: uint16(req.AutoEndPort),
|
|
responseHeaders: req.ResponseHeaders,
|
|
sub: subordinate.NewMessageHandler(),
|
|
agent: i.agent,
|
|
}
|
|
acc.sub.MessageHandler = func(msg subordinate.Message) {
|
|
logrus.Info(msg)
|
|
}
|
|
var bootErr error
|
|
acc.sub.BootHandler = func(msgType string, msg subordinate.Message) {
|
|
switch msgType {
|
|
case subordinate.BootMessage:
|
|
if v, found := msg["frontend_token"]; found {
|
|
if str, ok := v.(string); ok {
|
|
acc.frontendToken = str
|
|
}
|
|
}
|
|
if v, found := msg["bind_address"]; found {
|
|
if sr, ok := v.(string); ok {
|
|
acc.bindAddress = sr
|
|
}
|
|
}
|
|
|
|
case subordinate.ErrorMessage:
|
|
if v, found := msg[subordinate.ErrorMessage]; found {
|
|
if str, ok := v.(string); ok {
|
|
bootErr = errors.New(str)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
acc.sub.MalformedHandler = func(msg subordinate.Message) {
|
|
logrus.Error(msg)
|
|
}
|
|
|
|
logrus.Infof("executing '%v'", accCmd)
|
|
|
|
acc.process, err = proctree.StartChild(acc.sub.Tail, accCmd...)
|
|
if err != nil {
|
|
return nil, err
|
|
}
|
|
|
|
<-acc.sub.BootComplete
|
|
|
|
if bootErr == nil {
|
|
go acc.monitor()
|
|
i.agent.addAccess <- acc
|
|
return &agentGrpc.AccessPrivateResponse{FrontendToken: acc.frontendToken}, nil
|
|
|
|
} else {
|
|
if err := proctree.WaitChild(acc.process); err != nil {
|
|
logrus.Errorf("error joining: %v", err)
|
|
}
|
|
return nil, fmt.Errorf("unable to start access: %v", bootErr)
|
|
}
|
|
}
|