add/fix gtk-doc comments, make functions match prototypes, etc
[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_IS_SERVER        "is-server"
39 #define SOUP_SOCKET_SSL_CREDENTIALS  "ssl-creds"
40
41 /**
42  * SoupSocketCallback:
43  * @sock: the #SoupSocket
44  * @status: an HTTP status code indicating success or failure
45  * @user_data: the data passed to soup_socket_client_new_async()
46  *
47  * The callback function passed to soup_socket_client_new_async().
48  **/
49 typedef void (*SoupSocketCallback)            (SoupSocket         *sock,
50                                                guint               status,
51                                                gpointer            user_data);
52
53 /**
54  * SoupSocketListenerCallback:
55  * @listener: the listening #SoupSocket
56  * @sock: the newly-received #SoupSocket
57  * @user_data: the data passed to soup_socket_server_new().
58  *
59  * The callback function passed to soup_socket_server_new(), which
60  * receives new connections.
61  **/
62 typedef void (*SoupSocketListenerCallback)    (SoupSocket         *listener,
63                                                SoupSocket         *sock,
64                                                gpointer            user_data);
65
66 GType soup_socket_get_type (void);
67
68 SoupSocket    *soup_socket_new                (const char         *optname1,
69                                                ...);
70
71 guint          soup_socket_connect            (SoupSocket         *sock,
72                                                SoupAddress        *remote_addr);
73 gboolean       soup_socket_listen             (SoupSocket         *sock,
74                                                SoupAddress        *local_addr);
75 gboolean       soup_socket_start_ssl          (SoupSocket         *sock);
76 gboolean       soup_socket_start_proxy_ssl    (SoupSocket         *sock,
77                                                const char         *ssl_host);
78
79 void           soup_socket_disconnect         (SoupSocket         *sock);
80 gboolean       soup_socket_is_connected       (SoupSocket         *sock);
81
82 SoupSocket    *soup_socket_client_new_async   (const char         *hostname,
83                                                guint               port,
84                                                gpointer            ssl_creds,
85                                                SoupSocketCallback  callback,
86                                                gpointer            user_data);
87 SoupSocket    *soup_socket_client_new_sync    (const char         *hostname,
88                                                guint               port,
89                                                gpointer            ssl_creds,
90                                                guint              *status_ret);
91 SoupSocket    *soup_socket_server_new         (SoupAddress        *local_addr,
92                                                gpointer            ssl_creds,
93                                                SoupSocketListenerCallback callback,
94                                                gpointer            user_data);
95
96 SoupAddress   *soup_socket_get_local_address  (SoupSocket         *sock);
97 SoupAddress   *soup_socket_get_remote_address (SoupSocket         *sock);
98
99
100 /**
101  * SoupSocketIOStatus:
102  * @SOUP_SOCKET_OK: Success
103  * @SOUP_SOCKET_WOULD_BLOCK: Cannot read/write any more at this time
104  * @SOUP_SOCKET_EOF: End of file
105  * @SOUP_SOCKET_ERROR: Other error
106  *
107  * Return value from the #SoupSocket IO methods.
108  **/
109 typedef enum {
110         SOUP_SOCKET_OK,
111         SOUP_SOCKET_WOULD_BLOCK,
112         SOUP_SOCKET_EOF,
113         SOUP_SOCKET_ERROR
114 } SoupSocketIOStatus;
115
116 SoupSocketIOStatus  soup_socket_read       (SoupSocket         *sock,
117                                             gpointer            buffer,
118                                             gsize               len,
119                                             gsize              *nread);
120 SoupSocketIOStatus  soup_socket_read_until (SoupSocket         *sock,
121                                             gpointer            buffer,
122                                             gsize               len,
123                                             gconstpointer       boundary,
124                                             gsize               boundary_len,
125                                             gsize              *nread,
126                                             gboolean           *got_boundary);
127
128 SoupSocketIOStatus  soup_socket_write      (SoupSocket         *sock,
129                                             gconstpointer       buffer,
130                                             gsize               len,
131                                             gsize              *nwrote);
132
133
134 #endif /* SOUP_SOCKET_H */