// Copyright (c) 2011 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_PEPPER_SESSION_H_ #define REMOTING_PROTOCOL_PEPPER_SESSION_H_ #include #include #include #include "base/memory/ref_counted.h" #include "base/timer.h" #include "crypto/rsa_private_key.h" #include "net/base/completion_callback.h" #include "remoting/protocol/jingle_messages.h" #include "remoting/protocol/session.h" #include "remoting/protocol/session_config.h" namespace net { class Socket; class StreamSocket; } // namespace net namespace remoting { class IqRequest; namespace protocol { class Authenticator; class PepperChannel; class PepperSessionManager; // Implements the protocol::Session interface using the Pepper P2P // Transport API. Created by PepperSessionManager for incoming and // outgoing connections. class PepperSession : public Session { public: virtual ~PepperSession(); // Session interface. virtual void SetStateChangeCallback( const StateChangeCallback& callback) OVERRIDE; virtual Error error() OVERRIDE; 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; 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 void Close() OVERRIDE; private: friend class PepperSessionManager; friend class PepperStreamChannel; typedef std::map ChannelsMap; explicit PepperSession(PepperSessionManager* session_manager); // Start cs connection by sending session-initiate message. void StartConnection(const std::string& peer_jid, Authenticator* authenticator, CandidateSessionConfig* config, const StateChangeCallback& state_change_callback); // Handler for session-initiate response. void OnSessionInitiateResponse(const buzz::XmlElement* response); // Called when an error occurs. Sets |error_| and closes the session. void OnError(Error error); // Called by PepperSessionManager on incoming |message|. Must fill // in |reply|. void OnIncomingMessage(const JingleMessage& message, JingleMessageReply* reply); // Message handlers for incoming messages. void OnAccept(const JingleMessage& message, JingleMessageReply* reply); void OnSessionInfo(const JingleMessage& message, JingleMessageReply* reply); void OnTerminate(const JingleMessage& message, JingleMessageReply* reply); void ProcessTransportInfo(const JingleMessage& message); // Called from OnAccept() to initialize session config. bool InitializeConfigFromDescription(const ContentDescription* description); void ProcessAuthenticationStep(); void OnSessionInfoResponse(const buzz::XmlElement* response); // Called by PepperChannel. void AddLocalCandidate(const cricket::Candidate& candidate); void OnDeleteChannel(PepperChannel* channel); void SendTransportInfo(); void OnTransportInfoResponse(const buzz::XmlElement* response); // Close all the channels and terminate the session. void CloseInternal(bool failed); // Sets |state_| to |new_state| and calls state change callback. void SetState(State new_state); PepperSessionManager* session_manager_; std::string peer_jid_; scoped_ptr candidate_config_; StateChangeCallback state_change_callback_; std::string session_id_; State state_; Error error_; SessionConfig config_; scoped_ptr authenticator_; scoped_ptr initiate_request_; scoped_ptr session_info_request_; scoped_ptr transport_info_request_; ChannelsMap channels_; base::OneShotTimer transport_infos_timer_; std::list pending_candidates_; DISALLOW_COPY_AND_ASSIGN(PepperSession); }; } // namespace protocol } // namespace remoting #endif // REMOTING_PROTOCOL_PEPPER_SESSION_H_