Documentation ¶
Overview ¶
package p2p is a low-level library responsible for peer discovery and sending/receiving messages.
Index ¶
- Variables
- func ConnectToBootstrapList(ctx context.Context, host host.Host) error
- func NewDHT(ctx context.Context, host host.Host) (*dht.IpfsDHT, error)
- type Config
- type Message
- type MessageHandler
- type Node
- func (n *Node) AddPeerScore(id peer.ID, tag string, diff int)
- func (n *Node) Connect(peerInfo peer.AddrInfo, timeout time.Duration) error
- func (n *Node) GetNumPeers() int
- func (n *Node) ID() peer.ID
- func (n *Node) Multiaddrs() []ma.Multiaddr
- func (n *Node) SetPeerScore(id peer.ID, tag string, val int)
- func (n *Node) Start() error
- func (n *Node) UnsetPeerScore(id peer.ID, tag string)
Constants ¶
This section is empty.
Variables ¶
var BootstrapPeers []multiaddr.Multiaddr
BootstrapPeers is a list of peers to use for bootstrapping the DHT.
Functions ¶
func ConnectToBootstrapList ¶
Types ¶
type Config ¶
type Config struct { // Topic is a unique string representing the pubsub topic. Only Nodes which // have the same topic will share messages with one another. Topic string // ListenPort is the port on which to listen for new connections. It can be // set to 0 to make the OS automatically choose any available port. ListenPort int // Insecure controls whether or not messages should be encrypted. It should // always be set to false in production. Insecure bool // PrivateKey is the private key which will be used for signing messages and // generating a peer ID. PrivateKey p2pcrypto.PrivKey // MessageHandler is an interface responsible for validating, storing, and // finding new messages to share. MessageHandler MessageHandler // RendezvousString is a unique identifier for the rendezvous point. This node // will attempt to find peers with the same Rendezvous string. RendezvousString string // UseBootstrapList determines whether or not to use the list of predetermined // peers to bootstrap the DHT for peer discovery. UseBootstrapList bool // PeerstoreDir is the directory to use for peerstore data. PeerstoreDir string }
Config contains configuration options for a Node.
type MessageHandler ¶
type MessageHandler interface { // HandleMessages is called whenever new messages are received. It should only // return an error if there was a problem handling the messages. It should not // return an error for invalid or duplicate messages. HandleMessages([]*Message) error GetMessagesToShare(max int) ([][]byte, error) }
MessageHandler is an interface responsible for validating and storing messages as well as selecting messages which are ready to be shared.
type Node ¶
type Node struct {
// contains filtered or unexported fields
}
Node is the main type for the p2p package. It represents a particpant in the 0x Mesh network who is capable of sending, receiving, validating, and storing messages.
func New ¶
New creates a new Node with the given context and config. The Node will stop all background operations if the context is canceled.
func (*Node) AddPeerScore ¶
AddPeerScore adds diff to the current score for a given peer. Tag is a unique identifier for the score. A peer's total score is the sum of the scores associated with each tag. Peers that end up with a low total score will eventually be disconnected.
func (*Node) Connect ¶
Connect ensures there is a connection between this host and the peer with given peerInfo. If there is not an active connection, Connect will dial the peer, and block until a connection is open, timeout is exceeded, or an error is returned.
func (*Node) GetNumPeers ¶
GetNumPeers returns the number of peers the node is connected to
func (*Node) Multiaddrs ¶
Multiaddrs returns all multi addresses at which the node is dialable.
func (*Node) SetPeerScore ¶
SetPeerScore sets the current score for a given peer (overwriting any previous value with the same tag). Tag is a unique identifier for the score. A peer's total score is the sum of the scores associated with each tag. Peers that end up with a low total score will eventually be disconnected.