/* * uhub - A tiny ADC p2p connection hub * Copyright (C) 2007-2009, Jan Vidar Krey * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * */ #ifndef HAVE_UHUB_NETWORK_CONNECTION_H #define HAVE_UHUB_NETWORK_CONNECTION_H #include "uhub.h" #define NET_EVENT_TIMEOUT 0x0001 #define NET_EVENT_READ 0x0002 #define NET_EVENT_WRITE 0x0004 #define NET_EVENT_SOCKERROR 0x1000 /* Socket error, closed */ #define NET_EVENT_CLOSED 0x2000 /* Socket closed */ struct net_connection; struct net_timer; struct net_backend; /** * Initialize the network backend. * Returns 1 on success, or 0 on failure. */ extern int net_backend_initialize(); /** * Shutdown the network connection backend. */ extern void net_backend_shutdown(); /** * Process the network backend. */ extern int net_backend_process(); typedef void (*net_connection_cb)(struct net_connection*, int event, void* ptr); typedef void (*net_timeout_cb)(struct net_timer*, void* ptr); extern void net_timer_initialize(struct net_timer* timer, net_timeout_cb callback, void* ptr); extern void net_timer_reset(struct net_timer* timer, int seconds); extern void net_timer_shutdown(struct net_timer* timer); extern int net_con_get_sd(struct net_connection* con); extern void* net_con_get_ptr(struct net_connection* con); extern struct net_connection* net_con_create(); extern void net_con_destroy(struct net_connection*); extern void net_con_initialize(struct net_connection* con, int sd, net_connection_cb callback, const void* ptr, int events); extern void net_con_reinitialize(struct net_connection* con, net_connection_cb callback, const void* ptr, int events); extern void net_con_update(struct net_connection* con, int events); /** * Close the connection. * This will ensure a connection is closed properly and will generate a NET_EVENT_DESTROYED event which indicates * that the con can safely be deleted (or set to NULL). * @returns 1 if the memory pointed to by con can be freed immediately, or 0 if it needs to go through the NET_EVENT_DESTROYED event. */ extern int net_con_close(struct net_connection* con); /** * Send data * * @return returns the number of bytes sent. * 0 if no data is sent, and this function should be called again (EWOULDBLOCK/EINTR) * <0 if an error occured, the negative number contains the error code. */ extern ssize_t net_con_send(struct net_connection* con, const void* buf, size_t len); /** * Receive data * * @return returns the number of bytes sent. * 0 if no data is sent, and this function should be called again (EWOULDBLOCK/EINTR) * <0 if an error occured, the negative number contains the error code. */ extern ssize_t net_con_recv(struct net_connection* con, void* buf, size_t len); /** * Receive data without removing them from the recv() buffer. * NOTE: This does not currently work for SSL connections after the SSL handshake has been * performed. */ extern ssize_t net_con_peek(struct net_connection* con, void* buf, size_t len); /** * Set timeout for connetion. * * @param seconds the number of seconds into the future. */ extern void net_con_set_timeout(struct net_connection* con, int seconds); extern void net_con_clear_timeout(struct net_connection* con); #ifdef SSL_SUPPORT /** * Start SSL_accept() */ extern ssize_t net_con_ssl_accept(struct net_connection*); /** * Start SSL_connect() */ extern ssize_t net_con_ssl_connect(struct net_connection*); enum net_con_ssl_mode { net_con_ssl_mode_server, net_con_ssl_mode_client, }; extern ssize_t net_con_ssl_handshake(struct net_connection* con, enum net_con_ssl_mode, void* ssl_ctx); #endif /* SSL_SUPPORT */ #endif /* HAVE_UHUB_NETWORK_CONNECTION_H */