Frameworks/libpurple.framework/Versions/0.6.2/Headers/httpconn.h
author Zachary West <zacw@adium.im>
Fri Aug 21 13:25:11 2009 -0700 (2009-08-21)
changeset 2592 e8d15275025e
parent 1739 Frameworks/libpurple.framework/Versions/0.6.0/Headers/httpconn.h@8b0daad9656c
permissions -rw-r--r--
im.pidgin.adium.1-4 at 267c6165e02e34318a1823960bd04c0639952f73
     1 /**
     2  * @file httpconn.h HTTP connection
     3  *
     4  * purple
     5  *
     6  * Purple is the legal property of its developers, whose names are too numerous
     7  * to list here.  Please refer to the COPYRIGHT file distributed with this
     8  * source distribution.
     9  *
    10  * This program is free software; you can redistribute it and/or modify
    11  * it under the terms of the GNU General Public License as published by
    12  * the Free Software Foundation; either version 2 of the License, or
    13  * (at your option) any later version.
    14  *
    15  * This program is distributed in the hope that it will be useful,
    16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
    17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
    18  * GNU General Public License for more details.
    19  *
    20  * You should have received a copy of the GNU General Public License
    21  * along with this program; if not, write to the Free Software
    22  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02111-1301  USA
    23  */
    24 #ifndef _MSN_HTTPCONN_H_
    25 #define _MSN_HTTPCONN_H_
    26 
    27 typedef struct _MsnHttpConn MsnHttpConn;
    28 
    29 #include "circbuffer.h"
    30 #include "servconn.h"
    31 
    32 /**
    33  * An HTTP Connection.
    34  */
    35 struct _MsnHttpConn
    36 {
    37 	MsnSession *session; /**< The MSN Session. */
    38 	MsnServConn *servconn; /**< The connection object. */
    39 
    40 	PurpleProxyConnectData *connect_data;
    41 
    42 	char *full_session_id; /**< The full session id. */
    43 	char *session_id; /**< The trimmed session id. */
    44 
    45 	int timer; /**< The timer for polling. */
    46 
    47 	gboolean waiting_response; /**< The flag that states if we are waiting
    48 								 a response from the server. */
    49 	gboolean connected;        /**< The flag that states if the connection is on. */
    50 	gboolean virgin;           /**< The flag that states if this connection
    51 								 should specify the host (not gateway) to
    52 								 connect to. */
    53 
    54 	char *host; /**< The HTTP gateway host. */
    55 	GList *queue; /**< The queue of data chunks to write. */
    56 
    57 	int fd; /**< The connection's file descriptor. */
    58 	guint inpa; /**< The connection's input handler. */
    59 
    60 	char *rx_buf; /**< The receive buffer. */
    61 	int rx_len; /**< The receive buffer length. */
    62 
    63 	PurpleCircBuffer *tx_buf;
    64 	guint tx_handler;
    65 };
    66 
    67 /**
    68  * Creates a new HTTP connection object.
    69  *
    70  * @param servconn The connection object.
    71  *
    72  * @return The new object.
    73  */
    74 MsnHttpConn *msn_httpconn_new(MsnServConn *servconn);
    75 
    76 /**
    77  * Destroys an HTTP connection object.
    78  *
    79  * @param httpconn The HTTP connection object.
    80  */
    81 void msn_httpconn_destroy(MsnHttpConn *httpconn);
    82 
    83 /**
    84  * Writes a chunk of data to the HTTP connection.
    85  *
    86  * @param servconn    The server connection.
    87  * @param data        The data to write.
    88  * @param data_len    The size of the data to write.
    89  *
    90  * @return The number of bytes written.
    91  */
    92 gssize msn_httpconn_write(MsnHttpConn *httpconn, const char *data, size_t data_len);
    93 
    94 /**
    95  * Connects the HTTP connection object to a host.
    96  *
    97  * @param httpconn The HTTP connection object.
    98  * @param host The host to connect to.
    99  * @param port The port to connect to.
   100  */
   101 gboolean msn_httpconn_connect(MsnHttpConn *httpconn,
   102 							  const char *host, int port);
   103 
   104 /**
   105  * Disconnects the HTTP connection object.
   106  *
   107  * @param httpconn The HTTP connection object.
   108  */
   109 void msn_httpconn_disconnect(MsnHttpConn *httpconn);
   110 
   111 #endif /* _MSN_HTTPCONN_H_ */