broker

package
v0.0.10 Latest Latest
Warning

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

Go to latest
Published: Nov 10, 2018 License: MPL-2.0 Imports: 23 Imported by: 0

Documentation

Overview

Package broker is a generated protocol buffer package.

It is generated from these files:

events.proto

It has these top-level messages:

MessagePublished

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type Broker

type Broker struct {
	Peer          *peer.Peer
	Subscriptions SubscriptionStore
	Sessions      SessionStore
	Topics        TopicStore

	Listener     io.Closer
	TCPTransport io.Closer
	TLSTransport io.Closer
	WSSTransport io.Closer
	RPC          io.Closer
	// contains filtered or unexported fields
}

func New

func New(id identity.Identity, config Config) *Broker

func (*Broker) Authenticate

func (b *Broker) Authenticate(transport listener.Transport, sessionID, username string, password string) (tenant string, id string, err error)

func (*Broker) Join

func (b *Broker) Join(hosts []string)

func (*Broker) ListRetainedMessages

func (b *Broker) ListRetainedMessages() (topics.RetainedMessageList, error)

func (*Broker) ListSessions

func (b *Broker) ListSessions() (sessions.SessionList, error)

func (*Broker) ListSubscriptions

func (b *Broker) ListSubscriptions() (subscriptions.SubscriptionList, error)

func (*Broker) OnBrokerStopped added in v0.0.9

func (b *Broker) OnBrokerStopped(f func()) func()

func (*Broker) OnConnect

func (b *Broker) OnConnect(transportSession *listener.Session)

func (*Broker) OnMessagePublished added in v0.0.9

func (b *Broker) OnMessagePublished(recipient string, f func(p *packet.Publish)) func()

func (*Broker) OnPublish

func (b *Broker) OnPublish(id, tenant string, packet *packet.Publish) error

func (*Broker) OnSessionClosed

func (b *Broker) OnSessionClosed(id, tenant string)

func (*Broker) OnSessionLost

func (b *Broker) OnSessionLost(id, tenant string)

func (*Broker) OnSubscribe

func (b *Broker) OnSubscribe(id string, tenant string, packet *packet.Subscribe) error

func (*Broker) OnUnsubscribe

func (b *Broker) OnUnsubscribe(id string, tenant string, packet *packet.Unsubscribe) error

func (*Broker) Stop

func (b *Broker) Stop()

type Config

type Config struct {
	TCPPort    int
	TLS        *tls.Config
	TLSPort    int
	WSSPort    int
	RPCPort    int
	GossipPort int
	AuthHelper func(transport listener.Transport, sessionID, username string, password string) (tenant string, id string, err error)
	Session    SessionConfig
}

func DefaultConfig

func DefaultConfig() Config

type MessagePublished

type MessagePublished struct {
	Recipient []string `protobuf:"bytes,1,rep,name=Recipient" json:"Recipient,omitempty"`
	Topic     []byte   `protobuf:"bytes,2,opt,name=Topic,proto3" json:"Topic,omitempty"`
	Qos       []int32  `protobuf:"varint,3,rep,packed,name=Qos" json:"Qos,omitempty"`
	Payload   []byte   `protobuf:"bytes,4,opt,name=Payload,proto3" json:"Payload,omitempty"`
	Retained  bool     `protobuf:"varint,5,opt,name=Retained" json:"Retained,omitempty"`
	Dup       bool     `protobuf:"varint,6,opt,name=Dup" json:"Dup,omitempty"`
}

func (*MessagePublished) Descriptor

func (*MessagePublished) Descriptor() ([]byte, []int)

func (*MessagePublished) GetDup

func (m *MessagePublished) GetDup() bool

func (*MessagePublished) GetPayload

func (m *MessagePublished) GetPayload() []byte

func (*MessagePublished) GetQos

func (m *MessagePublished) GetQos() []int32

func (*MessagePublished) GetRecipient

func (m *MessagePublished) GetRecipient() []string

func (*MessagePublished) GetRetained

func (m *MessagePublished) GetRetained() bool

func (*MessagePublished) GetTopic

func (m *MessagePublished) GetTopic() []byte

func (*MessagePublished) ProtoMessage

func (*MessagePublished) ProtoMessage()

func (*MessagePublished) Reset

func (m *MessagePublished) Reset()

func (*MessagePublished) String

func (m *MessagePublished) String() string

type SessionConfig added in v0.0.9

type SessionConfig struct {
	MaxInflightSize int
}

type SessionStore

type SessionStore interface {
	ByID(id string) (*sessions.Session, error)
	ByPeer(peer uint64) (sessions.SessionList, error)
	All() (sessions.SessionList, error)
	Exists(id string) bool
	Upsert(sess *sessions.Session) error
	Delete(id string) error
	On(event string, handler func(*sessions.Session)) func()
}

type SubscriptionStore

type SubscriptionStore interface {
	ByTopic(tenant string, pattern []byte) (*subscriptions.SubscriptionList, error)
	ByID(id string) (*subscriptions.Subscription, error)
	All() (subscriptions.SubscriptionList, error)
	ByPeer(peer uint64) (subscriptions.SubscriptionList, error)
	BySession(id string) (subscriptions.SubscriptionList, error)
	Sessions() ([]string, error)
	Create(subscription *subscriptions.Subscription) error
	Delete(id string) error
	On(event string, handler func(*subscriptions.Subscription)) func()
}

type TopicStore

type TopicStore interface {
	Create(message *topics.RetainedMessage) error
	ByTopicPattern(tenant string, pattern []byte) (topics.RetainedMessageList, error)
	All() (topics.RetainedMessageList, error)
	On(event string, handler func(*topics.RetainedMessage)) func()
}

Directories

Path Synopsis
rpc
Package rpc is a generated protocol buffer package.
Package rpc is a generated protocol buffer package.

Jump to

Keyboard shortcuts

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