Documentation ¶
Index ¶
- Variables
- type ConnStatus
- type ConnectionNotifier
- func (c ConnectionNotifier) Close()
- func (c ConnectionNotifier) ClosedStream(n network.Network, s network.Stream)
- func (c ConnectionNotifier) Connected(n network.Network, cc network.Conn)
- func (c ConnectionNotifier) Disconnected(n network.Network, cc network.Conn)
- func (c ConnectionNotifier) Listen(n network.Network, m multiaddr.Multiaddr)
- func (c ConnectionNotifier) ListenClose(n network.Network, m multiaddr.Multiaddr)
- func (c ConnectionNotifier) OpenedStream(n network.Network, s network.Stream)
- type IdentityCredential
- type Metrics
- type Peer
- type PeerConnection
- type PeerStats
- type RLNRelay
- type ReceptorService
- type Service
- type SpamHandler
- type VersionInfo
- type WakuNode
- func (w *WakuNode) AddDiscoveredPeer(ID peer.ID, addrs []ma.Multiaddr, origin wps.Origin, pubsubTopics []string)
- func (w *WakuNode) AddPeer(address ma.Multiaddr, origin wps.Origin, pubSubTopics []string, ...) (peer.ID, error)
- func (w *WakuNode) Broadcaster() relay.Broadcaster
- func (w *WakuNode) ClosePeerByAddress(address string) error
- func (w *WakuNode) ClosePeerById(id peer.ID) error
- func (w *WakuNode) DialPeer(ctx context.Context, address string) error
- func (w *WakuNode) DialPeerByID(ctx context.Context, peerID peer.ID) error
- func (w *WakuNode) DialPeerWithInfo(ctx context.Context, peerInfo peer.AddrInfo) error
- func (w *WakuNode) DialPeerWithMultiAddress(ctx context.Context, address ma.Multiaddr) error
- func (w *WakuNode) DiscV5() *discv5.DiscoveryV5
- func (w *WakuNode) ENR() *enode.Node
- func (w *WakuNode) FilterFullNode() *filter.WakuFilterFullNode
- func (w *WakuNode) FilterLightnode() *filter.WakuFilterLightNode
- func (w *WakuNode) Host() host.Host
- func (w *WakuNode) ID() string
- func (w *WakuNode) LegacyFilter() *legacy_filter.WakuFilter
- func (w *WakuNode) Lightpush() *lightpush.WakuLightPush
- func (w *WakuNode) ListenAddresses() []ma.Multiaddr
- func (w *WakuNode) PeerCount() int
- func (w *WakuNode) PeerExchange() *peer_exchange.WakuPeerExchange
- func (w *WakuNode) PeerStats() PeerStats
- func (w *WakuNode) Peers() ([]*Peer, error)
- func (w *WakuNode) PeersByShard(cluster uint16, shard uint16) peer.IDSlice
- func (w *WakuNode) RLNRelay() RLNRelay
- func (w *WakuNode) Relay() *relay.WakuRelay
- func (w *WakuNode) Rendezvous() *rendezvous.Rendezvous
- func (w *WakuNode) SetDiscV5Bootnodes(nodes []*enode.Node) error
- func (w *WakuNode) Start(ctx context.Context) error
- func (w *WakuNode) Status() (isOnline bool, hasHistory bool)
- func (w *WakuNode) Stop()
- func (w *WakuNode) Store() store.Store
- func (w *WakuNode) Timesource() timesource.Timesource
- type WakuNodeOption
- func WithAdvertiseAddresses(advertiseAddrs ...ma.Multiaddr) WakuNodeOption
- func WithConnectionNotification(ch chan<- PeerConnection) WakuNodeOption
- func WithConnectionStatusChannel(connStatus chan ConnStatus) WakuNodeOption
- func WithDNS4Domain(dns4Domain string) WakuNodeOption
- func WithDiscoveryV5(udpPort uint, bootnodes []*enode.Node, autoUpdate bool) WakuNodeOption
- func WithDynamicRLNRelay(keystorePath string, keystorePassword string, treePath string, ...) WakuNodeOption
- func WithExternalIP(ip net.IP) WakuNodeOption
- func WithHostAddress(hostAddr *net.TCPAddr) WakuNodeOption
- func WithKeepAlive(t time.Duration) WakuNodeOption
- func WithLegacyWakuFilter(fullnode bool, filterOpts ...legacy_filter.Option) WakuNodeOption
- func WithLibP2POptions(opts ...libp2p.Option) WakuNodeOption
- func WithLightPush() WakuNodeOption
- func WithLogLevel(lvl zapcore.Level) WakuNodeOption
- func WithLogger(l *zap.Logger) WakuNodeOption
- func WithMaxPeerConnections(maxPeers int) WakuNodeOption
- func WithMessageProvider(s store.MessageProvider) WakuNodeOption
- func WithMultiaddress(addresses ...multiaddr.Multiaddr) WakuNodeOption
- func WithNTP(ntpURLs ...string) WakuNodeOption
- func WithPeerExchange() WakuNodeOption
- func WithPeerStore(ps peerstore.Peerstore) WakuNodeOption
- func WithPrivateKey(privKey *ecdsa.PrivateKey) WakuNodeOption
- func WithPrometheusRegisterer(reg prometheus.Registerer) WakuNodeOption
- func WithRendezvous(db *rendezvous.DB) WakuNodeOption
- func WithSecureWebsockets(address string, port int, certPath string, keyPath string) WakuNodeOption
- func WithStaticRLNRelay(memberIndex *r.MembershipIndex, spamHandler rln.SpamHandler) WakuNodeOption
- func WithWakuFilterFullNode(filterOpts ...filter.Option) WakuNodeOption
- func WithWakuFilterLightNode() WakuNodeOption
- func WithWakuRelay(opts ...pubsub.Option) WakuNodeOption
- func WithWakuRelayAndMinPeers(minRelayPeersToPublish int, opts ...pubsub.Option) WakuNodeOption
- func WithWakuStore() WakuNodeOption
- func WithWakuStoreFactory(factory storeFactory) WakuNodeOption
- func WithWebsockets(address string, port int) WakuNodeOption
- type WakuNodeParameters
Constants ¶
This section is empty.
Variables ¶
var DefaultLibP2POptions = []libp2p.Option{ libp2p.ChainOptions( libp2p.Transport(tcp.NewTCPTransport), libp2p.Transport(quic.NewTransport), libp2p.Transport(libp2pwebtransport.New), ), libp2p.UserAgent(userAgent), libp2p.ChainOptions( libp2p.Muxer("/yamux/1.0.0", yamux.DefaultTransport), libp2p.Muxer("/mplex/6.7.0", mplex.DefaultTransport), ), libp2p.EnableNATService(), libp2p.ConnectionManager(newConnManager(200, 300, connmgr.WithGracePeriod(0))), libp2p.EnableHolePunching(), }
Default options used in the libp2p node
var DefaultWakuNodeOptions = []WakuNodeOption{ WithPrometheusRegisterer(prometheus.NewRegistry()), WithMaxPeerConnections(50), }
Default options used in the libp2p node
var GitCommit string
GitCommit is a commit hash.
var Version string
Version is the version of go-waku at the time of compilation
Functions ¶
This section is empty.
Types ¶
type ConnStatus ¶
ConnStatus is used to indicate if the node is online, has access to history and also see the list of peers the node is aware of
type ConnectionNotifier ¶
type ConnectionNotifier struct { DisconnectChan chan peer.ID // contains filtered or unexported fields }
ConnectionNotifier is a custom Notifier to be used to display when a peer connects or disconnects to the node
func NewConnectionNotifier ¶
func NewConnectionNotifier(ctx context.Context, h host.Host, connNotifCh chan<- PeerConnection, metrics Metrics, log *zap.Logger) ConnectionNotifier
NewConnectionNotifier creates an instance of ConnectionNotifier to react to peer connection changes
func (ConnectionNotifier) Close ¶
func (c ConnectionNotifier) Close()
Close quits the ConnectionNotifier
func (ConnectionNotifier) ClosedStream ¶
func (c ConnectionNotifier) ClosedStream(n network.Network, s network.Stream)
ClosedStream is called when a stream closed
func (ConnectionNotifier) Connected ¶
func (c ConnectionNotifier) Connected(n network.Network, cc network.Conn)
Connected is called when a connection is opened
func (ConnectionNotifier) Disconnected ¶
func (c ConnectionNotifier) Disconnected(n network.Network, cc network.Conn)
Disconnected is called when a connection closed
func (ConnectionNotifier) Listen ¶
func (c ConnectionNotifier) Listen(n network.Network, m multiaddr.Multiaddr)
Listen is called when network starts listening on an addr
func (ConnectionNotifier) ListenClose ¶
func (c ConnectionNotifier) ListenClose(n network.Network, m multiaddr.Multiaddr)
ListenClose is called when network stops listening on an address
func (ConnectionNotifier) OpenedStream ¶
func (c ConnectionNotifier) OpenedStream(n network.Network, s network.Stream)
OpenedStream is called when a stream opened
type IdentityCredential ¶ added in v0.6.0
type IdentityCredential = struct { IDTrapdoor byte32 `json:"idTrapdoor"` IDNullifier byte32 `json:"idNullifier"` IDSecretHash byte32 `json:"idSecretHash"` IDCommitment byte32 `json:"idCommitment"` }
type Metrics ¶ added in v0.8.0
type Metrics interface { RecordVersion(version string, commit string) RecordDial() RecordPeerConnected() RecordPeerDisconnected() }
Metrics exposes the functions required to update prometheus metrics for the waku node
type PeerConnection ¶ added in v0.6.0
type RLNRelay ¶
type RLNRelay interface { IdentityCredential() (IdentityCredential, error) MembershipIndex() uint AppendRLNProof(msg *pb.WakuMessage, senderEpochTime time.Time) error Validator(spamHandler SpamHandler) func(ctx context.Context, message *pb.WakuMessage, topic string) bool Start(ctx context.Context) error Stop() error IsReady(ctx context.Context) (bool, error) }
type ReceptorService ¶ added in v0.4.0
type SpamHandler ¶ added in v0.8.0
type SpamHandler = func(message *pb.WakuMessage, topic string) error
type VersionInfo ¶
func GetVersionInfo ¶
func GetVersionInfo() VersionInfo
func (VersionInfo) String ¶
func (v VersionInfo) String() string
type WakuNode ¶
type WakuNode struct {
// contains filtered or unexported fields
}
func New ¶
func New(opts ...WakuNodeOption) (*WakuNode, error)
New is used to instantiate a WakuNode using a set of WakuNodeOptions
func (*WakuNode) AddDiscoveredPeer ¶ added in v0.8.0
func (w *WakuNode) AddDiscoveredPeer(ID peer.ID, addrs []ma.Multiaddr, origin wps.Origin, pubsubTopics []string)
AddDiscoveredPeer to add a discovered peer to the node peerStore
func (*WakuNode) AddPeer ¶
func (w *WakuNode) AddPeer(address ma.Multiaddr, origin wps.Origin, pubSubTopics []string, protocols ...protocol.ID) (peer.ID, error)
AddPeer is used to add a peer and the protocols it support to the node peerstore TODO: Need to update this for autosharding, to only take contentTopics and optional pubSubTopics or provide an alternate API only for contentTopics.
func (*WakuNode) Broadcaster ¶
func (w *WakuNode) Broadcaster() relay.Broadcaster
Broadcaster is used to access the message broadcaster that is used to push messages to different protocols
func (*WakuNode) ClosePeerByAddress ¶
ClosePeerByAddress is used to disconnect from a peer using its multiaddress
func (*WakuNode) ClosePeerById ¶
ClosePeerById is used to close a connection to a peer
func (*WakuNode) DialPeer ¶
DialPeer is used to connect to a peer using a string containing a multiaddress
func (*WakuNode) DialPeerByID ¶
DialPeerByID is used to connect to an already known peer
func (*WakuNode) DialPeerWithInfo ¶ added in v0.6.0
DialPeerWithInfo is used to connect to a peer using its address information
func (*WakuNode) DialPeerWithMultiAddress ¶
DialPeerWithMultiAddress is used to connect to a peer using a multiaddress
func (*WakuNode) DiscV5 ¶
func (w *WakuNode) DiscV5() *discv5.DiscoveryV5
DiscV5 is used to access any operation related to DiscoveryV5
func (*WakuNode) FilterFullNode ¶ added in v0.8.0
func (w *WakuNode) FilterFullNode() *filter.WakuFilterFullNode
FilterLightnode is used to access any operation related to Waku Filter protocol Full node feature
func (*WakuNode) FilterLightnode ¶ added in v0.6.0
func (w *WakuNode) FilterLightnode() *filter.WakuFilterLightNode
FilterFullNode is used to access any operation related to Waku Filter protocol Light node feature
func (*WakuNode) LegacyFilter ¶ added in v0.6.0
func (w *WakuNode) LegacyFilter() *legacy_filter.WakuFilter
LegacyFilter is used to access any operation related to Waku LegacyFilter protocol
func (*WakuNode) Lightpush ¶
func (w *WakuNode) Lightpush() *lightpush.WakuLightPush
Lightpush is used to access any operation related to Waku Lightpush protocol
func (*WakuNode) ListenAddresses ¶
ListenAddresses returns all the multiaddresses used by the host
func (*WakuNode) PeerExchange ¶
func (w *WakuNode) PeerExchange() *peer_exchange.WakuPeerExchange
PeerExchange is used to access any operation related to Peer Exchange
func (*WakuNode) Peers ¶
Peers return the list of peers, addresses, protocols supported and connection status
func (*WakuNode) PeersByShard ¶ added in v0.8.0
func (*WakuNode) Rendezvous ¶ added in v0.8.0
func (w *WakuNode) Rendezvous() *rendezvous.Rendezvous
Rendezvous is used to access any operation related to Rendezvous
func (*WakuNode) SetDiscV5Bootnodes ¶
Set the bootnodes on discv5
func (*WakuNode) Status ¶
Status returns the current status of the node (online or not) and if the node has access to history nodes or not
func (*WakuNode) Stop ¶
func (w *WakuNode) Stop()
Stop stops the WakuNode and closess all connections to the host
func (*WakuNode) Timesource ¶
func (w *WakuNode) Timesource() timesource.Timesource
Timesource returns the timesource used by this node to obtain the current wall time Depending on the configuration it will be the local time or a ntp syncd time
type WakuNodeOption ¶
type WakuNodeOption func(*WakuNodeParameters) error
func WithAdvertiseAddresses ¶ added in v0.5.0
func WithAdvertiseAddresses(advertiseAddrs ...ma.Multiaddr) WakuNodeOption
WithAdvertiseAddresses is a WakuNodeOption that allows overriding the address used in the waku node with custom value
func WithConnectionNotification ¶ added in v0.6.0
func WithConnectionNotification(ch chan<- PeerConnection) WakuNodeOption
func WithConnectionStatusChannel ¶
func WithConnectionStatusChannel(connStatus chan ConnStatus) WakuNodeOption
WithConnectionStatusChannel is a WakuNodeOption used to set a channel where the connection status changes will be pushed to. It's useful to identify when peer connections and disconnections occur
func WithDNS4Domain ¶ added in v0.8.0
func WithDNS4Domain(dns4Domain string) WakuNodeOption
WithDNS4Domain is a WakuNodeOption that adds a custom domain name to listen
func WithDiscoveryV5 ¶
func WithDiscoveryV5(udpPort uint, bootnodes []*enode.Node, autoUpdate bool) WakuNodeOption
WithDiscoveryV5 is a WakuOption used to enable DiscV5 peer discovery
func WithDynamicRLNRelay ¶ added in v0.8.0
func WithDynamicRLNRelay(keystorePath string, keystorePassword string, treePath string, membershipContract common.Address, membershipIndex *uint, spamHandler rln.SpamHandler, ethClientAddress string) WakuNodeOption
WithDynamicRLNRelay enables the Waku V2 RLN protocol in onchain mode.
func WithExternalIP ¶ added in v0.6.0
func WithExternalIP(ip net.IP) WakuNodeOption
WithExternalIP is a WakuNodeOption that allows overriding the advertised external IP used in the waku node with custom value
func WithHostAddress ¶
func WithHostAddress(hostAddr *net.TCPAddr) WakuNodeOption
WithHostAddress is a WakuNodeOption that configures libp2p to listen on a specific address
func WithKeepAlive ¶
func WithKeepAlive(t time.Duration) WakuNodeOption
WithKeepAlive is a WakuNodeOption used to set the interval of time when each peer will be ping to keep the TCP connection alive
func WithLegacyWakuFilter ¶ added in v0.6.0
func WithLegacyWakuFilter(fullnode bool, filterOpts ...legacy_filter.Option) WakuNodeOption
WithLegacyWakuFilter enables the legacy Waku Filter protocol. This WakuNodeOption accepts a list of WakuFilter gossipsub options to setup the protocol
func WithLibP2POptions ¶
func WithLibP2POptions(opts ...libp2p.Option) WakuNodeOption
WithLibP2POptions is a WakuNodeOption used to configure the libp2p node. This can potentially override any libp2p config that was set with other WakuNodeOption
func WithLightPush ¶
func WithLightPush() WakuNodeOption
WithLightPush is a WakuNodeOption that enables the lightpush protocol
func WithLogLevel ¶ added in v0.5.0
func WithLogLevel(lvl zapcore.Level) WakuNodeOption
WithLogLevel is a WakuNodeOption that sets the log level for go-waku
func WithLogger ¶
func WithLogger(l *zap.Logger) WakuNodeOption
WithLogger is a WakuNodeOption that adds a custom logger
func WithMaxPeerConnections ¶ added in v0.8.0
func WithMaxPeerConnections(maxPeers int) WakuNodeOption
func WithMessageProvider ¶
func WithMessageProvider(s store.MessageProvider) WakuNodeOption
WithMessageProvider is a WakuNodeOption that sets the MessageProvider used to store and retrieve persisted messages
func WithMultiaddress ¶
func WithMultiaddress(addresses ...multiaddr.Multiaddr) WakuNodeOption
WithMultiaddress is a WakuNodeOption that configures libp2p to listen on a list of multiaddresses
func WithNTP ¶
func WithNTP(ntpURLs ...string) WakuNodeOption
WithNTP is used to use ntp for any operation that requires obtaining time A list of ntp servers can be passed but if none is specified, some defaults will be used
func WithPeerExchange ¶
func WithPeerExchange() WakuNodeOption
WithPeerExchange is a WakuOption used to enable Peer Exchange
func WithPeerStore ¶ added in v0.7.0
func WithPeerStore(ps peerstore.Peerstore) WakuNodeOption
func WithPrivateKey ¶
func WithPrivateKey(privKey *ecdsa.PrivateKey) WakuNodeOption
WithPrivateKey is used to set an ECDSA private key in a libp2p node
func WithPrometheusRegisterer ¶ added in v0.8.0
func WithPrometheusRegisterer(reg prometheus.Registerer) WakuNodeOption
WithPrometheusRegisterer configures go-waku to use reg as the Registerer for all metrics subsystems
func WithRendezvous ¶ added in v0.6.0
func WithRendezvous(db *rendezvous.DB) WakuNodeOption
WithRendezvous is a WakuOption used to set the node as a rendezvous point, using an specific storage for the peer information
func WithSecureWebsockets ¶
func WithSecureWebsockets(address string, port int, certPath string, keyPath string) WakuNodeOption
WithSecureWebsockets is a WakuNodeOption used to enable secure websockets support
func WithStaticRLNRelay ¶ added in v0.8.0
func WithStaticRLNRelay(memberIndex *r.MembershipIndex, spamHandler rln.SpamHandler) WakuNodeOption
WithStaticRLNRelay enables the Waku V2 RLN protocol in offchain mode
func WithWakuFilterFullNode ¶ added in v0.6.0
func WithWakuFilterFullNode(filterOpts ...filter.Option) WakuNodeOption
WithWakuFilterFullNode enables the Waku Filter V2 protocol full node functionality. This WakuNodeOption accepts a list of WakuFilter options to setup the protocol
func WithWakuFilterLightNode ¶ added in v0.6.0
func WithWakuFilterLightNode() WakuNodeOption
WithWakuFilter enables the Waku Filter V2 protocol for lightnode functionality
func WithWakuRelay ¶
func WithWakuRelay(opts ...pubsub.Option) WakuNodeOption
WithWakuRelay enables the Waku V2 Relay protocol. This WakuNodeOption accepts a list of WakuRelay gossipsub option to setup the protocol
func WithWakuRelayAndMinPeers ¶
func WithWakuRelayAndMinPeers(minRelayPeersToPublish int, opts ...pubsub.Option) WakuNodeOption
WithWakuRelayAndMinPeers enables the Waku V2 Relay protocol. This WakuNodeOption accepts a min peers require to publish and a list of WakuRelay gossipsub option to setup the protocol
func WithWakuStore ¶
func WithWakuStore() WakuNodeOption
WithWakuStore enables the Waku V2 Store protocol and if the messages should be stored or not in a message provider.
func WithWakuStoreFactory ¶
func WithWakuStoreFactory(factory storeFactory) WakuNodeOption
WithWakuStoreFactory is used to replace the default WakuStore with a custom implementation that implements the store.Store interface
func WithWebsockets ¶
func WithWebsockets(address string, port int) WakuNodeOption
WithWebsockets is a WakuNodeOption used to enable websockets support
type WakuNodeParameters ¶
type WakuNodeParameters struct {
// contains filtered or unexported fields
}
func (WakuNodeParameters) AddressFactory ¶
func (w WakuNodeParameters) AddressFactory() basichost.AddrsFactory
AddressFactory returns the address factory used by the node's host
func (*WakuNodeParameters) GetPrivKey ¶
func (w *WakuNodeParameters) GetPrivKey() *crypto.PrivKey
GetPrivKey returns the private key used in the node
func (WakuNodeParameters) Identity ¶
func (w WakuNodeParameters) Identity() config.Option
Identity returns a libp2p option containing the identity used by the node
func (WakuNodeParameters) MultiAddresses ¶
func (w WakuNodeParameters) MultiAddresses() []multiaddr.Multiaddr
MultiAddresses return the list of multiaddresses configured in the node
func (WakuNodeParameters) TLSConfig ¶
func (w WakuNodeParameters) TLSConfig() *tls.Config
TLSConfig returns the TLS config used for setting up secure websockets