#ifndef CONNECTION_HPP #define CONNECTION_HPP #include "Logger.hpp" #include "Common.hpp" #include "Socket.hpp" #include "Message.hpp" #include /** @todo make connection an iface and this class shall be a TcpConnection, * inherited from connection */ class Connection { public: Connection ( const int socket, Message *message, const size_t bufferLength = 1024 ) : m_socket(socket) , m_host() , m_port() , m_message(message) , m_buffer(0) , m_bufferLength(bufferLength) { TRACE; m_socket.getPeerName(m_host, m_port); m_buffer = new unsigned char[m_bufferLength]; } Connection ( const std::string host, const std::string port, Message *message, const size_t bufferLength = 1024 ) : m_socket(AF_INET, SOCK_STREAM) , m_host(host) , m_port(port) , m_message(message) , m_buffer(0) , m_bufferLength(bufferLength) { TRACE; m_socket.createSocket(); m_buffer = new unsigned char[m_bufferLength]; } virtual ~Connection() { TRACE; m_socket.closeSocket(); delete[] m_buffer; } Connection* create(const int socket) { TRACE; Connection *conn = new Connection( socket, m_message->clone(), m_bufferLength); conn->m_message->setConnection(conn); return conn; } bool connectToHost() { TRACE; return m_socket.connectToHost(m_host, m_port); } bool bindToHost() { TRACE; return m_socket.bindToHost(m_host, m_port); } bool listen( const int maxPendingQueueLen = 64 ) { TRACE; return m_socket.listen( maxPendingQueueLen ); } void closeConnection() { TRACE; m_socket.closeSocket(); } bool send( const void* message, const size_t length ) { TRACE; return m_socket.send( message, length ); } bool receive() { TRACE; ssize_t length; if ( !m_socket.receive(m_buffer, m_bufferLength, &length) ) { if (length == -1) { LOG( Logger::ERR, errnoToString("ERROR reading from socket. ").c_str() ); } else if (length == 0) { LOG( Logger::INFO, std::string("Connection closed by "). append(m_host).append(":").append(m_port).c_str() ); } return false; } LOG ( Logger::DEBUG, std::string("Received: "). append(TToStr(length)).append(" bytes from: "). append(m_host).append(":").append(m_port).c_str() ); return m_message->buildMessage( (void*)m_buffer, (size_t)length); } int getSocket() const { TRACE; return m_socket.getSocket(); } std::string getHost() const { TRACE; return m_host; } std::string getPort() const { TRACE; return m_port; } private: Connection(const Connection&); Connection& operator=(const Connection&); Socket m_socket; std::string m_host; std::string m_port; Message *m_message; unsigned char *m_buffer; size_t m_bufferLength; }; #endif // CONNECTION_HPP