webstream

package
v0.57.0-rc0 Latest Latest
Warning

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

Go to latest
Published: Jan 6, 2025 License: AGPL-3.0 Imports: 23 Imported by: 0

Documentation

Overview

Package webstream provides controls for streaming from the web server.

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type BackoffTuningOptions

type BackoffTuningOptions struct {
	// BaseSleep sets the initial amount of time to wait after an error.
	BaseSleep time.Duration
	// MaxSleep determines the maximum amount of time that streamSource is
	// permitted to a sleep after receiving a single error.
	MaxSleep time.Duration
	// Cooldown sets how long since the last error that we can reset our backoff. This
	// should be greater than MaxSleep. This prevents a scenario where we haven't made
	// a call to read for a long time and the error may go away sooner.
	Cooldown time.Duration
}

BackoffTuningOptions represents a set of parameters for determining exponential backoff when receiving multiple simultaneous errors.

BaseSleep is the duration to wait after receiving a new error. After that, the wait time doubles for every subsequent, consecutive error of the same type, until the wait duration reaches the MaxSleep duration.

func (*BackoffTuningOptions) GetSleepTimeFromErrorCount

func (opts *BackoffTuningOptions) GetSleepTimeFromErrorCount(errorCount int) time.Duration

GetSleepTimeFromErrorCount returns a sleep time from an error count.

type Resolution added in v0.50.0

type Resolution struct {
	Width, Height int32
}

Resolution holds the width and height of a video stream. We use int32 to match the resolution type in the proto.

func GenerateResolutions added in v0.50.0

func GenerateResolutions(width, height int32, logger logging.Logger) []Resolution

GenerateResolutions takes the original width and height of an image and returns a list of the original resolution with 4 smaller width/height options that maintain the same aspect ratio.

type Server added in v0.24.0

type Server struct {
	streampb.UnimplementedStreamServiceServer
	// contains filtered or unexported fields
}

Server implements the gRPC audio/video streaming service.

func NewServer added in v0.24.0

func NewServer(
	robot robot.Robot,
	streamConfig gostream.StreamConfig,
	logger logging.Logger,
) *Server

NewServer returns a server that will run on the given port and initially starts with the given stream.

func (*Server) AddNewStreams added in v0.49.0

func (server *Server) AddNewStreams(ctx context.Context) error

AddNewStreams adds new video and audio streams to the server using the updated set of video and audio sources. It refreshes the sources, checks for a valid stream configuration, and starts the streams if applicable.

func (*Server) AddStream added in v0.24.0

AddStream implements part of the StreamServiceServer.

func (*Server) Close added in v0.24.0

func (server *Server) Close() error

Close closes the Server and waits for spun off goroutines to complete.

func (*Server) GetStreamOptions added in v0.50.0

func (server *Server) GetStreamOptions(
	ctx context.Context,
	req *streampb.GetStreamOptionsRequest,
) (*streampb.GetStreamOptionsResponse, error)

GetStreamOptions implements part of the StreamServiceServer. It returns the available dynamic resolutions for a given stream name. The resolutions are scaled down from the original resolution in the camera properties.

func (*Server) ListStreams added in v0.24.0

ListStreams implements part of the StreamServiceServer.

func (*Server) NewStream added in v0.24.0

func (server *Server) NewStream(config gostream.StreamConfig) (gostream.Stream, error)

NewStream informs the stream server of new streams that are capable of being streamed.

func (*Server) RemoveStream added in v0.24.0

RemoveStream implements part of the StreamServiceServer.

func (*Server) SetStreamOptions added in v0.53.0

func (server *Server) SetStreamOptions(
	ctx context.Context,
	req *streampb.SetStreamOptionsRequest,
) (*streampb.SetStreamOptionsResponse, error)

SetStreamOptions implements part of the StreamServiceServer. It sets the resolution of the stream to the given width and height.

type StreamAlreadyRegisteredError added in v0.24.0

type StreamAlreadyRegisteredError struct {
	// contains filtered or unexported fields
}

StreamAlreadyRegisteredError indicates that a stream has a name that is already registered on the stream server.

func (*StreamAlreadyRegisteredError) Error added in v0.24.0

Directories

Path Synopsis
Package camera provides utilities for working with camera resources in the context of streaming.
Package camera provides utilities for working with camera resources in the context of streaming.
Package state controls the source of the RTP packets being written to the stream's subscribers and ensures there is only one active at a time while there are peer connections to receive RTP packets.
Package state controls the source of the RTP packets being written to the stream's subscribers and ensures there is only one active at a time while there are peer connections to receive RTP packets.

Jump to

Keyboard shortcuts

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