From 1508969d508e41de824d1d1227be708136760cfa Mon Sep 17 00:00:00 2001 From: Matthias Schiffer Date: Tue, 8 Jul 2008 22:31:29 +0200 Subject: Request-Verarbeitung ?berarbeitet --- src/Common/Request/DisconnectRequest.h | 44 +++++++++++++++++++++++++++++++--- 1 file changed, 41 insertions(+), 3 deletions(-) (limited to 'src/Common/Request/DisconnectRequest.h') diff --git a/src/Common/Request/DisconnectRequest.h b/src/Common/Request/DisconnectRequest.h index 309504d..9023c13 100644 --- a/src/Common/Request/DisconnectRequest.h +++ b/src/Common/Request/DisconnectRequest.h @@ -20,15 +20,53 @@ #ifndef DISCONNECTREQUEST_H_ #define DISCONNECTREQUEST_H_ -#include "../RequestInfo.h" +#include "Request.h" +#include "../RequestManager.h" +#include +#include namespace Mad { namespace Common { namespace Request { -class DisconnectRequest: public RequestInfo { +class DisconnectRequest: public Request { + private: + DisconnectRequest() {} + public: - DisconnectRequest() : RequestInfo(TYPE_DISCONNECT) {} + static bool send(Net::Connection *connection, RequestManager &requestManager) { + Request *request = new DisconnectRequest(); + + if(requestManager.sendRequest(connection, request)) + return true; + + delete request; + return false; + } + + virtual bool sendRequest(Net::Connection *connection, unsigned short requestId) { + if(isSent()) + return false; + + if(!connection->send(Net::Packet(Net::Packet::TYPE_DISCONNECT_REQ, requestId))) + return false; + + setSent(); + return true; + } + + virtual bool handlePacket(Net::Connection *connection, const Net::Packet &packet) { + if(isFinished()) + return false; + + if(packet.getType() != Net::Packet::TYPE_DISCONNECT_REP) + return false; // TODO Logging + + connection->disconnect(); + + setFinished(); + return true; + } }; } -- cgit v1.2.3