zrok/endpoints/tcpTunnel/backend.go

80 lines
1.8 KiB
Go
Raw Normal View History

package tcpTunnel
2023-04-14 19:09:54 +02:00
import (
"github.com/openziti/sdk-golang/ziti"
"github.com/openziti/sdk-golang/ziti/config"
"github.com/openziti/sdk-golang/ziti/edge"
2023-04-21 19:35:58 +02:00
"github.com/openziti/zrok/endpoints"
"github.com/pkg/errors"
"github.com/sirupsen/logrus"
"net"
"time"
)
2023-04-14 19:09:54 +02:00
type BackendConfig struct {
2023-04-14 19:09:54 +02:00
IdentityPath string
EndpointAddress string
ShrToken string
2023-04-25 21:16:05 +02:00
RequestsChan chan *endpoints.Request
2023-04-14 19:09:54 +02:00
}
type Backend struct {
cfg *BackendConfig
2023-04-14 19:09:54 +02:00
listener edge.Listener
}
func NewBackend(cfg *BackendConfig) (*Backend, error) {
options := ziti.ListenOptions{
ConnectTimeout: 5 * time.Minute,
MaxConnections: 64,
}
zcfg, err := config.NewFromFile(cfg.IdentityPath)
if err != nil {
return nil, errors.Wrap(err, "error loading config")
}
listener, err := ziti.NewContextWithConfig(zcfg).ListenWithOptions(cfg.ShrToken, &options)
2023-04-17 18:47:52 +02:00
if err != nil {
return nil, errors.Wrap(err, "error listening")
}
b := &Backend{
cfg: cfg,
listener: listener,
}
return b, nil
}
func (b *Backend) Run() error {
logrus.Info("started")
defer logrus.Info("exited")
for {
if conn, err := b.listener.Accept(); err == nil {
go b.handle(conn)
} else {
return err
}
}
}
func (b *Backend) handle(conn net.Conn) {
2023-04-25 21:16:05 +02:00
logrus.Debugf("handling '%v'", conn.RemoteAddr())
2023-04-21 21:09:01 +02:00
if rAddr, err := net.ResolveTCPAddr("tcp", b.cfg.EndpointAddress); err == nil {
if rConn, err := net.DialTCP("tcp", nil, rAddr); err == nil {
go endpoints.TXer(conn, rConn)
go endpoints.TXer(rConn, conn)
2023-04-25 21:16:05 +02:00
b.cfg.RequestsChan <- &endpoints.Request{
Stamp: time.Now(),
RemoteAddr: conn.RemoteAddr().String(),
Method: "OPEN",
Path: rAddr.String(),
}
2023-04-21 21:09:01 +02:00
} else {
logrus.Errorf("error dialing '%v': %v", b.cfg.EndpointAddress, err)
_ = conn.Close()
return
}
} else {
logrus.Errorf("error resolving '%v': %v", b.cfg.EndpointAddress, err)
}
}