rtsp-client: vmethod for modifying tunnel GET response
[platform/upstream/gstreamer.git] / gst / rtsp-server / rtsp-client.h
index 72c5187..01f8208 100644 (file)
@@ -68,18 +68,25 @@ typedef gboolean (*GstRTSPClientSendFunc)      (GstRTSPClient *client,
 struct _GstRTSPClient {
   GObject       parent;
 
+  /*< private >*/
   GstRTSPClientPrivate *priv;
+  gpointer _gst_reserved[GST_PADDING];
 };
 
 /**
  * GstRTSPClientClass:
  * @create_sdp: called when the SDP needs to be created for media.
+ * @configure_client_media: called when the stream in media needs to be configured.
+ *    The default implementation will configure the blocksize on the payloader when
+ *    spcified in the request headers.
  * @configure_client_transport: called when the client transport needs to be
  *    configured.
  * @params_set: set parameters. This function should also initialize the
  *    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.
  */
@@ -87,11 +94,15 @@ struct _GstRTSPClientClass {
   GObjectClass  parent_class;
 
   GstSDPMessage * (*create_sdp) (GstRTSPClient *client, GstRTSPMedia *media);
+  gboolean        (*configure_client_media)     (GstRTSPClient * client,
+                                                 GstRTSPMedia * media, GstRTSPStream * stream,
+                                                 GstRTSPContext * ctx);
   gboolean        (*configure_client_transport) (GstRTSPClient * client,
                                                  GstRTSPContext * ctx,
                                                  GstRTSPTransport * ct);
   GstRTSPResult   (*params_set) (GstRTSPClient *client, GstRTSPContext *ctx);
   GstRTSPResult   (*params_get) (GstRTSPClient *client, GstRTSPContext *ctx);
+  gchar *         (*make_path_from_uri) (GstRTSPClient *client, const GstRTSPUrl *uri);
 
   /* signals */
   void     (*closed)                  (GstRTSPClient *client);
@@ -104,6 +115,12 @@ struct _GstRTSPClientClass {
   void     (*teardown_request)        (GstRTSPClient *client, GstRTSPContext *ctx);
   void     (*set_parameter_request)   (GstRTSPClient *client, GstRTSPContext *ctx);
   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-1];
 };
 
 GType                 gst_rtsp_client_get_type          (void);
@@ -155,7 +172,7 @@ GstRTSPResult         gst_rtsp_client_send_message      (GstRTSPClient * client,
  * A return value of #GST_RTSP_FILTER_KEEP will leave @sess untouched in
  * @client.
  *
- * A value of GST_RTSP_FILTER_REF will add @sess to the result #GList of
+ * A value of #GST_RTSP_FILTER_REF will add @sess to the result #GList of
  * gst_rtsp_client_session_filter().
  *
  * Returns: a #GstRTSPFilterResult.