Sinks are the end components for all DSL GStreamer Pipelines. A Pipeline must have at least one sink in use, along with other certain components, to reach a state of Ready.
All Sinks are derived from the "Component" class, therefore all component methods can be called with any Sink.
component
╰── sink
DSL supports fifteen (15) different types of Sinks:
- 3D Window Sink - renders/overlays video on a Parent XWindow (Jetson Platform Only)... based on the 3D graphics rendering API.
- EGL Window Sink - renders/overlays video on a Parent XWindow... based on the EGL API.
- V4L2 Sink - streams video to a V4L2 device or v4l2loopback.
- File Sink - encodes video to a media container file
- Record Sink - similar to the File sink but with Start/Stop/Duration control and a cache for pre-start buffering.
- RTMP Sink - streams encoded video using the Real-time Messaging Protocol (RTMP) to social media networks, live streaming platforms, and media servers.
- RTSP Client Sink - streams encoded video using the Real-time Streaming Protocol (RTSP) as a client of a media server.
- RTSP Server Sink - streams encoded video via an RTSP (UDP) Server on a specified port.
- WebRTC Sink - streams encoded video to a web browser or mobile application. (Requires GStreamer 1.18 or later)
- Message Sink - converts Object Detection Event (ODE) metadata into a message payload and sends it to the server using a specified communication protocol.
- Application Sink - allows the application to receive buffers or samples from a DSL Pipeline.
- Interpipe Sink - allows pipeline buffers and events to flow to other independent pipelines, each with an Interpipe Source. Disabled by default, requires additional install/build steps.
- Multi-Image Sink - encodes and saves video frames to JPEG files at specified dimensions and frame-rate.
- Frame-Capture Sink - encodes and saves video frames to JPEG files on demand or on schedule. Disabled by default, requires additional install/build steps.
- Fake Sink - consumes/drops all data.
Sinks are created by calling one of the type-specific constructors. As with all components, Sinks must be uniquely named from all other components created.
The relationship between Pipelines and Sinks is one-to-many. The same relationship exists between Branches and Sinks. Once added to a Pipeline, a Sink must be removed before it can be used with another. Sinks are deleted by calling dsl_component_delete
, dsl_component_delete_many
, or dsl_component_delete_all
When adding a Sink(s) to a Pipeline or Branch, DSL automatically inserts a Splitter Tee between the last component and the Sink(s) as shown in the image below, even if there is only one. This ensures that additional Sinks can be added (and removed) once the Pipeline is playing.
Sinks are added to a Pipeline by calling dsl_pipeline_component_add
or dsl_pipeline_component_add_many
and removed with dsl_pipeline_component_remove
, dsl_pipeline_component_remove_many
, or dsl_pipeline_component_remove_all
.
A similar set of Services are used when adding/removing a to/from a branch: dsl_branch_component_add
, dsl_branch_component_add_many
, dsl_branch_component_remove
, dsl_branch_component_remove_many
, and dsl_branch_component_remove_all
.
IMPORTANT!: A Sink Component can be added as a branch to either a Splitter or Demuxer Tee.
All Sinks -- except for the Smart Record and RTSP Client Sinks -- support the following common properties accessible through corresponding get/set base Sink Methods. (Note: the follow bullets are quotes from the GStreamer Documentation)
sync
: Each Sink sets a timestamp for when a frame should be played, ifsync=true
it will block the pipeline and only play the frame after that time. This is useful for playing from a video file, or other non-live sources. If you play a video file withsync=false
it will play back as fast as it can be read and processed. Seedsl_sink_sync_enabled_get
anddsl_sink_sync_enabled_set
. As a general rule- Set
sync=true
if using non-live sources and/or if the stream is to be rendered and viewed. - Set
sync=false
if using live sources and/or if significantly processing the stream.
- Set
async
: Ifasync=true
, the Sink will perform asynchronous state changes. Whenasync=false
, the Sink will not signal the parent when it prerolls. Use this option when dealing with sparse streams or when synchronization is not required. Seedsl_sink_async_enabled_get
anddsl_sink_async_enabled_set
.max-lateness
: The max-lateness property affects how the Sink deals with buffers that arrive too late. A buffer arrives too late in the Sink when the presentation time (as a combination of the last segment, buffer timestamp and element base_time) plus the duration is before the current time of the clock. If the frame is later than max-lateness (in nanoseconds), the sink will drop the buffer without calling the render method. This feature is disabled ifsync=false
. Seedsl_sink_max_lateness_get
anddsl_sink_max_lateness_set
.qos
:Ifqos=true
, the property will enable the quality-of-service features of the Sink which gather statistics about the real-time performance of the clock synchronization. For each buffer received in the Sink, statistics are gathered and a QOS event is sent upstream with these numbers. This information can then be used by upstream elements to reduce their processing rate, for example. Seedsl_sink_qos_enabled_get
anddsl_sink_qos_enabled_set
.
IMPORTANT! All DSL Sink Components use the default property values assigned to their GStreamer (GST) Sink Plugins, except for.
- All set their
async
property tofalse
on construction. Synchronization is required to support multiple levels of multiple Secondary Inference - All disable
max-latness
by setting the property to-1
. - All set their
qos
value tofalse
(disabled).
- A single value indicates that the gstreamer-default is used.
a/b
values define both the gstreamer-default/DSL-default values.
Sink | GST Plugin | sync | async | max-lateness | qos |
---|---|---|---|---|---|
3D Window Sink | nv3dsink | true | true/false | 5000000/-1 | true/false |
EGL Window Sink | nveglglessink | true | true/false | 5000000/-1 | true/false |
V4L2 Sink | v4l2sink | true | true/false | 5000000/-1 | true/false |
File Sink | filesink | false | true/false | -1 | false |
Record Sink1 | na | na | na | na | na |
RTMP Sink | rtmpsink | true | true/false | -1 | false |
RTSP Client Sink2 | rtspclientsink | na | na | na | na |
RTSP Server Sink | udpsink | true | true/false | -1 | false |
WebRTC Sink | fakesink | false | true/false | -1 | false |
Message Sink | nvmsgbroker | true | true/false | -1 | false |
App Sink | appsink | true | true/false | -1 | false |
Interpipe Sink | interpipesink | false | true/false | -1 | false |
Multi-Image Sink | multifilesink | false | true/false | -1 | false |
Frame-Capture Sink | appsink | true | true/false | -1 | false |
Fake Sink | fakesink | false | true/false | -1 | false |
- 1 The NVIDIA Smart Recording Bin - used by the Record Sink - does not support/extern any of the common sink properties. ↩
- 2 The rtspclientsink plugin is not derived from the GStreamer basesink which implements the common sink properties. ↩
Types:
Callback Types:
dsl_sink_app_new_data_handler_cb
dsl_sink_window_key_event_handler_cb
dsl_sink_window_button_event_handler_cb
dsl_sink_window_delete_event_handler_cb
dsl_record_client_listener_cb
dsl_sink_webrtc_client_listener_cb
Constructors:
dsl_sink_app_new
dsl_sink_window_3d_new
dsl_sink_window_egl_new
dsl_sink_v4l2_new
dsl_sink_file_new
dsl_sink_record_new
dsl_sink_rtmp_new
dsl_sink_rtsp_client_new
dsl_sink_rtsp_server_new
dsl_sink_webrtc_new
dsl_sink_message_new
dsl_sink_interpipe_new
dsl_sink_image_multi_new
dsl_sink_frame_capture_new
dsl_sink_fake_new
Sink Methods
dsl_sink_sync_enabled_get
dsl_sink_sync_enabled_set
dsl_sink_async_enabled_get
dsl_sink_async_enabled_set
dsl_sink_max_lateness_get
dsl_sink_max_lateness_set
dsl_sink_qos_enabled_get
dsl_sink_qos_enabled_set
dsl_sink_pph_add
dsl_sink_pph_remove
App Sink Methods
3D & EGL Window Sink Methods
dsl_sink_window_offsets_get
dsl_sink_window_offsets_set
dsl_sink_window_dimensions_get
dsl_sink_window_dimensions_set
dsl_sink_window_handle_get
dsl_sink_window_handle_set
dsl_sink_window_fullscreen_enabled_get
dsl_sink_window_fullscreen_enabled_set
dsl_sink_window_key_event_handler_add
dsl_sink_window_key_event_handler_remove
dsl_sink_window_button_event_handler_add
dsl_sink_window_button_event_handler_remove
dsl_sink_window_delete_event_handler_add
dsl_sink_window_delete_event_handler_remove
EGL Window Sink Methods
V4L2 Sink Methods
dsl_sink_v4l2_device_location_get
dsl_sink_v4l2_device_location_set
dsl_sink_v4l2_device_name_get
dsl_sink_v4l2_device_fd_get
dsl_sink_v4l2_device_flags_get
dsl_sink_v4l2_buffer_in_format_get
dsl_sink_v4l2_buffer_in_format_set
dsl_sink_v4l2_picture_settings_get
dsl_sink_v4l2_picture_settings_set
Encode Sink Methods
dsl_sink_encode_settings_get
dsl_sink_encode_settings_set
dsl_sink_encode_dimensions_get
dsl_sink_encode_dimensions_set
Smart-Record Sink Methods
dsl_sink_record_session_start
dsl_sink_record_session_stop
dsl_sink_record_outdir_get
dsl_sink_record_outdir_set
dsl_sink_record_container_get
dsl_sink_record_container_set
dsl_sink_record_cache_size_get
dsl_sink_record_cache_size_set
dsl_sink_record_dimensions_get
dsl_sink_record_dimensions_set
dsl_sink_record_is_on_get
dsl_sink_record_video_player_add
dsl_sink_record_video_player_remove
dsl_sink_record_mailer_add
dsl_sink_record_mailer_remove
dsl_sink_record_reset_done_get
RTMP Sink Methods
RTSP Client Sink Methods
dsl_sink_rtsp_client_credentials_set
dsl_sink_rtsp_client_latency_get
dsl_sink_rtsp_client_latency_set
dsl_sink_rtsp_client_profiles_get
dsl_sink_rtsp_client_profiles_set
dsl_sink_rtsp_client_protocols_get
dsl_sink_rtsp_client_protocols_set
dsl_sink_rtsp_client_tls_validation_flags_get
dsl_sink_rtsp_client_tls_validation_flags_set
RTSP Server Sink Methods
WebRTC Sink Methods
dsl_sink_webrtc_connection_close
dsl_sink_webrtc_servers_get
dsl_sink_webrtc_servers_set
dsl_sink_webrtc_client_listener_add
dsl_sink_webrtc_client_listener_remove
IOT Message Converter Sink Methods
dsl_sink_message_converter_settings_get
dsl_sink_message_converter_settings_set
dsl_sink_message_broker_settings_get
dsl_sink_message_broker_settings_set
dsl_sink_message_payload_debug_dir_get
dsl_sink_message_payload_debug_dir_set
Interpipe Sink Methods
dsl_sink_interpipe_forward_settings_get
dsl_sink_interpipe_forward_settings_set
dsl_sink_interpipe_num_listeners_get
Multi-Image Sink Methods
dsl_sink_image_multi_file_path_get
dsl_sink_image_multi_file_path_set
dsl_sink_image_multi_dimensions_get
dsl_sink_image_multi_dimensions_set
dsl_sink_image_multi_frame_rate_get
dsl_sink_image_multi_frame_rate_set
dsl_sink_image_multi_file_max_get
dsl_sink_image_multi_file_max_set
Frame-Capture Sink Methods
The following return codes are used by the Sink API
#define DSL_RESULT_SINK_RESULT 0x00040000
#define DSL_RESULT_SINK_NAME_NOT_UNIQUE 0x00040001
#define DSL_RESULT_SINK_NAME_NOT_FOUND 0x00040002
#define DSL_RESULT_SINK_NAME_BAD_FORMAT 0x00040003
#define DSL_RESULT_SINK_THREW_EXCEPTION 0x00040004
#define DSL_RESULT_SINK_FILE_PATH_NOT_FOUND 0x00040005
#define DSL_RESULT_SINK_IS_IN_USE 0x00040007
#define DSL_RESULT_SINK_SET_FAILED 0x00040008
#define DSL_RESULT_SINK_CODEC_VALUE_INVALID 0x00040009
#define DSL_RESULT_SINK_CONTAINER_VALUE_INVALID 0x0004000A
#define DSL_RESULT_SINK_COMPONENT_IS_NOT_SINK 0x0004000B
#define DSL_RESULT_SINK_COMPONENT_IS_NOT_ENCODE_SINK 0x0004000C
#define DSL_RESULT_SINK_COMPONENT_IS_NOT_WINDOW_SINK 0x0004000D
#define DSL_RESULT_SINK_OBJECT_CAPTURE_CLASS_ADD_FAILED 0x0004000E
#define DSL_RESULT_SINK_OBJECT_CAPTURE_CLASS_REMOVE_FAILED 0x0004000F
#define DSL_RESULT_SINK_HANDLER_ADD_FAILED 0x00040010
#define DSL_RESULT_SINK_HANDLER_REMOVE_FAILED 0x00040011
#define DSL_RESULT_SINK_PLAYER_ADD_FAILED 0x00040012
#define DSL_RESULT_SINK_PLAYER_REMOVE_FAILED 0x00040013
#define DSL_RESULT_SINK_MAILER_ADD_FAILED 0x00040014
#define DSL_RESULT_SINK_MAILER_REMOVE_FAILED 0x00040015
#define DSL_RESULT_SINK_3D_NOT_SUPPORTED 0x00040016
#define DSL_RESULT_SINK_WEBRTC_CLIENT_LISTENER_ADD_FAILED 0x00040017
#define DSL_RESULT_SINK_WEBRTC_CLIENT_LISTENER_REMOVE_FAILED 0x00040018
#define DSL_RESULT_SINK_WEBRTC_CONNECTION_CLOSED_FAILED 0x00040019
#define DSL_RESULT_SINK_MESSAGE_CONFIG_FILE_NOT_FOUND 0x00040020
#define DSL_RESULT_SINK_COMPONENT_IS_NOT_MESSAGE_SINK 0x00040021
The following codec types are used by the Sink API
#define DSL_CODEC_H264 0
#define DSL_CODEC_H265 1
The following video container types are used by the File Sink API
#define DSL_CONTAINER_MPEG4 0
#define DSL_CONTAINER_MK4 1
#define DSL_RECORDING_EVENT_START 0
#define DSL_RECORDING_EVENT_END 1
#define DSL_FLOW_OK 0
#define DSL_FLOW_EOS 1
#define DSL_FLOW_ERROR 2
#define DSL_SINK_APP_DATA_TYPE_SAMPLE 0
#define DSL_SINK_APP_DATA_TYPE_BUFFER 1
#define DSL_VIDEO_FORMAT_YUY2 L"YUY2"
#define DSL_VIDEO_FORMAT_YVYU L"YVYU"
#define DSL_V4L2_DEVICE_TYPE_NONE 0x00000000
#define DSL_V4L2_DEVICE_TYPE_CAPTURE 0x00000001
#define DSL_V4L2_DEVICE_TYPE_OUTPUT 0x00000002
#define DSL_V4L2_DEVICE_TYPE_OVERLAY 0x00000004
#define DSL_V4L2_DEVICE_TYPE_VBI_CAPTURE 0x00000010
#define DSL_V4L2_DEVICE_TYPE_VBI_OUTPUT 0x00000020
#define DSL_V4L2_DEVICE_TYPE_TUNER 0x00010000
#define DSL_V4L2_DEVICE_TYPE_AUDIO 0x00020000
#define DSL_RTSP_PROFILE_UNKNOWN 0x00000000
#define DSL_RTSP_PROFILE_AVP 0x00000001
#define DSL_RTSP_PROFILE_SAVP 0x00000002
#define DSL_RTSP_PROFILE_AVPF 0x00000004
#define DSL_RTSP_PROFILE_SAVPF 0x00000008
#define DSL_RTSP_LOWER_TRANS_UNKNOWN 0x00000000
#define DSL_RTSP_LOWER_TRANS_UDP 0x00000001
#define DSL_RTSP_LOWER_TRANS_UDP_MCAST 0x00000002
#define DSL_RTSP_LOWER_TRANS_TCP 0x00000004
#define DSL_RTSP_LOWER_TRANS_HTTP 0x00000010
#define DSL_RTSP_LOWER_TRANS_TLS 0x00000020
Flags used to validate the RTSP server certificate.
#define DSL_TLS_CERTIFICATE_UNKNOWN_CA 0x00000001
#define DSL_TLS_CERTIFICATE_BAD_IDENTITY 0x00000002
#define DSL_TLS_CERTIFICATE_NOT_ACTIVATED 0x00000004
#define DSL_TLS_CERTIFICATE_EXPIRED 0x00000008
#define DSL_TLS_CERTIFICATE_REVOKED 0x00000010
#define DSL_TLS_CERTIFICATE_INSECURE 0x00000020
#define DSL_TLS_CERTIFICATE_GENERIC_ERROR 0x00000040
#define DSL_TLS_CERTIFICATE_VALIDATE_ALL 0x0000007f
Used by the WebRTC Sink to communicate its current state to listening clients
#define DSL_SOCKET_CONNECTION_STATE_CLOSED 0
#define DSL_SOCKET_CONNECTION_STATE_INITIATED 1
#define DSL_SOCKET_CONNECTION_STATE_OPENED 2
#define DSL_SOCKET_CONNECTION_STATE_FAILED 3
Defines the Payload schema types that can be used with the Message Sink
#define DSL_MSG_PAYLOAD_DEEPSTREAM 0
#define DSL_MSG_PAYLOAD_DEEPSTREAM_MINIMAL 1
The following -D flags are defined in the DSL Makefile
-DNVDS_AZURE_PROTO_LIB='L"$(LIB_INSTALL_DIR)/libnvds_azure_proto.so"' \
-DNVDS_AZURE_EDGE_PROTO_LIB='L"$(LIB_INSTALL_DIR)/libnvds_azure_edge_proto.so"' \
-DNVDS_AMQP_PROTO_LIB='L"$(LIB_INSTALL_DIR)/libnvds_amqp_proto.so"' \
-DNVDS_KAFKA_PROTO_LIB='L"$(LIB_INSTALL_DIR)/libnvds_kafka_proto.so"' \
-DNVDS_REDIS_PROTO_LIB='L"$(LIB_INSTALL_DIR)/libnvds_redis_edge_proto.so"'
typedef struct dsl_recording_info
{
uint recording_event;
uint sessionId;
const wchar_t* filename;
const wchar_t* dirpath;
uint64_t duration;
uint containerType;
uint width;
uint height;
} dsl_recording_info;
Structure typedef used to provide recording session information provided to the client on callback
Fields
recording_event
- specifies which recording event has occurred. One ofDSL_RECORDING_EVENT_START
orDSL_RECORDING_EVENT_END
sessionId
- the unique sessions id assigned on record startfilename
- filename generated for the completed recording. Null on recording start.directory
- path for the completed recording. Null on recording start.duration
- duration of the recording in milliseconds. 0 on recording start.containerType
- DSL_CONTAINER_MP4 or DSL_CONTAINER_MP4width
- width of the recording in pixelsheight
- height of the recording in pixels
Python Example
##
# Function to be called on recording start and complete
##
def recording_event_listener(session_info_ptr, client_data):
print(' *** Recording Event *** ')
session_info = session_info_ptr.contents
print('event type: ', session_info.recording_event)
print('session_id: ', session_info.session_id)
print('filename: ', session_info.filename)
print('dirpath: ', session_info.dirpath)
print('duration: ', session_info.duration)
print('container: ', session_info.container_type)
print('width: ', session_info.width)
print('height: ', session_info.height)
typedef struct _dsl_webrtc_connection_data
{
uint current_state;
} dsl_webrtc_connection_data;
A structure typedef used to provide connection date for a given WebRTC Sink
Fields
current_state
- the current state of the WebRTC Sink's WebSocket connection, one of the defined WebRTC Connection States.
typedef uint (*dsl_sink_app_new_data_handler_cb)(uint data_type,
void* data, void* client_data);
Callback typedef for the App Sink Component. The function is registered when the App Sink is created with dsl_sink_app_new
. Once the Pipeline is playing, the function will be called when new data is available to process. The type of data is specified with the App Sink constructor.
Parameters
data_type
[in] eitherDSL_SINK_APP_DATA_TYPE_SAMPLE
orDSL_SINK_APP_DATA_TYPE_BUFFER
. See App Sink data-types.client_data
[in] opaque pointer to client's user data, provided by the client.
Returns
- One of the DSL_FLOW constant values.
typedef void (*dsl_sink_window_key_event_handler_cb)(const wchar_t* key, void* client_data);
Callback typedef for a client XWindow KeyRelease
event handler function. Functions of this type are added to a Window Sink by calling dsl_sink_window_key_event_handler_add
. Once added, the function will be called on every XWindow KeyRelease
event. The handler function is removed by calling dsl_sink_window_key_event_handler_remove
.
Parameters
key
- [in] UNICODE key string for the key pressedclient_data
- [in] opaque pointer to client's user data, passed into the Window Sink on callback add
typedef void (*dsl_sink_window_button_event_handler_cb)(uint button, uint xpos, uint ypos, void* client_data);
Callback typedef for a client XWindow ButtonPress
event handler function. Functions of this type are added to a Window Sink by calling dsl_sink_window_button_event_handler_add
. Once added, the function will be called on every XWindow ButtonPress
event. The handler function is removed by calling dsl_sink_window_button_event_handler_remove
.
Parameters
button
- [in] one of DSL_BUTTON_ID indicating which mouse button was pressedxpos
- [in] positional X-offset from the XWindow's upper left corner in pixelsypos
- [in] positional Y-offset from the XWindow's upper left corner in pixelsclient_data
- [in] opaque pointer to client's user data, passed into the Window Sink on callback add
typedef void (*dsl_sink_window_delete_event_handler_cb)(void* client_data);
Callback typedef for a client XWindow Delete
event handler function. Functions of this type are added to a Pipeline by calling dsl_sink_window_delete_event_handler_add
. Once added, the function will be called on XWindow Delete
event. The handler function is removed by calling dsl_sink_window_button_event_handler_remove
.
Parameters
client_data
- [in] opaque pointer to client's user data, passed into the Window Sink on callback add
typedef void* (*dsl_record_client_listener_cb)(void* info, void* user_data);
Callback typedef for clients to listen for a notification that a Recording Session has started or ended.
Parameters
info
[in] opaque pointer to the connection info, see... seedsl_capture_info
.client_data
[in] opaque pointer to client's user data, provided by the client.
typedef void (*dsl_sink_webrtc_client_listener_cb)(dsl_webrtc_connection_data* data,
void* client_data);
Callback typedef for a client to listen for WebRTC Sink connection events.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
Parameters
info
[in] opaque pointer to the session info, seedsl_webrtc_connection_data
.client_data
[in] opaque pointer to client's user data, provided by the client.
DslReturnType dsl_sink_app_new(const wchar_t* name, uint data_type,
dsl_sink_app_new_data_handler_cb client_handler, void* client_data);
The constructor creates a new, uniquely named App Sink component. Construction will fail if the name is currently in use.
component
╰── sink
╰── app sink
Parameters
name
- [in] unique name for the App Sink to create.data_type
- [in] eitherDSL_SINK_APP_DATA_TYPE_SAMPLE
orDSL_SINK_APP_DATA_TYPE_BUFFER
. See App Sink data-types.client_handler
- [in] client callback function to be called with each new buffer received.client_data
[in] opaque pointer to client data returned on callback to theclient_handler
function.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_app_new('my-app-sink', DSL_SINK_APP_DATA_TYPE_BUFFER,
my_data_handler, NULL)
DslReturnType dsl_sink_window_3d_new(const wchar_t* name,
uint offset_x, uint offset_y, uint width, uint height);
The constructor creates a uniquely named 3D Window Sink with given offsets and dimensions. Construction will fail if the name is currently in use. Window Sinks are used to render video onto an XWindow Display.
IMPORTANT: The 3D Window Sink is only available on the Jetson platform.
component
╰── sink
╰── window sink
╰── 3d window sink
Parameters
name
- [in] unique name for the 3D Window Sink to create.x_offset
- [in] offset in the X direction from the upper left corner of the display in pixels.y_offset
- [in] offset in the Y direction from the upper left corner of the display in pixels.width
- [in] width of the 3D Window Sink in pixels.height
- [in] height of the 3D Window Sink in pixels.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_3d_new('my-window-sink', 200, 100, 1280, 720)
DslReturnType dsl_sink_window_egl_new(const wchar_t* name,
uint offset_x, uint offset_y, uint width, uint height);
The constructor creates a uniquely named EGL Window Sink with given offsets and dimensions. Construction will fail if the name is currently in use. Window Sinks are used to render video onto an XWindow Display.
component
╰── sink
╰── window sink
╰── egl window sink
Parameters
name
- [in] unique name for the EGL Window Sink to create.x_offset
- [out] offset in the X direction in pixels from the upper left most corner of the display.y_offset
- [out] offset in the Y direction in pixels from the upper left most corner of the display.width
- [in] width of the EGL Window Sink in pixels.height
- [in] height of the EGL Window Sink in pixels.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_egl_new('my-window-sink', 0, 0, 1280, 720)
DslReturnType dsl_sink_v4l2_new(const wchar_t* name,
const wchar_t* device_location);
The constructor creates a uniquely named V4L2 Sink that streams to any compatible V4L2 Device or v4l2loopback. Construction will fail if the name is currently in use.
component
╰── sink
╰── v4l2 sink
Parameters
name
- [in] unique name for the V4L2 Sink to create.device_location
- [in] device-location setting for the V4L2 Sink.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_v4l2_new('my-v4l2-sink', '/dev/video0')
DslReturnType dsl_sink_file_new(const wchar_t* name, const wchar_t* filepath,
uint codec, uint container, uint bit_rate, uint interval);
The constructor creates a uniquely named File Sink. Construction will fail if the name is currently in use. There are two Codec formats - H.264
and H.265
- and two video container types - MPEG4
and MK4
- supported.
component
╰── sink
╰── encode sink
╰── file sink
Parameters
name
- [in] unique name for the File Sink to create.filepath
- [in] absolute or relative filespec for the media file to write to.codec
- [in] one of the Codec Types defined above.container
- [in] one of the Video Container Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to code the video. Set to 0 to code every frame.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_file_new('my-file-sink', './my-video.mp4', DSL_CODEC_H264, DSL_CONTAINER_MPEG, 0, 0)
DslReturnType dsl_sink_record_new(const wchar_t* name, const wchar_t* outdir, uint codec,
uint container, uint bitrate, uint interval, dsl_record_client_listener_cb client_listener);
The constructor creates a uniquely named Record Sink. Construction will fail if the name is currently in use. There are two Codec formats - H.264
and H.265
- and two video container types - MPEG4
and MK4
- supported.
Note: the Sink name is used as the filename prefix, followed by session id and NTP time.
component
╰── sink
╰── encode sink
╰── record sink
Parameters
name
- [in] unique name for the Record Sink to create.outdir
- [in] absolute or relative pathspec for the directory to save the recorded video streams.codec
- [in] one of the Codec Types defined above.container
- [in] one of the Video Container Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to encode the video. Set to 0 to code every frame.client_listener
- [in] client callback function of typedsl_record_client_listener_cb
to be called when a [Recording Event}(#smart-recording-events) occurs.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_new('my-record-sink',
'./', DSL_CODEC_H265, DSL_CONTAINER_MPEG, 0, 0, my-client-recording-event-cb)
DslReturnType dsl_sink_rtmp_new(const wchar_t* name, const wchar_t* uri,
uint bitrate, uint interval);
The constructor creates a uniquely named RTMP Sink. Construction will fail if the name is currently in use. There is only one Codec format supported; H.264
.
component
╰── sink
╰── encode sink
╰── rtmp sink
Parameters
name
- [in] unique name for the RTMP Sink to create.uri
- [in] the RTMP URI to stream to.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to encode the video. Set to 0 to encode every frame.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtmp_new('my-rtmp-sink',
'rtmp://localhost/path/to/stream/to', 0, 0)
DslReturnType dsl_sink_rtsp_client_new(const wchar_t* name, const wchar_t* uri,
uint codec, uint bitrate, uint interval);
The constructor creates a uniquely named RTSP Client Sink. Construction will fail if the name is currently in use. There are two Codec formats supported; H.264
and H.265
.
component
╰── sink
╰── encode sink
╰── rtsp client sink
Parameters
name
- [in] unique name for the RTSP Client Sink to create.uri
- [in] the RTSP URI to stream to.codec
- [in] one of the Codec Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to encode the video. Set to 0 to code every frame.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_new('my-rtsp-client-sink',
'rtsp://server_endpoint/stream', DSL_CODEC_H264, 0, 0)
DslReturnType dsl_sink_rtsp_server_new(const wchar_t* name, const wchar_t* host,
uint udp_port, uint rtmp_port, uint codec, uint bitrate, uint interval);
The constructor creates a uniquely named RTSP Server Sink. Construction will fail if the name is currently in use. There are two Codec formats - H.264
and H.265
- supported. The RTSP server is configured when the Pipeline is called to Play. The server is then started and attached to the g-main-loop context once dsl_main_loop_run
is called. Once attached, the server can accept connections.
Important Note: the URI is derived from the device identification, rtmp_port
, and server mount point which is derived from the unique RTSP Server Sink name,
When the client and DSL application are both running locally:
rtsp://<device-name>.local:<rtmp-port-number>/<rtsp-server-sink-name>
examples:
rtsp://my-jetson-device.local:8554/my-rtsp-server-sink
rtsp://0.0.0.0:8554/my-rtsp-server-sink
When the client is running remotely from the DSL application:
rtsp://<user-name>:<password>@<ip-address>:<rtmp-port-number>/<rtsp-server-sink-name>
for example:
rtsp://admin:[email protected]:8554/my-rtsp-server-sink
component
╰── sink
╰── encode sink
╰── rtsp sink
Parameters
name
- [in] unique name for the RTSP Server Sink to create.host
- [in] host nameudp_port
- [in] UDP port setting for the RTSP server.rtsp_port
- [in] RTSP port setting for the RTSP server.codec
- [in] one of the Codec Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to encode the video. Set to 0 to code every frame.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retVal = dsl_sink_rtsp_server_new('my-rtsp-server-sink', host_uri, 5400, 8554, DSL_CODEC_H264, 4000000,0)
DslReturnType dsl_sink_webrtc_new(const wchar_t* name, const wchar_t* stun_server,
const wchar_t* turn_server, uint codec, uint bitrate, uint interval);
The constructor creates a uniquely named WebRTC Sink. Construction will fail if the name is currently in use. There are two Codec formats - H.264
and H.265
. The WebRTC Sink Implements a Signaling Transceiver which is automatically added and removed from the WebSocket Server when added and removed from a Pipeline or Branch. Refer to the WebSocket Server API Reference for more information.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
component
╰── sink
╰── encode sink
╰── webrtc sink
Parameters
name
- [in] unique name for the WebRTC Sink to create.stun_server
- [in] STUN server to use - of the form stun://hostname:port. Set to NULL to omit if using TURN server(s).turn_server
- [in] TURN server(s) to use - of the form turn(s)://username:password@host:port. Set to NULL to omit if using a STUN server.codec
- [in] one of the Codec Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] frame interval at which to encode the video. Set to 0 to code every frame.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
STUN_SERVER = "stun://stun.l.google.com:19302"
retval = dsl_sink_webrtc_new('my-webrtc-sink', STUN_SERVER, DSL_CODEC_H264, 0, 0)
DslReturnType dsl_sink_message_new(const wchar_t* name,
const wchar_t* converter_config_file, uint payload_type,
const wchar_t* broker_config_file, const wchar_t* protocol_lib,
const wchar_t* connection_string, const wchar_t* topic);
The constructor creates a uniquely named Message Sink. Construction will fail if the name is currently in use. The Message Sink converts ODE metadata -- generated by an Add Message Meta ODE Action -- into a message payload and sends it to the server using a specified communication protocol.
Important: refer to the DeepStream Plugin Guide for information on the Message Converter and Message Broker, and for information on configuration and use of the different Protocol Adapters.
Note: refer to DSL Message Broker API reference and DSL - Azure MQTT Protocol Adapter Libraries for additional information.
component
╰── sink
╰── message sink
Parameters
name
- [in] unique name for the Message Sink to create.converter_config_file
- [in] absolute or relative path to a message-converter configuration file of type text or csv.payload_type
- [in] one of the Message Converter payload schema type constants defined above.broker_config_file
- [in] broker_config_file absolute or relative path to a message-broker configuration file required by nvds_msgapi_* interface.protocol_lib
- [in] absolute or relative path to the protocol adapter that implements the nvds_msgapi_* interface. See the NVIDIA Installed Protocol Adapter Paths defined above.connection_string
- [in] endpoint for communication with server of the format<name>;<port>;<specifier>
topic
- [in] (optional) message topic for each message sent to the server.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
CONNECTION_STRING = 'HostName=my-hub.azure-devices.net;DeviceId=nano-1;SharedAccessKey=abcd1234EFGH5678ijkl'
retval = dsl_sink_message_new('my-message-sink', converter_config_file, DSL_MSG_PAYLOAD_DEEPSTREAM,
broker_config_file, NVDS_AZURE_PROTO_LIB, CONNECTION_STRING, '/ode/data')
DslReturnType dsl_sink_interpipe_new(const wchar_t* name,
boolean forward_eos, boolean forward_events);
The constructor creates a new, uniquely named Inter-Pipe Sink component. Construction will fail if the name is currently in use.
Important! The Interpipe Services are disabled by default and require additional install/build steps.
Refer to the Interpipe Services overview for more information.
component
╰── sink
╰── interpipe sink
Parameters
name
- [in] unique name for the Interpipe Sink to create.forward_eos
- [in] set to true to forward the EOS event to all listeners. False to not forward.forward_events
- [in] set to true to forward downstream events to all listeners (except for EOS). False to not forward.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retVal = dsl_sink_interpipe_new('my-interpipe-sink',
True, True)
DslReturnType dsl_sink_image_multi_new(const wchar_t* name,
const wchar_t* file_path, uint width, uint height,
uint fps_n, uint fps_d);
The constructor creates a new, uniquely named Multi-Image Sink. Construction will fail if the name is currently in use.
The Sink Encodes each frame into a JPEG image and saves it to a file specified by a given folder/filename-pattern. The size can be scaled by setting the width and height to non-zero values. The rate can be controlled by setting the fps_n and fps_d to non-zero values as well. The maximum rate at which the sink can encode and save is hardware/platform dependent. It is up to the user to manage the maximum setting. Exceeding the limit may lead to corrupted files.
component
╰── sink
╰── multi-image sink
Parameters
name
- [in] unique name for the Multi-Image Sink to create.file_path
- [in] use the printf style %d in the absolute or relative path. Example:"./my_images/image.%04d.jpg"
, will create files in"./my_images/"
named"image.0000.jpg"
,"image.0001.jpg"
,"image.0002.jpg"
etc.width
- [in] width of the images to save in pixels. Set to 0 for no transcode.height
- [in] height of the images to save in pixels. Set to 0 for no transcode.fps_n
- [in] fps_n frames/second fraction numerator. Set to 0 for no rate-change.fps_d
- [in] fps_d frames/second fraction denominator. Set to 0 for no rate-change.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retVal = dsl_sink_image_multi_new('my-multi-image-sink',
'./frame_%04d.jpg', 640, 360, 1, 10)
DslReturnType dsl_sink_frame_capture_new(const wchar_t* name,
const wchar_t* frame_capture_action);
The constructor creates a new, uniquely named Frame-Capture Sink. Construction will fail if the name is currently in use. The Sink is created with an ODE Frame-Capture Action which performs the image encoding and saving. All captured frames are copied and buffered in the Sink's processing thread. The encoding and saving of each buffered frame is done in the g-idle-thread context.
There are two methods for capturing frames:
- The Application initiates a frame-capture of the next buffer by calling
dsl_sink_frame_capture_initiate
. - An upstream Custom PPH schedules a frame-capture for a specific frame-number by calling
dsl_sink_frame_capture_schedule
.
Capture-complete-listeners (to notify on completion), Image Players (to auto-play the new image) and SMTP Mailers (to mail the new image) can be added to the Capture Action as well.
Important! The Frame-Capture Sink Services are disabled by default and require additional install/build steps to use.
Note: The first capture may cause a noticeable short pause to the stream while cuda dependencies are loaded and cached.
component
╰── sink
╰── frame-capture sink
Parameters
name
- [in] unique name for the Frame-Capture Sink to create.frame_capture_action
- [in] unique name of the ODE Frame-Capture Action to use.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retVal = dsl_sink_frame_capture_new('my-frame-capture-sink',
'my-frame-capture-action')
DslReturnType dsl_sink_fake_new(const wchar_t* name);
The constructor creates a uniquely named Fake Sink. Construction will fail if the name is currently in use.
component
╰── sink
╰── fake sink
Parameters
name
- [in] unique name for the Fake Sink to create.
Returns
DSL_RESULT_SUCCESS
on successful creation. One of the Return Values defined above on failure.
Python Example
retVal = dsl_sink_fake_new('my-fake-sink')
As with all Pipeline components, Sinks are deleted by calling dsl_component_delete
, dsl_component_delete_many
, or dsl_component_delete_all
.
DslReturnType dsl_sink_sync_enabled_get(const wchar_t* name, boolean* enabled);
This service gets the current sync
enabled property in use by the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Sink to query.enabled
- [out] true if thesync
property for the named Sink is enabled, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, enabled = dsl_sink_sync_enabled_get('my-overlay-sink')
DslReturnType dsl_sink_sync_enabled_set(const wchar_t* name, boolean enabled);
This service sets the sync
enabled property for the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Message Sink to update.enabled
- [in] set to true to enable theasync
property, false to disable.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_sync_enabled_set('my-overlay-sink', False)
DslReturnType dsl_sink_async_enabled_get(const wchar_t* name, boolean* enabled);
This service gets the current sync
enabled property in use by the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Sink to query.enabled
- [out] true if theasync
property for the named Sink is enabled, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, enabled = dsl_sink_async_enabled_get('my-overlay-sink')
DslReturnType dsl_sink_async_enabled_set(const wchar_t* name, boolean enabled);
This service sets the async
enabled property for the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Message Sink to update.enabled
- [in] set to true to enable theasync
property, false to disable.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_async_enabled_set('my-overlay-sink', False)
DslReturnType dsl_sink_max_lateness_get(const wchar_t* name, int64_t* max_lateness);
This service gets the current value of the max_lateness
property in use by the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Sink to query.max_lateness
- [out] the maximum number of nanoseconds a buffer can be late. -1 equals unlimited lateness.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, max_lateness = dsl_sink_max_lateness_get('my-overlay-sink')
DslReturnType dsl_sink_max_lateness_set(const wchar_t* name, int64_t max_lateness);
This service sets the max_lateness
property for the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Message Sink to update.max_lateness
- [in] the maximum number of nanoseconds a buffer can be late. Set to -1 for unlimited lateness.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_max_lateness_set('my-overlay-sink', -1)
DslReturnType dsl_sink_qos_enabled_get(const wchar_t* name, boolean* enabled);
This service gets the current qos
enabled property in use by the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Sink to query.enabled
- [out] true if theqos
property for the named Sink is enabled, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, enabled = dsl_sink_qos_enabled_get('my-overlay-sink')
DslReturnType dsl_sink_qos_enabled_set(const wchar_t* name, boolean enabled);
This service sets the qos
enabled property for the named Sink. See the Common Sink Properties for more information.
Parameters
name
- [in] unique name of the Message Sink to update.enabled
- [in] set to true to enable theqos
property, false to disable.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_qos_enabled_set('my-overlay-sink', False)
DslReturnType dsl_sink_pph_add(const wchar_t* name, const wchar_t* handler);
This service adds a Pad-Probe-Handler (PPH) to the sink pad of the Named Sink component. The PPH will be invoked on every buffer-ready event for the sink pad. More than one PPH can be added to a single Sink Component.
Parameters
name
[in] unique name of the Tee to update.handler
[in] unique name of the PPH to add.
Returns
DSL_RESULT_SUCCESS
on successful add. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_pph_add('my-window-sink', 'my-meter-pph')
DslReturnType dsl_sink_pph_remove(const wchar_t* name, const wchar_t* handler);
This service removes a Pad-Probe-Handler from a named Sink
Parameters
name
[in] unique name of the Sink to update.handler
[in] unique name of the Pad probe handler to remove.
Returns
DSL_RESULT_SUCCESS
on successful remove. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_pph_remove('my-window-sink', 'my-meter-pph')
DslReturnType dsl_sink_app_data_type_get(const wchar_t* name, uint* data_type);
This service gets the current data-type setting in use by a named App Sink Component.
Parameters
name
- [in] unique name of the App Sink to query.data_type
- [out] eitherDSL_SINK_APP_DATA_TYPE_SAMPLE
orDSL_SINK_APP_DATA_TYPE_BUFFER
. See App Sink data-types.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, data_type = dsl_sink_app_data_type_get('my-app-sink')
DslReturnType dsl_sink_app_data_type_set(const wchar_t* name, uint data_type);
This service sets the data-type setting for the named App Sink Component to use.
Parameters
name
- [in] unique name of the App Sink to update.data_type
- [in] eitherDSL_SINK_APP_DATA_TYPE_SAMPLE
orDSL_SINK_APP_DATA_TYPE_BUFFER
. See App Sink data-types.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_app_data_type_set('my-app-sink', DSL_SINK_APP_DATA_TYPE_BUFFER)
DslReturnType dsl_sink_window_offsets_get(const wchar_t* name,
uint* x_offset, uint* y_offsetY);
This service returns the current X and Y offsets for the named Window Sink; 3D or EGL.
Parameters
name
- [in] unique name of the Window Sink to query.x_offset
- [out] offset in the X direction in pixels from the upper left most corner of the Display.y_offset
- [out] offset in the Y direction in pixels from the upper left most corner of the Display.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, x_offset, y_offset = dsl_sink_window_offsets_get('my-window-sink')
DslReturnType dsl_sink_window_offsets_set(const wchar_t* name,
uint x_offset, uint y_offset);
This service updates the X and Y offsets for the named Window Sink; 3D or EGL.
IMPORTANT! This service may be called while the Pipeline is playing.
Parameters
name
- [in] unique name of the Window Sink to update.x_offset
- [in] new offset in the X direction in pixels from the upper left most corner of the Display.y_offset
- [in] new offset in the Y direction in pixels from the upper left most corner of the Display.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_offests_set('my-window-sink', 100, 100)
DslReturnType dsl_sink_window_dimensions_get(const wchar_t* name,
uint* width, uint* height);
This service returns the current dimensions for the named Window Sink; 3D or EGL.
Parameters
name
- [in] unique name of the Window Sink to query.width
- [out] current width of the Window Sink in pixels.height
- [out] current height of the Window Sink in pixels.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, width, height = dsl_sink_window_dimensions_get('my-window-sink')
DslReturnType dsl_sink_window_dimensions_set(const wchar_t* name,
uint width, uint height);
This service updates the dimensions of a named Window Sink; 3D or EGL.
IMPORTANT! This service may be called while the Pipeline is playing.
Parameters
name
- [in] unique name of the Window Sink to update.width
- [in] new width setting for the Window Sink in pixels.height
- [in] new height setting for the Window Sink in pixels.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_dimensions_set('my-window-sink', 1280, 720)
DslReturnType dsl_sink_window_handle_get(const wchar_t* name, uint64_t* handle);
This service returns the current XWindow handle in use by the named Window Sink. The handle is set to Null
on Sink creation and will remain Null
until,
- The Sink creates an internal XWindow synchronized on Transition to a state of playing, or
- The Client Application passes an XWindow handle into the Pipeline by calling
dsl_sink_window_handle_set
.
Parameters
name
- [in] unique name for the Window Sink to query.handle
- [out] XWindow handle in use by the named Window Sink
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, handle = dsl_sink_window_handle_get('my-window-sink')
DslReturnType dsl_sink_window_handle_set(const wchar_t* name, uint64_t handle);
This service sets the XWindow for the named 3D or EGL Window Sink to use. Setting the handle to 0 will clear any previously provided handle. The Window Sink will create its own XWindow if the handle is set to 0.
Parameters
name
- [in] unique name for the Window Sink to update.handle
- [in] XWindow handle for the Window-Sink to use, or 0 to clear the value.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure
Python Example
retval = dsl_sink_window_handle_set('my-window-sink', handle)
DslReturnType dsl_sink_window_fullscreen_enabled_get(const wchar_t* name,
boolean* enabled);
This service gets the current full-screen-enabled setting for the named Window Sink's XWindow.
Parameters
name
- [in] unique name of the Window Sink to queryenabled
- [out] true if the XWindow's full-screen mode is enabled, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, enabled = dsl_sink_window_fullscreen_enabled_get('my-window-sink')
DslReturnType dsl_sink_window_fullscreen_enabled_set(const wchar_t* name,
boolean enabled);
This service sets the full-screen-enabled setting for the Window Sink's XWindow. The service will fail if called while the Pipeline is playing.
Parameters
name
- [in] unique name of the Window Sink to updateenabled
- [in] set to true to enable the XWindow's full-screen mode, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_fullscreen_enabled_set('my-window-sink', enabled=True)
DslReturnType dsl_sink_window_key_event_handler_add(const wchar_t* name,
dsl_sink_window_key_event_handler_cb handler, void* client_data);
This service adds a callback function of type dsl_sink_window_key_event_handler_cb
to a named Window Sink. The function will be called on every XWindow KeyReleased
event with Key string and the client provided client_data
. Multiple callback functions can be registered with one Window Sink, and one callback function can be registered with multiple Window Sinks.
Parameters
name
- [in] unique name of the Window Sink to update.handler
- [in] XWindow event handler callback function to add.client_data
- [in] opaque pointer to user data returned to the handler when called back
Returns
DSL_RESULT_SUCCESS
on successful addition. One of the Return Values defined above on failure.
Python Example
def key_event_handler(key_string, client_data):
print('key pressed = ', key_string)
retval = dsl_sink_window_key_event_handler_add('my-window-sink',
key_event_handler, None)
DslReturnType dsl_sink_window_key_event_handler_remove(const wchar_t* name,
dsl_sink_window_key_event_handler_cb handler);
This service removes a function of type dsl_sink_window_key_event_handler_cb
that was previously added with dsl_sink_window_key_event_handler_add
.
Parameters
name
- [in] unique name of the Window Sink to updatehandler
- [in] XWindow event handler callback function to remove.
Returns
DSL_RESULT_SUCCESS
on successful removal. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_key_event_handler_remove('my-window-sink',
key_event_handler)
DslReturnType dsl_sink_window_button_event_handler_add(const wchar_t* name,
dsl_sink_window_button_event_handler_cb handler, void* client_data);
This service adds a callback function of type dsl_sink_window_button_event_handler_cb
to a named Window Sink. The function will be called on every XWindow ButtonPressed
event with Button ID, X and Y positional offsets, and the client provided client_data
. Multiple callback functions can be registered with one Window Sink, and one callback function can be registered with multiple Window Sinks.
Parameters
name
- [in] unique name of the Window Sink to update.handler
- [in] XWindow event handler callback function to add.client_data
- [in] opaque pointer to user data returned to the handler when called back
Returns
DSL_RESULT_SUCCESS
on successful addition . One of the Return Values defined above on failure.
Python Example
def button_event_handler(button, xpos, ypos, client_data):
print('button = ', button)
print('xpos = ', xpos)
print('ypos = ', ypos)
retval = dsl_sink_window_button_event_handler_add('my-window-sink',
button_event_handler, None)
DslReturnType dsl_sink_window_button_event_handler_remove(const wchar_t* name,
dsl_sink_window_button_event_handler_cb handler);
This service removes a function of type dsl_sink_window_button_event_handler_cb
that was previously added with dsl_sink_window_button_event_handler_add
.
Parameters
name
- [in] unique name of the Window Sink to update.handler
- [in] XWindow event handler callback function to remove.
Returns
DSL_RESULT_SUCCESS
on successful removal. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_button_event_handler_remove('my-window-sink',
button_event_handler)
DslReturnType dsl_sink_window_delete_event_handler_add(const wchar_t* name,
dsl_sink_window_delete_event_handler_cb handler, void* client_data);
This service adds a callback function of type dsl_sink_window_delete_event_handler_cb
to a named Window Sink; 3D or EGL. The function will be called on when the XWindow is closed/deleted. Multiple callback functions can be registered with one Window Sink, and one callback function can be registered with multiple Window Sink.
Parameters
name
- [in] unique name of the Window Sink to update.handler
- [in] XWindow event handler callback function to add.client_data
- [in] opaque pointer to user data returned to the handler when called back
Returns
DSL_RESULT_SUCCESS
on successful addition. One of the Return Values defined above on failure.
Python Example
def xwindow_delete_event_handler(client_data):
dsl_pipeline_stop('my-pipeline')
dsl_main_loop_quit()
retval = dsl_sink_window_delete_event_handler_add('my-window-sink',
xwindow_delete_event_handler, None)
DslReturnType dsl_sink_window_delete_event_handler_remove(const wchar_t* name,
dsl_sink_window_delete_event_handler_cb handler);
This service removes a function of type dsl_sink_window_delete_event_handler_cb
that was previously added with dsl_sink_window_delete_event_handler_add
.
Parameters
name
- [in] unique name of the Window Sink to updatehandler
- [in] XWindow event handler callback function to remove.
Returns
DSL_RESULT_SUCCESS
on successful removal. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_delete_event_handler_remove('my-pipeline',
xwindow_delete_event_handler)
DslReturnType dsl_sink_window_force_aspect_ratio_get(const wchar_t* name,
boolean* force);
This service returns the force-aspect-ratio
property setting for the named EGL Window Sink. The Sink's aspect ratio will be maintained on Window resize if set.
Parameters
name
- [in] unique name of the EGL Window Sink to query.force
- [out] true if the property is set, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, force = dsl_sink_window_egl_force_aspect_ratio_get('my-window-sink')
DslReturnType dsl_sink_window_egl_force_aspect_ratio_set(const wchar_t* name,
boolean force);
This service sets the force-aspect-ratio
property for the named EGL Window Sink. The Sink's aspect ratio will be maintained on Window resize if set. This service will fail if the Sink is currently linked.
Parameters
name
- [in] unique name of the Window Sink to update.force
- [in] set true to force the aspect ratio on window resize., false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_window_egl_force_aspect_ratio_get('my-window-sink', True)
DslReturnType dsl_sink_v4l2_device_location_get(const wchar_t* name,
const wchar_t** device_location);
This service gets the device-location setting for the named V4L2 Sink.
Parameters
name
- [in] unique name of the V4L2 Sink to query.device_location
- [out] current device-location setting.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, device_location = dsl_sink_v4l2_device_location_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_device_location_set(const wchar_t* name,
const wchar_t* device_location);
This service sets the device-location for the named V4L2 Sink to use.
Parameters
name
- [in] unique name of the V4L2 Sink to update.device_location
- [in] new device-location setting to use.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_v4l2_device_location_set('my-v4l2-sink', '/dev/video10')
DslReturnType dsl_sink_v4l2_device_name_get(const wchar_t* name,
const wchar_t** device_name);
This service gets the device-name setting for the named V4L2 Sink.
IMPORTANT! The default value = "" on Sink creation. The value is updated after negotiation with the V4L2 device.
Parameters
name
- [in] unique name of the V4L2 Sink to query.device_name
- [out] device-name of the v4l2 device once connected.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, device_name = dsl_sink_v4l2_device_name_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_device_fd_get(const wchar_t* name,
int* device_fd);
This service gets the device-file-descriptor setting for the named V4L2 Sink.
IMPORTANT! The default-file-descriptor = 0 on Sink creation. The value is updated after negotiation with the V4L2 device.
Parameters
name
- [in] unique name of the V4L2 Sink to query.device_fd
- [out] file-descriptor of the v4l2 device once connected.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, device_fd = dsl_sink_v4l2_device_fd_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_device_flags_get(const wchar_t* name,
uint* device_flags);
This service gets the device-flags setting for the named V4L2 Sink.
IMPORTANT! The default-flags = DSL_V4L2_DEVICE_TYPE_NONE
on Sink creation. The value is updated after negotiation with the V4L2 device.
Parameters
name
- [in] unique name of the V4L2 Sink to query.device_flags
- [out] mask of V4L2 Device Type Flags
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, device_flags = dsl_sink_v4l2_device_flags_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_buffer_in_format_get(const wchar_t* name,
const wchar_t** format);
This service gets the current buffer-in-format -- the format set on input to the v4l2sink plugin -- for the named V4L2 Sink.
Parameters
name
- [in] unique name of the V4L2 Sink to query.format
- [out] current buffer-in-format setting defined as one of the Buffer Format constants. Default =DSL_VIDEO_FORMAT_YUY2
.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, format = dsl_sink_v4l2_buffer_in_format_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_buffer_in_format_set(const wchar_t* name,
const wchar_t* format);
This service sets the buffer-in-format -- the format set on input to the v4l2sink plugin -- for the named V4L2 Sink to use.
Parameters
name
- [in] unique name of the V4L2 Sink to update.format
- [in] new format setting to use. A string value or one of the Buffer Format constants
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_v4l2_buffer_in_format_set('my-v4l2-sink', DSL_VIDEO_FORMAT_YVYU)
DslReturnType dsl_sink_v4l2_picture_settings_get(const wchar_t* name,
int* brightness, int* contrast, int* saturation);
This service gets the current picture brightness, contrast, and saturation settings for the named V4L2 Sink.
Parameters
name
- [in] unique name of the V4L2 Sink to query.brightness
- [out] current picture brightness level, or more precisely, the black level. Default = 0.contrast
- [out] current picture color contrast setting or luma gain. Default = 0.saturation
- [out] current picture color saturation setting or chroma gain. Default = 0.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, brightness, contrast, saturation = dsl_sink_v4l2_picture_settings_get('my-v4l2-sink')
DslReturnType dsl_sink_v4l2_picture_settings_set(const wchar_t* name,
int brightness, int contrast, int saturation);
This service sets the current picture brightness, contrast, and saturation settings for the named V4L2 Sink to use.
Parameters
name
- [in] unique name of the V4L2 Sink to update.brightness
- [in] new picture brightness level, or more precisely, the black level to use.contrast
- [in] new picture contrast setting, or luma gain, to use.saturation
- [in] new color saturation setting, or chroma gain, to use.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_v4l2_picture_settings_set('my-v4l2-sink', -10, 14, 0)
DslReturnType dsl_sink_encode_settings_get(const wchar_t* name,
uint* codec, uint* bitrate, uint* interval);
This service returns the current bitrate and interval settings for the named Encode Sink; File Sink, Smart-Record Sink, RTMP Sink, RTSP Client Sink, RTSP Server Sink, or WebRTC Sink.
Parameters
name
- [in] unique name of the Encode Sink to query.codec
- [out] current codec in use, one of the Codec Types defined above.bitrate
- [out] current bit rate at which to code the video.interval
- [out] current frame interval at which to encode the video. 0 equals code every frame
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, bitrate, interval = dsl_sink_encode_settings_get('my-file-sink')
DslReturnType dsl_sink_encode_settings_set(const wchar_t* name,
uint codec, uint bitrate, uint interval);
This service sets the bitrate and interval settings for the named Encode Sink; File Sink, Smart-Record Sink, RTMP Sink, RTSP Client Sink, RTSP Server Sink, or WebRTC Sink. The service will fail if the Encode Sink is currently linked.
IMPORTANT! The RTMP Sink only supports the H.264 codec. Setting the codec
parameter to DSL_CODEC_H265
will cause this service to fail.
Parameters
name
- [in] unique name of the Encode Sink to update.codec
- [in] new codec to use, one of the Codec Types defined above.bitrate
- [in] bitrate at which to encode the video. Set to 0 to use the encoder's default (4Mbps).interval
- [in] new frame interval at which to encode the video. Set to 0 to code every frame.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_encode_settings_set('my-file-sink', `DSL_CODEC_H264`, 4000000, 1)
DslReturnType dsl_sink_encode_dimensions_get(const wchar_t* name,
uint* width, uint* height);
This service gets the current input dimensions for the named Encode Sink; File Sink, Smart-Record Sink, RTMP Sink, RTSP Client Sink, RTSP Server Sink, or WebRTC Sink. Values of 0 indicate NO scaling.
The dimensions, if non-zero, are used to scale the video input into the Sinks's encoder element.
Parameters
name
- [in] unique name of the Encode Sink to query.width
- [out] current width of the Encode Sink input in pixels.height
- [out] current height of the Encode Sink input pixels.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, width, height = dsl_sink_encode_dimensions_get('my-rtsp-server-sink')
DslReturnType dsl_sink_encode_dimensions_set(const wchar_t* name,
uint width, uint height);
This service updates the dimensions of a named Encode Sink; File Sink, Smart-Record Sink, RTMP Sink, RTSP Client Sink, RTSP Server Sink, or WebRTC Sink. Set the values to 0 to indicate NO scaling.
Parameters
name
- [in] unique name of the Encode Sink to update.width
- [in] new width setting for the Encode Sink in pixels.height
- [in] new height setting for the Encode Sink in pixels.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_encode_dimensions_set('my-rtsp-server-sink', 1280, 720)
DslReturnType dsl_sink_record_session_start(const wchar_t* name,
uint start, uint duration, void* client_data);
This service starts a new recording session for the named Record Sink
Parameters
name
[in] unique name of the Record Sink to start the session.start
[in] start time in seconds before the current time should be less than the video cache size.duration
[in] in seconds from the current time to record.client_data
[in] opaque pointer to client data returned on callback to the client listener function provided on Sink creation.
Returns
DSL_RESULT_SUCCESS
on successful start. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_session_start('my-record-sink', 15, 900, None)
DslReturnType dsl_sink_record_session_stop(const wchar_t* name);
This service stops a current recording in session.
Parameters
name
[in] unique name of the Record Sink to stop.
Returns
DSL_RESULT_SUCCESS
on successful Stop. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_session_stop('my-record-sink')
DslReturnType dsl_sink_record_outdir_get(const wchar_t* name, const wchar_t** outdir);
This service returns the video recording output directory.
Parameters
name
[in] name of the Record Sink to query.outdir
- [out] absolute pathspec for the directory to save the recorded video streams.
Returns
DSL_RESULT_SUCCESS
on successful Query. One of the Return Values defined above on failure.
Python Example
retval, outdir = dsl_sink_record_outdir_get('my-record-sink')
DslReturnType dsl_sink_record_outdir_set(const wchar_t* name, const wchar_t* outdir);
This service sets the video recording output directory.
Parameters
name
[in] name of the Record Sink to update.outdir
- [in] absolute or relative pathspec for the directory to save the recorded video streams.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_outdir_set('my-record-sink', './recordings')
DslReturnType dsl_sink_record_container_get(const wchar_t* name, uint* container);
This service returns the media container type used when recording.
Parameters
name
[in] name of the Record Sink to query.container
- [out] one of the Video Container Types defined above.
Returns
DSL_RESULT_SUCCESS
on successful Query. One of the Return Values defined above on failure.
Python Example
retval, container_type = dsl_sink_record_container_get('my-record-sink')
DslReturnType dsl_sink_record_container_set(const wchar_t* name, uint container);
This service sets the media container type to use when recording.
Parameters
name
[in] name of the Record Sink to update.container
- [in] on of the Video Container Types defined above.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_container_set('my-record-sink', DSL_CONTAINER_MP4)
DslReturnType dsl_sink_record_cache_size_get(const wchar_t* name, uint* cache_size);
This service returns the video recording cache size in units of seconds. A fixed size cache is created when the Pipeline is linked and played. The default cache size is set to DSL_DEFAULT_VIDEO_RECORD_CACHE_IN_SEC.
Parameters
name
[in] name of the Record Sink to query.cache_size
[out] current cache size setting.
Returns
DSL_RESULT_SUCCESS
on successful Query. One of the Return Values defined above on failure.
Python Example
retval, cache_size = dsl_sink_record_cache_size_get('my-record-sink')
DslReturnType dsl_sink_record_cache_size_set(const wchar_t* name, uint cache_size);
This service sets the video recording cache size in units of seconds. A fixed size cache is created when the Pipeline is linked and played. The default cache size is set to DSL_DEFAULT_VIDEO_RECORD_CACHE_IN_SEC.
Parameters
name
[in] name of the Record Sink to query.cache_size
[in] new cache size setting to use on Pipeline play.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_cache_size_set('my-record-sink', 15)
DslReturnType dsl_sink_record_dimensions_get(const wchar_t* name, uint* width, uint* height);
This service returns the dimensions, width and height, used for the video recordings. Values of zero (default) indicate no-transcode.
Parameters
name
[in] name of the Record Sink to query.width
[out] current width of the video recording in pixels.height
[out] current height of the video recording in pixels.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, width, height = dsl_sink_record_dimensions_get('my-record-sink')
DslReturnType dsl_sink_record_dimensions_set(const wchar_t* name, uint width, uint height);
This service sets the dimensions, width and height, for the video recordings created. Values of zero (default) indicate no-transcode.
Parameters
name
[in] name of the Record Sink to update.width
[in] width to set the video recording in pixels.height
[in] height to set the video in pixels.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_dimensions_set('my-record-sink', 1280, 720)
DslReturnType dsl_sink_record_is_on_get(const wchar_t* name, boolean* is_on);
This service returns the current recording state of the Record Sink.
Parameters
name
[in] name of the Record Sink to query.is_on
[out] true if the Record Sink is currently recording a session, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, is_on = dsl_sink_record_is_on_get('my-record-sink')
DslReturnType dsl_sink_record_reset_done_get(const wchar_t* name, boolean* reset_done);
This service returns the current state of the Reset Done flag.
Parameters
name
[in] name of the Record Sink to query.reset_done
[out] true if Reset has been done, false otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, reset_done = dsl_sink_record_reset_done_get('my-record-sink')
DslReturnType dsl_sink_record_video_player_add(const wchar_t* name,
const wchar_t* player)
This service adds a Video Player, Render or RTSP type, to a named Recording Sink. Once added, each recorded video's file_path will be added (or queued) with the Video Player to be played according to the Players settings.
Parameters
name
[in] name of the Record Sink to update.player
[in] name of the Video Player to add.
Returns
DSL_RESULT_SUCCESS
on successful add. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_video_player_add('my-record-sink, 'my-video-render-player')
DslReturnType dsl_sink_record_video_player_remove(const wchar_t* name,
const wchar_t* player)
This service removes a Video Player, Render or RTSP type, from a named Recording Sink.
Parameters
name
[in] name of the Record Sink to updateplayer
[in] player name of the Video Player to remove
Returns
DSL_RESULT_SUCCESS
on successful remove. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_video_player_remove('my-record-sink', 'my-video-render-player'
DslReturnType dsl_sink_record_mailer_add(const wchar_t* name,
const wchar_t* mailer, const wchar_t* subject);
This service adds a Mailer to a named Recording Sink. Once added, the file_name, location, and specifics of each recorded video will be emailed by the Mailer according to its current settings.
Parameters
name
[in] name of the Record Sink to update.mailer
[in] name of the Mailer to add.subject
[in] subject line to use for all outgoing mail.
Returns
DSL_RESULT_SUCCESS
on successful add. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_mailer_add('my-record-sink, 'my-mailer', "New Recording Complete!")
DslReturnType dsl_sink_record_mailer_remove(const wchar_t* name,
const wchar_t* mailer)
This service removes a Mailer from a named Recording Sink.
Parameters
name
[in] name of the Record Sink to update.mailer
[in] name of the Mailer to remove.
Returns
DSL_RESULT_SUCCESS
on successful remove. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_record_mailer_remove('my-record-sink', 'my-mailer')
DslReturnType dsl_sink_rtmp_uri_get(const wchar_t* name, const wchar_t** uri);
This service gets the current RTMP URI in use for the named RTMP Sink.
Parameters
name
- [in] unique name of the RTMP Sink to query.uri
- [out] uniform resource identifier (URI) in use.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, uri = dsl_sink_rtmp_uri_get('my-rtmp-sink')
DslReturnType dsl_sink_rtmp_uri_set(const wchar_t* name, const wchar_t* uri);
This service sets the RTMP URI for the named RTMP Sink to use.
Parameters
name
- [in] unique name of the RTMP Sink to update.uri
- [in] uniform resource identifier (URI) for the RTMP Sink to use.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtmp_uri_set('my-rtmp-sink', 'rtmp://0.0.0.0/new/path/to/stream/to')
DslReturnType dsl_sink_rtsp_client_credentials_set(const wchar_t* name,
const wchar_t* user_id, const wchar_t* user_pw);
This service sets the user credentials for the named RTSP Client Sink to use.
IMPORTANT!: For security purposes, credentials are NOT logged or saved as a result of this call by DSL. In addition, there is no corresponding "Get" service for user credentials, meaning there is no way of reading the current credentials once set.
Parameters
name
- [in] unique name of the RTSP Client to update.user_id
- [in] user identification for client authentication.user_pw
- [in] user password for client authentication.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_credentials_set('my-rtsp-client-sink',
'admin', '12345678')
DslReturnType dsl_sink_rtsp_client_latency_get(const wchar_t* name, uint* latency);
This service gets the current latency setting for the named RTSP Client Sink.
Parameters
name
- [in] unique name of the RTSP Client Sink to query.latency
- [out] current latency -- the amount of data to buffer -- in units of ms. Default = 2000ms.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, latency = dsl_sink_rtsp_client_latency_get('my-rtsp-client-sink')
DslReturnType dsl_sink_rtsp_client_latency_set(const wchar_t* name, uint latency);
This service sets the latency setting for the named RTSP Client to use.
Parameters
name
- [in] unique name of the RTSP Client to update.latency
- [in] new latency -- the amount of data to buffer -- in units of ms..
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_latency_set('my-rtsp-client-sink', 1000)
DslReturnType dsl_sink_rtsp_client_profiles_get(const wchar_t* name,
uint* profiles);
This service gets the current allowed RTSP profiles for the named RTSP Client Sink.
Parameters
name
- [in] unique name of the RTSP Client Sink to query.profiles
- [out] mask of RTSP Profile constant values. Default =DSL_RTSP_PROFILE_AVP
.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, profiles = dsl_sink_rtsp_client_profiles_get('my-rtsp-client-sink')
DslReturnType dsl_sink_rtsp_client_profiles_set(const wchar_t* name,
uint profiles);
This service sets the allowed RTSP profiles for the named RTSP Client to use.
Parameters
name
- [in] unique name of the RTSP Client to update.profiles
- [in] mask of RTSP Profile constant values.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_profiles_set('my-rtsp-client-sink',
DSL_RTSP_PROFILE_SAV)
DslReturnType dsl_sink_rtsp_client_protocols_set(const wchar_t* name,
uint protocols);
This service gets the current allowed RTSP lower-protocols for the named RTSP Client Sink.
Default = DSL_RTSP_LOWER_TRANS_TCP | DSL_RTSP_LOWER_TRANS_UDP_MCAST | DSL_RTSP_LOWER_TRANS_UDP
Parameters
name
- [in] unique name of the RTSP Client Sink to query.protocols
- [out] mask of RTSP Lower-Protocol constant values.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, protocols = dsl_sink_rtsp_client_protocols_get('my-rtsp-client-sink')
DslReturnType dsl_sink_rtsp_client_protocols_set(const wchar_t* name,
uint protocols);
This service sets the allowed lower-protocols for the named RTSP Client to use.
Parameters
name
- [in] unique name of the RTSP Client to update.protocols
- [in] mask of RTSP Lower-Protocol constant values.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_profiles_set('my-rtsp-client-sink',
DSL_RTSP_LOWER_TRANS_HTTP)
DslReturnType dsl_sink_rtsp_client_tls_validation_flags_get(const wchar_t* name,
uint* flags);
This service gets the current TLS connection validation flags for the named RTSP Client Sink.
Parameters
name
- [in] unique name of the RTSP Client Sink to query.flags
- [out] mask of TLS certificate validation constants. Default =DSL_TLS_CERTIFICATE_VALIDATE_ALL
.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure
Python Example
retval, flags = dsl_sink_rtsp_client_tls_validation_flags_get('my-rtsp-client-sink')
DslReturnType dsl_sink_rtsp_client_tls_validation_flags_set(const wchar_t* name,
uint flags);
This service sets the TLS connection validation flags for the named RTSP Client to use.
Parameters
name
- [in] unique name of the RTSP Client to update.flags
- [out] mask of TLS certificate validation constants.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_rtsp_client_tls_validation_flags_set('my-rtsp-client-sink',
DSL_TLS_CERTIFICATE_NOT_ACTIVATED)
This service returns the current RTSP video codec and Port settings for the named RTSP Sink.
DslReturnType dsl_sink_rtsp_server_settings_get(const wchar_t* name,
uint* udp_port, uint* rtsp_port);
Parameters
name
- [in] unique name of the RTSP Sink to query.udp_port
- [out] the current UDP Port number in use.rtsp_port
- [out] the current RTSP Port number in use.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, udp_port, rtsp_port = dsl_sink_rtsp_server_settings_get('my-rtsp-sink')
DslReturnType dsl_sink_webrtc_connection_close(const wchar_t* name);
This service closes a currently open WebSocket connection for the named WebRTC Sink.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
Parameters
name
[in] unique name of the WebRTC Sink to update.
Returns DSL_RESULT_SUCCESS
on successful close. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_webrtc_connection_close('my-webrtc-sink')
DslReturnType dsl_sink_webrtc_servers_get(const wchar_t* name,
const wchar_t** stun_server, const wchar_t** turn_server);
This service queries a named WebRTC Sink component for its current STUN or TURN server(s) in use.
IMPORTANT: The WebRTC Sink implementation requires DS 1.18.0 or later.
Parameters
name
[in] unique name of the WebRTC Sink to query.stun_server
[out] current STUN server in use, NULL if omitted.turn_server
[out] current TURN server in use, NULL if omitted.
Returns DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, stun_server, turn_server = dsl_sink_webrtc_servers_get('my-webrtc-sink')
DslReturnType dsl_sink_webrtc_servers_set(const wchar_t* name,
const wchar_t* stun_server, const wchar_t* turn_server);
This service updates a named WebRTC Sink component with either a new STUN or TURN server(s) to use.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
Parameters
name
[in] unique name of the WebRTC Sink to query.stun_server
- [in] STUN server to use - of the form stun://hostname:port. Set to NULL to omit if using TURN server(s).turn_server
- [in] TURN server(s) to use - of the form turn(s)://username:password@host:port. Set to NULL to omit if using a STUN server.
Returns DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_webrtc_servers_get('my-webrtc-sink', NULL, turn_server)
DslReturnType dsl_sink_webrtc_client_listener_add(const wchar_t* name,
dsl_sink_webrtc_client_listener_cb listener, void* client_data);
This service adds a callback function of type dsl_sink_webrtc_client_listener_cb
to the WebRTC Sink. The function will be called on all changes of WebSocket connection state. Multiple callback functions can be added to the WebRTC Sink.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
Parameters
name
[in] unique name of the WebRTC Sink to update.listener
- [in] listener callback function to add.client_data
- [in] opaque pointer to user data, returned to the listener on call back
Returns DSL_RESULT_SUCCESS
on successful add. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_webrtc_client_listener_add('my-webrtc-sink', client_listener_cb, None)
DslReturnType dsl_sink_webrtc_client_listener_remove(const wchar_t* name,
dsl_sink_webrtc_client_listener_cb listener);
This service removes a callback function of type dsl_sink_webrtc_client_listener_cb
from the WebRTC Sink.
IMPORTANT: The WebRTC Sink implementation requires GStreamer 1.18 or later.
Parameters
name
[in] unique name of the WebRTC Sink to update.listener
- [in] listener callback function to remove.
Returns
DSL_RESULT_SUCCESS
on successful removal. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_webrtc_client_listener_remove('my-webrtc-sink', client_listener_cb)
DslReturnType dsl_sink_message_converter_settings_get(const wchar_t* name,
const wchar_t** converter_config_file, uint* payload_type);
This service gets the current Message Converter settings in use by the named Message Sink.
Important refer to the Deepstream Plugin Guide for information on the Message Converter configuration file settings.
Parameters
name
- [in] unique name of the Encode Sink to query.converter_config_file
- [out] absolute file-path to the current Message Converter config file in use.payload_type
- [out] the current payload schema type in use, one of the Message Converter payload schema type constants defined above.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, converter_config_file, payload_type = dsl_sink_message_converter_settings_get('my-message-sink')
DslReturnType dsl_sink_message_converter_settings_set(const wchar_t* name,
const wchar_t* converter_config_file, uint payload_type);
This service sets the Message Converter settings to be used by the named Message Sink.
Important refer to the DeepStream Plugin Guide for information on the Message Converter configuration file settings.
Parameters
name
- [in] unique name of the Encode Sink to update.converter_config_file
- [in] relative or absolute file-path to a Message Converter config file to use.payload_type
- [in] the current payload schema type in use, one of the Message Converter payload schema type constants defined above.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_message_converter_settings_get('my-message-sink',
converter_config_file, DSL_MSG_PAYLOAD_DEEPSTREAM)
DslReturnType dsl_sink_message_broker_settings_get(const wchar_t* name,
const wchar_t** broker_config_file, const wchar_t** protocol_lib,
const wchar_t** connection_string, const wchar_t** topic);
This service gets the current Message Broker settings in use by the named Message Sink.
Important refer to the DeepStream Plugin Guide for information on the Message Broker configuration file and connection string, and for information on configuration and use of the different Protocol Adapters.
Parameters
name
- [in] unique name of the Message Sink to query.broker_config_file
- [out] absolute file-path to the current Message Broker config file in use.protocol_lib
- [out] absolute file-path to the current protocol adapter library in use.connection_string
- [out] current connection string in use.topic
- [out] (optional) current message topic in use.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, broker_config_file, protocol_lib, connection_string, topic =
dsl_sink_message_broker_settings_get('my-message-sink')
DslReturnType dsl_sink_message_broker_settings_set(const wchar_t* name,
const wchar_t* broker_config_file, const wchar_t* protocol_lib,
const wchar_t* connection_string, const wchar_t* topic);
This service sets the Message Broker settings to be used by the named Message Sink.
Important refer to the DeepStream Plugin Guide for information on the Message Broker configuration file and connection string, and for information on configuration and use of the different Protocol Adapters.
Parameters
name
- [in] unique name of the Message Sink to update.broker_config_file
- [in] absolute or relative file-path to a new Message Broker config file to use.protocol_lib
- [in] absolute or relative file-path to a new protocol adapter library to use.connection_string
- [in] new connection string to use.topic
- [in] (optional) new message topic to use for all messages sent.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_message_broker_settings_get('my-message-sink',
broker_config_file, protocol_lib, connection_string, new_topic)
DslReturnType dsl_sink_message_payload_debug_dir_get(const wchar_t* name,
const wchar_t** debug_dir);
This service gets the current payload dumping/debugging directory for the named Message Sink. Null string indicates that payload dumping is disabled.
Parameters
name
- [in] unique name of the Message Sink to query.debug_dir
- [out] absolute or relative path to the directory to dump payload data.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, debug_dir = dsl_sink_message_payload_debug_dir_get('my-message-sink')
DslReturnType dsl_sink_message_payload_debug_dir_set(const wchar_t* name,
const wchar_t* debug_dir);
This service sets the payload dumping/debugging directory for the named Message Sink.
Parameters
name
- [in] unique name of the Message Sink to update.debug_dir
- [in] absolute or relative path to the directory to dump payload data.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_message_payload_debug_dir_set('my-message-sink', './dump')
DslReturnType dsl_sink_interpipe_forward_settings_get(const wchar_t* name,
boolean* forward_eos, boolean* forward_events);
This service gets the current forward settings in use for the named Interpipe Sink component.
Parameters
name
- [in] unique name of the Interpipe Sink to query.forward_eos
- [out] if true, the EOS event will be forwarded to all listeners. False otherwise.forward_events
- [out] if true, all downstream events will be forwarded to all the listeners (except for EOS). False otherwise.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, forward_eos, forward_events = dsl_sink_interpipe_forward_settings_get(
'my-interpipe-sink')
DslReturnType dsl_sink_interpipe_forward_settings_set(const wchar_t* name,
boolean forward_eos, boolean forward_events);
This service sets the forward settings for named Interpipe Sink component.
Parameters
name
- [in] unique name of the Interpipe Sink to update.forward_eos
- [in] set to true to forward the EOS event to all listeners. False to not forward.forward_events
- [in] set to true to forward downstream events to all listeners (except for EOS). False to not forward.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_interpipe_forward_settings_set('my-interpipe-sink',
True, True)
DslReturnType dsl_sink_interpipe_num_listeners_get(const wchar_t* name,
uint* num_listeners);
This service gets the current number of Interpipe Sources listening to the named Interpipe Sink component.
Parameters
name
- [in] unique name of the Interpipe Sink to query.num_listeners
- [out] current number of Interpipe Sources listening.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, num_listeners = dsl_sink_interpipe_num_listeners_get('my-interpipe-sink')
DslReturnType dsl_sink_image_multi_file_path_get(const wchar_t* name,
const wchar_t** file_path);
This service gets the current output file-path in use by the named Multi-Image Sink component.
Parameters
name
- [in] unique name of the Interpipe Sink to query.file_path
- [out] current file-path in use by the Multi-Image Sink.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, file_path = dsl_sink_image_multi_file_path_get('my-multi-image-sink')
DslReturnType dsl_sink_image_multi_file_path_set(const wchar_t* name,
const wchar_t* file_path);
This service sets the output file-path for the named Multi-Image Sink to use.
Parameters
name
- [in] unique name of the Multi-Image Sink to update.file_path
- [in] use the printf style %d in the absolute or relative path. Example:"./my_images/image.%04d.jpg"
, will create files in"./my_images/"
named"image.0000.jpg"
,"image.0001.jpg"
,"image.0002.jpg"
etc.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_image_multi_file_path_set('my-multi-image-sink',
"./my_images/image.%04d.jpg")
DslReturnType dsl_sink_image_multi_dimensions_get(const wchar_t* name,
uint* width, uint* height);
This service gets the current dimensions in use by the named Multi-Image Sink component. Values of 0 indicate no transcode.
Parameters
name
- [in] unique name of the Interpipe Sink to query.width
- [out] current width to save images in pixels.height
- [out] current height to save images in pixels.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, width, height = dsl_sink_image_multi_dimensions_get(
'my-multi-image-sink')
DslReturnType dsl_sink_image_multi_dimensions_set(const wchar_t* name,
uint width, uint height);
This service sets the dimensions for the named Multi-Image Sink to use.
Parameters
name
- [in] unique name of the Multi-Image Sink to update.width
- [in] new width setting in units of pixels. Set to 0 for no transcode.height
- [in] new width setting in units of pixels. Set to 0 for no transcode.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_image_multi_dimensions_set('my-multi-image-sink',
640, 360)
DslReturnType dsl_sink_image_multi_frame_rate_get(const wchar_t* name,
uint* fps_n, uint* fps_d);
This service gets the current frame-rate in use by the named Multi-Image Sink component. Values of 0 indicate no rate-change.
Parameters
name
- [in] unique name of the Interpipe Sink to query.fps_n
- [out] current frames per second numerator.fps_d
- [out] current frames per second denominator.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, fps_n, fps_d = dsl_sink_image_multi_frame_rate_get(
'my-multi-image-sink')
DslReturnType dsl_sink_image_multi_frame_rate_set(const wchar_t* name,
uint fps_n, uint fps_d);
This service sets the frame-rate for the named Multi-Image Sink to use.
Parameters
name
- [in] unique name of the Multi-Image Sink to update.fps_n
- [in] new frames per second numerator. Set to 0 for no rate-change.fps_d
- [in] new frames per second denominator. Set to 0 for no rate-change.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_image_multi_frame_rate_set(my-multi-image-sink',
1, 30)
DslReturnType dsl_sink_image_multi_file_max_get(const wchar_t* name,
uint* max);
This service gets the current max-file setting in use by the named Multi-Image Sink component. Once the maximum is reached, old files start to be deleted to make room for new ones. Default = 0 - no max.
Parameters
name
- [in] unique name of the Interpipe Sink to query.max
- [out] current max-file setting in use.
Returns
DSL_RESULT_SUCCESS
on successful query. One of the Return Values defined above on failure.
Python Example
retval, max = dsl_sink_image_multi_file_max_get(
'my-multi-image-sink')
DslReturnType dsl_sink_image_multi_file_max_set(const wchar_t* name,
uint max);
This service sets the max-file setting for named Multi-Image Sink to use. Once the maximum is reached, old files start to be deleted to make room for new ones. Default = 0 - no max.
Parameters
name
- [in] unique name of the Multi-Image Sink to update.max
- [in] new max-files setting to use. Set to 0 for no maximum.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_image_multi_file_max_set('my-multi-image-sink', 100)
DslReturnType dsl_sink_frame_capture_initiate(const wchar_t* name);
This service initiates a "frame-capture action" to capture the next buffer processed by the named Frame-Capture Sink.
All captured frames are copied and buffered in the Sink's processing thread. The encoding and saving of each buffered frame is done in the g-idle-thread context.
Note: The first capture may cause a noticeable short pause to the stream while cuda dependencies are loaded and cached.
Parameters
name
- [in] unique name of the Frame-Capture Sink to update.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_frame_capture_initiate('my-frame-capture-sink')
DslReturnType dsl_sink_frame_capture_schedule(const wchar_t* name,
uint64_t frame_number);
This service schedules a "frame-capture action" for a specified frame-number to be processed by the named Frame-Capture Sink once the frame arrives. Multiple frames can be scheduled (queued) for processing. The Sink will log an ERROR message durring buffer processing if the scheduled frame-number(s) is less (earlier in time) than the current frame-number.
All captured frames are copied and buffered in the Sink's processing thread. The encoding and saving of each buffered frame is done in the g-idle-thread context.
Note: The first capture may cause a noticeable short pause to the stream while cuda dependencies are loaded and cached.
Parameters
name
- [in] unique name of the Frame-Capture Sink to update.frame_num
- [in] unique frame-number of the frame to capture.
Returns
DSL_RESULT_SUCCESS
on successful update. One of the Return Values defined above on failure.
Python Example
retval = dsl_sink_frame_capture_schedule('my-frame-capture-sink', frame_meta.frame_num)
- List of all Services
- Pipeline
- Player
- Source
- Tap
- Dewarper
- Preprocessor
- Inference Engine and Server
- Tracker
- Segmentation Visualizer
- Tiler
- Demuxer and Splitter Tees
- Remuxer
- On-Screen Display
- Sink
- Branch
- Component
- Custom Component
- Pad Probe Handler
- ODE Trigger
- ODE Accumulator
- ODE Acton
- ODE Area
- ODE Heat-Mapper
- Mailer
- WebSocket Server
- Message Broker
- Info API