diff options
author | Remko Tronçon <git@el-tramo.be> | 2012-12-25 14:39:48 (GMT) |
---|---|---|
committer | Remko Tronçon <git@el-tramo.be> | 2013-05-11 10:22:56 (GMT) |
commit | 927d62cc54c8a5087dba6b61afa9ad30dc528a23 (patch) | |
tree | e67dc911bd30c0519d31a542d8e085bbb209879d /Swiften/Jingle/JingleSessionImpl.h | |
parent | 17b188343e7208b875af7af30d94f0bf948f6b93 (diff) | |
download | swift-927d62cc54c8a5087dba6b61afa9ad30dc528a23.zip swift-927d62cc54c8a5087dba6b61afa9ad30dc528a23.tar.bz2 |
File Transfer refactoring.
Allocate S5B server lazily.
Forward forts lazily.
Various state machine fixes.
Temporarily disabling S5B proxy support.
Change-Id: I3145e85a99b15a7e457306bbfbe9c0eb570191e4
Diffstat (limited to 'Swiften/Jingle/JingleSessionImpl.h')
-rw-r--r-- | Swiften/Jingle/JingleSessionImpl.h | 14 |
1 files changed, 11 insertions, 3 deletions
diff --git a/Swiften/Jingle/JingleSessionImpl.h b/Swiften/Jingle/JingleSessionImpl.h index 3c1559a..b7f4a55 100644 --- a/Swiften/Jingle/JingleSessionImpl.h +++ b/Swiften/Jingle/JingleSessionImpl.h @@ -1,5 +1,5 @@ /* - * Copyright (c) 2011 Remko Tronçon + * Copyright (c) 2011-2013 Remko Tronçon * Licensed under the GNU General Public License v3. * See Documentation/Licenses/GPLv3.txt for more information. */ @@ -7,11 +7,14 @@ #pragma once #include <boost/shared_ptr.hpp> +#include <map> #include <Swiften/Jingle/JingleSession.h> +#include <Swiften/Queries/GenericRequest.h> namespace Swift { class IQRouter; + class Request; class JingleSessionImpl : public JingleSession { friend class JingleResponder; @@ -24,19 +27,24 @@ namespace Swift { virtual void sendTerminate(JinglePayload::Reason::Type reason); virtual void sendInfo(boost::shared_ptr<Payload>); virtual void sendAccept(const JingleContentID&, JingleDescription::ref, JingleTransportPayload::ref); - virtual void sendTransportInfo(const JingleContentID&, JingleTransportPayload::ref); + virtual std::string sendTransportInfo(const JingleContentID&, JingleTransportPayload::ref); virtual void sendTransportAccept(const JingleContentID&, JingleTransportPayload::ref); virtual void sendTransportReject(const JingleContentID&, JingleTransportPayload::ref); virtual void sendTransportReplace(const JingleContentID&, JingleTransportPayload::ref); private: + typedef boost::shared_ptr<GenericRequest<JinglePayload> > RequestRef; + void handleIncomingAction(JinglePayload::ref); - void sendSetRequest(JinglePayload::ref payload); + std::string sendSetRequest(JinglePayload::ref payload); JinglePayload::ref createPayload() const; + void handleRequestResponse(RequestRef); private: IQRouter *iqRouter; JID peerJID; + typedef std::map<RequestRef, boost::bsignals::connection > RequestsMap; + RequestsMap pendingRequests; }; } |