waku

package
v0.6.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 12, 2023 License: MIT Imports: 50 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func Execute

func Execute(options Options)

Execute starts a go-waku node with settings determined by the Options parameter

func ExtractDBAndMigration added in v0.5.0

func ExtractDBAndMigration(databaseURL string) (*sql.DB, func(*sql.DB) error, error)

Types

type DNSDiscoveryOptions

type DNSDiscoveryOptions struct {
	Enable     bool
	URLs       cli.StringSlice
	Nameserver string
}

DNSDiscoveryOptions are settings used for enabling DNS-based discovery protocol that stores merkle trees in DNS records which contain connection information for nodes. It's very useful for bootstrapping a p2p network.

type DiscV5Options

type DiscV5Options struct {
	Enable     bool
	Nodes      cli.StringSlice
	Port       uint
	AutoUpdate bool
}

DiscV5Options are settings to enable a modified version of Ethereum’s Node Discovery Protocol v5 as a means for ambient node discovery.

type FilterOptions

type FilterOptions struct {
	Enable          bool
	UseV1           bool
	DisableFullNode bool
	Nodes           []multiaddr.Multiaddr
	NodesV1         []multiaddr.Multiaddr
	Timeout         time.Duration
}

FilterOptions are settings used to enable filter protocol. This is a protocol that enables subscribing to messages that a peer receives. This is a more lightweight version of WakuRelay specifically designed for bandwidth restricted devices.

type LightpushOptions

type LightpushOptions struct {
	Enable bool
	Nodes  []multiaddr.Multiaddr
}

LightpushOptions are settings used to enable the lightpush protocol. This is a lightweight protocol used to avoid having to run the relay protocol which is more resource intensive. With this protocol a message is pushed to a peer that supports both the lightpush protocol and relay protocol. That peer will broadcast the message and return a confirmation that the message was broadcasted

type MetricsOptions

type MetricsOptions struct {
	Enable  bool
	Address string
	Port    int
}

MetricsOptions are settings used to start a prometheus server for obtaining useful node metrics to monitor the health of behavior of the go-waku node.

type Options

type Options struct {
	Port               int
	Address            string
	Dns4DomainName     string
	NodeKey            *ecdsa.PrivateKey
	KeyFile            string
	KeyPasswd          string
	GenerateKey        bool
	Overwrite          bool
	StaticNodes        []multiaddr.Multiaddr
	KeepAlive          time.Duration
	AdvertiseAddresses []multiaddr.Multiaddr
	ShowAddresses      bool
	LogLevel           string
	LogEncoding        string
	LogOutput          string
	NAT                string
	ExtIP              string
	PersistPeers       bool
	UserAgent          string
	PProf              bool

	PeerExchange PeerExchangeOptions
	Websocket    WSOptions
	Relay        RelayOptions
	Store        StoreOptions
	Filter       FilterOptions
	LightPush    LightpushOptions
	RLNRelay     RLNRelayOptions
	DiscV5       DiscV5Options
	DNSDiscovery DNSDiscoveryOptions
	Rendezvous   RendezvousOptions
	Metrics      MetricsOptions
	RPCServer    RPCServerOptions
	RESTServer   RESTServerOptions
}

Options contains all the available features and settings that can be configured via flags when executing go-waku as a service.

type PeerExchangeOptions

type PeerExchangeOptions struct {
	Enable bool
	Node   *multiaddr.Multiaddr
}

PeerExchangeOptions are settings used with the peer exchange protocol

type RESTServerOptions

type RESTServerOptions struct {
	Enable             bool
	Port               int
	Address            string
	Admin              bool
	Private            bool
	RelayCacheCapacity int
}

RESTServerOptions are settings used to start a rest http server

type RLNRelayOptions

type RLNRelayOptions struct {
	Enable                    bool
	CredentialsPath           string
	CredentialsPassword       string
	MembershipIndex           int
	PubsubTopic               string
	ContentTopic              string
	Dynamic                   bool
	ETHPrivateKey             *ecdsa.PrivateKey
	ETHClientAddress          string
	MembershipContractAddress common.Address
}

type RPCServerOptions

type RPCServerOptions struct {
	Enable             bool
	Port               int
	Address            string
	Admin              bool
	Private            bool
	RelayCacheCapacity int
}

RPCServerOptions are settings used to start a json rpc server

type RelayOptions

type RelayOptions struct {
	Enable                 bool
	Topics                 cli.StringSlice
	ProtectedTopics        []cliutils.ProtectedTopic
	PeerExchange           bool
	MinRelayPeersToPublish int
}

RelayOptions are settings to enable the relay protocol which is a pubsub approach to peer-to-peer messaging with a strong focus on privacy, censorship-resistance, security and scalability.

type RendezvousOptions added in v0.5.2

type RendezvousOptions struct {
	Enable bool
	Server bool
	Nodes  []multiaddr.Multiaddr
}

type StoreOptions

type StoreOptions struct {
	Enable               bool
	DatabaseURL          string
	RetentionTime        time.Duration
	RetentionMaxMessages int
	ResumeNodes          []multiaddr.Multiaddr
	Nodes                []multiaddr.Multiaddr
}

StoreOptions are settings used for enabling the store protocol, used to retrieve message history from other nodes as well as acting as a store node and provide message history to nodes that ask for it.

type WSOptions

type WSOptions struct {
	Enable   bool
	WSPort   int
	WSSPort  int
	Address  string
	Secure   bool
	KeyPath  string
	CertPath string
}

WSOptions are settings used for enabling websockets and secure websockets support

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL