summaryrefslogtreecommitdiffstats
path: root/remoting/protocol/jingle_session.h
diff options
context:
space:
mode:
Diffstat (limited to 'remoting/protocol/jingle_session.h')
-rw-r--r--remoting/protocol/jingle_session.h144
1 files changed, 57 insertions, 87 deletions
diff --git a/remoting/protocol/jingle_session.h b/remoting/protocol/jingle_session.h
index c011e88..13a29bc 100644
--- a/remoting/protocol/jingle_session.h
+++ b/remoting/protocol/jingle_session.h
@@ -13,17 +13,7 @@
#include "third_party/libjingle/source/talk/base/sigslot.h"
#include "third_party/libjingle/source/talk/p2p/base/session.h"
-namespace jingle_glue {
-class PseudoTcpAdapter;
-class StreamSocketAdapter;
-class TransportChannelSocketAdapter;
-} // namespace jingle_glue
-
namespace net {
-class CertVerifier;
-class ClientSocketFactory;
-class Socket;
-class StreamSocket;
class X509Certificate;
} // namespace net
@@ -31,6 +21,7 @@ namespace remoting {
namespace protocol {
+class JingleChannelConnector;
class JingleSessionManager;
// Implements protocol::Session that work over libjingle session (the
@@ -41,32 +32,33 @@ class JingleSession : public protocol::Session,
public:
static const char kChromotingContentName[];
- // Chromotocol Session interface.
- virtual void SetStateChangeCallback(StateChangeCallback* callback);
-
- virtual net::Socket* control_channel();
- virtual net::Socket* event_channel();
- virtual net::Socket* video_channel();
-
- virtual net::Socket* video_rtp_channel();
- virtual net::Socket* video_rtcp_channel();
-
- virtual const std::string& jid();
-
- virtual const CandidateSessionConfig* candidate_config();
-
- virtual const SessionConfig* config();
- virtual void set_config(const SessionConfig* config);
-
- virtual const std::string& initiator_token();
- virtual void set_initiator_token(const std::string& initiator_token);
- virtual const std::string& receiver_token();
- virtual void set_receiver_token(const std::string& receiver_token);
-
- virtual void Close();
+ // Session interface.
+ virtual void SetStateChangeCallback(StateChangeCallback* callback) OVERRIDE;
+ virtual void CreateStreamChannel(
+ const std::string& name,
+ const StreamChannelCallback& callback) OVERRIDE;
+ virtual void CreateDatagramChannel(
+ const std::string& name,
+ const DatagramChannelCallback& callback) OVERRIDE;
+ virtual net::Socket* control_channel() OVERRIDE;
+ virtual net::Socket* event_channel() OVERRIDE;
+ virtual net::Socket* video_channel() OVERRIDE;
+ virtual net::Socket* video_rtp_channel() OVERRIDE;
+ virtual net::Socket* video_rtcp_channel() 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 const std::string& initiator_token() OVERRIDE;
+ virtual void set_initiator_token(const std::string& initiator_token) OVERRIDE;
+ virtual const std::string& receiver_token() OVERRIDE;
+ virtual void set_receiver_token(const std::string& receiver_token) OVERRIDE;
+ virtual void Close() OVERRIDE;
private:
+ friend class JingleDatagramConnector;
friend class JingleSessionManager;
+ friend class JingleStreamConnector;
// Create a JingleSession used in client mode. A server certificate is
// required.
@@ -104,20 +96,7 @@ class JingleSession : public protocol::Session,
// Initialize the session configuration from a received connection response
// stanza.
bool InitializeConfigFromDescription(
- const cricket::SessionDescription* description);
-
- // Configures channels and calls InitializeSSL().
- void InitializeChannels();
-
- // Helper method to initialize PseudoTcp over the datagram-oriented |channel|.
- // If things don't immediately fail then a new StreamSocket is placed in
- // |pseudo_tcp|.
- bool EstablishPseudoTcp(net::Socket* channel,
- scoped_ptr<net::StreamSocket>* pseudo_tcp);
-
- // Helper method to initialize SSL over a StreamSocket.
- bool EstablishSSLConnection(net::StreamSocket* socket,
- scoped_ptr<net::StreamSocket>* ssl_socket);
+ const cricket::SessionDescription* description);
// Used for Session.SignalState sigslot.
void OnSessionState(cricket::BaseSession* session,
@@ -130,10 +109,30 @@ class JingleSession : public protocol::Session,
void OnAccept();
void OnTerminate();
- void OnConnect(int result);
+ // Notifies upper layer about incoming connection and
+ // accepts/rejects connection.
+ void AcceptConnection();
+
+ void AddChannelConnector(const std::string& name,
+ JingleChannelConnector* connector);
- // Called by SSL socket to notify connect event.
- void OnSSLConnect(int result);
+ // Called by JingleChannelConnector when it has finished connecting
+ // the channel and needs to be destroyed.
+ void OnChannelConnectorFinished(const std::string& name,
+ JingleChannelConnector* connector);
+
+ // Creates channels after session has been accepted.
+ // TODO(sergeyu): Don't create channels in JingleSession.
+ void CreateChannels();
+
+ // Callbacks for the channels created in JingleSession.
+ // TODO(sergeyu): Remove this method once *_channel() methods are
+ // removed from Session interface.
+ void OnStreamChannelConnected(
+ const std::string& name, net::StreamSocket* socket);
+ void OnChannelConnected(const std::string& name, net::Socket* socket);
+
+ const cricket::ContentInfo* GetContentInfo() const;
void SetState(State new_state);
@@ -178,43 +177,14 @@ class JingleSession : public protocol::Session,
// These data members are only set on the receiving side.
scoped_ptr<const CandidateSessionConfig> candidate_config_;
- // |raw_foo_channel_| is a reference to the Cricket transport channel foo,
- // which is owned by the Cricket session.
- // |foo_channel_| owns the Socket adapter for that channel.
- // |foo_socket_| takes ownership of the Socket from |foo_channel_| and wraps
- // it with PseudoTcp. |foo_ssl_socket_| takes ownership from |foo_socket_|
- // and runs the SSL protocol over it. Finally |foo_socket_wrapper_| takes
- // ownership of |foo_ssl_socket_|, wrapping it with a SocketWrapper to work
- // around issues with callers of the resulting Sockets continuing to access
- // them after CloseInternal() has completed.
- // TODO(wez): Fix the tear-down issue and remove SocketWrapper.
-
- cricket::TransportChannel* raw_control_channel_;
- scoped_ptr<jingle_glue::TransportChannelSocketAdapter> control_channel_;
- scoped_ptr<net::StreamSocket> control_socket_;
- scoped_ptr<net::StreamSocket> control_ssl_socket_;
-
- cricket::TransportChannel* raw_event_channel_;
- scoped_ptr<jingle_glue::TransportChannelSocketAdapter> event_channel_;
- scoped_ptr<net::StreamSocket> event_socket_;
- scoped_ptr<net::StreamSocket> event_ssl_socket_;
-
- cricket::TransportChannel* raw_video_channel_;
- scoped_ptr<jingle_glue::TransportChannelSocketAdapter> video_channel_;
- scoped_ptr<net::StreamSocket> video_socket_;
- scoped_ptr<net::StreamSocket> video_ssl_socket_;
-
- // Used to verify the certificate received in SSLClientSocket.
- scoped_ptr<net::CertVerifier> cert_verifier_;
-
- cricket::TransportChannel* raw_video_rtp_channel_;
- scoped_ptr<jingle_glue::TransportChannelSocketAdapter> video_rtp_channel_;
- cricket::TransportChannel* raw_video_rtcp_channel_;
- scoped_ptr<jingle_glue::TransportChannelSocketAdapter> video_rtcp_channel_;
-
- // Callback called by the SSL layer.
- net::CompletionCallbackImpl<JingleSession> connect_callback_;
- net::CompletionCallbackImpl<JingleSession> ssl_connect_callback_;
+ // Channels that are currently being connected.
+ std::map<std::string, JingleChannelConnector*> channel_connectors_;
+
+ scoped_ptr<net::Socket> control_channel_socket_;
+ scoped_ptr<net::Socket> event_channel_socket_;
+ scoped_ptr<net::Socket> video_channel_socket_;
+ scoped_ptr<net::Socket> video_rtp_channel_socket_;
+ scoped_ptr<net::Socket> video_rtcp_channel_socket_;
ScopedRunnableMethodFactory<JingleSession> task_factory_;