107 lines
3.4 KiB
Go
Raw Normal View History

2019-08-07 18:44:33 +01:00
// Package tunnel provides gre network tunnelling
package tunnel
import (
"context"
"errors"
"time"
"go.unistack.org/micro/v3/network/transport"
)
// DefaultTunnel contains default tunnel implementation
var DefaultTunnel Tunnel
2019-10-15 15:40:04 +01:00
const (
// Unicast send over one link
2019-10-15 15:40:04 +01:00
Unicast Mode = iota
// Multicast send to all channel listeners
2019-10-15 15:40:04 +01:00
Multicast
// Broadcast send to all links
2019-10-15 15:40:04 +01:00
Broadcast
)
2019-09-04 12:00:11 +01:00
var (
// DefaultDialTimeout is the dial timeout if none is specified
DefaultDialTimeout = time.Second * 5
// ErrDialTimeout is returned by a call to Dial where the timeout occurs
ErrDialTimeout = errors.New("dial timeout")
// ErrDiscoverChan is returned when we failed to receive the "announce" back from a discovery
ErrDiscoverChan = errors.New("failed to discover channel")
2019-09-11 11:57:41 -07:00
// ErrLinkNotFound is returned when a link is specified at dial time and does not exist
ErrLinkNotFound = errors.New("link not found")
2020-01-13 20:06:02 +00:00
// ErrLinkDisconnected is returned when a link we attempt to send to is disconnected
ErrLinkDisconnected = errors.New("link not connected")
// ErrLinkLoopback is returned when attempting to send an outbound message over loopback link
2020-01-13 20:06:02 +00:00
ErrLinkLoopback = errors.New("link is loopback")
// ErrLinkRemote is returned when attempting to send a loopback message over remote link
ErrLinkRemote = errors.New("link is remote")
2019-12-07 23:28:39 +00:00
// ErrReadTimeout is a timeout on session.Recv
ErrReadTimeout = errors.New("read timeout")
2019-12-12 17:10:32 +00:00
// ErrDecryptingData is for when theres a nonce error
ErrDecryptingData = errors.New("error decrypting data")
2019-09-04 12:00:11 +01:00
)
// Mode of the session
2019-10-15 15:40:04 +01:00
type Mode uint8
// Tunnel creates a gre tunnel on top of the micro/transport.
2019-08-31 17:32:20 +01:00
// It establishes multiple streams using the Micro-Tunnel-Channel header
2019-08-07 18:44:33 +01:00
// and Micro-Tunnel-Session header. The tunnel id is a hash of
// the address being requested.
type Tunnel interface {
// Init initializes tunnel with options
2019-08-07 21:58:25 +01:00
Init(opts ...Option) error
// Address returns the address the tunnel is listening on
2019-08-21 12:55:10 +01:00
Address() string
// Connect connects the tunnel
Connect(ctx context.Context) error
// Close closes the tunnel
Close(ctx context.Context) error
// Links returns all the links the tunnel is connected to
2019-09-11 12:49:27 -07:00
Links() []Link
// Dial allows a client to connect to a channel
Dial(ctx context.Context, channel string, opts ...DialOption) (Session, error)
// Listen allows to accept connections on a channel
Listen(ctx context.Context, channel string, opts ...ListenOption) (Listener, error)
// String returns the name of the tunnel implementation
2019-08-20 17:21:35 +01:00
String() string
2019-08-07 18:44:33 +01:00
}
2019-09-04 15:41:57 +01:00
// Link represents internal links to the tunnel
type Link interface {
// Id returns the link unique Id
2019-09-04 15:41:57 +01:00
Id() string
2019-10-22 16:53:47 +01:00
// Delay is the current load on the link (lower is better)
2019-10-22 16:50:00 +01:00
Delay() int64
// Length returns the roundtrip time as nanoseconds (lower is better)
Length() int64
2019-10-22 17:02:22 +01:00
// Current transfer rate as bits per second (lower is better)
Rate() float64
// Is this a loopback link
Loopback() bool
// State of the link: connected/closed/error
State() string
2019-09-04 15:41:57 +01:00
// honours transport socket
transport.Socket
}
// Listener provides similar constructs to the transport.Listener
2019-08-07 18:44:33 +01:00
type Listener interface {
2019-08-31 17:32:20 +01:00
Accept() (Session, error)
2019-08-30 20:05:00 +01:00
Channel() string
2019-08-07 18:44:33 +01:00
Close() error
}
2019-08-30 20:05:00 +01:00
// Session is a unique session created when dialling or accepting connections on the tunnel
type Session interface {
2019-08-31 17:32:20 +01:00
// The unique session id
2019-08-07 18:44:33 +01:00
Id() string
2019-08-31 17:32:20 +01:00
// The channel name
2019-08-30 20:05:00 +01:00
Channel() string
2019-09-11 12:07:43 -07:00
// The link the session is on
Link() string
2019-08-07 18:44:33 +01:00
// a transport socket
transport.Socket
2019-08-05 19:41:48 +01:00
}