View Source Membrane.RTMPServer.ClientHandler behaviour (Membrane RTMP plugin v0.28.1)
A behaviour describing the actions that might be taken by the client handler in response to different events.
Summary
Types
Type representing the user defined state of the client handler.
A type representing a module which implements Membrane.RTMPServer.ClientHandler
behaviour.
Callbacks
Callback invoked when the socket connection is terminated. In normal
conditions, handle_delete_stream
is called before this one. If delete_stream
is not called and connection_closed is, it might just mean that the
connection was lost (for instance when TCP socket is closed unexpectedly).
The callback invoked when new piece of data is received from a given client.
Callback invoked when the RMTP stream is finished.
The callback invoked when the client handler receives a message that is not recognized as an internal message of the client handler.
The callback invoked once the client handler is created. It should return the initial state of the client handler.
The optional callback invoked when the client handler receives RTMP message with metadata information (just like a resolution or a framerate of a video stream). The following messages are considered the ones that contain metadata
Functions
Returns a specification to start this module under a supervisor.
Makes the client handler ask client for the desired number of buffers
Types
@type state() :: any()
Type representing the user defined state of the client handler.
@type t() :: module()
A type representing a module which implements Membrane.RTMPServer.ClientHandler
behaviour.
Callbacks
Callback invoked when the socket connection is terminated. In normal
conditions, handle_delete_stream
is called before this one. If delete_stream
is not called and connection_closed is, it might just mean that the
connection was lost (for instance when TCP socket is closed unexpectedly).
It is up to the users to determined how to handle it in their case.
The callback invoked when new piece of data is received from a given client.
Callback invoked when the RMTP stream is finished.
The callback invoked when the client handler receives a message that is not recognized as an internal message of the client handler.
The callback invoked once the client handler is created. It should return the initial state of the client handler.
@callback handle_metadata( {:metadata_message, Membrane.RTMP.Messages.OnMetaData.t() | Membrane.RTMP.Messages.SetDataFrame.t()}, state() ) :: state()
The optional callback invoked when the client handler receives RTMP message with metadata information (just like a resolution or a framerate of a video stream). The following messages are considered the ones that contain metadata:
- OnMetaData
- SetDataFrame
Functions
Returns a specification to start this module under a supervisor.
See Supervisor
.
@spec demand_data(pid(), non_neg_integer()) :: :ok
Makes the client handler ask client for the desired number of buffers