/* * ConnectionRequestHandlerGroup.cpp * * Copyright (C) 2009 Matthias Schiffer * * 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 . */ #include "ConnectionRequestHandlerGroup.h" #include "../Application.h" #include "../ConnectionManager.h" #include namespace Mad { namespace Server { namespace RequestHandlers { void ConnectionRequestHandlerGroup::handleDaemonListRequest(boost::shared_ptr packet _UNUSED_PARAMETER_, Common::XmlPacket *ret, Common::Connection *connection _UNUSED_PARAMETER_) { // TODO Require authentication ret->setType("OK"); ret->addList("hosts"); std::vector daemons = application->getConnectionManager()->getDaemonList(); for(std::vector::iterator daemon = daemons.begin(); daemon != daemons.end(); ++daemon) { (*ret)["hosts"].addEntry(); (*ret)["hosts"].back().add("name", daemon->getName()); (*ret)["hosts"].back().add("address", daemon->getIP()); (*ret)["hosts"].back().add("state", daemon->getState()); } } void ConnectionRequestHandlerGroup::handleIdentifyRequest(boost::shared_ptr packet, Common::XmlPacket *ret, Common::Connection *connection) { if((*packet)["hostname"].isEmpty()) application->getConnectionManager()->identifyClientConnection(connection); else application->getConnectionManager()->identifyDaemonConnection(connection, (*packet)["hostname"]); ret->setType("OK"); } void ConnectionRequestHandlerGroup::handleLogRequest(boost::shared_ptr packet, Common::XmlPacket *ret, Common::Connection *connection) { // TODO Require authentication try { application->getLogManager()->log((*packet)["category"], (*packet)["level"], (*packet)["timestamp"], (*packet)["message"], application->getConnectionManager()->getDaemonName(connection)); } catch(Core::Exception &e) { application->logf(Core::LoggerBase::ERROR, "Can't determine daemon name: %s", e.strerror().c_str()); } ret->setType("OK"); } ConnectionRequestHandlerGroup::ConnectionRequestHandlerGroup(Application *application0) : application(application0) { registerHandler("ListHosts", boost::bind(&ConnectionRequestHandlerGroup::handleDaemonListRequest, this, _1, _2, _3)); registerHandler("Identify", boost::bind(&ConnectionRequestHandlerGroup::handleIdentifyRequest, this, _1, _2, _3)); registerHandler("Log", boost::bind(&ConnectionRequestHandlerGroup::handleLogRequest, this, _1, _2, _3)); } } } }