[−][src]Trait gstreamer_rtsp_server::RTSPServerExt
Required methods
fn client_filter(
&self,
func: Option<&mut dyn FnMut(&RTSPServer, &RTSPClient) -> RTSPFilterResult>
) -> Vec<RTSPClient>
&self,
func: Option<&mut dyn FnMut(&RTSPServer, &RTSPClient) -> RTSPFilterResult>
) -> Vec<RTSPClient>
Call func for each client managed by self. The result value of func
determines what happens to the client. func will be called with self
locked so no further actions on self can be performed from func.
If func returns RTSPFilterResult::Remove, the client will be removed from
self.
If func returns RTSPFilterResult::Keep, the client will remain in self.
If func returns RTSPFilterResult::Ref, the client will remain in self but
will also be added with an additional ref to the result glib::List of this
function..
When func is None, RTSPFilterResult::Ref will be assumed for each client.
func
a callback
user_data
user data passed to func
Returns
a glib::List with all
clients for which func returned RTSPFilterResult::Ref. After usage, each
element in the glib::List should be unreffed before the list is freed.
fn create_socket<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>
) -> Result<Socket, Error>
&self,
cancellable: Option<&P>
) -> Result<Socket, Error>
Create a gio::Socket for self. The socket will listen on the
configured service.
cancellable
a gio::Cancellable
Returns
the gio::Socket for self or None when an error
occurred.
fn create_source<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>
) -> Result<Source, Error>
&self,
cancellable: Option<&P>
) -> Result<Source, Error>
Create a glib::Source for self. The new source will have a default
GSocketSourceFunc of RTSPServer::io_func.
cancellable if not None can be used to cancel the source, which will cause
the source to trigger, reporting the current condition (which is likely 0
unless cancellation happened at the same time as a condition change). You can
check for this in the callback using gio::CancellableExt::is_cancelled.
This takes a reference on self until source is destroyed.
cancellable
a gio::Cancellable or None.
Returns
the glib::Source for self or None when an error
occurred. Free with g_source_unref ()
fn get_address(&self) -> Option<GString>
Get the address on which the server will accept connections.
Returns
the server address. g_free after usage.
fn get_auth(&self) -> Option<RTSPAuth>
Get the RTSPAuth used as the authentication manager of self.
Returns
the RTSPAuth of self. gobject::ObjectExt::unref after
usage.
fn get_backlog(&self) -> i32
fn get_bound_port(&self) -> i32
fn get_content_length_limit(&self) -> u32
fn get_mount_points(&self) -> Option<RTSPMountPoints>
Get the RTSPMountPoints used as the mount points of self.
Returns
the RTSPMountPoints of self. gobject::ObjectExt::unref after
usage.
fn get_service(&self) -> Option<GString>
Get the service on which the server will accept connections.
Returns
the service. use g_free after usage.
fn get_session_pool(&self) -> Option<RTSPSessionPool>
Get the RTSPSessionPool used as the session pool of self.
Returns
the RTSPSessionPool used for sessions. gobject::ObjectExt::unref after
usage.
fn get_thread_pool(&self) -> Option<RTSPThreadPool>
Get the RTSPThreadPool used as the thread pool of self.
Returns
the RTSPThreadPool of self. gobject::ObjectExt::unref after
usage.
fn set_address(&self, address: &str)
Configure self to accept connections on the given address.
This function must be called before the server is bound.
address
the address
fn set_auth<P: IsA<RTSPAuth>>(&self, auth: Option<&P>)
fn set_backlog(&self, backlog: i32)
configure the maximum amount of requests that may be queued for the server.
This function must be called before the server is bound.
backlog
the backlog
fn set_content_length_limit(&self, limit: u32)
Define an appropriate request size limit and reject requests exceeding the limit.
Feature: v1_18
fn set_mount_points<P: IsA<RTSPMountPoints>>(&self, mounts: Option<&P>)
fn set_service(&self, service: &str)
Configure self to accept connections on the given service.
service should be a string containing the service name (see services(5)) or
a string containing a port number between 1 and 65535.
When service is set to "0", the server will listen on a random free
port. The actual used port can be retrieved with
RTSPServerExt::get_bound_port.
This function must be called before the server is bound.
service
the service
fn set_session_pool<P: IsA<RTSPSessionPool>>(&self, pool: Option<&P>)
fn set_thread_pool<P: IsA<RTSPThreadPool>>(&self, pool: Option<&P>)
fn transfer_connection<P: IsA<Socket>>(
&self,
socket: &P,
ip: &str,
port: i32,
initial_buffer: Option<&str>
) -> Result<(), BoolError>
&self,
socket: &P,
ip: &str,
port: i32,
initial_buffer: Option<&str>
) -> Result<(), BoolError>
Take an existing network socket and use it for an RTSP connection. This
is used when transferring a socket from an HTTP server which should be used
as an RTSP over HTTP tunnel. The initial_buffer contains any remaining data
that the HTTP server read from the socket while parsing the HTTP header.
socket
a network socket
ip
the IP address of the remote client
port
the port used by the other end
initial_buffer
any initial data that was already read from the socket
Returns
TRUE if all was ok, FALSE if an error occurred.
fn get_property_content_length_limit(&self) -> u32
fn set_property_content_length_limit(&self, content_length_limit: u32)
fn connect_client_connected<F: Fn(&Self, &RTSPClient) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_address_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_backlog_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_bound_port_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_content_length_limit_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_mount_points_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_service_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
fn connect_property_session_pool_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId
&self,
f: F
) -> SignalHandlerId
Implementors
impl<O: IsA<RTSPServer>> RTSPServerExt for O[src]
fn client_filter(
&self,
func: Option<&mut dyn FnMut(&RTSPServer, &RTSPClient) -> RTSPFilterResult>
) -> Vec<RTSPClient>[src]
&self,
func: Option<&mut dyn FnMut(&RTSPServer, &RTSPClient) -> RTSPFilterResult>
) -> Vec<RTSPClient>
fn create_socket<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>
) -> Result<Socket, Error>[src]
&self,
cancellable: Option<&P>
) -> Result<Socket, Error>
fn create_source<P: IsA<Cancellable>>(
&self,
cancellable: Option<&P>
) -> Result<Source, Error>[src]
&self,
cancellable: Option<&P>
) -> Result<Source, Error>
fn get_address(&self) -> Option<GString>[src]
fn get_auth(&self) -> Option<RTSPAuth>[src]
fn get_backlog(&self) -> i32[src]
fn get_bound_port(&self) -> i32[src]
fn get_content_length_limit(&self) -> u32[src]
fn get_mount_points(&self) -> Option<RTSPMountPoints>[src]
fn get_service(&self) -> Option<GString>[src]
fn get_session_pool(&self) -> Option<RTSPSessionPool>[src]
fn get_thread_pool(&self) -> Option<RTSPThreadPool>[src]
fn set_address(&self, address: &str)[src]
fn set_auth<P: IsA<RTSPAuth>>(&self, auth: Option<&P>)[src]
fn set_backlog(&self, backlog: i32)[src]
fn set_content_length_limit(&self, limit: u32)[src]
fn set_mount_points<P: IsA<RTSPMountPoints>>(&self, mounts: Option<&P>)[src]
fn set_service(&self, service: &str)[src]
fn set_session_pool<P: IsA<RTSPSessionPool>>(&self, pool: Option<&P>)[src]
fn set_thread_pool<P: IsA<RTSPThreadPool>>(&self, pool: Option<&P>)[src]
fn transfer_connection<P: IsA<Socket>>(
&self,
socket: &P,
ip: &str,
port: i32,
initial_buffer: Option<&str>
) -> Result<(), BoolError>[src]
&self,
socket: &P,
ip: &str,
port: i32,
initial_buffer: Option<&str>
) -> Result<(), BoolError>
fn get_property_content_length_limit(&self) -> u32[src]
fn set_property_content_length_limit(&self, content_length_limit: u32)[src]
fn connect_client_connected<F: Fn(&Self, &RTSPClient) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_address_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_backlog_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_bound_port_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_content_length_limit_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_mount_points_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_service_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId
fn connect_property_session_pool_notify<F: Fn(&Self) + Send + Sync + 'static>(
&self,
f: F
) -> SignalHandlerId[src]
&self,
f: F
) -> SignalHandlerId