#include "pop.h"
#include "hcconn.h"
+#include "hcconn_ssl.h"
#include "tcp_connect.h"
#define CONFFILE SYSCONFDIR "/popproxy.conf"
int fd;
HCConn *conn;
HCConn *ssl_conn;
+ int r;
fd = hc_tcp_connect (server, port);
if (fd < 0)
{
}
conn = hc_conn_new (NULL, NULL);
ssl_conn = hc_conn_new (NULL, NULL);
- hc_conn_set_driver_channel (conn, fd);
- hc_conn_set_driver_ssl (ssl_conn, conn);
+ r = hc_conn_set_driver_channel (conn, fd);
+ if (r != 0)
+ {
+ hc_conn_close (ssl_conn);
+ hc_conn_close (conn);
+ close (fd);
+ return NULL;
+ }
+ r = hc_conn_set_driver_ssl_client (ssl_conn, conn);
+ if (r != 0)
+ {
+ hc_conn_close (ssl_conn);
+ hc_conn_close (conn);
+ return NULL;
+ }
return ssl_conn;
}
+static HCConn *
+client_conn_new (int fd)
+{
+ HCConn *conn;
+ HCConn *ssl_conn;
+ HCConn *pop_conn;
+ int r;
+ conn = hc_conn_new (NULL, NULL);
+ r = hc_conn_set_driver_channel (conn, fd);
+ if (r != 0)
+ {
+ hc_conn_close (conn);
+ close (fd);
+ return NULL;
+ }
+ ssl_conn = hc_conn_new (NULL, NULL);
+ hc_conn_set_driver_ssl_server (ssl_conn, conn);
+ if (r != 0)
+ {
+ hc_conn_close (ssl_conn);
+ hc_conn_close (conn);
+ return NULL;
+ }
+ pop_conn = hc_conn_new (NULL, NULL);
+ r = hc_conn_set_driver_pop (pop_conn, conn);
+ if (r != 0)
+ {
+ hc_conn_close (pop_conn);
+ hc_conn_close (ssl_conn);
+ return NULL;
+ }
+ return pop_conn;
+}
+
static void
push_other (HCConn *conn, HCEvent event, gpointer data)
{
static void
new_client (int fd, struct sockaddr *addr, socklen_t saddr, gpointer data)
{
- HCConn *conn;
+ HCConn *client_conn;
HCConn *server_conn;
struct pop_address *address = data;
if (fd < 0)
g_critical ("Server has received an error event.");
return;
}
+
+ /* FIXME: Should be independent of address type. */
g_message ("Received connection from %s.",
inet_ntoa (((struct sockaddr_in *) addr)->sin_addr));
{
return;
}
+ client_conn = client_conn_new (fd);
+ if (client_conn == NULL)
+ {
+ hc_conn_close (server_conn);
+ return;
+ }
- conn = hc_conn_new (NULL, NULL);
- hc_conn_set_driver_channel (conn, fd);
-
- hc_conn_set_callback (conn, push_other, server_conn);
- hc_conn_set_callback (server_conn, push_other, conn);
+ hc_conn_set_callback (client_conn, push_other, server_conn);
+ hc_conn_set_callback (server_conn, push_other, client_conn);
}