/* * 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 Lesser 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 Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License along * with this program. If not, see . */ #include "ConnectionRequestHandlerGroup.h" #include "../Application.h" #include "../ConnectionManager.h" #include #include #include namespace Mad { namespace Server { namespace RequestHandlers { void ConnectionRequestHandlerGroup::handleAuthMethodRequest(boost::shared_ptr /*packet*/, Common::XmlPacket *ret, Common::Connection* /*connection*/) { ret->setType("OK"); Common::XmlPacket::List *list = ret->createList("methods"); const std::vector &methods = application->getAuthManager()->getMethods(); for(std::vector::const_iterator method = methods.begin(); method != methods.end(); ++method) { Common::XmlPacket::List::iterator entry = list->addEntry(); entry->set("name", *method); } } void ConnectionRequestHandlerGroup::handleAuthRequest(boost::shared_ptr packet, Common::XmlPacket *ret, Common::Connection *connection) { std::vector response; boost::shared_ptr authContext = application->getConnectionManager()->authenticateConnection(connection, packet->get("method"), packet->get("user"), packet->get&>("challenge"), response); if(!response.empty()) ret->set("response", response); if(authContext->isAuthenticated()) ret->setType("OK"); else ret->setType("Continue"); } void ConnectionRequestHandlerGroup::handleDaemonListRequest(boost::shared_ptr /*packet*/, Common::XmlPacket *ret, Common::Connection *connection) { if(!application->getConnectionManager()->isAuthenticated(connection)) throw(Core::Exception(Core::Exception::PERMISSION)); ret->setType("OK"); Common::XmlPacket::List *list = ret->createList("hosts"); std::vector daemons = application->getConnectionManager()->getDaemonList(); for(std::vector::iterator daemon = daemons.begin(); daemon != daemons.end(); ++daemon) { Common::XmlPacket::List::iterator entry = list->addEntry(); entry->set("name", daemon->getName()); entry->set("address", daemon->getIP()); entry->set("state", daemon->getState()); } } void ConnectionRequestHandlerGroup::handleIdentifyRequest(boost::shared_ptr packet, Common::XmlPacket *ret, Common::Connection *connection) { application->getConnectionManager()->identifyDaemonConnection(connection, packet->get("hostname")); ret->setType("OK"); } void ConnectionRequestHandlerGroup::handleLogRequest(boost::shared_ptr packet, Common::XmlPacket *ret, Common::Connection *connection) { // TODO Require authentication boost::posix_time::ptime timestamp(boost::posix_time::not_a_date_time); const std::string ×tr = packet->get("timestamp"); if(!timestr.empty()) { try { timestamp = boost::posix_time::from_iso_string(timestr); } catch(...) {} } try { application->getLogManager()->log( static_cast(packet->get("category")), static_cast(packet->get("level")), timestamp, packet->get("message"), application->getConnectionManager()->getDaemonName(connection)); } catch(Core::Exception &e) { application->logf(Core::LoggerBase::LOG_ERROR, "Can't determine daemon name: %s", e.strerror().c_str()); } ret->setType("OK"); } ConnectionRequestHandlerGroup::ConnectionRequestHandlerGroup(Application *application0) : application(application0) { registerHandler("GetAuthMethods", boost::bind(&ConnectionRequestHandlerGroup::handleAuthMethodRequest, this, _1, _2, _3)); registerHandler("Authenticate", boost::bind(&ConnectionRequestHandlerGroup::handleAuthRequest, this, _1, _2, _3)); 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)); } } } }