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/openziti/zrok/sdk/golang/sdk" "github.com/sirupsen/logrus" "os" ) func (i *agentGrpcImpl) SharePrivate(_ context.Context, req *agentGrpc.SharePrivateRequest) (*agentGrpc.SharePrivateResponse, 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'?") } shrCmd := []string{os.Args[0], "share", "private", "--subordinate", "-b", req.BackendMode} shr := &share{ shareMode: sdk.PrivateShareMode, backendMode: sdk.BackendMode(req.BackendMode), sub: subordinate.NewMessageHandler(), agent: i.agent, } shr.sub.MessageHandler = func(msg subordinate.Message) { logrus.Info(msg) } var bootErr error shr.sub.BootHandler = func(msgType string, msg subordinate.Message) { bootErr = shr.bootHandler(msgType, msg) } shr.sub.MalformedHandler = func(msg subordinate.Message) { logrus.Error(msg) } if req.Insecure { shrCmd = append(shrCmd, "--insecure") } shr.insecure = req.Insecure if req.Closed { shrCmd = append(shrCmd, "--closed") } shr.closed = req.Closed for _, grant := range req.AccessGrants { shrCmd = append(shrCmd, "--access-grant", grant) } shr.accessGrants = req.AccessGrants shrCmd = append(shrCmd, req.Target) shr.target = req.Target logrus.Infof("executing '%v'", shrCmd) shr.process, err = proctree.StartChild(shr.sub.Tail, shrCmd...) if err != nil { return nil, err } <-shr.sub.BootComplete if bootErr == nil { go shr.monitor() i.agent.addShare <- shr return &agentGrpc.SharePrivateResponse{Token: shr.token}, nil } else { if err := proctree.WaitChild(shr.process); err != nil { logrus.Errorf("error joining: %v", err) } return nil, fmt.Errorf("unable to start share: %v", bootErr) } }