summaryrefslogtreecommitdiffstats
path: root/webkit
diff options
context:
space:
mode:
authorsergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-06 23:16:42 +0000
committersergeyu@chromium.org <sergeyu@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2011-04-06 23:16:42 +0000
commit00f0b81e684035f705e44b818bb039bbeae2c274 (patch)
tree6357372615e1822f5e98fdcdffe6c07d814cd801 /webkit
parentf0dbe56c5e204e4b2945a33732faabf9aafc3229 (diff)
downloadchromium_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')
-rw-r--r--webkit/glue/p2p_transport.h25
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