gstreamer_rtsp_server::prelude

Trait RTSPServerExt

Source
pub trait RTSPServerExt: IsA<RTSPServer> + 'static {
Show 29 methods // Provided methods fn client_filter( &self, func: Option<&mut dyn FnMut(&RTSPServer, &RTSPClient) -> RTSPFilterResult>, ) -> Vec<RTSPClient> { ... } fn create_socket( &self, cancellable: Option<&impl IsA<Cancellable>>, ) -> Result<Socket, Error> { ... } fn create_source( &self, cancellable: Option<&impl IsA<Cancellable>>, ) -> Result<Source, Error> { ... } fn address(&self) -> Option<GString> { ... } fn auth(&self) -> Option<RTSPAuth> { ... } fn backlog(&self) -> i32 { ... } fn bound_port(&self) -> i32 { ... } fn content_length_limit(&self) -> u32 { ... } fn mount_points(&self) -> Option<RTSPMountPoints> { ... } fn service(&self) -> GString { ... } fn session_pool(&self) -> Option<RTSPSessionPool> { ... } fn thread_pool(&self) -> Option<RTSPThreadPool> { ... } fn set_address(&self, address: &str) { ... } fn set_auth(&self, auth: Option<&impl IsA<RTSPAuth>>) { ... } fn set_backlog(&self, backlog: i32) { ... } fn set_content_length_limit(&self, limit: u32) { ... } fn set_mount_points(&self, mounts: Option<&impl IsA<RTSPMountPoints>>) { ... } fn set_service(&self, service: &str) { ... } fn set_session_pool(&self, pool: Option<&impl IsA<RTSPSessionPool>>) { ... } fn set_thread_pool(&self, pool: Option<&impl IsA<RTSPThreadPool>>) { ... } fn transfer_connection( &self, socket: impl IsA<Socket>, ip: &str, port: i32, initial_buffer: Option<&str>, ) -> Result<(), BoolError> { ... } fn connect_client_connected<F: Fn(&Self, &RTSPClient) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_address_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_backlog_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_bound_port_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_content_length_limit_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_mount_points_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_service_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... } fn connect_session_pool_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId { ... }
}
Expand description

Trait containing all RTSPServer methods.

§Implementors

RTSPOnvifServer, RTSPServer

Provided Methods§

Source

fn client_filter( &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 GList of this function..

When func is None, RTSPFilterResult::Ref will be assumed for each client.

§func

a callback

§Returns

a GList with all clients for which func returned RTSPFilterResult::Ref. After usage, each element in the GList should be unreffed before the list is freed.

Source

fn create_socket( &self, cancellable: Option<&impl IsA<Cancellable>>, ) -> 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.

Source

fn create_source( &self, cancellable: Option<&impl IsA<Cancellable>>, ) -> 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 [CancellableExtManual::is_cancelled()][crate::gio::prelude::CancellableExtManual::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 ()

Source

fn address(&self) -> Option<GString>

Get the address on which the server will accept connections.

§Returns

the server address. g_free() after usage.

Source

fn auth(&self) -> Option<RTSPAuth>

Get the RTSPAuth used as the authentication manager of self.

§Returns

the RTSPAuth of self. g_object_unref() after usage.

Source

fn backlog(&self) -> i32

The maximum amount of queued requests for the server.

§Returns

the server backlog.

Source

fn bound_port(&self) -> i32

Get the port number where the server was bound to.

§Returns

the port number

Source

fn content_length_limit(&self) -> u32

Get the Content-Length limit of self.

§Returns

the Content-Length limit.

Source

fn mount_points(&self) -> Option<RTSPMountPoints>

Get the RTSPMountPoints used as the mount points of self.

§Returns

the RTSPMountPoints of self. g_object_unref() after usage.

Source

fn service(&self) -> GString

Get the service on which the server will accept connections.

§Returns

the service. use g_free() after usage.

Source

fn session_pool(&self) -> Option<RTSPSessionPool>

Get the RTSPSessionPool used as the session pool of self.

§Returns

the RTSPSessionPool used for sessions. g_object_unref() after usage.

Source

fn thread_pool(&self) -> Option<RTSPThreadPool>

Get the RTSPThreadPool used as the thread pool of self.

§Returns

the RTSPThreadPool of self. g_object_unref() after usage.

Source

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

Source

fn set_auth(&self, auth: Option<&impl IsA<RTSPAuth>>)

configure auth to be used as the authentication manager of self.

§auth

a RTSPAuth

Source

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

Source

fn set_content_length_limit(&self, limit: u32)

Define an appropriate request size limit and reject requests exceeding the limit.

Source

fn set_mount_points(&self, mounts: Option<&impl IsA<RTSPMountPoints>>)

configure mounts to be used as the mount points of self.

§mounts

a RTSPMountPoints

Source

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 bound_port().

This function must be called before the server is bound.

§service

the service

Source

fn set_session_pool(&self, pool: Option<&impl IsA<RTSPSessionPool>>)

configure pool to be used as the session pool of self.

§pool

a RTSPSessionPool

Source

fn set_thread_pool(&self, pool: Option<&impl IsA<RTSPThreadPool>>)

configure pool to be used as the thread pool of self.

§pool

a RTSPThreadPool

Source

fn transfer_connection( &self, socket: impl IsA<Socket>, 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.

Source

fn connect_client_connected<F: Fn(&Self, &RTSPClient) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_address_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_backlog_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_bound_port_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_content_length_limit_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_mount_points_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_service_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Source

fn connect_session_pool_notify<F: Fn(&Self) + Send + Sync + 'static>( &self, f: F, ) -> SignalHandlerId

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§