mirror of
https://github.com/openziti/zrok.git
synced 2024-11-29 03:24:15 +01:00
85 lines
1.7 KiB
Go
85 lines
1.7 KiB
Go
package agent
|
|
|
|
import (
|
|
"github.com/openziti/zrok/agent/agentGrpc"
|
|
"github.com/openziti/zrok/environment/env_core"
|
|
"github.com/pkg/errors"
|
|
"github.com/sirupsen/logrus"
|
|
"google.golang.org/grpc"
|
|
"net"
|
|
"os"
|
|
)
|
|
|
|
type Agent struct {
|
|
root env_core.Root
|
|
agentSocket string
|
|
shares map[string]*share
|
|
inShares chan *share
|
|
outShares chan *share
|
|
accesses map[string]*access
|
|
inAccesses chan *access
|
|
outAccesses chan *access
|
|
}
|
|
|
|
func NewAgent(root env_core.Root) (*Agent, error) {
|
|
if !root.IsEnabled() {
|
|
return nil, errors.Errorf("unable to load environment; did you 'zrok enable'?")
|
|
}
|
|
return &Agent{
|
|
root: root,
|
|
shares: make(map[string]*share),
|
|
inShares: make(chan *share),
|
|
outShares: make(chan *share),
|
|
accesses: make(map[string]*access),
|
|
inAccesses: make(chan *access),
|
|
outAccesses: make(chan *access),
|
|
}, nil
|
|
}
|
|
|
|
func (a *Agent) Run() error {
|
|
logrus.Infof("started")
|
|
|
|
go a.manager()
|
|
|
|
agentSocket, err := a.root.AgentSocket()
|
|
if err != nil {
|
|
return err
|
|
}
|
|
l, err := net.Listen("unix", agentSocket)
|
|
if err != nil {
|
|
return err
|
|
}
|
|
a.agentSocket = agentSocket
|
|
|
|
srv := grpc.NewServer()
|
|
agentGrpc.RegisterAgentServer(srv, &agentGrpcImpl{a: a})
|
|
if err := srv.Serve(l); err != nil {
|
|
return err
|
|
}
|
|
|
|
return nil
|
|
}
|
|
|
|
func (a *Agent) Shutdown() {
|
|
if err := os.Remove(a.agentSocket); err != nil {
|
|
logrus.Warnf("unable to remove agent socket: %v", err)
|
|
}
|
|
}
|
|
|
|
func (a *Agent) manager() {
|
|
logrus.Info("started")
|
|
defer logrus.Warn("exited")
|
|
|
|
for {
|
|
select {
|
|
case inShare := <-a.inShares:
|
|
logrus.Infof("adding new share '%v'", inShare.token)
|
|
a.shares[inShare.token] = inShare
|
|
|
|
case outShare := <-a.outShares:
|
|
logrus.Infof("removing share '%v'", outShare.token)
|
|
delete(a.shares, outShare.token)
|
|
}
|
|
}
|
|
}
|