}
}
+static GstRTSPResult
+tunnel_http_response (GstRTSPWatch * watch, GstRTSPMessage * request,
+ GstRTSPMessage * response, gpointer user_data)
+{
+ GstRTSPClientClass *klass;
+
+ GstRTSPClient *client = GST_RTSP_CLIENT (user_data);
+ klass = GST_RTSP_CLIENT_GET_CLASS (client);
+
+ if (klass->tunnel_http_response) {
+ klass->tunnel_http_response (client, request, response);
+ }
+
+ return GST_RTSP_OK;
+}
+
static GstRTSPWatchFuncs watch_funcs = {
message_received,
message_sent,
tunnel_start,
tunnel_complete,
error_full,
- tunnel_lost
+ tunnel_lost,
+ tunnel_http_response
};
static void
* RTSP response(ctx->response) via a call to gst_rtsp_message_init_response()
* @params_get: get parameters. This function should also initialize the
* RTSP response(ctx->response) via a call to gst_rtsp_message_init_response()
+ * @tunnel_http_response: called when a response to the GET request is about to
+ * be sent for a tunneled connection. The response can be modified. Since 1.4
*
* The client class structure.
*/
void (*get_parameter_request) (GstRTSPClient *client, GstRTSPContext *ctx);
void (*handle_response) (GstRTSPClient *client, GstRTSPContext *ctx);
+ void (*tunnel_http_response) (GstRTSPClient * client, GstRTSPMessage * request,
+ GstRTSPMessage * response);
/*< private >*/
- gpointer _gst_reserved[GST_PADDING_LARGE];
+ gpointer _gst_reserved[GST_PADDING_LARGE-1];
};
GType gst_rtsp_client_get_type (void);