}
static struct ssl_data *
-ssl_data_new_client (void)
+ssl_data_new (int server)
{
struct ssl_data *ssl;
+ if (server)
+ return NULL;
ssl = g_slice_new (struct ssl_data);
ssl_client_session_new (&ssl->session);
ssl->buffer = g_string_sized_new (4096);
}
}
-void
-hc_conn_set_driver_ssl_client (HCConn *conn, HCConn *lowconn)
+static int
+hc_conn_set_driver_ssl (HCConn *conn, HCConn *lowconn, int server)
{
- struct ssl_data *ssl = ssl_data_new_client ();
+ struct ssl_data *ssl;
+ ssl = ssl_data_new (server);
+ if (ssl == NULL)
+ return -1;
ssl->lowconn = lowconn;
conn->layer = ssl;
conn->read = hc_conn_ssl_read;
conn->close = hc_conn_ssl_close;
hc_conn_set_callback (lowconn, hc_conn_ssl_watch, conn);
ssl_server_connect (conn);
+ return 0;
+}
+
+int
+hc_conn_set_driver_ssl_client (HCConn *conn, HCConn *lowconn)
+{
+ return hc_conn_set_driver_ssl (conn, lowconn, 0);
}