add a "timeout" property, which gets passed from server to socket, and
[platform/upstream/libsoup.git] / libsoup / soup-socket.h
1 /* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
2 /*
3  * Copyright (C) 2000-2003, Ximian, Inc.
4  */
5
6 #ifndef SOUP_SOCKET_H
7 #define SOUP_SOCKET_H 1
8
9 #include <libsoup/soup-types.h>
10
11 #define SOUP_TYPE_SOCKET            (soup_socket_get_type ())
12 #define SOUP_SOCKET(obj)            (G_TYPE_CHECK_INSTANCE_CAST ((obj), SOUP_TYPE_SOCKET, SoupSocket))
13 #define SOUP_SOCKET_CLASS(klass)    (G_TYPE_CHECK_CLASS_CAST ((klass), SOUP_TYPE_SOCKET, SoupSocketClass))
14 #define SOUP_IS_SOCKET(obj)         (G_TYPE_CHECK_INSTANCE_TYPE ((obj), SOUP_TYPE_SOCKET))
15 #define SOUP_IS_SOCKET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((obj), SOUP_TYPE_SOCKET))
16 #define SOUP_SOCKET_GET_CLASS(obj)  (G_TYPE_INSTANCE_GET_CLASS ((obj), SOUP_TYPE_SOCKET, SoupSocketClass))
17
18 struct SoupSocket {
19         GObject parent;
20
21 };
22
23 typedef struct {
24         GObjectClass parent_class;
25
26         /* signals */
27         void (*connect_result) (SoupSocket *, guint);
28         void (*readable)       (SoupSocket *);
29         void (*writable)       (SoupSocket *);
30         void (*disconnected)   (SoupSocket *);
31
32         void (*new_connection) (SoupSocket *, SoupSocket *);
33 } SoupSocketClass;
34
35 #define SOUP_SOCKET_FLAG_NONBLOCKING "non-blocking"
36 #define SOUP_SOCKET_FLAG_NODELAY     "nodelay"
37 #define SOUP_SOCKET_FLAG_REUSEADDR   "reuseaddr"
38 #define SOUP_SOCKET_FLAG_CLOEXEC     "cloexec"
39 #define SOUP_SOCKET_IS_SERVER        "is-server"
40 #define SOUP_SOCKET_SSL_CREDENTIALS  "ssl-creds"
41 #define SOUP_SOCKET_ASYNC_CONTEXT    "async-context"
42 #define SOUP_SOCKET_TIMEOUT          "timeout"
43
44 /**
45  * SoupSocketCallback:
46  * @sock: the #SoupSocket
47  * @status: an HTTP status code indicating success or failure
48  * @user_data: the data passed to soup_socket_client_new_async()
49  *
50  * The callback function passed to soup_socket_client_new_async().
51  **/
52 typedef void (*SoupSocketCallback)            (SoupSocket         *sock,
53                                                guint               status,
54                                                gpointer            user_data);
55
56 /**
57  * SoupSocketListenerCallback:
58  * @listener: the listening #SoupSocket
59  * @sock: the newly-received #SoupSocket
60  * @user_data: the data passed to soup_socket_server_new().
61  *
62  * The callback function passed to soup_socket_server_new(), which
63  * receives new connections.
64  **/
65 typedef void (*SoupSocketListenerCallback)    (SoupSocket         *listener,
66                                                SoupSocket         *sock,
67                                                gpointer            user_data);
68
69 GType soup_socket_get_type (void);
70
71 SoupSocket    *soup_socket_new                (const char         *optname1,
72                                                ...) G_GNUC_NULL_TERMINATED;
73
74 guint          soup_socket_connect            (SoupSocket         *sock,
75                                                SoupAddress        *remote_addr);
76 gboolean       soup_socket_listen             (SoupSocket         *sock,
77                                                SoupAddress        *local_addr);
78 gboolean       soup_socket_start_ssl          (SoupSocket         *sock);
79 gboolean       soup_socket_start_proxy_ssl    (SoupSocket         *sock,
80                                                const char         *ssl_host);
81
82 void           soup_socket_disconnect         (SoupSocket         *sock);
83 gboolean       soup_socket_is_connected       (SoupSocket         *sock);
84
85 SoupSocket    *soup_socket_client_new_async   (const char         *hostname,
86                                                guint               port,
87                                                gpointer            ssl_creds,
88                                                SoupSocketCallback  callback,
89                                                gpointer            user_data);
90 SoupSocket    *soup_socket_client_new_sync    (const char         *hostname,
91                                                guint               port,
92                                                gpointer            ssl_creds,
93                                                guint              *status_ret);
94 SoupSocket    *soup_socket_server_new         (SoupAddress        *local_addr,
95                                                gpointer            ssl_creds,
96                                                SoupSocketListenerCallback callback,
97                                                gpointer            user_data);
98
99 SoupAddress   *soup_socket_get_local_address  (SoupSocket         *sock);
100 SoupAddress   *soup_socket_get_remote_address (SoupSocket         *sock);
101
102
103 /**
104  * SoupSocketIOStatus:
105  * @SOUP_SOCKET_OK: Success
106  * @SOUP_SOCKET_WOULD_BLOCK: Cannot read/write any more at this time
107  * @SOUP_SOCKET_EOF: End of file
108  * @SOUP_SOCKET_ERROR: Other error
109  *
110  * Return value from the #SoupSocket IO methods.
111  **/
112 typedef enum {
113         SOUP_SOCKET_OK,
114         SOUP_SOCKET_WOULD_BLOCK,
115         SOUP_SOCKET_EOF,
116         SOUP_SOCKET_ERROR
117 } SoupSocketIOStatus;
118
119 SoupSocketIOStatus  soup_socket_read       (SoupSocket         *sock,
120                                             gpointer            buffer,
121                                             gsize               len,
122                                             gsize              *nread);
123 SoupSocketIOStatus  soup_socket_read_until (SoupSocket         *sock,
124                                             gpointer            buffer,
125                                             gsize               len,
126                                             gconstpointer       boundary,
127                                             gsize               boundary_len,
128                                             gsize              *nread,
129                                             gboolean           *got_boundary);
130
131 SoupSocketIOStatus  soup_socket_write      (SoupSocket         *sock,
132                                             gconstpointer       buffer,
133                                             gsize               len,
134                                             gsize              *nwrote);
135
136
137 #endif /* SOUP_SOCKET_H */