Documentation ¶
Index ¶
- Constants
- func ConnectErrors() <-chan *terminal.Error
- func EnableConnecting(my *hub.Hub)
- func HandleSluiceRequest(connInfo *network.Connection, conn net.Conn)
- type ConnectOp
- type ConnectRequest
- type PingOp
- type PingOpRequest
- type PingOpResponse
- type Tunnel
- type TunnelContext
- type TunnelContextHop
- type TunnelContextHopIPInfo
Constants ¶
const ConnectOpType string = "connect"
ConnectOpType is the type ID for the connection operation.
const (
// PingOpType is the type ID of the latency test operation.
PingOpType = "ping"
)
Variables ¶
This section is empty.
Functions ¶
func ConnectErrors ¶
ConnectErrors returns errors of connect operations. It only has a small and shared buffer and may only be used for indications, not for full monitoring.
func EnableConnecting ¶
EnableConnecting enables connecting from this Hub.
func HandleSluiceRequest ¶
func HandleSluiceRequest(connInfo *network.Connection, conn net.Conn)
HandleSluiceRequest handles a sluice request to build a tunnel.
Types ¶
type ConnectOp ¶
type ConnectOp struct { terminal.OperationBase // contains filtered or unexported fields }
ConnectOp is used to connect data tunnels to servers on the Internet.
func NewConnectOp ¶
NewConnectOp starts a new connect operation.
func (*ConnectOp) HandleStop ¶
HandleStop gives the operation the ability to cleanly shut down. The returned error is the error to send to the other side. Should never be called directly. Call Stop() instead.
type ConnectRequest ¶
type ConnectRequest struct { Domain string `json:"d,omitempty"` IP net.IP `json:"ip,omitempty"` UsePriorityDataMsgs bool `json:"pr,omitempty"` Protocol packet.IPProtocol `json:"p,omitempty"` Port uint16 `json:"po,omitempty"` QueueSize uint32 `json:"qs,omitempty"` }
ConnectRequest holds all the information necessary for a connect operation.
func (*ConnectRequest) Address ¶
func (r *ConnectRequest) Address() string
Address returns the address of the connext request.
func (*ConnectRequest) DialNetwork ¶
func (r *ConnectRequest) DialNetwork() string
DialNetwork returns the address of the connect request.
func (*ConnectRequest) String ¶
func (r *ConnectRequest) String() string
type PingOp ¶
type PingOp struct { terminal.OneOffOperationBase // contains filtered or unexported fields }
PingOp is used to measure latency.
func (*PingOp) HandleStop ¶
HandleStop gives the operation the ability to cleanly shut down. The returned error is the error to send to the other side. Should never be called directly. Call Stop() instead.
type PingOpRequest ¶
type PingOpRequest struct {
Nonce []byte `json:"n,omitempty"`
}
PingOpRequest is a ping request.
type PingOpResponse ¶
type PingOpResponse struct { Nonce []byte `json:"n,omitempty"` Time time.Time `json:"t,omitempty"` }
PingOpResponse is a ping response.
type Tunnel ¶
type Tunnel struct {
// contains filtered or unexported fields
}
Tunnel represents the local information and endpoint of a data tunnel.
type TunnelContext ¶
type TunnelContext struct { Path []*TunnelContextHop PathCost float32 RoutingAlg string // contains filtered or unexported fields }
TunnelContext holds additional information about the tunnel to be added to a connection.
func (*TunnelContext) GetExitNodeID ¶
func (tc *TunnelContext) GetExitNodeID() string
GetExitNodeID returns the ID of the exit node. It returns an empty string in case no path exists.
func (*TunnelContext) StopTunnel ¶
func (tc *TunnelContext) StopTunnel() error
StopTunnel stops the tunnel.
type TunnelContextHop ¶
type TunnelContextHop struct { ID string Name string IPv4 *TunnelContextHopIPInfo `json:",omitempty"` IPv6 *TunnelContextHopIPInfo `json:",omitempty"` }
TunnelContextHop holds hop data for TunnelContext.