Documentation ¶
Index ¶
- Constants
- func NewIPAddrFallback(maxRetries uint8) *ipAddrFallback
- func NewTunnelsForHA() tunnelsForHA
- func StartTunnelDaemon(ctx context.Context, config *TunnelConfig, ...) error
- type ConnAwareLogger
- type ConnectivityError
- type EdgeAddrHandler
- type EdgeTunnelServer
- type ReconnectSignal
- type Supervisor
- type TunnelConfig
- type TunnelServer
Constants ¶
View Source
const ( PQKex = tls.CurveID(0x6399) // X25519Kyber768Draft00 PQKexName = "X25519Kyber768Draft00" )
Variables ¶
This section is empty.
Functions ¶
func NewIPAddrFallback ¶
func NewIPAddrFallback(maxRetries uint8) *ipAddrFallback
func NewTunnelsForHA ¶
func NewTunnelsForHA() tunnelsForHA
NewTunnelsForHA initializes the Prometheus metrics etc for a tunnelsForHA.
func StartTunnelDaemon ¶
func StartTunnelDaemon( ctx context.Context, config *TunnelConfig, orchestrator *orchestration.Orchestrator, connectedSignal *signal.Signal, reconnectCh chan ReconnectSignal, graceShutdownC <-chan struct{}, ) error
Types ¶
type ConnAwareLogger ¶
type ConnAwareLogger struct {
// contains filtered or unexported fields
}
func NewConnAwareLogger ¶
func NewConnAwareLogger(logger *zerolog.Logger, tracker *tunnelstate.ConnTracker, observer *connection.Observer) *ConnAwareLogger
func (*ConnAwareLogger) ConnAwareLogger ¶
func (c *ConnAwareLogger) ConnAwareLogger() *zerolog.Event
func (*ConnAwareLogger) Logger ¶
func (c *ConnAwareLogger) Logger() *zerolog.Logger
func (*ConnAwareLogger) ReplaceLogger ¶
func (c *ConnAwareLogger) ReplaceLogger(logger *zerolog.Logger) *ConnAwareLogger
type ConnectivityError ¶
type ConnectivityError struct {
// contains filtered or unexported fields
}
func NewConnectivityError ¶
func NewConnectivityError(hasReachedMaxRetries bool) *ConnectivityError
func (*ConnectivityError) Error ¶
func (e *ConnectivityError) Error() string
func (*ConnectivityError) HasReachedMaxRetries ¶
func (e *ConnectivityError) HasReachedMaxRetries() bool
type EdgeAddrHandler ¶
type EdgeAddrHandler interface { // ShouldGetNewAddress will check the edge connection error and determine if // the edge address should be replaced with a new one. Also, will return if the // error should be recognized as a connectivity error, or otherwise, a general // application error. ShouldGetNewAddress(connIndex uint8, err error) (needsNewAddress bool, connectivityError error) }
EdgeAddrHandler provides a mechanism switch between behaviors in ServeTunnel for handling the errors when attempting to make edge connections.
type EdgeTunnelServer ¶
type EdgeTunnelServer struct {
// contains filtered or unexported fields
}
type ReconnectSignal ¶
type ReconnectSignal struct { // wait this many seconds before re-establish the connection Delay time.Duration }
func (ReconnectSignal) DelayBeforeReconnect ¶
func (r ReconnectSignal) DelayBeforeReconnect()
func (ReconnectSignal) Error ¶
func (r ReconnectSignal) Error() string
Error allows us to use ReconnectSignal as a special error to force connection abort
type Supervisor ¶
type Supervisor struct {
// contains filtered or unexported fields
}
Supervisor manages non-declarative tunnels. Establishes TCP connections with the edge, and reconnects them if they disconnect.
func NewSupervisor ¶
func NewSupervisor(config *TunnelConfig, orchestrator *orchestration.Orchestrator, reconnectCh chan ReconnectSignal, gracefulShutdownC <-chan struct{}) (*Supervisor, error)
type TunnelConfig ¶
type TunnelConfig struct { GracePeriod time.Duration ReplaceExisting bool OSArch string ClientID string CloseConnOnce *sync.Once // Used to close connectedSignal no more than once EdgeAddrs []string Region string EdgeIPVersion allregions.ConfigIPVersion EdgeBindAddr net.IP HAConnections int IsAutoupdated bool LBPool string Tags []pogs.Tag Log *zerolog.Logger LogTransport *zerolog.Logger Observer *connection.Observer ReportedVersion string Retries uint MaxEdgeAddrRetries uint8 RunFromTerminal bool NeedPQ bool NamedTunnel *connection.TunnelProperties ProtocolSelector connection.ProtocolSelector EdgeTLSConfigs map[connection.Protocol]*tls.Config PacketConfig *ingress.GlobalRouterConfig RPCTimeout time.Duration WriteStreamTimeout time.Duration DisableQUICPathMTUDiscovery bool QUICConnectionLevelFlowControlLimit uint64 QUICStreamLevelFlowControlLimit uint64 FeatureSelector *features.FeatureSelector }
Click to show internal directories.
Click to hide internal directories.