123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224 |
- /* GStreamer
- * Copyright (C) <2005,2009> Wim Taymans <[email protected]>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Library General Public License for more details.
- *
- * You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the
- * Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
- * Boston, MA 02110-1301, USA.
- */
- /*
- * Unless otherwise indicated, Source Code is licensed under MIT license.
- * See further explanation attached in License Statement (distributed in the file
- * LICENSE).
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy of
- * this software and associated documentation files (the "Software"), to deal in
- * the Software without restriction, including without limitation the rights to
- * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies
- * of the Software, and to permit persons to whom the Software is furnished to do
- * so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- */
- #ifndef __GST_RTSP_CONNECTION_H__
- #define __GST_RTSP_CONNECTION_H__
- #include <glib.h>
- #include <gst/gstconfig.h>
- #include <gst/rtsp/gstrtspdefs.h>
- #include <gst/rtsp/gstrtspurl.h>
- #include <gst/rtsp/gstrtspmessage.h>
- #include <gio/gio.h>
- G_BEGIN_DECLS
- /**
- * GstRTSPConnection:
- *
- * Opaque RTSP connection object.
- */
- typedef struct _GstRTSPConnection GstRTSPConnection;
- /* opening/closing a connection */
- GstRTSPResult gst_rtsp_connection_create (const GstRTSPUrl *url, GstRTSPConnection **conn);
- GstRTSPResult gst_rtsp_connection_create_from_socket (GSocket * socket,
- const gchar * ip,
- guint16 port,
- const gchar * initial_buffer,
- GstRTSPConnection ** conn);
- GstRTSPResult gst_rtsp_connection_accept (GSocket *socket, GstRTSPConnection **conn, GCancellable *cancellable);
- GstRTSPResult gst_rtsp_connection_connect (GstRTSPConnection *conn, GTimeVal *timeout);
- GstRTSPResult gst_rtsp_connection_close (GstRTSPConnection *conn);
- GstRTSPResult gst_rtsp_connection_free (GstRTSPConnection *conn);
- /* TLS connections */
- GTlsConnection * gst_rtsp_connection_get_tls (GstRTSPConnection * conn, GError ** error);
- gboolean gst_rtsp_connection_set_tls_validation_flags (GstRTSPConnection * conn, GTlsCertificateFlags flags);
- GTlsCertificateFlags gst_rtsp_connection_get_tls_validation_flags (GstRTSPConnection * conn);
- void gst_rtsp_connection_set_tls_database (GstRTSPConnection * conn, GTlsDatabase * database);
- GTlsDatabase * gst_rtsp_connection_get_tls_database (GstRTSPConnection * conn);
- /* sending/receiving raw bytes */
- GstRTSPResult gst_rtsp_connection_read (GstRTSPConnection * conn, guint8 * data,
- guint size, GTimeVal * timeout);
- GstRTSPResult gst_rtsp_connection_write (GstRTSPConnection * conn, const guint8 * data,
- guint size, GTimeVal * timeout);
- /* sending/receiving messages */
- GstRTSPResult gst_rtsp_connection_send (GstRTSPConnection *conn, GstRTSPMessage *message,
- GTimeVal *timeout);
- GstRTSPResult gst_rtsp_connection_receive (GstRTSPConnection *conn, GstRTSPMessage *message,
- GTimeVal *timeout);
- /* status management */
- GstRTSPResult gst_rtsp_connection_poll (GstRTSPConnection *conn, GstRTSPEvent events,
- GstRTSPEvent *revents, GTimeVal *timeout);
- /* reset the timeout */
- GstRTSPResult gst_rtsp_connection_next_timeout (GstRTSPConnection *conn, GTimeVal *timeout);
- GstRTSPResult gst_rtsp_connection_reset_timeout (GstRTSPConnection *conn);
- /* flushing state */
- GstRTSPResult gst_rtsp_connection_flush (GstRTSPConnection *conn, gboolean flush);
- /* HTTP proxy support */
- GstRTSPResult gst_rtsp_connection_set_proxy (GstRTSPConnection *conn,
- const gchar *host, guint port);
- /* configure authentication data */
- GstRTSPResult gst_rtsp_connection_set_auth (GstRTSPConnection *conn, GstRTSPAuthMethod method,
- const gchar *user, const gchar *pass);
- void gst_rtsp_connection_set_auth_param (GstRTSPConnection *conn,
- const gchar * param,
- const gchar *value);
- void gst_rtsp_connection_clear_auth_params (GstRTSPConnection *conn);
- /* configure DSCP */
- GstRTSPResult gst_rtsp_connection_set_qos_dscp (GstRTSPConnection *conn,
- guint qos_dscp);
- /* accessors */
- GstRTSPUrl * gst_rtsp_connection_get_url (const GstRTSPConnection *conn);
- const gchar * gst_rtsp_connection_get_ip (const GstRTSPConnection *conn);
- void gst_rtsp_connection_set_ip (GstRTSPConnection *conn, const gchar *ip);
- GSocket * gst_rtsp_connection_get_read_socket (const GstRTSPConnection *conn);
- GSocket * gst_rtsp_connection_get_write_socket (const GstRTSPConnection *conn);
- void gst_rtsp_connection_set_http_mode (GstRTSPConnection *conn,
- gboolean enable);
- /* tunneling */
- void gst_rtsp_connection_set_tunneled (GstRTSPConnection *conn, gboolean tunneled);
- gboolean gst_rtsp_connection_is_tunneled (const GstRTSPConnection *conn);
- const gchar * gst_rtsp_connection_get_tunnelid (const GstRTSPConnection *conn);
- GstRTSPResult gst_rtsp_connection_do_tunnel (GstRTSPConnection *conn, GstRTSPConnection *conn2);
- void gst_rtsp_connection_set_remember_session_id (GstRTSPConnection *conn, gboolean remember);
- gboolean gst_rtsp_connection_get_remember_session_id (GstRTSPConnection *conn);
- /* async IO */
- /**
- * GstRTSPWatch:
- *
- * Opaque RTSP watch object that can be used for asynchronous RTSP
- * operations.
- */
- typedef struct _GstRTSPWatch GstRTSPWatch;
- /**
- * GstRTSPWatchFuncs:
- * @message_received: callback when a message was received
- * @message_sent: callback when a message was sent
- * @closed: callback when the connection is closed
- * @error: callback when an error occured
- * @tunnel_start: a client started a tunneled connection. The tunnelid of the
- * connection must be saved.
- * @tunnel_complete: a client finished a tunneled connection. In this callback
- * you usually pair the tunnelid of this connection with the saved one using
- * gst_rtsp_connection_do_tunnel().
- * @error_full: callback when an error occured with more information than
- * the @error callback.
- * @tunnel_lost: callback when the post connection of a tunnel is closed.
- * @tunnel_http_response: callback when an HTTP response to the GET request
- * is about to be sent for a tunneled connection. The response can be
- * modified in the callback. Since 1.4.
- *
- * Callback functions from a #GstRTSPWatch.
- */
- typedef struct {
- GstRTSPResult (*message_received) (GstRTSPWatch *watch, GstRTSPMessage *message,
- gpointer user_data);
- GstRTSPResult (*message_sent) (GstRTSPWatch *watch, guint id,
- gpointer user_data);
- GstRTSPResult (*closed) (GstRTSPWatch *watch, gpointer user_data);
- GstRTSPResult (*error) (GstRTSPWatch *watch, GstRTSPResult result,
- gpointer user_data);
- GstRTSPStatusCode (*tunnel_start) (GstRTSPWatch *watch, gpointer user_data);
- GstRTSPResult (*tunnel_complete) (GstRTSPWatch *watch, gpointer user_data);
- GstRTSPResult (*error_full) (GstRTSPWatch *watch, GstRTSPResult result,
- GstRTSPMessage *message, guint id,
- gpointer user_data);
- GstRTSPResult (*tunnel_lost) (GstRTSPWatch *watch, gpointer user_data);
- GstRTSPResult (*tunnel_http_response) (GstRTSPWatch *watch,
- GstRTSPMessage *request,
- GstRTSPMessage *response,
- gpointer user_data);
- /*< private >*/
- gpointer _gst_reserved[GST_PADDING-1];
- } GstRTSPWatchFuncs;
- GstRTSPWatch * gst_rtsp_watch_new (GstRTSPConnection *conn,
- GstRTSPWatchFuncs *funcs,
- gpointer user_data,
- GDestroyNotify notify);
- void gst_rtsp_watch_reset (GstRTSPWatch *watch);
- void gst_rtsp_watch_unref (GstRTSPWatch *watch);
- guint gst_rtsp_watch_attach (GstRTSPWatch *watch,
- GMainContext *context);
- void gst_rtsp_watch_set_send_backlog (GstRTSPWatch *watch,
- gsize bytes, guint messages);
- void gst_rtsp_watch_get_send_backlog (GstRTSPWatch *watch,
- gsize *bytes, guint *messages);
- GstRTSPResult gst_rtsp_watch_write_data (GstRTSPWatch *watch,
- const guint8 *data,
- guint size, guint *id);
- GstRTSPResult gst_rtsp_watch_send_message (GstRTSPWatch *watch,
- GstRTSPMessage *message,
- guint *id);
- GstRTSPResult gst_rtsp_watch_wait_backlog (GstRTSPWatch * watch,
- GTimeVal *timeout);
- void gst_rtsp_watch_set_flushing (GstRTSPWatch * watch,
- gboolean flush);
- G_END_DECLS
- #endif /* __GST_RTSP_CONNECTION_H__ */
|