// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef REMOTING_PROTOCOL_JINGLE_SESSION_H_ #define REMOTING_PROTOCOL_JINGLE_SESSION_H_ #include <list> #include <map> #include <set> #include <string> #include "base/memory/ref_counted.h" #include "base/timer/timer.h" #include "crypto/rsa_private_key.h" #include "net/base/completion_callback.h" #include "remoting/jingle_glue/iq_sender.h" #include "remoting/protocol/authenticator.h" #include "remoting/protocol/channel_factory.h" #include "remoting/protocol/jingle_messages.h" #include "remoting/protocol/session.h" #include "remoting/protocol/session_config.h" #include "remoting/protocol/transport.h" namespace net { class Socket; class StreamSocket; } // namespace net namespace remoting { namespace protocol { class ChannelMultiplexer; class JingleSessionManager; // JingleSessionManager and JingleSession implement the subset of the // Jingle protocol used in Chromoting. Instances of this class are // created by the JingleSessionManager. class JingleSession : public Session, public ChannelFactory, public Transport::EventHandler { public: virtual ~JingleSession(); // Session interface. virtual void SetEventHandler(Session::EventHandler* event_handler) OVERRIDE; virtual ErrorCode error() OVERRIDE; virtual const std::string& jid() OVERRIDE; virtual const CandidateSessionConfig* candidate_config() OVERRIDE; virtual const SessionConfig& config() OVERRIDE; virtual void set_config(const SessionConfig& config) OVERRIDE; virtual ChannelFactory* GetTransportChannelFactory() OVERRIDE; virtual ChannelFactory* GetMultiplexedChannelFactory() OVERRIDE; virtual void Close() OVERRIDE; // ChannelFactory interface. virtual void CreateStreamChannel( const std::string& name, const StreamChannelCallback& callback) OVERRIDE; virtual void CreateDatagramChannel( const std::string& name, const DatagramChannelCallback& callback) OVERRIDE; virtual void CancelChannelCreation(const std::string& name) OVERRIDE; // Transport::EventHandler interface. virtual void OnTransportCandidate( Transport* transport, const cricket::Candidate& candidate) OVERRIDE; virtual void OnTransportRouteChange(Transport* transport, const TransportRoute& route) OVERRIDE; virtual void OnTransportReady(Transport* transport, bool ready) OVERRIDE; virtual void OnTransportFailed(Transport* transport) OVERRIDE; virtual void OnTransportDeleted(Transport* transport) OVERRIDE; private: friend class JingleSessionManager; typedef std::map<std::string, Transport*> ChannelsMap; typedef base::Callback<void(JingleMessageReply::ErrorType)> ReplyCallback; explicit JingleSession(JingleSessionManager* session_manager); // Start connection by sending session-initiate message. void StartConnection(const std::string& peer_jid, scoped_ptr<Authenticator> authenticator, scoped_ptr<CandidateSessionConfig> config); // Adds to a new channel the remote candidates received before it was created. void AddPendingRemoteCandidates(Transport* channel, const std::string& name); // Called by JingleSessionManager for incoming connections. void InitializeIncomingConnection(const JingleMessage& initiate_message, scoped_ptr<Authenticator> authenticator); void AcceptIncomingConnection(const JingleMessage& initiate_message); // Sends |message| to the peer. The session is closed if the send fails or no // response is received within a reasonable time. All other responses are // ignored. void SendMessage(const JingleMessage& message); // Iq response handler. void OnMessageResponse(JingleMessage::ActionType request_type, IqRequest* request, const buzz::XmlElement* response); // Sends transport-info message with candidates from |pending_candidates_|. void SendTransportInfo(); // Response handler for transport-info responses. Transport-info timeouts are // ignored and don't terminate connection. void OnTransportInfoResponse(IqRequest* request, const buzz::XmlElement* response); // Called by JingleSessionManager on incoming |message|. Must call // |reply_callback| to send reply message before sending any other // messages. void OnIncomingMessage(const JingleMessage& message, const ReplyCallback& reply_callback); // Message handlers for incoming messages. void OnAccept(const JingleMessage& message, const ReplyCallback& reply_callback); void OnSessionInfo(const JingleMessage& message, const ReplyCallback& reply_callback); void OnTerminate(const JingleMessage& message, const ReplyCallback& reply_callback); void ProcessTransportInfo(const JingleMessage& message); // Called from OnAccept() to initialize session config. bool InitializeConfigFromDescription(const ContentDescription* description); // Called after the initial incoming authenticator message is processed. void ContinueAcceptIncomingConnection(); // Called after subsequent authenticator messages are processed. void ProcessAuthenticationStep(); // Terminates the session and sends session-terminate if it is // necessary. |error| specifies the error code in case when the // session is being closed due to an error. void CloseInternal(ErrorCode error); // Sets |state_| to |new_state| and calls state change callback. void SetState(State new_state); JingleSessionManager* session_manager_; std::string peer_jid_; scoped_ptr<CandidateSessionConfig> candidate_config_; Session::EventHandler* event_handler_; std::string session_id_; State state_; ErrorCode error_; SessionConfig config_; bool config_is_set_; scoped_ptr<Authenticator> authenticator_; // Pending Iq requests. Used for all messages except transport-info. std::set<IqRequest*> pending_requests_; // Pending transport-info requests. std::list<IqRequest*> transport_info_requests_; ChannelsMap channels_; scoped_ptr<ChannelMultiplexer> channel_multiplexer_; base::OneShotTimer<JingleSession> transport_infos_timer_; std::list<JingleMessage::NamedCandidate> pending_candidates_; // Pending remote candidates, received before the local channels were created. std::list<JingleMessage::NamedCandidate> pending_remote_candidates_; DISALLOW_COPY_AND_ASSIGN(JingleSession); }; } // namespace protocol } // namespace remoting #endif // REMOTING_PROTOCOL_JINGLE_SESSION_H_