Documentation ¶
Index ¶
- Constants
- Variables
- type LightPushOption
- func DefaultOptions(host host.Host) []LightPushOption
- func WithAutomaticPeerSelection(fromThesePeers ...peer.ID) LightPushOption
- func WithAutomaticRequestId() LightPushOption
- func WithFastestPeerSelection(ctx context.Context, fromThesePeers ...peer.ID) LightPushOption
- func WithPeer(p peer.ID) LightPushOption
- func WithRequestId(requestId []byte) LightPushOption
- type LightPushParameters
- type WakuLightPush
- func (wakuLP *WakuLightPush) IsStarted() bool
- func (wakuLP *WakuLightPush) Publish(ctx context.Context, message *pb.WakuMessage, opts ...LightPushOption) ([]byte, error)
- func (wakuLP *WakuLightPush) PublishToTopic(ctx context.Context, message *pb.WakuMessage, topic string, ...) ([]byte, error)
- func (wakuLP *WakuLightPush) Start() error
- func (wakuLP *WakuLightPush) Stop()
Constants ¶
const LightPushID_v20beta1 = libp2pProtocol.ID("/vac/waku/lightpush/2.0.0-beta1")
LightPushID_v20beta1 is the current Waku Lightpush protocol identifier
Variables ¶
var ( ErrNoPeersAvailable = errors.New("no suitable remote peers") ErrInvalidId = errors.New("invalid request id") )
Functions ¶
This section is empty.
Types ¶
type LightPushOption ¶
type LightPushOption func(*LightPushParameters)
func DefaultOptions ¶
func DefaultOptions(host host.Host) []LightPushOption
DefaultOptions are the default options to be used when using the lightpush protocol
func WithAutomaticPeerSelection ¶
func WithAutomaticPeerSelection(fromThesePeers ...peer.ID) LightPushOption
WithAutomaticPeerSelection is an option used to randomly select a peer from the peer store to push a waku message to. If a list of specific peers is passed, the peer will be chosen from that list assuming it supports the chosen protocol, otherwise it will chose a peer from the node peerstore
func WithAutomaticRequestId ¶
func WithAutomaticRequestId() LightPushOption
WithAutomaticRequestId is an option to automatically generate a request ID when publishing a message
func WithFastestPeerSelection ¶
func WithFastestPeerSelection(ctx context.Context, fromThesePeers ...peer.ID) LightPushOption
WithFastestPeerSelection is an option used to select a peer from the peer store with the lowest ping. If a list of specific peers is passed, the peer will be chosen from that list assuming it supports the chosen protocol, otherwise it will chose a peer from the node peerstore
func WithPeer ¶
func WithPeer(p peer.ID) LightPushOption
WithPeer is an option used to specify the peerID to push a waku message to
func WithRequestId ¶
func WithRequestId(requestId []byte) LightPushOption
WithRequestId is an option to set a specific request ID to be used when publishing a message
type LightPushParameters ¶
type LightPushParameters struct {
// contains filtered or unexported fields
}
type WakuLightPush ¶
type WakuLightPush struct {
// contains filtered or unexported fields
}
func NewWakuLightPush ¶
func NewWakuLightPush(ctx context.Context, h host.Host, relay *relay.WakuRelay, log *zap.Logger) *WakuLightPush
NewWakuRelay returns a new instance of Waku Lightpush struct
func (*WakuLightPush) IsStarted ¶
func (wakuLP *WakuLightPush) IsStarted() bool
IsStarted returns if the lightpush protocol has been mounted or not
func (*WakuLightPush) Publish ¶
func (wakuLP *WakuLightPush) Publish(ctx context.Context, message *pb.WakuMessage, opts ...LightPushOption) ([]byte, error)
Publish is used to broadcast a WakuMessage to the default waku pubsub topic via lightpush protocol
func (*WakuLightPush) PublishToTopic ¶
func (wakuLP *WakuLightPush) PublishToTopic(ctx context.Context, message *pb.WakuMessage, topic string, opts ...LightPushOption) ([]byte, error)
PublishToTopic is used to broadcast a WakuMessage to a pubsub topic via lightpush protocol
func (*WakuLightPush) Start ¶
func (wakuLP *WakuLightPush) Start() error
Start inits the lighpush protocol
func (*WakuLightPush) Stop ¶
func (wakuLP *WakuLightPush) Stop()
Stop unmounts the lightpush protocol