82 #ifndef JANUS_TRANSPORT_H
83 #define JANUS_TRANSPORT_H
100 #define JANUS_TRANSPORT_API_VERSION 7
116 #define JANUS_TRANSPORT_INIT(...) { \
119 .get_api_compatibility = NULL, \
120 .get_version = NULL, \
121 .get_version_string = NULL, \
122 .get_description = NULL, \
124 .get_author = NULL, \
125 .get_package = NULL, \
126 .is_janus_api_enabled = NULL, \
127 .is_admin_api_enabled = NULL, \
128 .send_message = NULL, \
129 .session_created = NULL, \
130 .session_over = NULL, \
131 .session_claimed = NULL, \
void(* p_free)(void *)
Pointer to the transport-provided function, if needed, that will be used to free the opaque transport...
Definition: transport.h:148
volatile gint destroyed
Whether this mapping has been destroyed definitely or not: if so, the transport shouldn't make use of...
Definition: transport.h:151
janus_transport * create_t(void)
The hook that transport plugins need to implement to be created from the Janus core.
Definition: transport.h:289
Reference counter mechanism.
int(*const init)(janus_transport_callbacks *callback, const char *config_path)
Transport plugin initialization/constructor.
Definition: transport.h:179
struct json_t json_t
Definition: plugin.h:225
GMutex janus_mutex
Janus mutex implementation.
Definition: mutex.h:61
void(*const incoming_request)(janus_transport *plugin, janus_transport_session *transport, void *request_id, gboolean admin, json_t *message, json_error_t *error)
Callback to notify a new incoming request.
Definition: transport.h:243
void(*const destroy)(void)
Transport plugin deinitialization/destructor.
Definition: transport.h:181
void * transport_p
Opaque pointer to the transport session.
Definition: transport.h:146
const char *(*const get_name)(void)
Informative method to request the name of the transport plugin.
Definition: transport.h:194
const char *(*const get_description)(void)
Informative method to request a description of the transport plugin.
Definition: transport.h:192
Definition: refcount.h:78
gboolean(*const is_api_secret_needed)(janus_transport *plugin)
Callback to check with the core if an API secret must be provided.
Definition: transport.h:257
int(*const send_message)(janus_transport_session *transport, void *request_id, gboolean admin, json_t *message)
Method to send a message to a client over a transport session.
Definition: transport.h:214
void(*const session_claimed)(janus_transport_session *transport, guint64 session_id)
Method to notify the transport plugin that a session it owned was claimed by another transport...
Definition: transport.h:231
gboolean(*const is_janus_api_enabled)(void)
Informative method to check whether any Janus API support is currently enabled in this transport...
Definition: transport.h:201
const char *(*const get_author)(void)
Informative method to request the author of the transport plugin.
Definition: transport.h:196
gboolean(*const is_admin_api_enabled)(void)
Informative method to check whether any Admin API support is currently enabled in this transport...
Definition: transport.h:203
gboolean(*const is_api_secret_valid)(janus_transport *plugin, const char *apisecret)
Callback to check with the core if a provided API secret is valid.
Definition: transport.h:265
void(*const transport_gone)(janus_transport *plugin, janus_transport_session *transport)
Callback to notify an existing transport instance went away.
Definition: transport.h:253
void(*const session_over)(janus_transport_session *transport, guint64 session_id, gboolean timeout, gboolean claimed)
Method to notify the transport plugin that a session it originated timed out.
Definition: transport.h:226
void(*const session_created)(janus_transport_session *transport, guint64 session_id)
Method to notify the transport plugin that a new session has been created from this transport...
Definition: transport.h:219
const char *(*const get_version_string)(void)
Informative method to request the string version of the transport plugin.
Definition: transport.h:190
The transport plugin session and callbacks interface.
Definition: transport.h:174
janus_transport_session * janus_transport_session_create(void *transport_p, void(*p_free)(void *))
Helper to create a janus_transport_session instance.
Definition: transport.c:24
gboolean(*const is_auth_token_needed)(janus_transport *plugin)
Callback to check with the core if an authentication token is needed.
Definition: transport.h:268
Callbacks to contact the Janus core.
Definition: transport.h:236
Transport-Gateway session mapping.
Definition: transport.h:144
const char *(*const get_package)(void)
Informative method to request the package name of the transport plugin (what will be used in web appl...
Definition: transport.h:198
janus_mutex mutex
Mutex to protect changes to transport_p.
Definition: transport.h:153
janus_refcount ref
Reference counter for this instance.
Definition: transport.h:155
int(*const get_version)(void)
Informative method to request the numeric version of the transport plugin.
Definition: transport.h:188
void(*const notify_event)(janus_transport *plugin, void *transport, json_t *event)
Callback to notify an event to the registered and subscribed event handlers.
Definition: transport.h:285
int(*const get_api_compatibility)(void)
Informative method to request the API version this transport plugin was compiled against.
Definition: transport.h:186
gboolean(*const is_auth_token_valid)(janus_transport *plugin, const char *token)
Callback to check with the core if a provided authentication token is valid.
Definition: transport.h:276
void janus_transport_session_destroy(janus_transport_session *session)
Helper to mark a janus_transport_session instance as destroyed.
Definition: transport.c:36
gboolean(*const events_is_enabled)(void)
Callback to check whether the event handlers mechanism is enabled.
Definition: transport.h:280