diff --git a/include/TcpConnection.hpp b/include/TcpConnection.hpp index e4826bb..f350231 100644 --- a/include/TcpConnection.hpp +++ b/include/TcpConnection.hpp @@ -13,9 +13,11 @@ class TcpConnection : public StreamConnection { public: - TcpConnection ( const int socket, - Message *message, - const size_t bufferLength = 1024 ); + enum State { + OPEN, + CLOSED + }; + TcpConnection ( const std::string host, const std::string port, @@ -32,14 +34,23 @@ public: bool send( const void* message, const size_t length ); bool receive(); - int getSocket() const; - bool bind(); bool listen( const int maxPendingQueueLen = 64 ); - int accept(); + bool accept(int &client_socket); + + int getSocket() const; + void setState(const State state); + + bool closed() const; + Message *getMessage() const; + size_t getBufferLength() const; private: + TcpConnection ( const int socket, + Message *message, + const size_t bufferLength = 1024 ); + TcpConnection(const TcpConnection&); TcpConnection& operator=(const TcpConnection&); @@ -47,6 +58,7 @@ private: Message *m_message; unsigned char *m_buffer; size_t m_bufferLength; + State m_state; }; diff --git a/src/TcpConnection.cpp b/src/TcpConnection.cpp index 5879de4..f039bb1 100644 --- a/src/TcpConnection.cpp +++ b/src/TcpConnection.cpp @@ -6,27 +6,6 @@ #include "AddrInfo.hpp" -TcpConnection::TcpConnection ( const int socket, - Message *message, - const size_t bufferLength ) - : StreamConnection("invalid", "invalid") - , m_socket(socket) - , m_message(message) - , m_buffer(0) - , m_bufferLength(bufferLength) -{ - TRACE; - - std::string host, port; - m_socket.getPeerName(host, port); - setHost(host); - setPort(port); - - m_buffer = new unsigned char[m_bufferLength]; - m_message->setConnection(this); -} - - TcpConnection::TcpConnection ( const std::string host, const std::string port, Message *message, @@ -36,6 +15,7 @@ TcpConnection::TcpConnection ( const std::string host, , m_message(message) , m_buffer(0) , m_bufferLength(bufferLength) + , m_state(CLOSED) { TRACE; m_socket.createSocket(); @@ -47,18 +27,21 @@ TcpConnection::TcpConnection ( const std::string host, TcpConnection::~TcpConnection() { TRACE; - disconnect(); - delete m_buffer; + + if (m_state == OPEN) + disconnect(); + + delete[] m_buffer; } Connection* TcpConnection::clone(const int socket) { - Connection *conn = new TcpConnection(socket, - m_message->clone(), - m_bufferLength ); + TcpConnection *tcpConnection = new TcpConnection(socket, + m_message->clone(), + m_bufferLength ); - return conn; + return tcpConnection; } @@ -75,6 +58,16 @@ bool TcpConnection::connect() if (!m_socket.connect(addrInfo[0])) return false; + std::string address, service; + if ( AddrInfo::convertNameInfo( addrInfo[0], address, service) ) { + LOG_BEGIN(Logger::INFO) + LOG_PROP("Host", address) + LOG_PROP("Port", service) + LOG_PROP("Socket", m_socket.getSocket()) + LOG_END("Connected to peer."); + } + + m_state = OPEN; return true; } @@ -92,6 +85,13 @@ bool TcpConnection::bind() if (!m_socket.bind(addrInfo[0])) return false; + std::string address, service; + if ( AddrInfo::convertNameInfo( addrInfo[0], address, service) ) { + LOG_BEGIN(Logger::INFO) + LOG_PROP("Host", address) + LOG_PROP("Port", service) + LOG_END("Binded to socket."); + } return true; } @@ -99,34 +99,27 @@ bool TcpConnection::bind() bool TcpConnection::listen( const int maxPendingQueueLen ) { TRACE; - return m_socket.listen( maxPendingQueueLen ); + + if (m_socket.listen(maxPendingQueueLen)) { + m_state = OPEN; + return true; + } + + return false; } -int TcpConnection::accept() +bool TcpConnection::accept(int &client_socket) { TRACE; - sockaddr clientAddr; - socklen_t clientAddrLen; - - /// @todo move accept to Socket - int client_socket = ::accept( getSocket(), &clientAddr, &clientAddrLen ) ; - - if ( client_socket == -1 ) { - LOG( Logger::ERR, errnoToString("ERROR accepting. ").c_str() ); - return -1; - } - - return client_socket; + return m_socket.accept(client_socket); } bool TcpConnection::disconnect() { TRACE; -// if ( getSocket() == -1 ) -// return false; - + m_state = CLOSED; return m_socket.closeSocket(); } @@ -143,17 +136,24 @@ bool TcpConnection::receive() TRACE; ssize_t length; - if ( !m_socket.receive(m_buffer, m_bufferLength, &length) ) { - if (length == 0) { - LOG( Logger::INFO, std::string("Connection closed by "). - append(m_host).append(":").append(TToStr(m_port)).c_str() ); - } + if (!m_socket.receive(m_buffer, m_bufferLength, &length)) + return false; + + if (length == 0) { + LOG_BEGIN(Logger::INFO) + LOG_PROP("Host", m_host) + LOG_PROP("Port", m_port) + LOG_PROP("Socket", m_socket.getSocket()) + LOG_END("Connection closed by peer."); return false; } - LOG ( Logger::DEBUG, std::string("Received: "). - append(TToStr(length)).append(" bytes from: "). - append(m_host).append(":").append(TToStr(m_port)).c_str() ); + LOG_BEGIN(Logger::INFO) + LOG_PROP("Host", m_host) + LOG_PROP("Port", m_port) + LOG_PROP("Socket", m_socket.getSocket()) + LOG_PROP("Bytes", length) + LOG_END("Received message from peer."); return m_message->buildMessage( (void*)m_buffer, (size_t)length); } @@ -162,6 +162,55 @@ bool TcpConnection::receive() int TcpConnection::getSocket() const { TRACE; - return m_socket.getSocket(); } + + +void TcpConnection::setState(const State state) +{ + TRACE; + m_state = state; +} + + +bool TcpConnection::closed() const +{ + TRACE; + return m_state == CLOSED; +} + + +Message* TcpConnection::getMessage() const +{ + TRACE; + return m_message; +} + + +size_t TcpConnection::getBufferLength() const +{ + TRACE; + return m_bufferLength; +} + + +TcpConnection::TcpConnection ( const int socket, + Message *message, + const size_t bufferLength ) + : StreamConnection("invalid", "invalid") + , m_socket(socket) + , m_message(message) + , m_buffer(0) + , m_bufferLength(bufferLength) + , m_state(OPEN) +{ + TRACE; + + std::string host, port; + m_socket.getPeerName(host, port); + setHost(host); + setPort(port); + + m_buffer = new unsigned char[m_bufferLength]; + m_message->setConnection(this); +}