/* * JsonRpc-Cpp - JSON-RPC implementation. * Copyright (C) 2008-2009 Sebastien Vincent * * 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 . */ /** * \file jsonrpc_tcpserver.h * \brief JSON-RPC TCP server. * \author Sebastien Vincent */ #ifndef JSONRPC_TCPSERVER_H #define JSONRPC_TCPSERVER_H #include #include "jsonrpc_common.h" #include "jsonrpc_server.h" namespace Json { namespace Rpc { /** * \class TcpServer * \brief JSON-RPC TCP server implementation. */ class TcpServer : public Server { public: /** * \brief Constructor. * \param address network address or FQDN to bind * \param port local port to bind */ TcpServer(const std::string& address, uint16_t port); /** * \brief Destructor. */ virtual ~TcpServer(); /** * \brief Receive data from the network and process it. * \param fd socket descriptor to receive data * \return true if message has been correctly received, processed and * response sent, false otherwise (mainly send/recv error) * \note This method will blocked until data comes. */ virtual bool Recv(int fd); /** * \brief Wait message. * * This function do a select() on the socket and Process() immediately * the JSON-RPC message. * \param ms millisecond to wait (0 means infinite) */ virtual void WaitMessage(uint32_t ms); /** * \brief Put the TCP socket in LISTEN state. */ bool Listen() const; /** * \brief Accept a new client socket. * \return -1 if error, 0 otherwise */ bool Accept(); /** * \brief Close listen socket and all client sockets. */ void Close(); /** * \brief Get the list of clients. * \return list of clients */ const std::list GetClients() const; private: /** * \brief List of client sockets. */ std::list m_clients; /** * \brief List of disconnected sockets to be purged. */ std::list m_purge; }; } /* namespace Rpc */ } /* namespace Json */ #endif /* JSONRPC_TCPSERVER_H */