Documentation ¶
Overview ¶
Package webstream provides controls for streaming from the web server.
Index ¶
- type BackoffTuningOptions
- type Resolution
- type Server
- func (server *Server) AddNewStreams(ctx context.Context) error
- func (server *Server) AddStream(ctx context.Context, req *streampb.AddStreamRequest) (*streampb.AddStreamResponse, error)
- func (server *Server) Close() error
- func (server *Server) GetStreamOptions(ctx context.Context, req *streampb.GetStreamOptionsRequest) (*streampb.GetStreamOptionsResponse, error)
- func (server *Server) ListStreams(ctx context.Context, req *streampb.ListStreamsRequest) (*streampb.ListStreamsResponse, error)
- func (server *Server) NewStream(config gostream.StreamConfig) (gostream.Stream, error)
- func (server *Server) RemoveStream(ctx context.Context, req *streampb.RemoveStreamRequest) (*streampb.RemoveStreamResponse, error)
- func (server *Server) SetStreamOptions(ctx context.Context, req *streampb.SetStreamOptionsRequest) (*streampb.SetStreamOptionsResponse, error)
- type StreamAlreadyRegisteredError
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
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
func (server *Server) AddStream(ctx context.Context, req *streampb.AddStreamRequest) (*streampb.AddStreamResponse, error)
AddStream implements part of the StreamServiceServer.
func (*Server) Close ¶ added in v0.24.0
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
func (server *Server) ListStreams(ctx context.Context, req *streampb.ListStreamsRequest) (*streampb.ListStreamsResponse, error)
ListStreams implements part of the StreamServiceServer.
func (*Server) NewStream ¶ added in v0.24.0
NewStream informs the stream server of new streams that are capable of being streamed.
func (*Server) RemoveStream ¶ added in v0.24.0
func (server *Server) RemoveStream(ctx context.Context, req *streampb.RemoveStreamRequest) (*streampb.RemoveStreamResponse, error)
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
func (e *StreamAlreadyRegisteredError) Error() string
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. |