diff options
author | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-06 23:16:42 +0000 |
---|---|---|
committer | sergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-06 23:16:42 +0000 |
commit | 00f0b81e684035f705e44b818bb039bbeae2c274 (patch) | |
tree | 6357372615e1822f5e98fdcdffe6c07d814cd801 /webkit/glue/p2p_transport.h | |
parent | f0dbe56c5e204e4b2945a33732faabf9aafc3229 (diff) | |
download | chromium_src-00f0b81e684035f705e44b818bb039bbeae2c274.zip chromium_src-00f0b81e684035f705e44b818bb039bbeae2c274.tar.gz chromium_src-00f0b81e684035f705e44b818bb039bbeae2c274.tar.bz2 |
P2P Transport implementation.
TEST=Unittests.
BUG=None
Review URL: http://codereview.chromium.org/6791023
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@80717 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'webkit/glue/p2p_transport.h')
-rw-r--r-- | webkit/glue/p2p_transport.h | 25 |
1 files changed, 15 insertions, 10 deletions
diff --git a/webkit/glue/p2p_transport.h b/webkit/glue/p2p_transport.h index 5cd30c5..e80ffb5 100644 --- a/webkit/glue/p2p_transport.h +++ b/webkit/glue/p2p_transport.h @@ -7,6 +7,10 @@ #include <string> +namespace net { +class Socket; +} // namespace net + namespace webkit_glue { // Interface for P2P transport. @@ -27,23 +31,24 @@ class P2PTransport { // Called when readable of writable state of the stream changes. virtual void OnStateChange(State state) = 0; - - // Called when a message received from the peer. P2PTransport keeps - // owneship of |data|. - virtual void OnMessageReceived(const char* data, size_t data_size) = 0; }; virtual ~P2PTransport() {} - // Initialize transport using specified configuration. - virtual void Init(const std::string& config, + // Initialize transport using specified configuration. Returns true + // if initialization succeeded. + virtual bool Init(const std::string& name, + const std::string& config, EventHandler* event_handler) = 0; - // Add candidate received from the remote peer. - virtual void AddRemoteCandidate(const std::string& address) = 0; + // Add candidate received from the remote peer. Returns false if the + // provided address is not in a valid format. + virtual bool AddRemoteCandidate(const std::string& address) = 0; - // Send data to the other end. Caller keeps ownership of |data|. - virtual void Send(const char* data, int data_size) = 0; + // Returns socket interface that can be used to send/receive + // data. Returned object is owned by the transport. Pending calls on + // the socket are canceled when the transport is destroyed. + virtual net::Socket* GetChannel() = 0; }; } // namespace webkit_glue |