comms

package
v0.1.17 Latest Latest
Warning

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

Go to latest
Published: Jul 31, 2024 License: Apache-2.0 Imports: 12 Imported by: 0

Documentation

Overview

Package comms defines the interface used by the Fleetspeak modules which communicate with clients.

Index

Constants

This section is empty.

Variables

View Source
var ErrNotAuthorized = errors.New("not authorized")

ErrNotAuthorized is returned by certain methods to indicate that the client is not authorized to communicate with this server.

Functions

This section is empty.

Types

type ClientInfo

type ClientInfo struct {
	ID          common.ClientID
	Key         crypto.PublicKey
	Labels      []*fspb.Label
	Blacklisted bool
	Cached      bool // Whether the data was retrieved from a cache.
}

A ClientInfo is the basic information that we have about a client.

type Communicator

type Communicator interface {
	Setup(Context) error // Configure the communicator to work with a Server.
	Start() error        // Tells the communicator to start sending and receiving messages.
	Stop()               // Tells the communicator to stop sending and receiving messages.
}

A Communicator can communicate with clients through some means (HTTP, etc).

type ConnectionInfo

type ConnectionInfo struct {
	Addr                     net.Addr
	Client                   ClientInfo
	ContactID                db.ContactID
	NonceSent, NonceReceived uint64
	AuthClientInfo           authorizer.ClientInfo

	// These are only set for streaming connections.
	Notices <-chan struct{} // publishes when there may be a new message for the client
	Fin     func()          // should be called to indicate that the streaming connection is closed.
	// contains filtered or unexported fields
}

A ConnectionInfo is the information that the FS system gathers and maintains about a particular connection to a client.

func (*ConnectionInfo) AddMessageTokens

func (i *ConnectionInfo) AddMessageTokens(delta map[string]uint64)

AddMessageTokens changes the tokens available count according to the provided delta.

func (*ConnectionInfo) MessageTokens

func (i *ConnectionInfo) MessageTokens() map[string]uint64

MessageTokens returns a copy of the current token available count. Thread safe.

func (*ConnectionInfo) SubtractMessageTokens

func (i *ConnectionInfo) SubtractMessageTokens(delta map[string]uint64)

SubtractMessageTokens changes the tokens available count according to the provided delta.

type Context

type Context interface {

	// InitializeConnection attempts to validate and configure a client
	// connection, and performs an initial exchange of messages.
	//
	// On success this effectively calls both HandleMessagesFromClient and
	// GetMessagesForClient.
	//
	// The returned ContactData should be sent back to the client unconditionally,
	// in order to update the client's de-duplication nonce.
	//
	// In addition, returns an indication whether there might be additional
	// messages for the client.
	InitializeConnection(ctx context.Context, addr net.Addr, key crypto.PublicKey, wcd *fspb.WrappedContactData, streaming bool) (i *ConnectionInfo, d *fspb.ContactData, more bool, err error)

	// ValidateMessagesFromClient validates the message contained in WrappedContactData.
	// On successful validation it returns the fspb.ValidationInfo data structure.
	ValidateMessagesFromClient(ctx context.Context, info *ConnectionInfo, wcd *fspb.WrappedContactData) (*fspb.ValidationInfo, error)

	// HandleMessagesFromClient processes the messages contained in a WrappedContactData
	// received from the client.  The ConnectionInfo parameter should have been
	// created by an InitializeConnection call made for this connection.
	HandleMessagesFromClient(ctx context.Context, info *ConnectionInfo, wcd *fspb.WrappedContactData) error

	// GetMessagesForClient finds unprocessed messages for a given client and
	// reserves them for processing. The ConnectionInfo parameter should have been
	// created by an InitializeConnection call made for this connection.
	//
	// In addition to some messages, also indicates wether there may be more
	// messages to get.
	//
	// Returns nil, false, nil when there are no outstanding messages for
	// the client.
	GetMessagesForClient(ctx context.Context, info *ConnectionInfo) (data *fspb.ContactData, more bool, err error)

	// ReadFile returns the data and modification time of file. Caller is
	// responsible for closing data.
	//
	// Calls to data are permitted to fail if ctx is canceled or expired.
	ReadFile(ctx context.Context, service, name string) (data db.ReadSeekerCloser, modtime time.Time, err error)

	// IsNotFound returns whether an error returned by ReadFile indicates that the
	// file was not found.
	IsNotFound(err error) bool

	// StatsCollector returns the stats.Collector used by the Fleetspeak
	// system.
	StatsCollector() stats.Collector

	// Authorizer returns the authorizer.Authorizer used by the Fleetspeak
	// system.  The Communicator is responsible for calling Accept1.
	Authorizer() authorizer.Authorizer
}

A Context defines the view of the Fleetspeak server provided to a Communicator.

Jump to

Keyboard shortcuts

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