}
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 void
+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);
ssl->lowconn = lowconn;
conn->layer = ssl;
conn->read = hc_conn_ssl_read;
hc_conn_set_callback (lowconn, hc_conn_ssl_watch, conn);
ssl_server_connect (conn);
}
+
+void hc_conn_set_driver_ssl_client (HCConn *conn, HCConn *lowconn)
+{
+ hc_conn_set_driver_ssl (conn, lowconn, 0);
+}