Home | History | Annotate | Download | only in protocol
      1 // Copyright (c) 2012 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef REMOTING_PROTOCOL_JINGLE_SESSION_H_
      6 #define REMOTING_PROTOCOL_JINGLE_SESSION_H_
      7 
      8 #include <list>
      9 #include <map>
     10 #include <set>
     11 #include <string>
     12 
     13 #include "base/memory/ref_counted.h"
     14 #include "base/timer/timer.h"
     15 #include "crypto/rsa_private_key.h"
     16 #include "net/base/completion_callback.h"
     17 #include "remoting/protocol/authenticator.h"
     18 #include "remoting/protocol/datagram_channel_factory.h"
     19 #include "remoting/protocol/jingle_messages.h"
     20 #include "remoting/protocol/session.h"
     21 #include "remoting/protocol/session_config.h"
     22 #include "remoting/protocol/transport.h"
     23 #include "remoting/signaling/iq_sender.h"
     24 
     25 namespace net {
     26 class Socket;
     27 class StreamSocket;
     28 }  // namespace net
     29 
     30 namespace remoting {
     31 namespace protocol {
     32 
     33 class SecureChannelFactory;
     34 class ChannelMultiplexer;
     35 class JingleSessionManager;
     36 class PseudoTcpChannelFactory;
     37 
     38 // JingleSessionManager and JingleSession implement the subset of the
     39 // Jingle protocol used in Chromoting. Instances of this class are
     40 // created by the JingleSessionManager.
     41 class JingleSession : public base::NonThreadSafe,
     42                       public Session,
     43                       public DatagramChannelFactory,
     44                       public Transport::EventHandler {
     45  public:
     46   virtual ~JingleSession();
     47 
     48   // Session interface.
     49   virtual void SetEventHandler(Session::EventHandler* event_handler) OVERRIDE;
     50   virtual ErrorCode error() OVERRIDE;
     51   virtual const std::string& jid() OVERRIDE;
     52   virtual const CandidateSessionConfig* candidate_config() OVERRIDE;
     53   virtual const SessionConfig& config() OVERRIDE;
     54   virtual void set_config(const SessionConfig& config) OVERRIDE;
     55   virtual StreamChannelFactory* GetTransportChannelFactory() OVERRIDE;
     56   virtual StreamChannelFactory* GetMultiplexedChannelFactory() OVERRIDE;
     57   virtual void Close() OVERRIDE;
     58 
     59   // DatagramChannelFactory interface.
     60   virtual void CreateChannel(const std::string& name,
     61                              const ChannelCreatedCallback& callback) OVERRIDE;
     62   virtual void CancelChannelCreation(const std::string& name) OVERRIDE;
     63 
     64   // Transport::EventHandler interface.
     65   virtual void OnTransportCandidate(
     66       Transport* transport,
     67       const cricket::Candidate& candidate) OVERRIDE;
     68   virtual void OnTransportRouteChange(Transport* transport,
     69                                       const TransportRoute& route) OVERRIDE;
     70   virtual void OnTransportFailed(Transport* transport) OVERRIDE;
     71   virtual void OnTransportDeleted(Transport* transport) OVERRIDE;
     72 
     73  private:
     74   friend class JingleSessionManager;
     75 
     76   typedef std::map<std::string, Transport*> ChannelsMap;
     77   typedef base::Callback<void(JingleMessageReply::ErrorType)> ReplyCallback;
     78 
     79   explicit JingleSession(JingleSessionManager* session_manager);
     80 
     81   // Start connection by sending session-initiate message.
     82   void StartConnection(const std::string& peer_jid,
     83                        scoped_ptr<Authenticator> authenticator,
     84                        scoped_ptr<CandidateSessionConfig> config);
     85 
     86   // Adds to a new channel the remote candidates received before it was created.
     87   void AddPendingRemoteCandidates(Transport* channel, const std::string& name);
     88 
     89   // Called by JingleSessionManager for incoming connections.
     90   void InitializeIncomingConnection(const JingleMessage& initiate_message,
     91                                     scoped_ptr<Authenticator> authenticator);
     92   void AcceptIncomingConnection(const JingleMessage& initiate_message);
     93 
     94   // Sends |message| to the peer. The session is closed if the send fails or no
     95   // response is received within a reasonable time. All other responses are
     96   // ignored.
     97   void SendMessage(const JingleMessage& message);
     98 
     99   // Iq response handler.
    100   void OnMessageResponse(JingleMessage::ActionType request_type,
    101                          IqRequest* request,
    102                          const buzz::XmlElement* response);
    103 
    104   // Sends transport-info message with candidates from |pending_candidates_|.
    105   void SendTransportInfo();
    106 
    107   // Response handler for transport-info responses. Transport-info timeouts are
    108   // ignored and don't terminate connection.
    109   void OnTransportInfoResponse(IqRequest* request,
    110                                const buzz::XmlElement* response);
    111 
    112   // Called by JingleSessionManager on incoming |message|. Must call
    113   // |reply_callback| to send reply message before sending any other
    114   // messages.
    115   void OnIncomingMessage(const JingleMessage& message,
    116                          const ReplyCallback& reply_callback);
    117 
    118   // Message handlers for incoming messages.
    119   void OnAccept(const JingleMessage& message,
    120                 const ReplyCallback& reply_callback);
    121   void OnSessionInfo(const JingleMessage& message,
    122                      const ReplyCallback& reply_callback);
    123   void OnTerminate(const JingleMessage& message,
    124                    const ReplyCallback& reply_callback);
    125   void ProcessTransportInfo(const JingleMessage& message);
    126 
    127   // Called from OnAccept() to initialize session config.
    128   bool InitializeConfigFromDescription(const ContentDescription* description);
    129 
    130   // Called after the initial incoming authenticator message is processed.
    131   void ContinueAcceptIncomingConnection();
    132 
    133   // Called after subsequent authenticator messages are processed.
    134   void ProcessAuthenticationStep();
    135 
    136   // Called after the authenticating step is finished.
    137   void ContinueAuthenticationStep();
    138 
    139   // Called when authentication is finished.
    140   void OnAuthenticated();
    141 
    142   // Terminates the session and sends session-terminate if it is
    143   // necessary. |error| specifies the error code in case when the
    144   // session is being closed due to an error.
    145   void CloseInternal(ErrorCode error);
    146 
    147   // Sets |state_| to |new_state| and calls state change callback.
    148   void SetState(State new_state);
    149 
    150   // Returns true if the state of the session is not CLOSED or FAILED
    151   bool is_session_active();
    152 
    153   JingleSessionManager* session_manager_;
    154   std::string peer_jid_;
    155   scoped_ptr<CandidateSessionConfig> candidate_config_;
    156   Session::EventHandler* event_handler_;
    157 
    158   std::string session_id_;
    159   State state_;
    160   ErrorCode error_;
    161 
    162   SessionConfig config_;
    163   bool config_is_set_;
    164 
    165   scoped_ptr<Authenticator> authenticator_;
    166 
    167   // Pending Iq requests. Used for all messages except transport-info.
    168   std::set<IqRequest*> pending_requests_;
    169 
    170   // Pending transport-info requests.
    171   std::list<IqRequest*> transport_info_requests_;
    172 
    173   ChannelsMap channels_;
    174   scoped_ptr<PseudoTcpChannelFactory> pseudotcp_channel_factory_;
    175   scoped_ptr<SecureChannelFactory> secure_channel_factory_;
    176   scoped_ptr<ChannelMultiplexer> channel_multiplexer_;
    177 
    178   base::OneShotTimer<JingleSession> transport_infos_timer_;
    179   std::list<JingleMessage::NamedCandidate> pending_candidates_;
    180 
    181   // Pending remote candidates, received before the local channels were created.
    182   std::list<JingleMessage::NamedCandidate> pending_remote_candidates_;
    183 
    184   base::WeakPtrFactory<JingleSession> weak_factory_;
    185 
    186   DISALLOW_COPY_AND_ASSIGN(JingleSession);
    187 };
    188 
    189 }  // namespace protocol
    190 }  // namespace remoting
    191 
    192 #endif  // REMOTING_PROTOCOL_JINGLE_SESSION_H_
    193