Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(406)

Unified Diff: content/public/renderer/socket_client.h

Issue 45183002: Expose the p2p client in content/public (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: some renaming Created 7 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: content/public/renderer/socket_client.h
diff --git a/content/public/renderer/socket_client.h b/content/public/renderer/socket_client.h
new file mode 100644
index 0000000000000000000000000000000000000000..3ff9ae12663b228fdeb88f1b676a384ace7e21b4
--- /dev/null
+++ b/content/public/renderer/socket_client.h
@@ -0,0 +1,77 @@
+// Copyright (c) 2011 The Chromium Authors. All rights reserved.
Alpha Left Google 2013/10/25 21:28:48 This is still called socket_client.h though, shoul
jam 2013/11/20 23:26:24 +1
hubbe 2013/11/21 22:07:30 Done.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CONTENT_PUBLIC_RENDERER_SOCKET_CLIENT_H_
+#define CONTENT_PUBLIC_RENDERER_SOCKET_CLIENT_H_
+
+#include <vector>
+
+#include "base/memory/ref_counted.h"
+#include "content/public/common/p2p_sockets.h"
+#include "net/base/ip_endpoint.h"
+
+namespace content {
+
+// P2P socket that routes all calls over IPC.
+//
+// The object runs on two threads: IPC thread and delegate thread. The
+// IPC thread is used to interact with P2PSocketDispatcher. All
+// callbacks to the user of this class are called on the delegate
+// thread which is specified in Init().
jam 2013/11/20 23:26:24 you're describing the implementation details. do w
hubbe 2013/11/21 22:07:30 Fixed.
hubbe 2013/11/21 22:07:30 Fixed.
jam 2013/11/23 02:03:14 What I mean is that this is an interface. The impl
hubbe 2013/11/25 19:15:07 I think so, because we expect the callers to use s
jam 2013/11/27 21:30:18 what is the ownership here? i.e. can the embedder
hubbe 2013/11/27 23:23:01 That's not the intent, the intent is for the user
jam 2013/11/28 00:08:57 ok, so you're saying that the ownership of this cl
+class P2PSocketClient : public base::RefCountedThreadSafe<P2PSocketClient> {
+ public:
+ P2PSocketClient() {}
+
+ // Delegate is called on the the same thread on which P2PSocketCLient is
+ // created.
+ class Delegate {
jam 2013/11/20 23:26:24 see http://www.chromium.org/developers/content-mod
hubbe 2013/11/21 22:07:30 Done.
+ public:
+ virtual ~Delegate() { }
+
+ virtual void OnOpen(const net::IPEndPoint& address) = 0;
jam 2013/11/20 23:26:24 nit: document every method
hubbe 2013/11/21 22:07:30 Done.
+ virtual void OnIncomingTcpConnection(const net::IPEndPoint& address,
+ P2PSocketClient* client) = 0;
+ virtual void OnSendComplete() = 0;
+ virtual void OnError() = 0;
+ virtual void OnDataReceived(const net::IPEndPoint& address,
+ const std::vector<char>& data) = 0;
+ };
+
+ // Initialize socket of the specified |type| and connected to the
+ // specified |address|. |address| matters only when |type| is set to
+ // P2P_SOCKET_TCP_CLIENT.
+ virtual void Init(P2PSocketType type,
+ const net::IPEndPoint& local_address,
+ const net::IPEndPoint& remote_address,
+ Delegate* delegate) = 0;
+
+ // Send the |data| to the |address|.
+ virtual void Send(const net::IPEndPoint& address,
+ const std::vector<char>& data) = 0;
+
+ // Send the |data| to the |address| using Differentiated Services Code Point
+ // |dscp|.
+ virtual void SendWithDscp(const net::IPEndPoint& address,
+ const std::vector<char>& data,
+ net::DiffServCodePoint dscp) = 0;
+
+ // Must be called before the socket is destroyed.
+ virtual void Close() = 0;
+
+ virtual int socket_id() const = 0;
+ virtual void set_delegate(Delegate* delegate) = 0;
jam 2013/11/20 23:26:24 nit: these two methods don't conform to google sty
hubbe 2013/11/21 22:07:30 Done.
+
+ protected:
+ virtual ~P2PSocketClient() {}
+
+ private:
+ // Calls destructor.
+ friend class base::RefCountedThreadSafe<P2PSocketClient>;
+
+ DISALLOW_COPY_AND_ASSIGN(P2PSocketClient);
jam 2013/11/20 23:26:24 nit: don't need this since pure virtual interfaces
hubbe 2013/11/21 22:07:30 Done.
+};
+
+} // namespace content
+
+#endif // CONTENT_PUBLIC_RENDERER_SOCKET_CLIENT_H_

Powered by Google App Engine
This is Rietveld 408576698