/* */ #include "HttpListenCommand.h" #include "DownloadEngine.h" #include "RecoverableException.h" #include "message.h" #include "Logger.h" #include "SocketCore.h" #include "HttpServerCommand.h" #include "CUIDCounter.h" #include "RequestGroupMan.h" #include "FileEntry.h" namespace aria2 { HttpListenCommand::HttpListenCommand(int32_t cuid, DownloadEngine* e): Command(cuid),_e(e) {} HttpListenCommand::~HttpListenCommand() { if(!_serverSocket.isNull()) { _e->deleteSocketForReadCheck(_serverSocket, this); } } bool HttpListenCommand::execute() { if(_e->_requestGroupMan->downloadFinished() || _e->isHaltRequested()) { return true; } try { if(_serverSocket->isReadable(0)) { SharedHandle socket(_serverSocket->acceptConnection()); socket->setNonBlockingMode(); std::pair peerInfo; socket->getPeerInfo(peerInfo); logger->info("XML-RPC: Accepted the connection from %s:%u.", peerInfo.first.c_str(), peerInfo.second); HttpServerCommand* c = new HttpServerCommand(_e->newCUID(), _e, socket); _e->setNoWait(true); _e->commands.push_back(c); } } catch(RecoverableException& e) { logger->debug(MSG_ACCEPT_FAILURE, _e, cuid); } _e->commands.push_back(this); return false; } bool HttpListenCommand::bindPort(uint16_t port) { if(!_serverSocket.isNull()) { _e->deleteSocketForReadCheck(_serverSocket, this); } _serverSocket.reset(new SocketCore()); logger->info("CUID#%d - Setting up HttpListenCommand", cuid); try { _serverSocket->bind(port); _serverSocket->beginListen(); _serverSocket->setNonBlockingMode(); logger->info(MSG_LISTENING_PORT, cuid, port); _e->addSocketForReadCheck(_serverSocket, this); return true; } catch(RecoverableException& e) { logger->error(MSG_BIND_FAILURE, e, cuid, port); if(!_serverSocket.isNull()) { _e->deleteSocketForReadCheck(_serverSocket, this); } _serverSocket->closeConnection(); } return false; } } // namespace aria2