stats

package
v0.1.14 Latest Latest
Warning

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

Go to latest
Published: Apr 23, 2024 License: Apache-2.0 Imports: 1 Imported by: 0

Documentation

Overview

Package stats contains interfaces and utilities relating to the collection of statistics from a fleetspeak client.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type ClientCollector

type ClientCollector interface {
	// AfterMessageProcessed is called after msg has been processed by the client.
	// isLocal is set when a message is sent to a local service instead of the Fleetspeak server.
	AfterMessageProcessed(msg *fspb.Message, isLocal bool, err error)
}

ClientCollector gets notified about client operations. Implementations of this interface must be thread-safe.

type Collector

Collector is a component which is notified when certain events occur. It can be implemented with different metric backends to enable monitoring of a Fleetspeak client. Implementations of this interface must be thread-safe.

type CommsContextCollector

type CommsContextCollector interface {
	// ContactDataCreated is called by the comms.Context when the Communicator uses it to create a
	// ContactData to be sent to the server.
	// wcd can be nil if an error occurred.
	ContactDataCreated(wcd *fspb.WrappedContactData, err error)

	// ContactDataProcessed is called by the comms.Context when the Communicator retrieves cd from the
	// server and passes it to the comms.Context for processing.
	ContactDataProcessed(cd *fspb.ContactData, streaming bool, err error)
}

CommsContextCollector gets notified when the Communicator makes use of its comms.Context. Implementations of this interface must be thread-safe.

type CommunicatorCollector

type CommunicatorCollector interface {
	// OutboundContactData gets called after an attempt to send a ContactData to the host.
	// bytesSent is the amount of bytes that were sent during the operation. err is an error
	// that occurred during the operation, if any.
	OutboundContactData(host string, bytesSent int, err error)
	// InboundContactData gets called after an attempt to receive a ContactData from the host.
	// bytesReceived is the amount of bytes that were received during the operation. err is an error
	// that occurred during the operation, if any.
	InboundContactData(host string, bytesReceived int, err error)
	// AfterGetFileRequest gets called when a communicator attempts to make a request for a file on
	// behalf of the client (see comms.Communicator documentation for more details about this
	// functionality).
	// didFetch indicates whether or not the requested file has been fetched from the server,
	// depending on whether it has been modified since we last fetched it.
	AfterGetFileRequest(host, service, name string, didFetch bool, err error)
}

CommunicatorCollector gets notified about operations and traffic of communicators. Implementations of this interface must be thread-safe.

type ConfigManagerCollector

type ConfigManagerCollector interface {
	// AfterConfigSync is called after each config sync attempt by the config manager.
	// err is the result of the operation.
	AfterConfigSync(err error)
	// AfterRekey is called after each rekey attempt by the config manager.
	AfterRekey(err error)
}

ConfigManagerCollector gets notified about config manager operations. Implementations of this interface must be thread-safe.

type DaemonServiceCollector

type DaemonServiceCollector interface {
	// DaemonServiceSubprocessFinished gets called when a service's subprocess terminates.
	// If the subprocess finished for a reason other than the service shutting down, the cause should
	// be passed as err.
	DaemonServiceSubprocessFinished(service string, err error)
}

DaemonServiceCollector gets notified about operations of daemonservice.Services. Implementations of this interface must be thread-safe.

type NoopCollector

type NoopCollector struct{}

NoopCollector implements Collector by doing nothing.

func (NoopCollector) AfterConfigSync

func (c NoopCollector) AfterConfigSync(err error)

AfterConfigSync implements Collector by doing nothing.

func (NoopCollector) AfterGetFileRequest

func (c NoopCollector) AfterGetFileRequest(host, service, name string, didFetch bool, err error)

AfterGetFileRequest implements Collector by doing nothing.

func (NoopCollector) AfterMessageProcessed

func (c NoopCollector) AfterMessageProcessed(msg *fspb.Message, isLocal bool, err error)

AfterMessageProcessed implements Collector by doing nothing.

func (NoopCollector) AfterRekey

func (c NoopCollector) AfterRekey(err error)

AfterRekey implements Collector by doing nothing.

func (NoopCollector) BeforeMessageRetry

func (c NoopCollector) BeforeMessageRetry(msg *fspb.Message)

BeforeMessageRetry implements Collector by doing nothing.

func (NoopCollector) ContactDataCreated

func (c NoopCollector) ContactDataCreated(wcd *fspb.WrappedContactData, err error)

ContactDataCreated implements Collector by doing nothing.

func (NoopCollector) ContactDataProcessed

func (c NoopCollector) ContactDataProcessed(cd *fspb.ContactData, streaming bool, err error)

ContactDataProcessed implements Collector by doing nothing.

func (NoopCollector) DaemonServiceSubprocessFinished

func (c NoopCollector) DaemonServiceSubprocessFinished(service string, err error)

DaemonServiceSubprocessFinished implements Collector by doing nothing.

func (NoopCollector) InboundContactData

func (c NoopCollector) InboundContactData(host string, bytesReceived int, err error)

InboundContactData implements Collector by doing nothing.

func (NoopCollector) MessageAcknowledged

func (c NoopCollector) MessageAcknowledged(msg *fspb.Message, size int)

MessageAcknowledged implements Collector by doing nothing.

func (NoopCollector) MessagePending

func (c NoopCollector) MessagePending(msg *fspb.Message, size int)

MessagePending implements Collector by doing nothing.

func (NoopCollector) OutboundContactData

func (c NoopCollector) OutboundContactData(host string, bytesSent int, err error)

OutboundContactData implements Collector by doing nothing.

func (NoopCollector) SocketServiceSocketClosed

func (c NoopCollector) SocketServiceSocketClosed(service string, err error)

SocketServiceSocketClosed implements Collector by doing nothing.

type RetryLoopCollector

type RetryLoopCollector interface {
	// BeforeMessageRetry is called when a message has been nacked and got readded to the outbound
	// message queue.
	BeforeMessageRetry(msg *fspb.Message)
	// MessagePending is called before a new message is being placed into the output channel.
	// A message is considered pending until it got Acked by the server. In case the message gets
	// Nacked, the RetryLoop will retry and the message is still considered pending.
	// size is the serialized message's size in bytes.
	MessagePending(msg *fspb.Message, size int)
	// MessageAcknowledged is called after a pending message has been acknowledged.
	// size is the serialized message's size in bytes.
	MessageAcknowledged(msg *fspb.Message, size int)
}

RetryLoopCollector gets notified about messages currently kept in memory by the RetryLoop. Implementations of this interface must be thread-safe.

type SocketServiceCollector

type SocketServiceCollector interface {
	// SocketServiceSocketClosed gets called when a service's socket was closed.
	// If the socket got closed for a reason other than the service shutting down, the cause should
	// be passed as err.
	SocketServiceSocketClosed(service string, err error)
}

SocketServiceCollector gets notified about operations of socketservice.Services. Implementations of this interface must be thread-safe.

Jump to

Keyboard shortcuts

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