summaryrefslogtreecommitdiffstats
path: root/src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp')
-rw-r--r--src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp109
1 files changed, 109 insertions, 0 deletions
diff --git a/src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp b/src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp
new file mode 100644
index 0000000..4ff8c40
--- /dev/null
+++ b/src/Server/RequestHandlers/DaemonRequestHandlerGroup.cpp
@@ -0,0 +1,109 @@
+/*
+ * DaemonRequestHandlerGroup.cpp
+ *
+ * Copyright (C) 2009 Matthias Schiffer <matthias@gamezock.de>
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+#include "DaemonRequestHandlerGroup.h"
+#include "../ConnectionManager.h"
+#include "../Requests/CommandRequest.h"
+
+#include <Common/Logger.h>
+#include <Common/Requests/FSInfoRequest.h>
+#include <Common/Requests/StatusRequest.h>
+
+namespace Mad {
+namespace Server {
+namespace RequestHandlers {
+
+void DaemonRequestHandlerGroup::DaemonRequestHandler::handlePacket(boost::shared_ptr<const Common::XmlPacket> packet) {
+ if(packet->getType() != type) {
+ Common::Logger::log(Common::Logger::ERROR, "Received an unexpected packet.");
+
+ Common::XmlPacket ret;
+ ret.setType("Error");
+ ret.add("ErrorCode", Net::Exception::UNEXPECTED_PACKET);
+
+ sendPacket(ret);
+
+ signalFinished();
+ return;
+ }
+
+ // TODO Require authentication
+
+ try {
+ boost::shared_ptr<Common::Connection> daemonCon = ConnectionManager::get()->getDaemonConnection((*packet)["daemon"]);
+ boost::shared_ptr<Common::Request> request;
+
+ if(type == "DaemonCommand")
+ request.reset(new Requests::CommandRequest((std::string&)((*packet)["command"]) == "reboot"));
+ else if(type == "DaemonFSInfo")
+ request.reset(new Common::Requests::FSInfoRequest);
+ else // type == "GetDaemonStatus"
+ request.reset(new Common::Requests::StatusRequest);
+
+ request->connectSignalFinished(boost::bind(&DaemonRequestHandlerGroup::DaemonRequestHandler::requestFinished, this, _1, _2));
+ Common::RequestManager::get()->sendRequest(daemonCon.get(), request);
+ }
+ catch(Net::Exception &e) {
+ Common::XmlPacket ret;
+ ret.setType("Error");
+ ret.add("ErrorCode", e.getErrorCode());
+ ret.add("SubCode", e.getSubCode());
+ ret.add("SubSubCode", e.getSubSubCode());
+ ret.add("Where", e.getWhere());
+
+ sendPacket(ret);
+ signalFinished();
+ }
+}
+
+void DaemonRequestHandlerGroup::DaemonRequestHandler::requestFinished(boost::shared_ptr<const Common::XmlPacket> packet, Net::Exception error) {
+ if(error) {
+ Common::XmlPacket ret;
+ ret.setType("Error");
+ ret.add("ErrorCode", error.getErrorCode());
+ ret.add("SubCode", error.getSubCode());
+ ret.add("SubSubCode", error.getSubSubCode());
+ ret.add("Where", error.getWhere());
+
+ sendPacket(ret);
+ }
+ else {
+ sendPacket(*packet);
+ }
+
+ signalFinished();
+}
+
+
+DaemonRequestHandlerGroup::DaemonRequestHandlerGroup() {
+ types.insert("DaemonCommand");
+ types.insert("DaemonFSInfo");
+ types.insert("GetDaemonStatus");
+}
+
+boost::shared_ptr<Common::RequestHandler> DaemonRequestHandlerGroup::createRequestHandler(const std::string &type) {
+ if(types.find(type) == types.end())
+ return boost::shared_ptr<Common::RequestHandler>();
+ else
+ return boost::shared_ptr<DaemonRequestHandler>(new DaemonRequestHandler(type));
+}
+
+}
+}
+}