Skip to content

RTP

An input type that allows streaming video and audio to the Smelter server over RTP. It supports both streaming over UDP and TCP (Smelter works as a TCP server).

Usage

To use RTP Input you must register it first. You can do it by sending a request like this:

Example request

POST: /api/input/:input_id/register
Content-Type: application/json
{
"type": "rtp_stream",
"transport_protocol": "tcp_server",
"port": 9001,
"video": {
"decoder": "ffmpeg_h264"
},
"audio": {
"decoder": "opus"
}
}

See HTTP Routes documentation to learn more about managing inputs.

Reference

Type definition

type RtpInput = {
type: "rtp_stream"
port: string | u16;
transport_protocol?: "udp" | "tcp_server";
video?: InputRtpVideoOptions;
audio?: InputRtpAudioOptions;
required?: bool;
offset_ms?: f64;
}

Parameters for registering an RTP stream as an input.

Properties

port

A port number or a port range in format START:END. If range is specified, a port from that range will be returned from register-input request.

  • Type: string | u16

transport_protocol

Transport protocol.

  • Type: "udp" | "tcp_server"
  • Supported values:
    • udp - UDP protocol.
    • tcp_server - TCP protocol where Smelter is the server side of the connection.

video

Parameters of a video included in the RTP stream.


audio

Parameters of an audio source included in the RTP stream.


required

Determines if the input stream is essential for output frame production. If set to true and the stream is delayed, Smelter will postpone output frames until the stream is received.

  • Type: bool
  • Default value: false

offset_ms

Offset in milliseconds relative to the pipeline start (start request). If unspecified, the stream synchronizes based on the delivery time of the initial frames.

  • Type: f64

InputRtpVideoOptions

type InputRtpVideoOptions = {
decoder: "ffmpeg_h264" | "vulkan_h264" | "ffmpeg_vp8" | "ffmpeg_vp9";
}

Properties

decoder

Video decoder.

  • Type: "ffmpeg_h264" | "vulkan_h264" | "ffmpeg_vp8" | "ffmpeg_vp9"
  • Supported values:
    • "ffmpeg_h264" - Use the software H264 decoder based on FFmpeg.
    • "vulkan_h264" (Required feature: vk-video ) - Hardware decoder. Requires GPU that supports Vulkan Video decoding.
    • "ffmpeg_vp8" - Use the software VP8 decoder based on FFmpeg.
    • "ffmpeg_vp9" - Use the software VP9 decoder based on FFmpeg.

InputRtpAudioOptions

type InputRtpAudioOptions =
| {
decoder: "opus";
}
| {
decoder: "aac";
audio_specific_config: string;
rtp_mode?: "low_bitrate" | "high_bitrate";
}

Properties (decoder: "opus")

Properties (decoder: "aac")

audio_specific_config

Configuration encoded in the format described in RFC 3640.

  • Type: string

For detailed instructions on obtaining this value, refer to the information provided in the table below:

Format/ProtocolLocation of AAC Specific Config (ASC)Notes
FFmpeg StreamingSDP fileUse the -sdp_file FILENAME option when streaming to a Smelter to generate an SDP file containing the ASC.
MP4 FilesInside the esds boxThe ASC is embedded as part of the esds box, not the entire box. Applies to regular MP4 and fragmented MP4s (used in HLS playlists with MP4 files).
FLV Files / RTMPInside the AACAUDIODATA tagThe ASC is contained within the AACAUDIODATA tag.

rtp_mode

Specifies the RFC 3640 mode that should be used when depacketizing this stream. For more information, visit RFC specification

  • Type: "low_bitrate" | "high_bitrate"
  • Default value: "high_bitrate"