Documentation ¶
Index ¶
- Constants
- Variables
- func AddrsFactory(announce []string, noAnnounce []string) func() (_ p2pconfig.AddrsFactory, err error)
- func BlockService(bs blockstore.Blockstore, ex exchange.Interface) blockservice.BlockService
- func ConnectionGater(ds datastore.Batching) (*conngater.BasicConnectionGater, error)
- func ConnectionManager(cfg Config, bpeers Bootstrappers) (coreconnmgr.ConnManager, error)
- func ConstructModule(tp node.Type, cfg *Config) fx.Option
- func ContentRouting(r routing.PeerRouting) routing.ContentRouting
- func DataExchange(params bitSwapParams) (exchange.Interface, blockstore.Blockstore, error)
- func Flags() *flag.FlagSet
- func GenesisFor(net Network) (string, error)
- func ID(key crypto.PrivKey, pstore peerstore.Peerstore) (peer.ID, error)
- func Key(kstore keystore.Keystore) (crypto.PrivKey, error)
- func Listen(listen []string) func(host host.Host) (err error)
- func ParseFlags(cmd *cobra.Command, cfg *Config) error
- func PeerRouting(cfg Config, params routingParams) (routing.PeerRouting, error)
- func PeerStore() (peerstore.Peerstore, error)
- func PubSub(cfg Config, params pubSubParams) (*pubsub.PubSub, error)
- func RoutedHost(base HostBase, r routing.PeerRouting) host.Host
- func WithHost(hst host.Host) fx.Option
- func WithP2PKey(key crypto.PrivKey) fx.Option
- func WithP2PKeyStr(key string) fx.Option
- type API
- func (api *API) BandwidthForPeer(ctx context.Context, id peer.ID) metrics.Stats
- func (api *API) BandwidthForProtocol(ctx context.Context, proto protocol.ID) metrics.Stats
- func (api *API) BandwidthStats(ctx context.Context) metrics.Stats
- func (api *API) BlockPeer(ctx context.Context, p peer.ID) error
- func (api *API) ClosePeer(ctx context.Context, id peer.ID) error
- func (api *API) Connect(ctx context.Context, pi peer.AddrInfo) error
- func (api *API) Connectedness(ctx context.Context, id peer.ID) network.Connectedness
- func (api *API) Info(ctx context.Context) peer.AddrInfo
- func (api *API) IsProtected(ctx context.Context, id peer.ID, tag string) bool
- func (api *API) ListBlockedPeers(ctx context.Context) []peer.ID
- func (api *API) NATStatus(ctx context.Context) (network.Reachability, error)
- func (api *API) PeerInfo(ctx context.Context, id peer.ID) peer.AddrInfo
- func (api *API) Peers(ctx context.Context) []peer.ID
- func (api *API) Protect(ctx context.Context, id peer.ID, tag string)
- func (api *API) PubSubPeers(ctx context.Context, topic string) []peer.ID
- func (api *API) ResourceState(ctx context.Context) (rcmgr.ResourceManagerStat, error)
- func (api *API) UnblockPeer(ctx context.Context, p peer.ID) error
- func (api *API) Unprotect(ctx context.Context, id peer.ID, tag string) bool
- type Bootstrappers
- type Config
- type ConnManagerConfig
- type HostBase
- type Module
- type Network
Constants ¶
const EnvCustomNetwork = "CELESTIA_CUSTOM"
EnvCustomNetwork is the environment variable name used for setting a custom network.
Variables ¶
var ErrInvalidNetwork = errors.New("params: invalid network")
ErrInvalidNetwork is thrown when unknown network is used.
Functions ¶
func AddrsFactory ¶
func AddrsFactory(announce []string, noAnnounce []string) func() (_ p2pconfig.AddrsFactory, err error)
AddrsFactory returns a constructor for AddrsFactory.
func BlockService ¶
func BlockService(bs blockstore.Blockstore, ex exchange.Interface) blockservice.BlockService
BlockService constructs IPFS's BlockService for fetching arbitrary Merkle structures.
func ConnectionGater ¶
func ConnectionGater(ds datastore.Batching) (*conngater.BasicConnectionGater, error)
ConnectionGater constructs a BasicConnectionGater.
func ConnectionManager ¶
func ConnectionManager(cfg Config, bpeers Bootstrappers) (coreconnmgr.ConnManager, error)
ConnectionManager provides a constructor for ConnectionManager.
func ConstructModule ¶
ConstructModule collects all the components and services related to p2p.
func ContentRouting ¶
func ContentRouting(r routing.PeerRouting) routing.ContentRouting
ContentRouting constructs nil content routing, as for our use-case existing ContentRouting mechanisms, e.g DHT, are unsuitable
func DataExchange ¶
func DataExchange(params bitSwapParams) (exchange.Interface, blockstore.Blockstore, error)
DataExchange provides a constructor for IPFS block's DataExchange over BitSwap.
func GenesisFor ¶ added in v0.5.0
GenesisFor reports a hash of a genesis block for a given network. Genesis is strictly defined and can't be modified.
func Listen ¶
Listen returns invoke function that starts listening for inbound connections with libp2p.Host.
func ParseFlags ¶
ParseFlags parses P2P flags from the given cmd and saves them to the passed config.
func PeerRouting ¶
func PeerRouting(cfg Config, params routingParams) (routing.PeerRouting, error)
PeerRouting provides constructor for PeerRouting over DHT. Basically, this provides a way to discover peer addresses by respecting public keys.
func RoutedHost ¶
func RoutedHost(base HostBase, r routing.PeerRouting) host.Host
RoutedHost constructs a wrapped Host that may fallback to address discovery, if any top-level operation on the Host is provided with PeerID(Hash(PbK)) only.
func WithP2PKey ¶
WithP2PKey sets custom Ed25519 private key for p2p networking.
func WithP2PKeyStr ¶
WithP2PKeyStr sets custom hex encoded Ed25519 private key for p2p networking.
Types ¶
type API ¶ added in v0.5.0
type API struct { Internal struct { Info func(context.Context) peer.AddrInfo `perm:"admin"` Peers func(context.Context) []peer.ID `perm:"admin"` PeerInfo func(ctx context.Context, id peer.ID) peer.AddrInfo `perm:"admin"` Connect func(ctx context.Context, pi peer.AddrInfo) error `perm:"admin"` ClosePeer func(ctx context.Context, id peer.ID) error `perm:"admin"` Connectedness func(ctx context.Context, id peer.ID) network.Connectedness `perm:"admin"` NATStatus func(context.Context) (network.Reachability, error) `perm:"admin"` BlockPeer func(ctx context.Context, p peer.ID) error `perm:"admin"` UnblockPeer func(ctx context.Context, p peer.ID) error `perm:"admin"` ListBlockedPeers func(context.Context) []peer.ID `perm:"admin"` Protect func(ctx context.Context, id peer.ID, tag string) `perm:"admin"` Unprotect func(ctx context.Context, id peer.ID, tag string) bool `perm:"admin"` IsProtected func(ctx context.Context, id peer.ID, tag string) bool `perm:"admin"` BandwidthStats func(context.Context) metrics.Stats `perm:"admin"` BandwidthForPeer func(ctx context.Context, id peer.ID) metrics.Stats `perm:"admin"` BandwidthForProtocol func(ctx context.Context, proto protocol.ID) metrics.Stats `perm:"admin"` ResourceState func(context.Context) (rcmgr.ResourceManagerStat, error) `perm:"admin"` PubSubPeers func(ctx context.Context, topic string) []peer.ID `perm:"admin"` } }
API is a wrapper around Module for the RPC. TODO(@distractedm1nd): These structs need to be autogenerated.
func (*API) BandwidthForPeer ¶ added in v0.5.0
func (*API) BandwidthForProtocol ¶ added in v0.5.0
func (*API) BandwidthStats ¶ added in v0.5.0
func (*API) Connectedness ¶ added in v0.5.0
func (*API) IsProtected ¶ added in v0.5.0
func (*API) ListBlockedPeers ¶ added in v0.5.0
func (*API) PubSubPeers ¶ added in v0.5.0
func (*API) ResourceState ¶ added in v0.5.0
func (*API) UnblockPeer ¶ added in v0.5.0
type Bootstrappers ¶ added in v0.5.0
Bootstrappers is a type definition for nodes that will be used as bootstrappers.
func BootstrappersFor ¶ added in v0.5.0
func BootstrappersFor(net Network) (Bootstrappers, error)
BootstrappersFor returns address information of bootstrap peers for a given network.
type Config ¶
type Config struct { // ListenAddresses - Addresses to listen to on local NIC. ListenAddresses []string // AnnounceAddresses - Addresses to be announced/advertised for peers to connect to AnnounceAddresses []string // NoAnnounceAddresses - Addresses the P2P subsystem may know about, but that should not be // announced/advertised, as undialable from WAN NoAnnounceAddresses []string // a bootstrapper. Bootstrapper bool // MutualPeers are peers which have a bidirectional peering agreement with the configured node. // Connections with those peers are protected from being trimmed, dropped or negatively scored. // NOTE: Any two peers must bidirectionally configure each other on their MutualPeers field. MutualPeers []string // PeerExchange configures the node, whether it should share some peers to a pruned peer. // This is enabled by default for Bootstrappers. PeerExchange bool // ConnManager is a configuration tuple for ConnectionManager. ConnManager ConnManagerConfig RoutingTableRefreshPeriod time.Duration }
Config combines all configuration fields for P2P subsystem.
func DefaultConfig ¶
func DefaultConfig() Config
DefaultConfig returns default configuration for P2P subsystem.
type ConnManagerConfig ¶
type ConnManagerConfig struct {
// Low and High are watermarks governing the number of connections that'll be maintained.
Low, High int
// GracePeriod is the amount of time a newly opened connection is given before it becomes subject
// to pruning.
GracePeriod time.Duration
}
ConnManagerConfig configures connection manager.
func DefaultConnManagerConfig ¶
func DefaultConnManagerConfig() ConnManagerConfig
DefaultConnManagerConfig returns defaults for ConnManagerConfig.
type HostBase ¶
func Host ¶
func Host(cfg Config, params hostParams, bw *metrics.BandwidthCounter, rm network.ResourceManager) (HostBase, error)
Host returns constructor for Host.
type Module ¶ added in v0.5.0
type Module interface { // Info returns address information about the host. Info(context.Context) peer.AddrInfo // Peers returns all peer IDs used across all inner stores. Peers(context.Context) []peer.ID // PeerInfo returns a small slice of information Peerstore has on the // given peer. PeerInfo(ctx context.Context, id peer.ID) peer.AddrInfo // Connect ensures there is a connection between this host and the peer with // given peer. Connect(ctx context.Context, pi peer.AddrInfo) error // ClosePeer closes the connection to a given peer. ClosePeer(ctx context.Context, id peer.ID) error // Connectedness returns a state signaling connection capabilities. Connectedness(ctx context.Context, id peer.ID) network.Connectedness // NATStatus returns the current NAT status. NATStatus(context.Context) (network.Reachability, error) // BlockPeer adds a peer to the set of blocked peers. BlockPeer(ctx context.Context, p peer.ID) error // UnblockPeer removes a peer from the set of blocked peers. UnblockPeer(ctx context.Context, p peer.ID) error // ListBlockedPeers returns a list of blocked peers. ListBlockedPeers(context.Context) []peer.ID // Protect adds a peer to the list of peers who have a bidirectional // peering agreement that they are protected from being trimmed, dropped // or negatively scored. Protect(ctx context.Context, id peer.ID, tag string) // Unprotect removes a peer from the list of peers who have a bidirectional // peering agreement that they are protected from being trimmed, dropped // or negatively scored, returning a bool representing whether the given // peer is protected or not. Unprotect(ctx context.Context, id peer.ID, tag string) bool // IsProtected returns whether the given peer is protected. IsProtected(ctx context.Context, id peer.ID, tag string) bool // BandwidthStats returns a Stats struct with bandwidth metrics for all // data sent/received by the local peer, regardless of protocol or remote // peer IDs. BandwidthStats(context.Context) metrics.Stats // BandwidthForPeer returns a Stats struct with bandwidth metrics associated with the given peer.ID. // The metrics returned include all traffic sent / received for the peer, regardless of protocol. BandwidthForPeer(ctx context.Context, id peer.ID) metrics.Stats // BandwidthForProtocol returns a Stats struct with bandwidth metrics associated with the given protocol.ID. BandwidthForProtocol(ctx context.Context, proto protocol.ID) metrics.Stats // ResourceState returns the state of the resource manager. ResourceState(context.Context) (rcmgr.ResourceManagerStat, error) // PubSubPeers returns the peer IDs of the peers joined on // the given topic. PubSubPeers(ctx context.Context, topic string) []peer.ID }
Module represents all accessible methods related to the node's p2p host / operations.
type Network ¶ added in v0.5.0
type Network string
Network is a type definition for DA network run by Celestia Node.
const ( // DefaultNetwork is the default network of the current build. DefaultNetwork = Mocha // Arabica testnet. See: celestiaorg/networks. Arabica Network = "arabica-2" // Mocha testnet. See: celestiaorg/networks. Mocha Network = "mocha" // Private can be used to set up any private network, including local testing setups. Private Network = "private" // BlockTime is a network block time. // TODO @renaynay @Wondertan (#790) BlockTime = time.Second * 30 )
NOTE: Every time we add a new long-running network, it has to be added here.
func ParseNetwork ¶ added in v0.5.0
ParseNetwork tries to parse the network from the flags and environment, and returns either the parsed network or the build's default network