micro/network/tunnel/options.go

193 lines
3.8 KiB
Go
Raw Normal View History

package tunnel
import (
"time"
"github.com/google/uuid"
"github.com/unistack-org/micro/v3/logger"
"github.com/unistack-org/micro/v3/meter"
"github.com/unistack-org/micro/v3/network/transport"
"github.com/unistack-org/micro/v3/tracer"
)
var (
// DefaultAddress is default tunnel bind address
2019-08-21 12:55:10 +01:00
DefaultAddress = ":0"
// DefaultToken the shared default token
2019-11-29 17:27:29 +00:00
DefaultToken = "go.micro.tunnel"
)
// Option func signature
type Option func(*Options)
// Options provides network configuration options
type Options struct {
// Logger used for logging
Logger logger.Logger
// Meter used for metrics
Meter meter.Meter
// Tracer used for tracing
Tracer tracer.Tracer
// Transport used for communication
Transport transport.Transport
// Token the shared auth token
Token string
// Name holds the tunnel name
Name string
// Id holds the tunnel id
Id string
// Address holds the tunnel address
Address string
// Nodes holds the tunnel nodes
Nodes []string
}
// DialOption func
type DialOption func(*DialOptions)
// DialOptions provides dial options
type DialOptions struct {
2019-09-11 11:57:41 -07:00
// Link specifies the link to use
Link string
2019-10-15 15:40:04 +01:00
// specify mode of the session
Mode Mode
2019-12-11 14:37:03 +00:00
// Wait for connection to be accepted
Wait bool
// the dial timeout
Timeout time.Duration
}
// ListenOption func
2019-10-15 15:40:04 +01:00
type ListenOption func(*ListenOptions)
// ListenOptions provides listen options
2019-10-15 15:40:04 +01:00
type ListenOptions struct {
// Mode specify mode of the session
2019-10-15 15:40:04 +01:00
Mode Mode
// Timeout the read timeout
2019-12-07 23:28:39 +00:00
Timeout time.Duration
2019-10-15 15:40:04 +01:00
}
// Id sets the tunnel id
func Id(id string) Option {
return func(o *Options) {
o.Id = id
}
}
// Logger sets the logger
func Logger(l logger.Logger) Option {
return func(o *Options) {
o.Logger = l
}
}
// Meter sets the meter
func Meter(m meter.Meter) Option {
return func(o *Options) {
o.Meter = m
}
}
// Address sets the tunnel address
func Address(a string) Option {
return func(o *Options) {
o.Address = a
}
}
// Nodes specify remote network nodes
2019-08-07 18:44:33 +01:00
func Nodes(n ...string) Option {
return func(o *Options) {
o.Nodes = n
}
}
2019-08-30 20:05:00 +01:00
// Token sets the shared token for auth
func Token(t string) Option {
return func(o *Options) {
o.Token = t
}
}
// Transport listens for incoming connections
func Transport(t transport.Transport) Option {
return func(o *Options) {
o.Transport = t
}
}
// ListenMode option
2019-10-15 16:08:38 +01:00
func ListenMode(m Mode) ListenOption {
2019-10-15 15:40:04 +01:00
return func(o *ListenOptions) {
2019-10-15 16:08:38 +01:00
o.Mode = m
2019-10-15 15:40:04 +01:00
}
}
// ListenTimeout for reads and writes on the listener session
2019-12-07 23:28:39 +00:00
func ListenTimeout(t time.Duration) ListenOption {
return func(o *ListenOptions) {
o.Timeout = t
}
}
// DialMode multicast sets the multicast option to send only to those mapped
2019-10-15 16:08:38 +01:00
func DialMode(m Mode) DialOption {
return func(o *DialOptions) {
2019-10-15 16:08:38 +01:00
o.Mode = m
}
}
2019-09-11 11:57:41 -07:00
// DialTimeout sets the dial timeout of the connection
func DialTimeout(t time.Duration) DialOption {
return func(o *DialOptions) {
o.Timeout = t
}
}
2019-09-11 11:57:41 -07:00
// DialLink specifies the link to pin this connection to.
// This is not applicable if the multicast option is set.
func DialLink(id string) DialOption {
return func(o *DialOptions) {
o.Link = id
}
}
2019-12-07 23:28:39 +00:00
2019-12-11 14:37:03 +00:00
// DialWait specifies whether to wait for the connection
// to be accepted before returning the session
func DialWait(b bool) DialOption {
return func(o *DialOptions) {
o.Wait = b
}
}
// NewOptions returns router default options with filled values
func NewOptions(opts ...Option) Options {
options := Options{
Id: uuid.New().String(),
Address: DefaultAddress,
Token: DefaultToken,
Logger: logger.DefaultLogger,
Meter: meter.DefaultMeter,
Tracer: tracer.DefaultTracer,
2019-12-07 23:28:39 +00:00
}
for _, o := range opts {
o(&options)
}
return options
2019-12-07 23:28:39 +00:00
}
// Tracer to be used for tracing
func Tracer(t tracer.Tracer) Option {
return func(o *Options) {
o.Tracer = t
}
}
// Name sets the name
func Name(n string) Option {
return func(o *Options) {
o.Name = n
}
}