diff options
Diffstat (limited to 'src/Core/Requests/DaemonStatusRequest.cpp')
-rw-r--r-- | src/Core/Requests/DaemonStatusRequest.cpp | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/Core/Requests/DaemonStatusRequest.cpp b/src/Core/Requests/DaemonStatusRequest.cpp new file mode 100644 index 0000000..118203f --- /dev/null +++ b/src/Core/Requests/DaemonStatusRequest.cpp @@ -0,0 +1,59 @@ +/* + * DaemonStatusRequest.cpp + * + * Copyright (C) 2008 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 "DaemonStatusRequest.h" +#include <Common/RequestManager.h> +#include <Net/Packets/HostStatusPacket.h> + +namespace Mad { +namespace Core { +namespace Requests { + +bool DaemonStatusRequest::send(Net::Connection *connection, const sigc::slot<void,const Net::Packets::HostStatusPacket&> &callback) { + DaemonStatusRequest *request = new DaemonStatusRequest(); + + request->finished.connect(callback); + + if(Mad::Common::RequestManager::getRequestManager()->sendRequest(connection, request)) + return true; + + delete request; + return false; +} + +bool DaemonStatusRequest::sendRequest(Net::Connection *connection, uint16_t requestId) { + if(!connection->send(Net::Packet(Net::Packet::STATUS, requestId))) + return false; + + return true; +} + +bool DaemonStatusRequest::handlePacket(Net::Connection*, const Net::Packet &packet) { + if(packet.getType() != Net::Packet::OK) + return false; // TODO Logging + + finished(Net::Packets::HostStatusPacket(packet)); + + signalFinished().emit(); + return true; +} + +} +} +} |