Documentation ¶
Overview ¶
Uses nacl's secret_box to encrypt a net.Conn. It is (meant to be) an implementation of the STS protocol. Note we do not (yet) assume that a remote peer's pubkey is known ahead of time, and thus we are technically still vulnerable to MITM. (TODO!) See docs/sts-final.pdf for more info
Index ¶
- Constants
- Variables
- func AddToIPRangeCounts(counts map[string]int, ip string) map[string]int
- func CheckIPRangeCounts(counts map[string]int, limits []int) bool
- func Connect2Switches(switches []*Switch, i, j int)
- func FuzzConn(conn net.Conn) net.Conn
- func FuzzConnAfter(conn net.Conn, d time.Duration) net.Conn
- func FuzzConnAfterFromConfig(conn net.Conn, d time.Duration, config *FuzzConnConfig) net.Conn
- func FuzzConnFromConfig(conn net.Conn, config *FuzzConnConfig) net.Conn
- func StartSwitches(switches []*Switch) error
- type AddrBook
- func (a *AddrBook) AddAddress(addr *NetAddress, src *NetAddress)
- func (a *AddrBook) AddOurAddress(addr *NetAddress)
- func (a *AddrBook) GetSelection() []*NetAddress
- func (a *AddrBook) MarkAttempt(addr *NetAddress)
- func (a *AddrBook) MarkBad(addr *NetAddress)
- func (a *AddrBook) MarkGood(addr *NetAddress)
- func (a *AddrBook) NeedMoreAddrs() bool
- func (a *AddrBook) OnStart() error
- func (a *AddrBook) OnStop()
- func (a *AddrBook) OurAddresses() []*NetAddress
- func (a *AddrBook) PickAddress(newBias int) *NetAddress
- func (a *AddrBook) RemoveAddress(addr *NetAddress)
- func (a *AddrBook) Save()
- func (a *AddrBook) Size() int
- func (a *AddrBook) Wait()
- type BaseReactor
- type Channel
- type ChannelDescriptor
- type ChannelStatus
- type ConnectionStatus
- type DefaultListener
- func (l *DefaultListener) Connections() <-chan net.Conn
- func (l *DefaultListener) ExternalAddress() *NetAddress
- func (l *DefaultListener) InternalAddress() *NetAddress
- func (l *DefaultListener) NetListener() net.Listener
- func (l *DefaultListener) OnStart() error
- func (l *DefaultListener) OnStop()
- func (l *DefaultListener) String() string
- type FuzzConnConfig
- type FuzzedConnection
- func (fc *FuzzedConnection) Close() error
- func (fc *FuzzedConnection) Config() *FuzzConnConfig
- func (fc *FuzzedConnection) LocalAddr() net.Addr
- func (fc *FuzzedConnection) Read(data []byte) (n int, err error)
- func (fc *FuzzedConnection) RemoteAddr() net.Addr
- func (fc *FuzzedConnection) SetDeadline(t time.Time) error
- func (fc *FuzzedConnection) SetReadDeadline(t time.Time) error
- func (fc *FuzzedConnection) SetWriteDeadline(t time.Time) error
- func (fc *FuzzedConnection) Write(data []byte) (n int, err error)
- type IPeerSet
- type Listener
- type MConnConfig
- type MConnection
- func (c *MConnection) CanSend(chID byte) bool
- func (c *MConnection) OnStart() error
- func (c *MConnection) OnStop()
- func (c *MConnection) Send(chID byte, msg interface{}) bool
- func (c *MConnection) Status() ConnectionStatus
- func (c *MConnection) String() string
- func (c *MConnection) TrySend(chID byte, msg interface{}) bool
- type NetAddress
- func (na *NetAddress) Dial() (net.Conn, error)
- func (na *NetAddress) DialTimeout(timeout time.Duration) (net.Conn, error)
- func (na *NetAddress) Equals(other interface{}) bool
- func (na *NetAddress) Less(other interface{}) bool
- func (na *NetAddress) Local() bool
- func (na *NetAddress) RFC1918() bool
- func (na *NetAddress) RFC3849() bool
- func (na *NetAddress) RFC3927() bool
- func (na *NetAddress) RFC3964() bool
- func (na *NetAddress) RFC4193() bool
- func (na *NetAddress) RFC4380() bool
- func (na *NetAddress) RFC4843() bool
- func (na *NetAddress) RFC4862() bool
- func (na *NetAddress) RFC6052() bool
- func (na *NetAddress) RFC6145() bool
- func (na *NetAddress) ReachabilityTo(o *NetAddress) int
- func (na *NetAddress) Routable() bool
- func (na *NetAddress) String() string
- func (na *NetAddress) Valid() bool
- type NodeInfo
- type PEXReactor
- func (r *PEXReactor) AddPeer(p *Peer)
- func (r *PEXReactor) GetChannels() []*ChannelDescriptor
- func (r *PEXReactor) IncrementMsgCountForPeer(addr string)
- func (r *PEXReactor) OnStart() error
- func (r *PEXReactor) OnStop()
- func (r *PEXReactor) ReachedMaxMsgCountForPeer(addr string) bool
- func (r *PEXReactor) Receive(chID byte, src *Peer, msgBytes []byte)
- func (r *PEXReactor) RemovePeer(p *Peer, reason interface{})
- func (r *PEXReactor) RequestPEX(p *Peer)
- func (r *PEXReactor) SendAddrs(p *Peer, addrs []*NetAddress)
- func (r *PEXReactor) SetEnsurePeersPeriod(d time.Duration)
- func (r *PEXReactor) SetMaxMsgCountByPeer(v uint16)
- type Peer
- func (p *Peer) Addr() net.Addr
- func (p *Peer) CanSend(chID byte) bool
- func (p *Peer) CloseConn()
- func (p *Peer) Connection() *MConnection
- func (p *Peer) Equals(other *Peer) bool
- func (p *Peer) Get(key string) interface{}
- func (p *Peer) HandshakeTimeout(ourNodeInfo *NodeInfo, timeout time.Duration) error
- func (p *Peer) IsOutbound() bool
- func (p *Peer) IsPersistent() bool
- func (p *Peer) OnStart() error
- func (p *Peer) OnStop()
- func (p *Peer) PubKey() crypto.PubKeyEd25519
- func (p *Peer) Send(chID byte, msg interface{}) bool
- func (p *Peer) String() string
- func (p *Peer) TrySend(chID byte, msg interface{}) bool
- func (p *Peer) WriteTo(w io.Writer) (n int64, err error)
- type PeerConfig
- type PeerSet
- type PexMessage
- type Reactor
- type SecretConnection
- func (sc *SecretConnection) Close() error
- func (sc *SecretConnection) LocalAddr() net.Addr
- func (sc *SecretConnection) Read(data []byte) (n int, err error)
- func (sc *SecretConnection) RemoteAddr() net.Addr
- func (sc *SecretConnection) RemotePubKey() crypto.PubKeyEd25519
- func (sc *SecretConnection) SetDeadline(t time.Time) error
- func (sc *SecretConnection) SetReadDeadline(t time.Time) error
- func (sc *SecretConnection) SetWriteDeadline(t time.Time) error
- func (sc *SecretConnection) Write(data []byte) (n int, err error)
- type Switch
- func (sw *Switch) AddListener(l Listener)
- func (sw *Switch) AddPeer(peer *Peer) error
- func (sw *Switch) AddReactor(name string, reactor Reactor) Reactor
- func (sw *Switch) Broadcast(chID byte, msg interface{}) chan bool
- func (sw *Switch) DialPeerWithAddress(addr *NetAddress, persistent bool) (*Peer, error)
- func (sw *Switch) DialSeeds(addrBook *AddrBook, seeds []string) error
- func (sw *Switch) FilterConnByAddr(addr net.Addr) error
- func (sw *Switch) FilterConnByPubKey(pubkey crypto.PubKeyEd25519) error
- func (sw *Switch) IsDialing(addr *NetAddress) bool
- func (sw *Switch) IsListening() bool
- func (sw *Switch) Listeners() []Listener
- func (sw *Switch) NodeInfo() *NodeInfo
- func (sw *Switch) NumPeers() (outbound, inbound, dialing int)
- func (sw *Switch) OnStart() error
- func (sw *Switch) OnStop()
- func (sw *Switch) Peers() IPeerSet
- func (sw *Switch) Reactor(name string) Reactor
- func (sw *Switch) Reactors() map[string]Reactor
- func (sw *Switch) SetAddrFilter(f func(net.Addr) error)
- func (sw *Switch) SetNodeInfo(nodeInfo *NodeInfo)
- func (sw *Switch) SetNodePrivKey(nodePrivKey crypto.PrivKeyEd25519)
- func (sw *Switch) SetPubKeyFilter(f func(crypto.PubKeyEd25519) error)
- func (sw *Switch) StopPeerForError(peer *Peer, reason interface{})
- func (sw *Switch) StopPeerGracefully(peer *Peer)
- type SwitchEventDonePeer
- type SwitchEventNewPeer
Constants ¶
const ( // FuzzModeDrop is a mode in which we randomly drop reads/writes, connections or sleep FuzzModeDrop = iota // FuzzModeDelay is a mode in which we randomly sleep FuzzModeDelay )
const ( // PexChannel is a channel for PEX messages PexChannel = byte(0x00) )
const Version = "0.5.0"
Variables ¶
var (
ErrSwitchDuplicatePeer = errors.New("Duplicate peer")
)
var PanicOnAddPeerErr = false
Functions ¶
func AddToIPRangeCounts ¶ added in v0.10.0
TODO Test
func CheckIPRangeCounts ¶ added in v0.10.0
TODO Test
func Connect2Switches ¶
Will connect switches i and j via net.Pipe() Blocks until a conection is established. NOTE: caller ensures i and j are within bounds
func FuzzConnAfter ¶
FuzzConnAfter creates a new FuzzedConnection. Fuzzing starts when the duration elapses.
func FuzzConnAfterFromConfig ¶
FuzzConnAfterFromConfig creates a new FuzzedConnection from a config. Fuzzing starts when the duration elapses.
func FuzzConnFromConfig ¶
func FuzzConnFromConfig(conn net.Conn, config *FuzzConnConfig) net.Conn
FuzzConnFromConfig creates a new FuzzedConnection from a config. Fuzzing starts immediately.
func StartSwitches ¶
Types ¶
type AddrBook ¶
type AddrBook struct { cmn.BaseService // contains filtered or unexported fields }
AddrBook - concurrency safe peer address manager.
func NewAddrBook ¶ added in v0.10.0
NewAddrBook creates a new address book. Use Start to begin processing asynchronous address updates.
func (*AddrBook) AddAddress ¶
func (a *AddrBook) AddAddress(addr *NetAddress, src *NetAddress)
NOTE: addr must not be nil
func (*AddrBook) AddOurAddress ¶
func (a *AddrBook) AddOurAddress(addr *NetAddress)
func (*AddrBook) GetSelection ¶ added in v0.10.0
func (a *AddrBook) GetSelection() []*NetAddress
GetSelection randomly selects some addresses (old & new). Suitable for peer-exchange protocols.
func (*AddrBook) MarkAttempt ¶ added in v0.10.0
func (a *AddrBook) MarkAttempt(addr *NetAddress)
func (*AddrBook) MarkBad ¶ added in v0.10.0
func (a *AddrBook) MarkBad(addr *NetAddress)
MarkBad currently just ejects the address. In the future, consider blacklisting.
func (*AddrBook) MarkGood ¶
func (a *AddrBook) MarkGood(addr *NetAddress)
func (*AddrBook) NeedMoreAddrs ¶ added in v0.10.0
func (*AddrBook) OurAddresses ¶ added in v0.10.0
func (a *AddrBook) OurAddresses() []*NetAddress
func (*AddrBook) PickAddress ¶ added in v0.10.0
func (a *AddrBook) PickAddress(newBias int) *NetAddress
Pick an address to connect to with new/old bias.
func (*AddrBook) RemoveAddress ¶
func (a *AddrBook) RemoveAddress(addr *NetAddress)
RemoveAddress removes the address from the book.
type BaseReactor ¶
type BaseReactor struct { cmn.BaseService // Provides Start, Stop, .Quit Switch *Switch }
func NewBaseReactor ¶
func NewBaseReactor(name string, impl Reactor) *BaseReactor
func (*BaseReactor) AddPeer ¶
func (_ *BaseReactor) AddPeer(peer *Peer)
func (*BaseReactor) GetChannels ¶
func (_ *BaseReactor) GetChannels() []*ChannelDescriptor
func (*BaseReactor) RemovePeer ¶
func (_ *BaseReactor) RemovePeer(peer *Peer, reason interface{})
func (*BaseReactor) SetSwitch ¶
func (br *BaseReactor) SetSwitch(sw *Switch)
type Channel ¶ added in v0.10.0
type Channel struct {
// contains filtered or unexported fields
}
TODO: lowercase. NOTE: not goroutine-safe.
type ChannelDescriptor ¶
type ChannelDescriptor struct { ID byte Priority int SendQueueCapacity int RecvBufferCapacity int RecvMessageCapacity int }
func (*ChannelDescriptor) FillDefaults ¶ added in v0.10.0
func (chDesc *ChannelDescriptor) FillDefaults()
type ChannelStatus ¶ added in v0.10.0
type ConnectionStatus ¶
type ConnectionStatus struct { SendMonitor flow.Status RecvMonitor flow.Status Channels []ChannelStatus }
type DefaultListener ¶ added in v0.10.0
type DefaultListener struct { cmn.BaseService // contains filtered or unexported fields }
Implements Listener
func (*DefaultListener) Connections ¶ added in v0.10.0
func (l *DefaultListener) Connections() <-chan net.Conn
A channel of inbound connections. It gets closed when the listener closes.
func (*DefaultListener) ExternalAddress ¶ added in v0.10.0
func (l *DefaultListener) ExternalAddress() *NetAddress
func (*DefaultListener) InternalAddress ¶ added in v0.10.0
func (l *DefaultListener) InternalAddress() *NetAddress
func (*DefaultListener) NetListener ¶ added in v0.10.0
func (l *DefaultListener) NetListener() net.Listener
NOTE: The returned listener is already Accept()'ing. So it's not suitable to pass into http.Serve().
func (*DefaultListener) OnStart ¶ added in v0.10.0
func (l *DefaultListener) OnStart() error
func (*DefaultListener) OnStop ¶ added in v0.10.0
func (l *DefaultListener) OnStop()
func (*DefaultListener) String ¶ added in v0.10.0
func (l *DefaultListener) String() string
type FuzzConnConfig ¶ added in v0.10.0
type FuzzConnConfig struct { Mode int MaxDelay time.Duration ProbDropRW float64 ProbDropConn float64 ProbSleep float64 }
FuzzConnConfig is a FuzzedConnection configuration.
func DefaultFuzzConnConfig ¶ added in v0.10.0
func DefaultFuzzConnConfig() *FuzzConnConfig
DefaultFuzzConnConfig returns the default config.
type FuzzedConnection ¶
type FuzzedConnection struct {
// contains filtered or unexported fields
}
FuzzedConnection wraps any net.Conn and depending on the mode either delays reads/writes or randomly drops reads/writes/connections.
func (*FuzzedConnection) Close ¶
func (fc *FuzzedConnection) Close() error
Close implements net.Conn.
func (*FuzzedConnection) Config ¶
func (fc *FuzzedConnection) Config() *FuzzConnConfig
Config returns the connection's config.
func (*FuzzedConnection) LocalAddr ¶
func (fc *FuzzedConnection) LocalAddr() net.Addr
LocalAddr implements net.Conn.
func (*FuzzedConnection) Read ¶
func (fc *FuzzedConnection) Read(data []byte) (n int, err error)
Read implements net.Conn.
func (*FuzzedConnection) RemoteAddr ¶
func (fc *FuzzedConnection) RemoteAddr() net.Addr
RemoteAddr implements net.Conn.
func (*FuzzedConnection) SetDeadline ¶
func (fc *FuzzedConnection) SetDeadline(t time.Time) error
SetDeadline implements net.Conn.
func (*FuzzedConnection) SetReadDeadline ¶
func (fc *FuzzedConnection) SetReadDeadline(t time.Time) error
SetReadDeadline implements net.Conn.
func (*FuzzedConnection) SetWriteDeadline ¶
func (fc *FuzzedConnection) SetWriteDeadline(t time.Time) error
SetWriteDeadline implements net.Conn.
type Listener ¶ added in v0.10.0
type Listener interface { Connections() <-chan net.Conn InternalAddress() *NetAddress ExternalAddress() *NetAddress String() string Stop() bool }
type MConnConfig ¶
type MConnConfig struct { SendRate int64 `mapstructure:"send_rate"` RecvRate int64 `mapstructure:"recv_rate"` }
MConnConfig is a MConnection configuration.
func DefaultMConnConfig ¶ added in v0.10.0
func DefaultMConnConfig() *MConnConfig
DefaultMConnConfig returns the default config.
type MConnection ¶ added in v0.10.0
type MConnection struct { cmn.BaseService LocalAddress *NetAddress RemoteAddress *NetAddress // contains filtered or unexported fields }
Each peer has one `MConnection` (multiplex connection) instance.
__multiplex__ *noun* a system or signal involving simultaneous transmission of several messages along a single channel of communication.
Each `MConnection` handles message transmission on multiple abstract communication `Channel`s. Each channel has a globally unique byte id. The byte id and the relative priorities of each `Channel` are configured upon initialization of the connection.
There are two methods for sending messages:
func (m MConnection) Send(chID byte, msg interface{}) bool {} func (m MConnection) TrySend(chID byte, msg interface{}) bool {}
`Send(chID, msg)` is a blocking call that waits until `msg` is successfully queued for the channel with the given id byte `chID`, or until the request times out. The message `msg` is serialized using the `tendermint/wire` submodule's `WriteBinary()` reflection routine.
`TrySend(chID, msg)` is a nonblocking call that returns false if the channel's queue is full.
Inbound message bytes are handled with an onReceive callback function.
func NewMConnection ¶ added in v0.10.0
func NewMConnection(conn net.Conn, chDescs []*ChannelDescriptor, onReceive receiveCbFunc, onError errorCbFunc) *MConnection
NewMConnection wraps net.Conn and creates multiplex connection
func NewMConnectionWithConfig ¶ added in v0.10.0
func NewMConnectionWithConfig(conn net.Conn, chDescs []*ChannelDescriptor, onReceive receiveCbFunc, onError errorCbFunc, config *MConnConfig) *MConnection
NewMConnectionWithConfig wraps net.Conn and creates multiplex connection with a config
func (*MConnection) CanSend ¶ added in v0.10.0
func (c *MConnection) CanSend(chID byte) bool
CanSend returns true if you can send more data onto the chID, false otherwise. Use only as a heuristic.
func (*MConnection) OnStart ¶ added in v0.10.0
func (c *MConnection) OnStart() error
func (*MConnection) OnStop ¶ added in v0.10.0
func (c *MConnection) OnStop()
func (*MConnection) Send ¶ added in v0.10.0
func (c *MConnection) Send(chID byte, msg interface{}) bool
Queues a message to be sent to channel.
func (*MConnection) Status ¶ added in v0.10.0
func (c *MConnection) Status() ConnectionStatus
func (*MConnection) String ¶ added in v0.10.0
func (c *MConnection) String() string
func (*MConnection) TrySend ¶ added in v0.10.0
func (c *MConnection) TrySend(chID byte, msg interface{}) bool
Queues a message to be sent to channel. Nonblocking, returns true if successful.
type NetAddress ¶
NetAddress defines information about a peer on the network including its IP address, and port.
func NewNetAddress ¶
func NewNetAddress(addr net.Addr) *NetAddress
NewNetAddress returns a new NetAddress using the provided TCP address. When testing, other net.Addr (except TCP) will result in using 0.0.0.0:0. When normal run, other net.Addr (except TCP) will panic. TODO: socks proxies?
func NewNetAddressIPPort ¶
func NewNetAddressIPPort(ip net.IP, port uint16) *NetAddress
NewNetAddressIPPort returns a new NetAddress using the provided IP and port number.
func NewNetAddressString ¶
func NewNetAddressString(addr string) (*NetAddress, error)
NewNetAddressString returns a new NetAddress using the provided address in the form of "IP:Port". Also resolves the host if host is not an IP.
func NewNetAddressStrings ¶
func NewNetAddressStrings(addrs []string) ([]*NetAddress, error)
NewNetAddressStrings returns an array of NetAddress'es build using the provided strings.
func (*NetAddress) Dial ¶
func (na *NetAddress) Dial() (net.Conn, error)
Dial calls net.Dial on the address.
func (*NetAddress) DialTimeout ¶
DialTimeout calls net.DialTimeout on the address.
func (*NetAddress) Equals ¶
func (na *NetAddress) Equals(other interface{}) bool
Equals reports whether na and other are the same addresses.
func (*NetAddress) Less ¶ added in v0.10.0
func (na *NetAddress) Less(other interface{}) bool
func (*NetAddress) Local ¶
func (na *NetAddress) Local() bool
Local returns true if it is a local address.
func (*NetAddress) RFC1918 ¶
func (na *NetAddress) RFC1918() bool
func (*NetAddress) RFC3849 ¶
func (na *NetAddress) RFC3849() bool
func (*NetAddress) RFC3927 ¶
func (na *NetAddress) RFC3927() bool
func (*NetAddress) RFC3964 ¶
func (na *NetAddress) RFC3964() bool
func (*NetAddress) RFC4193 ¶
func (na *NetAddress) RFC4193() bool
func (*NetAddress) RFC4380 ¶
func (na *NetAddress) RFC4380() bool
func (*NetAddress) RFC4843 ¶
func (na *NetAddress) RFC4843() bool
func (*NetAddress) RFC4862 ¶
func (na *NetAddress) RFC4862() bool
func (*NetAddress) RFC6052 ¶
func (na *NetAddress) RFC6052() bool
func (*NetAddress) RFC6145 ¶
func (na *NetAddress) RFC6145() bool
func (*NetAddress) ReachabilityTo ¶
func (na *NetAddress) ReachabilityTo(o *NetAddress) int
ReachabilityTo checks whenever o can be reached from na.
func (*NetAddress) Routable ¶
func (na *NetAddress) Routable() bool
Routable returns true if the address is routable.
func (*NetAddress) Valid ¶
func (na *NetAddress) Valid() bool
For IPv4 these are either a 0 or all bits set address. For IPv6 a zero address or one that matches the RFC3849 documentation address format.
type NodeInfo ¶
type NodeInfo struct { PubKey crypto.PubKeyEd25519 `json:"pub_key"` Moniker string `json:"moniker"` Network string `json:"network"` RemoteAddr string `json:"remote_addr"` ListenAddr string `json:"listen_addr"` Version string `json:"version"` // major.minor.revision Other []string `json:"other"` // other application specific data }
func (*NodeInfo) CompatibleWith ¶ added in v0.10.0
CONTRACT: two nodes are compatible if the major/minor versions match and network match
func (*NodeInfo) ListenHost ¶ added in v0.10.0
func (*NodeInfo) ListenPort ¶ added in v0.10.0
type PEXReactor ¶ added in v0.10.0
type PEXReactor struct { BaseReactor // contains filtered or unexported fields }
PEXReactor handles PEX (peer exchange) and ensures that an adequate number of peers are connected to the switch.
It uses `AddrBook` (address book) to store `NetAddress`es of the peers.
## Preventing abuse
For now, it just limits the number of messages from one peer to `defaultMaxMsgCountByPeer` messages per `msgCountByPeerFlushInterval` (1000 msg/hour).
NOTE [2017-01-17]:
Limiting is fine for now. Maybe down the road we want to keep track of the quality of peer messages so if peerA keeps telling us about peers we can't connect to then maybe we should care less about peerA. But I don't think that kind of complexity is priority right now.
func NewPEXReactor ¶ added in v0.10.0
func NewPEXReactor(b *AddrBook) *PEXReactor
NewPEXReactor creates new PEX reactor.
func (*PEXReactor) AddPeer ¶ added in v0.10.0
func (r *PEXReactor) AddPeer(p *Peer)
AddPeer implements Reactor by adding peer to the address book (if inbound) or by requesting more addresses (if outbound).
func (*PEXReactor) GetChannels ¶ added in v0.10.0
func (r *PEXReactor) GetChannels() []*ChannelDescriptor
GetChannels implements Reactor
func (*PEXReactor) IncrementMsgCountForPeer ¶ added in v0.10.0
func (r *PEXReactor) IncrementMsgCountForPeer(addr string)
Increment or initialize the msg count for the peer in the CMap
func (*PEXReactor) OnStart ¶ added in v0.10.0
func (r *PEXReactor) OnStart() error
OnStart implements BaseService
func (*PEXReactor) OnStop ¶ added in v0.10.0
func (r *PEXReactor) OnStop()
OnStop implements BaseService
func (*PEXReactor) ReachedMaxMsgCountForPeer ¶ added in v0.10.0
func (r *PEXReactor) ReachedMaxMsgCountForPeer(addr string) bool
ReachedMaxMsgCountForPeer returns true if we received too many messages from peer with address `addr`. NOTE: assumes the value in the CMap is non-nil
func (*PEXReactor) Receive ¶ added in v0.10.0
func (r *PEXReactor) Receive(chID byte, src *Peer, msgBytes []byte)
Receive implements Reactor by handling incoming PEX messages.
func (*PEXReactor) RemovePeer ¶ added in v0.10.0
func (r *PEXReactor) RemovePeer(p *Peer, reason interface{})
RemovePeer implements Reactor.
func (*PEXReactor) RequestPEX ¶ added in v0.10.0
func (r *PEXReactor) RequestPEX(p *Peer)
RequestPEX asks peer for more addresses.
func (*PEXReactor) SendAddrs ¶ added in v0.10.0
func (r *PEXReactor) SendAddrs(p *Peer, addrs []*NetAddress)
SendAddrs sends addrs to the peer.
func (*PEXReactor) SetEnsurePeersPeriod ¶ added in v0.10.0
func (r *PEXReactor) SetEnsurePeersPeriod(d time.Duration)
SetEnsurePeersPeriod sets period to ensure peers connected.
func (*PEXReactor) SetMaxMsgCountByPeer ¶ added in v0.10.0
func (r *PEXReactor) SetMaxMsgCountByPeer(v uint16)
SetMaxMsgCountByPeer sets maximum messages one peer can send to us during 'msgCountByPeerFlushInterval'.
type Peer ¶
type Peer struct { cmn.BaseService *NodeInfo Key string Data *cmn.CMap // User data. // contains filtered or unexported fields }
Peer could be marked as persistent, in which case you can use Redial function to reconnect. Note that inbound peers can't be made persistent. They should be made persistent on the other end.
Before using a peer, you will need to perform a handshake on connection.
func (*Peer) CanSend ¶ added in v0.10.0
CanSend returns true if the send queue is not full, false otherwise.
func (*Peer) CloseConn ¶
func (p *Peer) CloseConn()
CloseConn should be used when the peer was created, but never started.
func (*Peer) Connection ¶ added in v0.10.0
func (p *Peer) Connection() *MConnection
Connection returns underlying MConnection.
func (*Peer) Equals ¶ added in v0.10.0
Equals reports whenever 2 peers are actually represent the same node.
func (*Peer) HandshakeTimeout ¶ added in v0.10.0
HandshakeTimeout performs a handshake between a given node and the peer. NOTE: blocking
func (*Peer) IsOutbound ¶
IsOutbound returns true if the connection is outbound, false otherwise.
func (*Peer) IsPersistent ¶
IsPersistent returns true if the peer is persitent, false otherwise.
func (*Peer) PubKey ¶ added in v0.10.0
func (p *Peer) PubKey() crypto.PubKeyEd25519
PubKey returns peer's public key.
func (*Peer) Send ¶
Send msg to the channel identified by chID byte. Returns false if the send queue is full after timeout, specified by MConnection.
type PeerConfig ¶ added in v0.10.0
type PeerConfig struct { AuthEnc bool `mapstructure:"auth_enc"` // authenticated encryption // times are in seconds HandshakeTimeout time.Duration `mapstructure:"handshake_timeout"` DialTimeout time.Duration `mapstructure:"dial_timeout"` MConfig *MConnConfig `mapstructure:"connection"` Fuzz bool `mapstructure:"fuzz"` // fuzz connection (for testing) FuzzConfig *FuzzConnConfig `mapstructure:"fuzz_config"` }
PeerConfig is a Peer configuration.
func DefaultPeerConfig ¶ added in v0.10.0
func DefaultPeerConfig() *PeerConfig
DefaultPeerConfig returns the default config.
type PeerSet ¶
type PeerSet struct {
// contains filtered or unexported fields
}
PeerSet is a special structure for keeping a table of peers. Iteration over the peers is super fast and thread-safe.
func NewPeerSet ¶
func NewPeerSet() *PeerSet
type PexMessage ¶ added in v0.10.0
type PexMessage interface{}
PexMessage is a primary type for PEX messages. Underneath, it could contain either pexRequestMessage, or pexAddrsMessage messages.
func DecodeMessage ¶ added in v0.10.0
func DecodeMessage(bz []byte) (msgType byte, msg PexMessage, err error)
DecodeMessage implements interface registered above.
type SecretConnection ¶ added in v0.10.0
type SecretConnection struct {
// contains filtered or unexported fields
}
Implements net.Conn
func MakeSecretConnection ¶ added in v0.10.0
func MakeSecretConnection(conn io.ReadWriteCloser, locPrivKey crypto.PrivKeyEd25519) (*SecretConnection, error)
Performs handshake and returns a new authenticated SecretConnection. Returns nil if error in handshake. Caller should call conn.Close() See docs/sts-final.pdf for more information.
func (*SecretConnection) Close ¶ added in v0.10.0
func (sc *SecretConnection) Close() error
Implements net.Conn
func (*SecretConnection) LocalAddr ¶ added in v0.10.0
func (sc *SecretConnection) LocalAddr() net.Addr
func (*SecretConnection) Read ¶ added in v0.10.0
func (sc *SecretConnection) Read(data []byte) (n int, err error)
CONTRACT: data smaller than dataMaxSize is read atomically.
func (*SecretConnection) RemoteAddr ¶ added in v0.10.0
func (sc *SecretConnection) RemoteAddr() net.Addr
func (*SecretConnection) RemotePubKey ¶ added in v0.10.0
func (sc *SecretConnection) RemotePubKey() crypto.PubKeyEd25519
Returns authenticated remote pubkey
func (*SecretConnection) SetDeadline ¶ added in v0.10.0
func (sc *SecretConnection) SetDeadline(t time.Time) error
func (*SecretConnection) SetReadDeadline ¶ added in v0.10.0
func (sc *SecretConnection) SetReadDeadline(t time.Time) error
func (*SecretConnection) SetWriteDeadline ¶ added in v0.10.0
func (sc *SecretConnection) SetWriteDeadline(t time.Time) error
type Switch ¶
type Switch struct { cmn.BaseService // contains filtered or unexported fields }
The `Switch` handles peer connections and exposes an API to receive incoming messages on `Reactors`. Each `Reactor` is responsible for handling incoming messages of one or more `Channels`. So while sending outgoing messages is typically performed on the peer, incoming messages are received on the reactor.
func MakeConnectedSwitches ¶
func MakeConnectedSwitches(cfg *cfg.P2PConfig, n int, initSwitch func(int, *Switch) *Switch, connect func([]*Switch, int, int)) []*Switch
Returns n switches, connected according to the connect func. If connect==Connect2Switches, the switches will be fully connected. initSwitch defines how the ith switch should be initialized (ie. with what reactors). NOTE: panics if any switch fails to start.
func (*Switch) AddListener ¶ added in v0.10.0
Not goroutine safe.
func (*Switch) AddPeer ¶ added in v0.10.0
NOTE: This performs a blocking handshake before the peer is added. CONTRACT: If error is returned, peer is nil, and conn is immediately closed.
func (*Switch) AddReactor ¶
Not goroutine safe.
func (*Switch) Broadcast ¶
Broadcast runs a go routine for each attempted send, which will block trying to send for defaultSendTimeoutSeconds. Returns a channel which receives success values for each attempted send (false if times out) NOTE: Broadcast uses goroutines, so order of broadcast may not be preserved.
func (*Switch) DialPeerWithAddress ¶
func (sw *Switch) DialPeerWithAddress(addr *NetAddress, persistent bool) (*Peer, error)
func (*Switch) FilterConnByAddr ¶ added in v0.10.0
func (*Switch) FilterConnByPubKey ¶ added in v0.10.0
func (sw *Switch) FilterConnByPubKey(pubkey crypto.PubKeyEd25519) error
func (*Switch) IsDialing ¶ added in v0.10.0
func (sw *Switch) IsDialing(addr *NetAddress) bool
func (*Switch) IsListening ¶ added in v0.10.0
Not goroutine safe.
func (*Switch) SetAddrFilter ¶ added in v0.10.0
func (*Switch) SetNodePrivKey ¶ added in v0.10.0
func (sw *Switch) SetNodePrivKey(nodePrivKey crypto.PrivKeyEd25519)
Not goroutine safe. NOTE: Overwrites sw.nodeInfo.PubKey
func (*Switch) SetPubKeyFilter ¶ added in v0.10.0
func (sw *Switch) SetPubKeyFilter(f func(crypto.PubKeyEd25519) error)
func (*Switch) StopPeerForError ¶
Disconnect from a peer due to external error, retry if it is a persistent peer. TODO: make record depending on reason.
func (*Switch) StopPeerGracefully ¶
Disconnect from a peer gracefully. TODO: handle graceful disconnects.
type SwitchEventDonePeer ¶ added in v0.10.0
type SwitchEventDonePeer struct { Peer *Peer Error interface{} }
type SwitchEventNewPeer ¶ added in v0.10.0
type SwitchEventNewPeer struct {
Peer *Peer
}