sync with 0.9.3
[claws.git] / src / common / socket.h
1 /*
2  * Sylpheed -- a GTK+ based, lightweight, and fast e-mail client
3  * Copyright (C) 1999-2003 Hiroyuki Yamamoto
4  *
5  * This program is free software; you can redistribute it and/or modify
6  * it under the terms of the GNU General Public License as published by
7  * the Free Software Foundation; either version 2 of the License, or
8  * (at your option) any later version.
9  *
10  * This program is distributed in the hope that it will be useful,
11  * but WITHOUT ANY WARRANTY; without even the implied warranty of
12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
13  * GNU General Public License for more details.
14  *
15  * You should have received a copy of the GNU General Public License
16  * along with this program; if not, write to the Free Software
17  * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
18  */
19
20 #ifndef __SOCKET_H__
21 #define __SOCKET_H__
22
23 #ifdef HAVE_CONFIG_H
24 #  include "config.h"
25 #endif
26
27 #include <glib.h>
28 #include <netdb.h>
29
30 typedef struct _SockInfo        SockInfo;
31
32 #if USE_OPENSSL
33 #  include "ssl.h"
34 #endif
35
36 typedef enum
37 {
38         CONN_READY,
39         CONN_LOOKUPSUCCESS,
40         CONN_ESTABLISHED,
41         CONN_LOOKUPFAILED,
42         CONN_FAILED,
43         CONN_DISCONNECTED,
44 } ConnectionState;
45
46 typedef gint (*SockConnectFunc)         (SockInfo       *sock,
47                                          gpointer        data);
48 typedef gboolean (*SockFunc)            (SockInfo       *sock,
49                                          GIOCondition    condition,
50                                          gpointer        data);
51
52 struct _SockInfo
53 {
54         gint sock;
55 #if USE_OPENSSL
56         SSL *ssl;
57 #endif
58         GIOChannel *sock_ch;
59
60         gchar *hostname;
61         gushort port;
62         ConnectionState state;
63         gpointer data;
64
65         SockFunc callback;
66         GIOCondition condition;
67 };
68
69 gint sock_set_io_timeout                (guint sec);
70
71 gint sock_set_nonblocking_mode          (SockInfo *sock, gboolean nonblock);
72 gboolean sock_is_nonblocking_mode       (SockInfo *sock);
73
74 guint sock_add_watch                    (SockInfo *sock, GIOCondition condition,
75                                          SockFunc func, gpointer data);
76
77 struct hostent *my_gethostbyname        (const gchar *hostname);
78
79 SockInfo *sock_connect                  (const gchar *hostname, gushort port);
80 SockInfo *sock_connect_cmd              (const gchar *hostname, const gchar *tunnelcmd);
81 gint sock_connect_async                 (const gchar *hostname, gushort port,
82                                          SockConnectFunc func, gpointer data);
83 gint sock_connect_async_cancel          (gint id);
84
85 /* Basic I/O functions */
86 gint sock_printf        (SockInfo *sock, const gchar *format, ...)
87                          G_GNUC_PRINTF(2, 3);
88 gint sock_read          (SockInfo *sock, gchar *buf, gint len);
89 gint sock_write         (SockInfo *sock, const gchar *buf, gint len);
90 gint sock_write_all     (SockInfo *sock, const gchar *buf, gint len);
91 gint sock_gets          (SockInfo *sock, gchar *buf, gint len);
92 gchar *sock_getline     (SockInfo *sock);
93 gint sock_puts          (SockInfo *sock, const gchar *buf);
94 gint sock_peek          (SockInfo *sock, gchar *buf, gint len);
95 gint sock_close         (SockInfo *sock);
96
97 /* Functions to directly work on FD.  They are needed for pipes */
98 gint fd_connect_unix    (const gchar *path);
99 gint fd_open_unix       (const gchar *path);
100 gint fd_accept          (gint sock);
101
102 gint fd_read            (gint sock, gchar *buf, gint len);
103 gint fd_write           (gint sock, const gchar *buf, gint len);
104 gint fd_write_all       (gint sock, const gchar *buf, gint len);
105 gint fd_gets            (gint sock, gchar *buf, gint len);
106 gint fd_getline         (gint sock, gchar **str);
107 gint fd_close           (gint sock);
108
109 /* Functions for SSL */
110 #if USE_OPENSSL
111 gint ssl_read           (SSL *ssl, gchar *buf, gint len);
112 gint ssl_write          (SSL *ssl, const gchar *buf, gint len);
113 gint ssl_write_all      (SSL *ssl, const gchar *buf, gint len);
114 gint ssl_gets           (SSL *ssl, gchar *buf, gint len);
115 gint ssl_getline        (SSL *ssl, gchar **str);
116 gint ssl_peek           (SSL *ssl, gchar *buf, gint len);
117 #endif
118
119 #endif /* __SOCKET_H__ */