Media Over QUIC (MoQ) stack (headers) More...
#include <stddef.h>
#include <stdint.h>
#include <glib.h>
#include "../imquic/imquic.h"
#include "../imquic/moq.h"
#include "utils.h"
#include "qlog.h"
#include "refcount.h"
Go to the source code of this file.
Data Structures | |
struct | imquic_moq_setup_parameters |
MoQ setup parameters. More... | |
struct | imquic_moq_subscribe_parameters |
MoQ subscribe parameters. More... | |
struct | imquic_moq_buffer |
MoQ buffer. More... | |
struct | imquic_moq_context |
MoQ context. More... | |
struct | imquic_moq_stream |
MoQ stream. More... | |
struct | imquic_moq_subscription |
MoQ subscription, whether this is a publisher or a subscriber. More... | |
struct | imquic_moq_callbacks |
MoQ public callbacks. More... | |
Macros | |
#define | IMQUIC_MOQ 7171953 |
Typedefs | |
typedef enum imquic_moq_message_type | imquic_moq_message_type |
MoQ messages. | |
typedef enum imquic_moq_data_message_type | imquic_moq_data_message_type |
MoQ data messages. | |
typedef enum imquic_moq_setup_parameter_type | imquic_moq_setup_parameter_type |
MoQ setup parameter types. | |
typedef enum imquic_moq_subscribe_parameter_type | imquic_moq_subscribe_parameter_type |
MoQ subscribe parameter types. | |
typedef enum imquic_moq_role_type | imquic_moq_role_type |
MoQ roles. | |
typedef struct imquic_moq_setup_parameters | imquic_moq_setup_parameters |
MoQ setup parameters. | |
typedef struct imquic_moq_subscribe_parameters | imquic_moq_subscribe_parameters |
MoQ subscribe parameters. | |
typedef enum imquic_moq_group_order | imquic_moq_group_order |
Group ordering for FETCH. | |
typedef enum imquic_moq_fetch_type | imquic_moq_fetch_type |
MoQ FETCH types. | |
typedef struct imquic_moq_buffer | imquic_moq_buffer |
MoQ buffer. | |
typedef struct imquic_moq_context | imquic_moq_context |
MoQ context. | |
typedef struct imquic_moq_stream | imquic_moq_stream |
MoQ stream. | |
typedef struct imquic_moq_subscription | imquic_moq_subscription |
MoQ subscription, whether this is a publisher or a subscriber. | |
typedef struct imquic_moq_callbacks | imquic_moq_callbacks |
MoQ public callbacks. | |
Functions | |
void | imquic_moq_init (void) |
Initialize the native MoQ stack at startup. | |
void | imquic_moq_deinit (void) |
Uninitialize the native MoQ stack. | |
const char * | imquic_moq_message_type_str (imquic_moq_message_type type) |
Helper function to serialize to string the name of a imquic_moq_message_type value. | |
const char * | imquic_moq_data_message_type_str (imquic_moq_data_message_type type, imquic_moq_version version) |
Helper function to serialize to string the name of a imquic_moq_data_message_type value. | |
imquic_moq_delivery | imquic_moq_data_message_type_to_delivery (imquic_moq_data_message_type type, imquic_moq_version version) |
Helper function to return the imquic_moq_delivery mode associated to a imquic_moq_data_message_type type. | |
const char * | imquic_moq_setup_parameter_type_str (imquic_moq_setup_parameter_type type) |
Helper function to serialize to string the name of a imquic_moq_setup_parameter_type value. | |
const char * | imquic_moq_subscribe_parameter_type_str (imquic_moq_subscribe_parameter_type type) |
Helper function to serialize to string the name of a imquic_moq_subscribe_parameter_type value. | |
const char * | imquic_moq_role_type_str (imquic_moq_role_type type) |
Helper function to serialize to string the name of a imquic_moq_role_type value. | |
const char * | imquic_moq_group_order_str (imquic_moq_group_order type) |
Helper function to serialize to string the name of a imquic_moq_group_order value. | |
const char * | imquic_moq_fetch_type_str (imquic_moq_fetch_type type) |
Helper function to serialize to string the name of a imquic_moq_fetch_type value. | |
gboolean | imquic_moq_buffer_resize (imquic_moq_buffer *buffer, uint64_t new_size) |
Resize an existing buffer. | |
void | imquic_moq_buffer_append (imquic_moq_buffer *buffer, uint8_t *bytes, uint64_t length) |
Append data at the end of the buffer. | |
void | imquic_moq_buffer_shift (imquic_moq_buffer *buffer, uint64_t length) |
Move the data in the buffer back of a specific number of bytes. | |
void | imquic_moq_buffer_destroy (imquic_moq_buffer *buffer) |
Destroy an existing buffer. | |
void | imquic_moq_stream_destroy (imquic_moq_stream *moq_stream) |
Destroy an existing MoQ stream. | |
imquic_moq_subscription * | imquic_moq_subscription_create (uint64_t request_id, uint64_t track_alias) |
Helper to create a new subscription instance. | |
void | imquic_moq_subscription_destroy (imquic_moq_subscription *moq_sub) |
Destroy an existing MoQ subscription. | |
Parsing MoQ messages | |
int | imquic_moq_parse_message (imquic_moq_context *moq, uint64_t stream_id, uint8_t *bytes, size_t blen, gboolean complete, gboolean datagram) |
Parse an incoming MoQ message. | |
size_t | imquic_moq_parse_client_setup (imquic_moq_context *moq, uint8_t *bytes, size_t blen, gboolean legacy, uint8_t *error) |
Helper to parse a CLIENT_SETUP message. | |
size_t | imquic_moq_parse_server_setup (imquic_moq_context *moq, uint8_t *bytes, size_t blen, gboolean legacy, uint8_t *error) |
Helper to parse a SERVER_SETUP message. | |
size_t | imquic_moq_parse_max_request_id (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a MAX_REQUEST_ID message. | |
size_t | imquic_moq_parse_requests_blocked (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a REQUESTS_BLOCKED message. | |
size_t | imquic_moq_parse_announce (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an ANNOUNCE message. | |
size_t | imquic_moq_parse_announce_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an ANNOUNCE_OK message. | |
size_t | imquic_moq_parse_announce_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an ANNOUNCE_ERROR message. | |
size_t | imquic_moq_parse_unannounce (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an UNANNOUNCE message. | |
size_t | imquic_moq_parse_announce_cancel (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an ANNOUNCE_CANCEL message. | |
size_t | imquic_moq_parse_subscribe (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE message. | |
size_t | imquic_moq_parse_subscribe_update (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_UPDATE message. | |
size_t | imquic_moq_parse_subscribe_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_OK message. | |
size_t | imquic_moq_parse_subscribe_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_ERROR message. | |
size_t | imquic_moq_parse_unsubscribe (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an UNSUBSCRIBE message. | |
size_t | imquic_moq_parse_subscribe_done (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_DONE message. | |
size_t | imquic_moq_parse_subscribe_announces (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_ANNOUNCES message. | |
size_t | imquic_moq_parse_subscribe_announces_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_ANNOUNCES_OK message. | |
size_t | imquic_moq_parse_subscribe_announces_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a SUBSCRIBE_ANNOUNCES_ERROR message. | |
size_t | imquic_moq_parse_unsubscribe_announces (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse an UNSUBSCRIBE_ANNOUNCES message. | |
size_t | imquic_moq_parse_fetch (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a FETCH message. | |
size_t | imquic_moq_parse_fetch_cancel (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a FETCH_CANCEL message. | |
size_t | imquic_moq_parse_fetch_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a FETCH_OK message. | |
size_t | imquic_moq_parse_fetch_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a FETCH_ERROR message. | |
size_t | imquic_moq_parse_track_status_request (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a TRACK_STATUS_REQUEST message. | |
size_t | imquic_moq_parse_track_status (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a TRACK_STATUS message. | |
size_t | imquic_moq_parse_object_datagram (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_data_message_type dtype, uint8_t *error) |
Helper to parse an OBJECT_DATAGRAM message. | |
size_t | imquic_moq_parse_object_datagram_status (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_data_message_type dtype, uint8_t *error) |
Helper to parse an OBJECT_DATAGRAM_STATUS message. | |
size_t | imquic_moq_parse_stream_header_track (imquic_moq_context *moq, imquic_moq_stream *moq_stream, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a STREAM_HEADER_TRACK message. | |
int | imquic_moq_parse_stream_header_track_object (imquic_moq_context *moq, imquic_moq_stream *moq_stream, gboolean complete) |
Helper to parse a STREAM_HEADER_TRACK object. | |
size_t | imquic_moq_parse_subgroup_header (imquic_moq_context *moq, imquic_moq_stream *moq_stream, uint8_t *bytes, size_t blen, imquic_moq_data_message_type dtype, uint8_t *error) |
Helper to parse a SUBGROUP_HEADER message. | |
int | imquic_moq_parse_subgroup_header_object (imquic_moq_context *moq, imquic_moq_stream *moq_stream, gboolean complete) |
Helper to parse a SUBGROUP_HEADER object. | |
size_t | imquic_moq_parse_fetch_header (imquic_moq_context *moq, imquic_moq_stream *moq_stream, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a FETCH_HEADER message. | |
int | imquic_moq_parse_fetch_header_object (imquic_moq_context *moq, imquic_moq_stream *moq_stream, gboolean complete) |
Helper to parse a FETCH_HEADER object. | |
size_t | imquic_moq_parse_goaway (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint8_t *error) |
Helper to parse a GOAWAY message. | |
Building MoQ messages | |
size_t | imquic_moq_add_control_message (imquic_moq_context *moq, imquic_moq_message_type type, uint8_t *bytes, size_t blen, size_t poffset, size_t plen, size_t *start) |
Helper method to put a message header and a payload together. | |
size_t | imquic_moq_add_client_setup (imquic_moq_context *moq, uint8_t *bytes, size_t blen, GList *supported_versions, imquic_moq_setup_parameters *parameters) |
Helper method to add a CLIENT_SETUP message to a buffer. | |
size_t | imquic_moq_add_server_setup (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint32_t version, imquic_moq_setup_parameters *parameters) |
Helper method to add a SERVER_SETUP message to a buffer. | |
size_t | imquic_moq_add_max_request_id (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t max_request_id) |
Helper method to add a MAX_REQUEST_ID message to a buffer. | |
size_t | imquic_moq_add_requests_blocked (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t max_request_id) |
Helper method to add a REQUESTS_BLOCKED message to a buffer. | |
size_t | imquic_moq_add_announce (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_subscribe_parameters *parameters) |
Helper method to add an ANNOUNCE message to a buffer. | |
size_t | imquic_moq_add_announce_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace) |
Helper method to add an ANNOUNCE_OK message to a buffer. | |
size_t | imquic_moq_add_announce_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_announce_error_code error, const char *reason) |
Helper method to add an ANNOUNCE_ERROR message to a buffer. | |
size_t | imquic_moq_add_unannounce (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_namespace *track_namespace) |
Helper method to add an UNANNOUNCE message to a buffer. | |
size_t | imquic_moq_add_announce_cancel (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_namespace *track_namespace, imquic_moq_announce_error_code error, const char *reason) |
Helper method to add aN ANNOUNCE_CANCEL message to a buffer. | |
size_t | imquic_moq_add_subscribe (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t track_alias, imquic_moq_namespace *track_namespace, imquic_moq_name *track_name, uint8_t priority, uint8_t group_order, gboolean forward, imquic_moq_filter_type filter, uint64_t start_group, uint64_t start_object, uint64_t end_group, uint64_t end_object, imquic_moq_subscribe_parameters *parameters) |
Helper to add a SUBSCRIBE message to a buffer. | |
size_t | imquic_moq_add_subscribe_update (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t start_group, uint64_t start_object, uint64_t end_group, uint64_t end_object, uint8_t priority, gboolean forward, imquic_moq_subscribe_parameters *parameters) |
Helper method to add a SUBSCRIBE_UPDATE message to a buffer. | |
size_t | imquic_moq_add_subscribe_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t expires, imquic_moq_group_order group_order, gboolean content_exists, uint64_t largest_group_id, uint64_t largest_object_id, imquic_moq_subscribe_parameters *parameters) |
Helper method to add a SUBSCRIBE_OK message to a buffer. | |
size_t | imquic_moq_add_subscribe_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_sub_error_code error, const char *reason, uint64_t track_alias) |
Helper method to add a SUBSCRIBE_ERRROR message to a buffer. | |
size_t | imquic_moq_add_unsubscribe (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id) |
Helper method to add an UNSUBSCRIBE message to a buffer. | |
size_t | imquic_moq_add_subscribe_done (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_sub_done_code status, uint64_t streams_count, const char *reason, gboolean content_exists, uint64_t final_group, uint64_t final_object) |
Helper method to add a SUBSCRIBE_DONE message to a buffer. | |
size_t | imquic_moq_add_subscribe_announces (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_subscribe_parameters *parameters) |
Helper to add a SUBSCRIBE_ANNOUNCES message to a buffer. | |
size_t | imquic_moq_add_subscribe_announces_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace) |
Helper method to add a SUBSCRIBE_ANNOUNCES_OK message to a buffer. | |
size_t | imquic_moq_add_subscribe_announces_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_subannc_error_code error, const char *reason) |
Helper method to add a SUBSCRIBE_ANNOUNCES_ERRROR message to a buffer. | |
size_t | imquic_moq_add_unsubscribe_announces (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_namespace *track_namespace) |
Helper method to add an UNSUBSCRIBE_ANNOUNCES message to a buffer. | |
size_t | imquic_moq_add_fetch (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_fetch_type type, uint64_t request_id, uint64_t joining_request_id, uint64_t preceding_group_offset, imquic_moq_namespace *track_namespace, imquic_moq_name *track_name, uint8_t priority, imquic_moq_group_order group_order, uint64_t start_group, uint64_t start_object, uint64_t end_group, uint64_t end_object, imquic_moq_subscribe_parameters *parameters) |
Helper to add a FETCH message to a buffer. | |
size_t | imquic_moq_add_fetch_cancel (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id) |
Helper method to add an FETCH_CANCEL message to a buffer. | |
size_t | imquic_moq_add_fetch_ok (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint8_t group_order, uint8_t end_of_track, uint64_t largest_group_id, uint64_t largest_object_id, imquic_moq_subscribe_parameters *parameters) |
Helper method to add a FETCH_OK message to a buffer. | |
size_t | imquic_moq_add_fetch_error (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_fetch_error_code error, const char *reason) |
Helper method to add a FETCH_ERRROR message to a buffer. | |
size_t | imquic_moq_add_track_status_request (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_name *track_name, imquic_moq_subscribe_parameters *parameters) |
Helper to add a TRACK_STATUS_REQUEST message to a buffer. | |
size_t | imquic_moq_add_track_status (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, imquic_moq_namespace *track_namespace, imquic_moq_name *track_name, uint64_t status_code, uint64_t last_group_id, uint64_t last_object_id, imquic_moq_subscribe_parameters *parameters) |
Helper to add a TRACK_STATUS message to a buffer. | |
size_t | imquic_moq_add_object_datagram (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t track_alias, uint64_t group_id, uint64_t object_id, uint64_t object_status, uint8_t priority, uint8_t *payload, size_t plen, size_t extensions_count, uint8_t *extensions, size_t elen) |
Helper to add an OBJECT_DATAGRAM message to a buffer. | |
size_t | imquic_moq_add_object_datagram_status (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t track_alias, uint64_t group_id, uint64_t object_id, uint8_t priority, uint64_t object_status, uint8_t *extensions, size_t elen) |
Helper to add an OBJECT_DATAGRAM_STATUS message to a buffer. | |
size_t | imquic_moq_add_stream_header_track (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t track_alias, uint8_t priority) |
Helper to add a STREAM_HEADER_TRACK message to a buffer (only before v06) | |
size_t | imquic_moq_add_stream_header_track_object (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t group_id, uint64_t object_id, uint64_t object_status, uint8_t *payload, size_t plen) |
Helper to add an object to a buffer, formatted as expected for STREAM_HEADER_TRACK objects (so not all IDs) (only before v06) | |
size_t | imquic_moq_add_subgroup_header (imquic_moq_context *moq, imquic_moq_stream *moq_stream, uint8_t *bytes, size_t blen, uint64_t request_id, uint64_t track_alias, uint64_t group_id, uint64_t subgroup_id, uint8_t priority) |
Helper to add a SUBGROUP_HEADER message to a buffer (only after v06) | |
size_t | imquic_moq_add_subgroup_header_object (imquic_moq_context *moq, imquic_moq_stream *moq_stream, uint8_t *bytes, size_t blen, uint64_t object_id, uint64_t object_status, uint8_t *payload, size_t plen, size_t extensions_count, uint8_t *extensions, size_t elen) |
Helper to add an object to a buffer, formatted as expected for SUBGROUP_HEADER objects (so not all IDs) (only after v06) | |
size_t | imquic_moq_add_fetch_header (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t request_id) |
Helper to add a FETCH_HEADER message to a buffer (only after v07) | |
size_t | imquic_moq_add_fetch_header_object (imquic_moq_context *moq, uint8_t *bytes, size_t blen, uint64_t group_id, uint64_t subgroup_id, uint64_t object_id, uint8_t priority, uint64_t object_status, uint8_t *payload, size_t plen, size_t extensions_count, uint8_t *extensions, size_t elen) |
Helper to add an object to a buffer, formatted as expected for FETCH_HEADER objects (so not all IDs) (only before v06) | |
size_t | imquic_moq_add_goaway (imquic_moq_context *moq, uint8_t *bytes, size_t blen, const char *new_session_uri) |
Helper method to add a GOAWAY message to a buffer. | |
size_t | imquic_moq_add_object_extensions (imquic_moq_context *moq, uint8_t *bytes, size_t blen, size_t extensions_count, uint8_t *extensions, size_t elen) |
Helper method to add object extensions to a buffer. | |
Parsing and building MoQ parameters | |
size_t | imquic_moq_parse_setup_parameter (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_setup_parameters *params, uint8_t *error) |
Helper method to parse a MoQ setup parameter. | |
size_t | imquic_moq_parse_subscribe_parameter (imquic_moq_context *moq, uint8_t *bytes, size_t blen, imquic_moq_subscribe_parameters *params, uint8_t *error) |
Helper method to parse a MoQ subscribe parameter. | |
size_t | imquic_moq_parameter_add_int (imquic_moq_context *moq, uint8_t *bytes, size_t blen, int param, uint64_t number) |
Helper to add a MoQ (setup or subscribe) parameter with a numeric value to a buffer. | |
size_t | imquic_moq_parameter_add_data (imquic_moq_context *moq, uint8_t *bytes, size_t blen, int param, uint8_t *buf, size_t buflen) |
Helper to add a MoQ (setup or subscribe) parameter with generic data to a buffer. | |
size_t | imquic_moq_setup_parameters_serialize (imquic_moq_context *moq, imquic_moq_setup_parameters *parameters, uint8_t *bytes, size_t blen, uint8_t *params_num) |
Helper to serialize a imquic_moq_setup_parameters set to a buffer. | |
size_t | imquic_moq_subscribe_parameters_serialize (imquic_moq_context *moq, imquic_moq_subscribe_parameters *parameters, uint8_t *bytes, size_t blen, uint8_t *params_num) |
Helper to serialize a imquic_moq_subscribe_parameters set to a buffer. | |
Internal callbacks for MoQ endpoints | |
void | imquic_moq_new_connection (imquic_connection *conn, void *user_data) |
Callback the core invokes when a new QUIC connection using MoQ is available. | |
void | imquic_moq_stream_incoming (imquic_connection *conn, uint64_t stream_id, uint8_t *bytes, uint64_t offset, uint64_t length, gboolean complete) |
Callback the core invokes when there's new incoming data on a STREAM . | |
void | imquic_moq_datagram_incoming (imquic_connection *conn, uint8_t *bytes, uint64_t length) |
Callback the core invokes when there's new incoming data on a DATAGRAM . | |
void | imquic_moq_connection_gone (imquic_connection *conn) |
Callback the core invokes when an existing MoQ connection is not available anymore. | |
QLOG events tracing for MoQT | |
json_t * | imquic_qlog_moq_message_prepare (const char *type) |
Helper to create a new QLOG MoQT message. | |
void | imquic_qlog_moq_message_add_namespace (json_t *message, imquic_moq_namespace *track_namespace) |
Helper to add a stringified namespace tuple array to a message. | |
void | imquic_qlog_moq_message_add_track (json_t *message, imquic_moq_name *track_name) |
Helper to add a stringified track name to a message. | |
void | imquic_qlog_moq_message_add_setup_parameters (json_t *message, imquic_moq_setup_parameters *parameters, const char *name) |
Helper to add a stringified array of setup parameters to a message. | |
void | imquic_qlog_moq_message_add_subscribe_parameters (json_t *message, imquic_moq_subscribe_parameters *parameters, const char *name) |
Helper to add a stringified array of subscribe parameters to a message. | |
void | imquic_moq_qlog_control_message_created (imquic_qlog *qlog, uint64_t stream_id, size_t length, json_t *message) |
Add a control_message_created event. | |
void | imquic_moq_qlog_control_message_parsed (imquic_qlog *qlog, uint64_t stream_id, size_t length, json_t *message) |
Add a control_message_parsed event. | |
void | imquic_moq_qlog_stream_type_set (imquic_qlog *qlog, gboolean local, uint64_t stream_id, const char *type) |
Add a stream_type_set event. | |
void | imquic_moq_qlog_object_datagram_created (imquic_qlog *qlog, imquic_moq_object *object) |
Add a object_datagram_created event. | |
void | imquic_moq_qlog_object_datagram_parsed (imquic_qlog *qlog, imquic_moq_object *object) |
Add a object_datagram_parsed event. | |
void | imquic_moq_qlog_object_datagram_status_created (imquic_qlog *qlog, imquic_moq_object *object) |
Add a object_datagram_status_created event. | |
void | imquic_moq_qlog_object_datagram_status_parsed (imquic_qlog *qlog, imquic_moq_object *object) |
Add a object_datagram_status_parsed event. | |
void | imquic_moq_qlog_subgroup_header_created (imquic_qlog *qlog, imquic_moq_stream *stream) |
Add a subgroup_header_created event. | |
void | imquic_moq_qlog_subgroup_header_parsed (imquic_qlog *qlog, imquic_moq_stream *stream) |
Add a subgroup_header_parsed event. | |
void | imquic_moq_qlog_subgroup_object_created (imquic_qlog *qlog, uint64_t stream_id, imquic_moq_object *object) |
Add a subgroup_object_created event. | |
void | imquic_moq_qlog_subgroup_object_parsed (imquic_qlog *qlog, uint64_t stream_id, imquic_moq_object *object) |
Add a subgroup_object_parsed event. | |
void | imquic_moq_qlog_fetch_header_created (imquic_qlog *qlog, imquic_moq_stream *stream) |
Add a fetch_header_created event. | |
void | imquic_moq_qlog_fetch_header_parsed (imquic_qlog *qlog, imquic_moq_stream *stream) |
Add a fetch_header_parsed event. | |
void | imquic_moq_qlog_fetch_object_created (imquic_qlog *qlog, uint64_t stream_id, imquic_moq_object *object) |
Add a fetch_object_created event. | |
void | imquic_moq_qlog_fetch_object_parsed (imquic_qlog *qlog, uint64_t stream_id, imquic_moq_object *object) |
Add a fetch_object_parsed event. | |
Media Over QUIC (MoQ) stack (headers)
Implementation of the Media Over QUIC (MoQ) stack as part of the library itself. At the time of writing, this implements (most of) versions from -06 to to -11 of the protocol.
#define IMQUIC_MOQ 7171953 |
typedef struct imquic_moq_buffer imquic_moq_buffer |
MoQ buffer.
typedef struct imquic_moq_callbacks imquic_moq_callbacks |
MoQ public callbacks.
typedef struct imquic_moq_context imquic_moq_context |
MoQ context.
typedef enum imquic_moq_data_message_type imquic_moq_data_message_type |
MoQ data messages.
typedef enum imquic_moq_fetch_type imquic_moq_fetch_type |
MoQ FETCH types.
typedef enum imquic_moq_group_order imquic_moq_group_order |
Group ordering for FETCH.
typedef enum imquic_moq_message_type imquic_moq_message_type |
MoQ messages.
typedef enum imquic_moq_role_type imquic_moq_role_type |
MoQ roles.
MoQ setup parameter types.
typedef struct imquic_moq_setup_parameters imquic_moq_setup_parameters |
MoQ setup parameters.
typedef struct imquic_moq_stream imquic_moq_stream |
MoQ stream.
MoQ subscribe parameter types.
typedef struct imquic_moq_subscribe_parameters imquic_moq_subscribe_parameters |
MoQ subscribe parameters.
typedef struct imquic_moq_subscription imquic_moq_subscription |
MoQ subscription, whether this is a publisher or a subscriber.
MoQ data messages.
MoQ messages.
enum imquic_moq_role_type |
size_t imquic_moq_add_announce | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper method to add an ANNOUNCE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | Namespace to announce |
parameters | The parameters to add, if any |
size_t imquic_moq_add_announce_cancel | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_announce_error_code | error, | ||
const char * | reason ) |
Helper method to add aN ANNOUNCE_CANCEL
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
track_namespace | Namespace for which to cancel the announcement |
error | Error code associated to the message |
reason | Verbose description of the error, if any |
size_t imquic_moq_add_announce_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_announce_error_code | error, | ||
const char * | reason ) |
Helper method to add an ANNOUNCE_ERROR
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | Namespace for which the announcement caused an error (only before v11) |
error | Error code associated to the message |
reason | Verbose description of the error, if any |
size_t imquic_moq_add_announce_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace ) |
Helper method to add an ANNOUNCE_OK
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | Namespace for which the announcement succeeded (only before v11) |
size_t imquic_moq_add_client_setup | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
GList * | supported_versions, | ||
imquic_moq_setup_parameters * | parameters ) |
Helper method to add a CLIENT_SETUP
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
supported_versions | List of supported versions |
parameters | The setup parameters to send |
size_t imquic_moq_add_control_message | ( | imquic_moq_context * | moq, |
imquic_moq_message_type | type, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
size_t | poffset, | ||
size_t | plen, | ||
size_t * | start ) |
Helper method to put a message header and a payload together.
[in] | moq | The imquic_moq_context generating the message |
[in] | type | The ID of the control message to send |
[in] | bytes | The buffer to add the control message to |
[in] | blen | The size of the buffer |
[in] | poffset | Where in the provided buffer we already have the payload |
[in] | plen | Size of the payload in the buffer |
[out] | start | Where the final control message starts, in the buffer |
size_t imquic_moq_add_fetch | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_fetch_type | type, | ||
uint64_t | request_id, | ||
uint64_t | joining_request_id, | ||
uint64_t | preceding_group_offset, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_name * | track_name, | ||
uint8_t | priority, | ||
imquic_moq_group_order | group_order, | ||
uint64_t | start_group, | ||
uint64_t | start_object, | ||
uint64_t | end_group, | ||
uint64_t | end_object, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper to add a FETCH
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
type | The FETCH type |
request_id | The request ID to put in the message |
joining_request_id | The joining request ID to put in the message, if any |
preceding_group_offset | The preceding group offset for joining fetches, if any |
track_namespace | The namespace to put in the message |
track_name | The track name to put in the message |
priority | The fetchr priority to put in the message |
group_order | The group order to put in the message |
start_group | The start group ID to put in the message |
start_object | The start object ID to put in the message |
end_group | The end group ID to put in the message |
end_object | The end object ID to put in the message |
parameters | The parameters to add, if any |
size_t imquic_moq_add_fetch_cancel | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id ) |
Helper method to add an FETCH_CANCEL
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
size_t imquic_moq_add_fetch_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_fetch_error_code | error, | ||
const char * | reason ) |
Helper method to add a FETCH_ERRROR
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
error | Error code associated to the message |
reason | Verbose description of the error, if any |
size_t imquic_moq_add_fetch_header | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id ) |
Helper to add a FETCH_HEADER
message to a buffer (only after v07)
STREAM
and send the header: after that, imquic_moq_add_fetch_header_object is used to send all objects that belong to this track. moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
size_t imquic_moq_add_fetch_header_object | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | group_id, | ||
uint64_t | subgroup_id, | ||
uint64_t | object_id, | ||
uint8_t | priority, | ||
uint64_t | object_status, | ||
uint8_t * | payload, | ||
size_t | plen, | ||
size_t | extensions_count, | ||
uint8_t * | extensions, | ||
size_t | elen ) |
Helper to add an object to a buffer, formatted as expected for FETCH_HEADER
objects (so not all IDs) (only before v06)
moq | The imquic_moq_context generating the object |
bytes | The buffer to add the object to |
blen | The size of the buffer |
group_id | The group ID |
subgroup_id | The subgroup ID |
object_id | The object ID |
priority | The publisher priority to put in the message |
object_status | The object status (only added if the payload length is 0) |
payload | The buffer containing the payload of the object |
plen | The size of the payload buffer |
extensions_count | The number of object extensions, if any (only in v08, deprecated in v09) |
extensions | The buffer containing the object extensions, if any (only since v08) |
elen | The size of the object extensions buffer (only since v08) |
size_t imquic_moq_add_fetch_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint8_t | group_order, | ||
uint8_t | end_of_track, | ||
uint64_t | largest_group_id, | ||
uint64_t | largest_object_id, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper method to add a FETCH_OK
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
group_order | The group order to put in the message |
end_of_track | Whether all objects have been published |
largest_group_id | Largest group ID to add to the message, if needed |
largest_object_id | Largest object ID to add to the message, if needed |
parameters | The parameters to add, if any |
size_t imquic_moq_add_goaway | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
const char * | new_session_uri ) |
Helper method to add a GOAWAY
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
new_session_uri | New uri value to put in the message, if any |
size_t imquic_moq_add_max_request_id | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | max_request_id ) |
Helper method to add a MAX_REQUEST_ID
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
max_request_id | Maximum request ID to put in the message |
size_t imquic_moq_add_object_datagram | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | track_alias, | ||
uint64_t | group_id, | ||
uint64_t | object_id, | ||
uint64_t | object_status, | ||
uint8_t | priority, | ||
uint8_t * | payload, | ||
size_t | plen, | ||
size_t | extensions_count, | ||
uint8_t * | extensions, | ||
size_t | elen ) |
Helper to add an OBJECT_DATAGRAM
message to a buffer.
DATAGRAM
support moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
track_alias | The track alias to put in the message |
group_id | The group ID to put in the message |
object_id | The object ID to put in the message |
object_status | The object status (only added if the payload length is 0) |
priority | The publisher priority to put in the message |
payload | The buffer containing the payload of the object |
plen | The size of the payload buffer |
extensions_count | The number of object extensions, if any (only in v08, deprecated in v09) |
extensions | The buffer containing the object extensions, if any (only since v08) |
elen | The size of the object extensions buffer (only since v08) |
size_t imquic_moq_add_object_datagram_status | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | track_alias, | ||
uint64_t | group_id, | ||
uint64_t | object_id, | ||
uint8_t | priority, | ||
uint64_t | object_status, | ||
uint8_t * | extensions, | ||
size_t | elen ) |
Helper to add an OBJECT_DATAGRAM_STATUS
message to a buffer.
DATAGRAM
support moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
track_alias | The track alias to put in the message |
group_id | The group ID to put in the message |
object_id | The object ID to put in the message |
priority | The publisher priority to put in the message |
object_status | The object status (only added if the payload length is 0) |
extensions | The buffer containing the object extensions, if any (only since v09) |
elen | The size of the object extensions buffer (only since v09) |
size_t imquic_moq_add_object_extensions | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
size_t | extensions_count, | ||
uint8_t * | extensions, | ||
size_t | elen ) |
Helper method to add object extensions to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the extensions to |
blen | The size of the buffer |
extensions_count | The number of object extensions, if any (ignored after v08, since v09 deprecated it) |
extensions | The buffer containing the object extensions, if any |
elen | The size of the object extensions buffer |
size_t imquic_moq_add_requests_blocked | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | max_request_id ) |
Helper method to add a REQUESTS_BLOCKED
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
max_request_id | Maximum request ID to put in the message |
size_t imquic_moq_add_server_setup | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint32_t | version, | ||
imquic_moq_setup_parameters * | parameters ) |
Helper method to add a SERVER_SETUP
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
version | Negotiated version |
parameters | The setup parameters to send |
size_t imquic_moq_add_stream_header_track | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | track_alias, | ||
uint8_t | priority ) |
Helper to add a STREAM_HEADER_TRACK
message to a buffer (only before v06)
STREAM
and send the header: after that, imquic_moq_add_stream_header_track_object is used to send all objects that belong to this track. moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
track_alias | The track alias to put in the message |
priority | The publisher priority to put in the message |
size_t imquic_moq_add_stream_header_track_object | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | group_id, | ||
uint64_t | object_id, | ||
uint64_t | object_status, | ||
uint8_t * | payload, | ||
size_t | plen ) |
Helper to add an object to a buffer, formatted as expected for STREAM_HEADER_TRACK
objects (so not all IDs) (only before v06)
moq | The imquic_moq_context generating the object |
bytes | The buffer to add the object to |
blen | The size of the buffer |
group_id | The group ID |
object_id | The object ID |
object_status | The object status (only added if the payload length is 0) |
payload | The buffer containing the payload of the object |
plen | The size of the payload buffer |
size_t imquic_moq_add_subgroup_header | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | track_alias, | ||
uint64_t | group_id, | ||
uint64_t | subgroup_id, | ||
uint8_t | priority ) |
Helper to add a SUBGROUP_HEADER
message to a buffer (only after v06)
STREAM
and send the header: after that, imquic_moq_add_stream_header_subgroup_object is used to send all objects that belong to this subgroup. moq | The imquic_moq_context generating the message |
moq_stream | The imquic_moq_context instance the object is for |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
track_alias | The track alias to put in the message |
group_id | The group ID to put in the message |
subgroup_id | The subgroup ID to put in the message |
priority | The publisher priority to put in the message |
size_t imquic_moq_add_subgroup_header_object | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | object_id, | ||
uint64_t | object_status, | ||
uint8_t * | payload, | ||
size_t | plen, | ||
size_t | extensions_count, | ||
uint8_t * | extensions, | ||
size_t | elen ) |
Helper to add an object to a buffer, formatted as expected for SUBGROUP_HEADER
objects (so not all IDs) (only after v06)
moq | The imquic_moq_context generating the object |
moq_stream | The imquic_moq_context instance the object is for |
bytes | The buffer to add the object to |
blen | The size of the buffer |
object_id | The object ID |
object_status | The object status (only added if the payload length is 0) |
payload | The buffer containing the payload of the object |
plen | The size of the payload buffer |
extensions_count | The number of object extensions, if any (only in v08, deprecated in v09) |
extensions | The buffer containing the object extensions, if any (only since v08) |
elen | The size of the object extensions buffer (only since v08) |
size_t imquic_moq_add_subscribe | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | track_alias, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_name * | track_name, | ||
uint8_t | priority, | ||
uint8_t | group_order, | ||
gboolean | forward, | ||
imquic_moq_filter_type | filter, | ||
uint64_t | start_group, | ||
uint64_t | start_object, | ||
uint64_t | end_group, | ||
uint64_t | end_object, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper to add a SUBSCRIBE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
track_alias | The track alias to put in the message |
track_namespace | The namespace to put in the message |
track_name | The track name to put in the message |
priority | The subscriber priority to put in the message |
group_order | The group order to put in the message |
forward | The forward value to put in the message (only starting from v11) |
filter | The filter as a imquic_moq_filter_type value |
start_group | The start group ID to put in the message |
start_object | The start object ID to put in the message |
end_group | The end group ID to put in the message |
end_object | The end object ID to put in the message |
parameters | The parameters to add, if any |
size_t imquic_moq_add_subscribe_announces | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper to add a SUBSCRIBE_ANNOUNCES
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | The namespace to put in the message |
parameters | The parameters to add, if any |
size_t imquic_moq_add_subscribe_announces_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_subannc_error_code | error, | ||
const char * | reason ) |
Helper method to add a SUBSCRIBE_ANNOUNCES_ERRROR
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | The namespace to put in the message (only before v11) |
error | Error code associated to the message |
reason | Verbose description of the error, if any |
size_t imquic_moq_add_subscribe_announces_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace ) |
Helper method to add a SUBSCRIBE_ANNOUNCES_OK
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | The namespace to put in the message (only before v11) |
size_t imquic_moq_add_subscribe_done | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_sub_done_code | status, | ||
uint64_t | streams_count, | ||
const char * | reason, | ||
gboolean | content_exists, | ||
uint64_t | final_group, | ||
uint64_t | final_object ) |
Helper method to add a SUBSCRIBE_DONE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
status | The status of the subscrption |
streams_count | The streams count (only after v07) |
reason | Verbose description of the status |
content_exists | Whether the following two properties should be added to the message (only before v08) |
final_group | Final group ID to add to the message, if needed (only before v08) |
final_object | Final object ID to add to the message, if needed (only before v08) |
size_t imquic_moq_add_subscribe_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_sub_error_code | error, | ||
const char * | reason, | ||
uint64_t | track_alias ) |
Helper method to add a SUBSCRIBE_ERRROR
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
error | Error code associated to the message |
reason | Verbose description of the error, if any |
track_alias | The track alias to put in the message |
size_t imquic_moq_add_subscribe_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | expires, | ||
imquic_moq_group_order | group_order, | ||
gboolean | content_exists, | ||
uint64_t | largest_group_id, | ||
uint64_t | largest_object_id, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper method to add a SUBSCRIBE_OK
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
expires | The expires value to put in the message |
group_order | The group order to put in the message |
content_exists | Whether the following two properties should be added to the message |
largest_group_id | Largest group ID to add to the message, if needed |
largest_object_id | Largest object ID to add to the message, if needed |
parameters | The parameters to add, if any (only after v06) |
size_t imquic_moq_add_subscribe_update | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
uint64_t | start_group, | ||
uint64_t | start_object, | ||
uint64_t | end_group, | ||
uint64_t | end_object, | ||
uint8_t | priority, | ||
gboolean | forward, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper method to add a SUBSCRIBE_UPDATE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
start_group | The start group ID to put in the message |
start_object | The start object ID to put in the message |
end_group | The end group ID to put in the message |
end_object | The end object ID to put in the message |
priority | The subscriber priority to put in the message |
forward | The forward value to put in the message (only starting from v11) |
parameters | The parameters to add, if any |
size_t imquic_moq_add_track_status | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_name * | track_name, | ||
uint64_t | status_code, | ||
uint64_t | last_group_id, | ||
uint64_t | last_object_id, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper to add a TRACK_STATUS
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | The namespace to put in the message (only before v11) |
track_name | The track name to put in the message (only before v11) |
status_code | The status code to put in the message |
last_group_id | The last group ID to put in the message |
last_object_id | The last object ID to put in the message |
parameters | The parameters to add, if any (only v11 and later) |
size_t imquic_moq_add_track_status_request | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id, | ||
imquic_moq_namespace * | track_namespace, | ||
imquic_moq_name * | track_name, | ||
imquic_moq_subscribe_parameters * | parameters ) |
Helper to add a TRACK_STATUS_REQUEST
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message (only v11 and later) |
track_namespace | The namespace to put in the message |
track_name | The track name to put in the message |
parameters | The parameters to add, if any (only v11 and later) |
size_t imquic_moq_add_unannounce | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_namespace * | track_namespace ) |
Helper method to add an UNANNOUNCE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
track_namespace | Namespace to unannounce |
size_t imquic_moq_add_unsubscribe | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint64_t | request_id ) |
Helper method to add an UNSUBSCRIBE
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
request_id | The request ID to put in the message |
size_t imquic_moq_add_unsubscribe_announces | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_namespace * | track_namespace ) |
Helper method to add an UNSUBSCRIBE_ANNOUNCES
message to a buffer.
moq | The imquic_moq_context generating the message |
bytes | The buffer to add the message to |
blen | The size of the buffer |
track_namespace | The namespace to put in the message |
void imquic_moq_buffer_append | ( | imquic_moq_buffer * | buffer, |
uint8_t * | bytes, | ||
uint64_t | length ) |
Append data at the end of the buffer.
buffer | Buffer to append the new data to |
bytes | Data to append |
length | Size of the data to append |
void imquic_moq_buffer_destroy | ( | imquic_moq_buffer * | buffer | ) |
Destroy an existing buffer.
buffer | Buffer to destroy |
gboolean imquic_moq_buffer_resize | ( | imquic_moq_buffer * | buffer, |
uint64_t | new_size ) |
Resize an existing buffer.
buffer | Buffer to resize |
new_size | New size of the buffer |
void imquic_moq_buffer_shift | ( | imquic_moq_buffer * | buffer, |
uint64_t | length ) |
Move the data in the buffer back of a specific number of bytes.
buffer | Buffer to update |
length | How many bytes back the buffer should be moved |
void imquic_moq_connection_gone | ( | imquic_connection * | conn | ) |
Callback the core invokes when an existing MoQ connection is not available anymore.
conn | The imquic_connection instance that is now gone |
const char * imquic_moq_data_message_type_str | ( | imquic_moq_data_message_type | type, |
imquic_moq_version | version ) |
Helper function to serialize to string the name of a imquic_moq_data_message_type value.
type | The imquic_data_moq_message_type value |
version | The version of the connection |
imquic_moq_delivery imquic_moq_data_message_type_to_delivery | ( | imquic_moq_data_message_type | type, |
imquic_moq_version | version ) |
Helper function to return the imquic_moq_delivery mode associated to a imquic_moq_data_message_type type.
type | The imquic_data_moq_message_type value |
version | The version of the connection |
void imquic_moq_datagram_incoming | ( | imquic_connection * | conn, |
uint8_t * | bytes, | ||
uint64_t | length ) |
Callback the core invokes when there's new incoming data on a DATAGRAM
.
conn | The imquic_connection instance for which new DATAGRAM data is available |
bytes | The new data that is available |
length | Size of the new data |
void imquic_moq_deinit | ( | void | ) |
Uninitialize the native MoQ stack.
const char * imquic_moq_fetch_type_str | ( | imquic_moq_fetch_type | type | ) |
Helper function to serialize to string the name of a imquic_moq_fetch_type value.
type | The imquic_moq_fetch_type value |
const char * imquic_moq_group_order_str | ( | imquic_moq_group_order | type | ) |
Helper function to serialize to string the name of a imquic_moq_group_order value.
type | The imquic_moq_group_order value |
void imquic_moq_init | ( | void | ) |
Initialize the native MoQ stack at startup.
const char * imquic_moq_message_type_str | ( | imquic_moq_message_type | type | ) |
Helper function to serialize to string the name of a imquic_moq_message_type value.
type | The imquic_moq_message_type value |
void imquic_moq_new_connection | ( | imquic_connection * | conn, |
void * | user_data ) |
Callback the core invokes when a new QUIC connection using MoQ is available.
conn | The imquic_connection instance that is now available |
user_data | Optional user data the user/application may have associated to the endpoint this connection belongs to |
size_t imquic_moq_parameter_add_data | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
int | param, | ||
uint8_t * | buf, | ||
size_t | buflen ) |
Helper to add a MoQ (setup or subscribe) parameter with generic data to a buffer.
moq | The imquic_moq_context instance the parameter is for |
bytes | Buffer to add the parameter to |
blen | Size of the buffer |
param | ID of the parameter to add |
buf | The data acting as a value for the parameter to add |
buflen | The size of the data value |
size_t imquic_moq_parameter_add_int | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
int | param, | ||
uint64_t | number ) |
Helper to add a MoQ (setup or subscribe) parameter with a numeric value to a buffer.
moq | The imquic_moq_context instance the parameter is for |
bytes | Buffer to add the parameter to |
blen | Size of the buffer |
param | ID of the parameter to add |
number | The numeric value of the parameter to add |
size_t imquic_moq_parse_announce | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an ANNOUNCE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_announce_cancel | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an ANNOUNCE_CANCEL
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_announce_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an ANNOUNCE_ERROR
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_announce_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an ANNOUNCE_OK
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_client_setup | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
gboolean | legacy, | ||
uint8_t * | error ) |
Helper to parse a CLIENT_SETUP
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[in] | legacy | Whether this is a legacy CLIENT_SETUP message (before v11) |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_fetch | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a FETCH
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_fetch_cancel | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a FETCH_CANCEL
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_fetch_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a FETCH_ERROR
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_fetch_header | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a FETCH_HEADER
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | moq_stream | The imquic_moq_context instance the object is from |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
int imquic_moq_parse_fetch_header_object | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
gboolean | complete ) |
Helper to parse a FETCH_HEADER
object.
[in] | moq | The imquic_moq_context instance the object is for |
[in] | moq_stream | The imquic_moq_context instance the object is from |
[in] | complete | Whether this data marks the completion of the QUIC stream it came from |
size_t imquic_moq_parse_fetch_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a FETCH_OK
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_goaway | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a GOAWAY
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_max_request_id | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a MAX_REQUEST_ID
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
int imquic_moq_parse_message | ( | imquic_moq_context * | moq, |
uint64_t | stream_id, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
gboolean | complete, | ||
gboolean | datagram ) |
Parse an incoming MoQ message.
STREAM
data), we move back to the beginning of the buffer and return, waiting for more data to arrive. moq | The imquic_moq_context instance the message is for |
stream_id | The QUIC stream ID the message came from |
bytes | The buffer containing the message to parse |
blen | Size of the buffer to parse |
complete | Whether this data marks the completion of the QUIC stream it came from |
datagram | Whether this is not coming from a STREAM but a DATAGRAM |
size_t imquic_moq_parse_object_datagram | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_data_message_type | dtype, | ||
uint8_t * | error ) |
Helper to parse an OBJECT_DATAGRAM
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[in] | dtype | Type of OBJECT_DATAGRAM (only relevant starting from v11) |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_object_datagram_status | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_data_message_type | dtype, | ||
uint8_t * | error ) |
Helper to parse an OBJECT_DATAGRAM_STATUS
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[in] | dtype | Type of OBJECT_DATAGRAM_STATUS (only relevant starting from v11) |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_requests_blocked | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a REQUESTS_BLOCKED
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_server_setup | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
gboolean | legacy, | ||
uint8_t * | error ) |
Helper to parse a SERVER_SETUP
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[in] | legacy | Whether this is a legacy SERVER_SETUP message (before v11) |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_setup_parameter | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_setup_parameters * | params, | ||
uint8_t * | error ) |
Helper method to parse a MoQ setup parameter.
[in] | moq | The imquic_moq_context instance to update with the new parameter |
[in] | bytes | Buffer containing the parameter to parse |
[in] | blen | Size of the buffer to parse |
[out] | params | imquic_moq_setup_parameters instance to put the parsed parameter in |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_stream_header_track | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a STREAM_HEADER_TRACK
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | moq_stream | The imquic_moq_context instance the object is from |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
int imquic_moq_parse_stream_header_track_object | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
gboolean | complete ) |
Helper to parse a STREAM_HEADER_TRACK
object.
[in] | moq | The imquic_moq_context instance the object is for |
[in] | moq_stream | The imquic_moq_context instance the object is from |
[in] | complete | Whether this data marks the completion of the QUIC stream it came from |
size_t imquic_moq_parse_subgroup_header | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_data_message_type | dtype, | ||
uint8_t * | error ) |
Helper to parse a SUBGROUP_HEADER
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | moq_stream | The imquic_moq_context instance the message came from |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[in] | dtype | Type of SUBGROUP_HEADER (only relevant starting from v11) |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
int imquic_moq_parse_subgroup_header_object | ( | imquic_moq_context * | moq, |
imquic_moq_stream * | moq_stream, | ||
gboolean | complete ) |
Helper to parse a SUBGROUP_HEADER
object.
[in] | moq | The imquic_moq_context instance the object is for |
[in] | moq_stream | The imquic_moq_context instance the object is from |
[in] | complete | Whether this data marks the completion of the QUIC stream it came from |
size_t imquic_moq_parse_subscribe | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_announces | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_ANNOUNCES
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_announces_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_ANNOUNCES_ERROR
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_announces_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_ANNOUNCES_OK
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_done | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_DONE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_error | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_ERROR
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_ok | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_OK
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_parameter | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
imquic_moq_subscribe_parameters * | params, | ||
uint8_t * | error ) |
Helper method to parse a MoQ subscribe parameter.
[in] | moq | The imquic_moq_context instance to update with the new parameter |
[in] | bytes | Buffer containing the parameter to parse |
[in] | blen | Size of the buffer to parse |
[out] | params | imquic_moq_subscribe_parameters instance to put the parsed parameter in |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_subscribe_update | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a SUBSCRIBE_UPDATE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_track_status | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a TRACK_STATUS
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_track_status_request | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse a TRACK_STATUS_REQUEST
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_unannounce | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an UNANNOUNCE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_unsubscribe | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an UNSUBSCRIBE
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
size_t imquic_moq_parse_unsubscribe_announces | ( | imquic_moq_context * | moq, |
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | error ) |
Helper to parse an UNSUBSCRIBE_ANNOUNCES
message.
[in] | moq | The imquic_moq_context instance the message is for |
[in] | bytes | The buffer containing the message to parse |
[in] | blen | Size of the buffer to parse |
[out] | error | In/out property, initialized to 0 and set to 1 in case of parsing errors |
void imquic_moq_qlog_control_message_created | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
size_t | length, | ||
json_t * | message ) |
Add a control_message_created
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this message |
length | The length of the message |
message | The message content |
void imquic_moq_qlog_control_message_parsed | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
size_t | length, | ||
json_t * | message ) |
Add a control_message_parsed
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this message |
length | The length of the message |
message | The message content |
void imquic_moq_qlog_fetch_header_created | ( | imquic_qlog * | qlog, |
imquic_moq_stream * | stream ) |
Add a fetch_header_created
event.
qlog | The imquic_qlog instance to add the event to |
stream | The stream used for this header |
void imquic_moq_qlog_fetch_header_parsed | ( | imquic_qlog * | qlog, |
imquic_moq_stream * | stream ) |
Add a fetch_header_parsed
event.
qlog | The imquic_qlog instance to add the event to |
stream | The stream used for this header |
void imquic_moq_qlog_fetch_object_created | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
imquic_moq_object * | object ) |
Add a fetch_object_created
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this object |
object | The object instance |
void imquic_moq_qlog_fetch_object_parsed | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
imquic_moq_object * | object ) |
Add a fetch_object_parsed
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this object |
object | The object instance |
void imquic_moq_qlog_object_datagram_created | ( | imquic_qlog * | qlog, |
imquic_moq_object * | object ) |
Add a object_datagram_created
event.
qlog | The imquic_qlog instance to add the event to |
object | The object instance |
void imquic_moq_qlog_object_datagram_parsed | ( | imquic_qlog * | qlog, |
imquic_moq_object * | object ) |
Add a object_datagram_parsed
event.
qlog | The imquic_qlog instance to add the event to |
object | The object instance |
void imquic_moq_qlog_object_datagram_status_created | ( | imquic_qlog * | qlog, |
imquic_moq_object * | object ) |
Add a object_datagram_status_created
event.
qlog | The imquic_qlog instance to add the event to |
object | The object instance |
void imquic_moq_qlog_object_datagram_status_parsed | ( | imquic_qlog * | qlog, |
imquic_moq_object * | object ) |
Add a object_datagram_status_parsed
event.
qlog | The imquic_qlog instance to add the event to |
object | The object instance |
void imquic_moq_qlog_stream_type_set | ( | imquic_qlog * | qlog, |
gboolean | local, | ||
uint64_t | stream_id, | ||
const char * | type ) |
Add a stream_type_set
event.
qlog | The imquic_qlog instance to add the event to |
local | Whether this is a local or remote stream |
stream_id | The Stream ID used for this message |
type | The stream type |
void imquic_moq_qlog_subgroup_header_created | ( | imquic_qlog * | qlog, |
imquic_moq_stream * | stream ) |
Add a subgroup_header_created
event.
qlog | The imquic_qlog instance to add the event to |
stream | The stream used for this header |
void imquic_moq_qlog_subgroup_header_parsed | ( | imquic_qlog * | qlog, |
imquic_moq_stream * | stream ) |
Add a subgroup_header_parsed
event.
qlog | The imquic_qlog instance to add the event to |
stream | The stream used for this header |
void imquic_moq_qlog_subgroup_object_created | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
imquic_moq_object * | object ) |
Add a subgroup_object_created
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this object |
object | The object instance |
void imquic_moq_qlog_subgroup_object_parsed | ( | imquic_qlog * | qlog, |
uint64_t | stream_id, | ||
imquic_moq_object * | object ) |
Add a subgroup_object_parsed
event.
qlog | The imquic_qlog instance to add the event to |
stream_id | The Stream ID used for this object |
object | The object instance |
const char * imquic_moq_role_type_str | ( | imquic_moq_role_type | type | ) |
Helper function to serialize to string the name of a imquic_moq_role_type value.
type | The imquic_moq_role_type value |
const char * imquic_moq_setup_parameter_type_str | ( | imquic_moq_setup_parameter_type | type | ) |
Helper function to serialize to string the name of a imquic_moq_setup_parameter_type value.
type | The imquic_moq_setup_parameter_type value |
size_t imquic_moq_setup_parameters_serialize | ( | imquic_moq_context * | moq, |
imquic_moq_setup_parameters * | parameters, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | params_num ) |
Helper to serialize a imquic_moq_setup_parameters set to a buffer.
[in] | moq | The imquic_moq_context instance the parameter is for |
[in] | parameters | The imquic_moq_setup_parameters to serialize |
[out] | bytes | The buffer to add paramerers to |
[in] | blen | The size of the buffer |
[out] | params_num | The number of parameters added to the buffer |
void imquic_moq_stream_destroy | ( | imquic_moq_stream * | moq_stream | ) |
Destroy an existing MoQ stream.
moq_stream | MoQ stream to destroy |
void imquic_moq_stream_incoming | ( | imquic_connection * | conn, |
uint64_t | stream_id, | ||
uint8_t * | bytes, | ||
uint64_t | offset, | ||
uint64_t | length, | ||
gboolean | complete ) |
Callback the core invokes when there's new incoming data on a STREAM
.
conn | The imquic_connection instance for which new STREAM data is available |
stream_id | The QUIC Stream ID for which new data is available |
bytes | The new data that is available |
offset | The offset in the stream this new data should be put in |
length | Size of the new data |
complete | Whether this data marks the end of this STREAM |
const char * imquic_moq_subscribe_parameter_type_str | ( | imquic_moq_subscribe_parameter_type | type | ) |
Helper function to serialize to string the name of a imquic_moq_subscribe_parameter_type value.
type | The imquic_moq_subscribe_parameter_type value |
size_t imquic_moq_subscribe_parameters_serialize | ( | imquic_moq_context * | moq, |
imquic_moq_subscribe_parameters * | parameters, | ||
uint8_t * | bytes, | ||
size_t | blen, | ||
uint8_t * | params_num ) |
Helper to serialize a imquic_moq_subscribe_parameters set to a buffer.
[in] | moq | The imquic_moq_context instance the parameter is for |
[in] | parameters | The imquic_moq_subscribe_parameters to serialize |
[out] | bytes | The buffer to add paramerers to |
[in] | blen | The size of the buffer |
[out] | params_num | The number of parameters added to the buffer |
imquic_moq_subscription * imquic_moq_subscription_create | ( | uint64_t | request_id, |
uint64_t | track_alias ) |
Helper to create a new subscription instance.
request_id | The request ID |
track_alias | The track alias |
void imquic_moq_subscription_destroy | ( | imquic_moq_subscription * | moq_sub | ) |
Destroy an existing MoQ subscription.
moq_sub | MoQ subscription to destroy |
void imquic_qlog_moq_message_add_namespace | ( | json_t * | message, |
imquic_moq_namespace * | track_namespace ) |
Helper to add a stringified namespace tuple array to a message.
track_namespace
property message | The message object to update |
track_namespace | The namespace to serialize to an array |
void imquic_qlog_moq_message_add_setup_parameters | ( | json_t * | message, |
imquic_moq_setup_parameters * | parameters, | ||
const char * | name ) |
Helper to add a stringified array of setup parameters to a message.
message | The message object to update |
parameters | The setup parameters to convert |
name | The name the array should have in the message object |
void imquic_qlog_moq_message_add_subscribe_parameters | ( | json_t * | message, |
imquic_moq_subscribe_parameters * | parameters, | ||
const char * | name ) |
Helper to add a stringified array of subscribe parameters to a message.
message | The message object to update |
parameters | The subscribe parameters to convert |
name | The name the array should have in the message object |
void imquic_qlog_moq_message_add_track | ( | json_t * | message, |
imquic_moq_name * | track_name ) |
Helper to add a stringified track name to a message.
track_name
property message | The message object to update |
track_name | The track name to add |
json_t * imquic_qlog_moq_message_prepare | ( | const char * | type | ) |
Helper to create a new QLOG MoQT message.
type
property type | The name of the message |