diff options
34 files changed, 25 insertions, 1676 deletions
diff --git a/build/common.gypi b/build/common.gypi index 62dad147..d401d1a 100644 --- a/build/common.gypi +++ b/build/common.gypi @@ -203,10 +203,6 @@ # Remoting compilation is enabled by default. Set to 0 to disable. 'remoting%': 1, - # P2P APIs are compiled in by default. Set to 0 to disable. - # Also note that this should be enabled for remoting to compile. - 'p2p_apis%': 1, - # Configuration policy is enabled by default. Set to 0 to disable. 'configuration_policy%': 1, @@ -549,7 +545,6 @@ 'enable_one_click_signin%': '<(enable_one_click_signin)', 'enable_webrtc%': '<(enable_webrtc)', 'chromium_win_pch%': '<(chromium_win_pch)', - 'p2p_apis%': '<(p2p_apis)', 'configuration_policy%': '<(configuration_policy)', 'safe_browsing%': '<(safe_browsing)', 'input_speech%': '<(input_speech)', @@ -1339,9 +1334,6 @@ ['enable_webrtc==1', { 'defines': ['ENABLE_WEBRTC=1'], }], - ['p2p_apis==1', { - 'defines': ['ENABLE_P2P_APIS=1'], - }], ['proprietary_codecs==1', { 'defines': ['USE_PROPRIETARY_CODECS'], }], diff --git a/chrome/test/ui/ppapi_uitest.cc b/chrome/test/ui/ppapi_uitest.cc index fa60e22..d64176a 100644 --- a/chrome/test/ui/ppapi_uitest.cc +++ b/chrome/test/ui/ppapi_uitest.cc @@ -867,17 +867,6 @@ IN_PROC_BROWSER_TEST_F(PPAPITest, MAYBE_DirectoryReader) { RunTestViaHTTP("DirectoryReader"); } -#if defined(ENABLE_P2P_APIS) -// Flaky. http://crbug.com/84294 -IN_PROC_BROWSER_TEST_F(PPAPITest, DISABLED_Transport) { - RunTest("Transport"); -} -// http://crbug.com/89961 -IN_PROC_BROWSER_TEST_F(OutOfProcessPPAPITest, DISABLED_Transport) { - RunTestViaHTTP("Transport"); -} -#endif // ENABLE_P2P_APIS - // There is no proxy. This is used for PDF metrics reporting, and PDF only // runs in process, so there's currently no need for a proxy. TEST_PPAPI_IN_PROCESS(UMA) diff --git a/content/browser/renderer_host/render_process_host_impl.cc b/content/browser/renderer_host/render_process_host_impl.cc index dd6dfdb..15e3246 100644 --- a/content/browser/renderer_host/render_process_host_impl.cc +++ b/content/browser/renderer_host/render_process_host_impl.cc @@ -532,7 +532,7 @@ void RenderProcessHostImpl::CreateMessageFilters() { base::Bind(&RenderWidgetHelper::GetNextRoutingID, base::Unretained(widget_helper_.get())))); -#if defined(ENABLE_P2P_APIS) +#if defined(ENABLE_WEBRTC) channel_->AddFilter(new content::P2PSocketDispatcherHost(resource_context)); #endif diff --git a/content/content_browser.gypi b/content/content_browser.gypi index 1d5c9e2..d3b37fe 100644 --- a/content/content_browser.gypi +++ b/content/content_browser.gypi @@ -777,7 +777,7 @@ 'browser/gamepad/platform_data_fetcher.cc', ] }], - ['p2p_apis==1', { + ['enable_webrtc==1', { 'sources': [ 'browser/renderer_host/p2p/socket_host.cc', 'browser/renderer_host/p2p/socket_host.h', diff --git a/content/content_renderer.gypi b/content/content_renderer.gypi index 161a48a..df4530e 100644 --- a/content/content_renderer.gypi +++ b/content/content_renderer.gypi @@ -222,24 +222,6 @@ 'renderer/websharedworkerrepository_impl.h', ], 'conditions': [ - ['p2p_apis==1', { - 'sources': [ - 'renderer/p2p/host_address_request.cc', - 'renderer/p2p/host_address_request.h', - 'renderer/p2p/ipc_network_manager.cc', - 'renderer/p2p/ipc_network_manager.h', - 'renderer/p2p/ipc_socket_factory.cc', - 'renderer/p2p/ipc_socket_factory.h', - 'renderer/p2p/p2p_transport_impl.cc', - 'renderer/p2p/p2p_transport_impl.h', - 'renderer/p2p/port_allocator.cc', - 'renderer/p2p/port_allocator.h', - 'renderer/p2p/socket_client.cc', - 'renderer/p2p/socket_client.h', - 'renderer/p2p/socket_dispatcher.cc', - 'renderer/p2p/socket_dispatcher.h', - ], - }], ['toolkit_uses_gtk == 1', { 'conditions': [ ['input_speech==0', { @@ -307,6 +289,20 @@ 'renderer/media/video_capture_module_impl.h', 'renderer/media/webrtc_audio_device_impl.cc', 'renderer/media/webrtc_audio_device_impl.h', + 'renderer/p2p/host_address_request.cc', + 'renderer/p2p/host_address_request.h', + 'renderer/p2p/ipc_network_manager.cc', + 'renderer/p2p/ipc_network_manager.h', + 'renderer/p2p/ipc_socket_factory.cc', + 'renderer/p2p/ipc_socket_factory.h', + 'renderer/p2p/p2p_transport_impl.cc', + 'renderer/p2p/p2p_transport_impl.h', + 'renderer/p2p/port_allocator.cc', + 'renderer/p2p/port_allocator.h', + 'renderer/p2p/socket_client.cc', + 'renderer/p2p/socket_client.h', + 'renderer/p2p/socket_dispatcher.cc', + 'renderer/p2p/socket_dispatcher.h', ], }], ['java_bridge==1', { diff --git a/content/content_tests.gypi b/content/content_tests.gypi index 0649023..fd4eb5c 100644 --- a/content/content_tests.gypi +++ b/content/content_tests.gypi @@ -320,12 +320,17 @@ 'conditions': [ ['enable_webrtc==1', { 'sources': [ + 'browser/renderer_host/p2p/socket_host_test_utils.h', + 'browser/renderer_host/p2p/socket_host_tcp_unittest.cc', + 'browser/renderer_host/p2p/socket_host_tcp_server_unittest.cc', + 'browser/renderer_host/p2p/socket_host_udp_unittest.cc', 'renderer/media/media_stream_dispatcher_unittest.cc', 'renderer/media/media_stream_impl_unittest.cc', 'renderer/media/peer_connection_handler_jsep_unittest.cc', 'renderer/media/peer_connection_handler_unittest.cc', 'renderer/media/rtc_video_decoder_unittest.cc', 'renderer/media/webrtc_audio_device_unittest.cc', + 'renderer/p2p/p2p_transport_impl_unittest.cc', ], 'dependencies': [ '../third_party/libjingle/libjingle.gyp:libjingle_peerconnection', @@ -353,15 +358,6 @@ 'renderer/active_notification_tracker_unittest.cc', ], }], - ['p2p_apis==1', { - 'sources': [ - 'browser/renderer_host/p2p/socket_host_test_utils.h', - 'browser/renderer_host/p2p/socket_host_tcp_unittest.cc', - 'browser/renderer_host/p2p/socket_host_tcp_server_unittest.cc', - 'browser/renderer_host/p2p/socket_host_udp_unittest.cc', - 'renderer/p2p/p2p_transport_impl_unittest.cc', - ], - }], ['use_x11 == 1', { 'dependencies': [ '../build/linux/system.gyp:dbus', diff --git a/content/renderer/p2p/port_allocator.cc b/content/renderer/p2p/port_allocator.cc index 756e0ac..4a0615e 100644 --- a/content/renderer/p2p/port_allocator.cc +++ b/content/renderer/p2p/port_allocator.cc @@ -12,7 +12,6 @@ #include "jingle/glue/utils.h" #include "net/base/escape.h" #include "net/base/ip_endpoint.h" -#include "ppapi/c/dev/ppb_transport_dev.h" #include "third_party/WebKit/Source/WebKit/chromium/public/WebFrame.h" #include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebURLError.h" #include "third_party/WebKit/Source/WebKit/chromium/public/platform/WebURLLoader.h" diff --git a/content/renderer/pepper/pepper_plugin_delegate_impl.cc b/content/renderer/pepper/pepper_plugin_delegate_impl.cc index d6a80c4..630dc78 100644 --- a/content/renderer/pepper/pepper_plugin_delegate_impl.cc +++ b/content/renderer/pepper/pepper_plugin_delegate_impl.cc @@ -1159,7 +1159,7 @@ void PepperPluginDelegateImpl::UnregisterHostResolver(uint32 host_resolver_id) { bool PepperPluginDelegateImpl::AddNetworkListObserver( webkit_glue::NetworkListObserver* observer) { -#if defined(ENABLE_P2P_APIS) +#if defined(ENABLE_WEBRTC) P2PSocketDispatcher* socket_dispatcher = render_view_->p2p_socket_dispatcher(); if (!socket_dispatcher) { @@ -1174,7 +1174,7 @@ bool PepperPluginDelegateImpl::AddNetworkListObserver( void PepperPluginDelegateImpl::RemoveNetworkListObserver( webkit_glue::NetworkListObserver* observer) { -#if defined(ENABLE_P2P_APIS) +#if defined(ENABLE_WEBRTC) P2PSocketDispatcher* socket_dispatcher = render_view_->p2p_socket_dispatcher(); if (socket_dispatcher) diff --git a/content/renderer/render_view_impl.cc b/content/renderer/render_view_impl.cc index b31576c..f37da15 100644 --- a/content/renderer/render_view_impl.cc +++ b/content/renderer/render_view_impl.cc @@ -599,12 +599,9 @@ RenderViewImpl::RenderViewImpl( host_window_ = parent_hwnd; -#if defined(ENABLE_P2P_APIS) +#if defined(ENABLE_WEBRTC) if (!p2p_socket_dispatcher_) p2p_socket_dispatcher_ = new content::P2PSocketDispatcher(this); -#endif - -#if defined(ENABLE_WEBRTC) if (!media_stream_dispatcher_) media_stream_dispatcher_ = new MediaStreamDispatcher(this); #endif @@ -3442,12 +3439,10 @@ void RenderViewImpl::EnsureMediaStreamImpl() { if (!RenderThreadImpl::current()) // Will be NULL during unit tests. return; -#if defined(ENABLE_P2P_APIS) +#if defined(ENABLE_WEBRTC) if (!p2p_socket_dispatcher_) p2p_socket_dispatcher_ = new content::P2PSocketDispatcher(this); -#endif -#if defined(ENABLE_WEBRTC) if (!media_stream_dispatcher_) media_stream_dispatcher_ = new MediaStreamDispatcher(this); diff --git a/ppapi/api/dev/ppb_transport_dev.idl b/ppapi/api/dev/ppb_transport_dev.idl deleted file mode 100644 index 24d552e..0000000 --- a/ppapi/api/dev/ppb_transport_dev.idl +++ /dev/null @@ -1,183 +0,0 @@ -/* Copyright (c) 2012 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. - */ - -/** - * This file defines the <code>PPB_Transport_Dev</code> interface. - */ -label Chrome { - M14 = 0.7 -}; - -[assert_size(4)] -enum PP_TransportType { - PP_TRANSPORTTYPE_DATAGRAM = 0, - PP_TRANSPORTTYPE_STREAM = 1 -}; - -[assert_size(4)] -enum PP_TransportProperty { - /** - * STUN server address and port, e.g "stun.example.com:19302". - */ - PP_TRANSPORTPROPERTY_STUN_SERVER = 0, - - /** - * Relay server address and port, e.g. "relay.example.com:12344". - */ - PP_TRANSPORTPROPERTY_RELAY_SERVER = 1, - - /** - * Username for the relay server. - */ - PP_TRANSPORTPROPERTY_RELAY_USERNAME = 2, - - /** - * Password for the relay server. - */ - PP_TRANSPORTPROPERTY_RELAY_PASSWORD = 3, - - /** - * Type of Relay server. Must be one of the PP_TransportRelayMode values. By - * default is set to PP_TRANSPORTRELAYMODE_TURN. - */ - PP_TRANSPORTPROPERTY_RELAY_MODE = 4, - - /** - * TCP receive window in bytes. Takes effect only for PseudoTCP connections. - */ - PP_TRANSPORTPROPERTY_TCP_RECEIVE_WINDOW = 5, - - /** - * TCP send window in bytes. Takes effect only for PseudoTCP connections. - */ - PP_TRANSPORTPROPERTY_TCP_SEND_WINDOW = 6, - - /** - * Boolean value that disables Neagle's algorithm when set to true. When - * Neagle's algorithm is disabled, all outgoing packets are sent as soon as - * possible. When set to false (by default) data may be buffered until there - * is a sufficient amount to send. - */ - PP_TRANSPORTPROPERTY_TCP_NO_DELAY = 7, - - /** - * Delay for ACK packets in milliseconds. By default set to 100ms. - */ - PP_TRANSPORTPROPERTY_TCP_ACK_DELAY = 8, - - /** - * Boolean value that disables TCP-based transports when set to true. By - * default set to false. - */ - PP_TRANSPORTPROPERTY_DISABLE_TCP_TRANSPORT = 9 -}; - -[assert_size(4)] -enum PP_TransportRelayMode { - /** - * RFC5766 compliant relay server. - */ - PP_TRANSPORTRELAYMODE_TURN = 0, - - /** - * Legacy Google relay server. - */ - PP_TRANSPORTRELAYMODE_GOOGLE = 1 -}; - -/** - * The transport interface provides peer-to-peer communication. - * - * TODO(juberti): other getters/setters - * connect state - * connect type, protocol - * RTT - */ -interface PPB_Transport_Dev { - /** - * Creates a new transport object with the specified name using the - * specified protocol. - */ - PP_Resource CreateTransport( - [in] PP_Instance instance, - [in] str_t name, - [in] PP_TransportType type); - - /** - * Returns PP_TRUE if resource is a Transport, PP_FALSE otherwise. - */ - PP_Bool IsTransport( - [in] PP_Resource resource); - - /** - * Returns PP_TRUE if the transport is currently writable (i.e. can - * send data to the remote peer), PP_FALSE otherwise. - */ - PP_Bool IsWritable( - [in] PP_Resource transport); - - /** - * Sets various configuration properties of the transport. - */ - int32_t SetProperty( - [in] PP_Resource transport, - [in] PP_TransportProperty property, - [in] PP_Var value); - - /** - * Establishes a connection to the remote peer. Returns - * PP_OK_COMPLETIONPENDING and notifies on |cb| when connectivity is - * established (or timeout occurs). - */ - int32_t Connect( - [in] PP_Resource transport, - [in] PP_CompletionCallback cb); - - /** - * Obtains another ICE candidate address to be provided to the - * remote peer. Returns PP_OK_COMPLETIONPENDING if there are no more - * addresses to be sent. After the callback is called - * GetNextAddress() must be called again to get the address. - */ - int32_t GetNextAddress( - [in] PP_Resource transport, - [out] PP_Var address, - [in] PP_CompletionCallback cb); - - /** - * Provides an ICE candidate address that was received from the remote peer. - */ - int32_t ReceiveRemoteAddress( - [in] PP_Resource transport, - [in] PP_Var address); - - /** - * Like recv(), receives data. Returns PP_OK_COMPLETIONPENDING if there is - * currently no data to receive. In that case, the |data| pointer should - * remain valid until the callback is called. - */ - int32_t Recv( - [in] PP_Resource transport, - [out] mem_t data, - [in] uint32_t len, - [in] PP_CompletionCallback cb); - - /** - * Like send(), sends data. Returns PP_OK_COMPLETIONPENDING if the socket is - * currently flow-controlled. In that case, the |data| pointer should remain - * valid until the callback is called. - */ - int32_t Send( - [in] PP_Resource transport, - [in] mem_t data, - [in] uint32_t len, - [in] PP_CompletionCallback cb); - - /** - * Disconnects from the remote peer. - */ - int32_t Close( - [in] PP_Resource transport); -}; diff --git a/ppapi/c/dev/ppb_transport_dev.h b/ppapi/c/dev/ppb_transport_dev.h deleted file mode 100644 index 47c4f3c..0000000 --- a/ppapi/c/dev/ppb_transport_dev.h +++ /dev/null @@ -1,186 +0,0 @@ -/* Copyright (c) 2012 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. - */ - -/* From dev/ppb_transport_dev.idl modified Wed Oct 5 14:06:02 2011. */ - -#ifndef PPAPI_C_DEV_PPB_TRANSPORT_DEV_H_ -#define PPAPI_C_DEV_PPB_TRANSPORT_DEV_H_ - -#include "ppapi/c/pp_bool.h" -#include "ppapi/c/pp_completion_callback.h" -#include "ppapi/c/pp_instance.h" -#include "ppapi/c/pp_macros.h" -#include "ppapi/c/pp_resource.h" -#include "ppapi/c/pp_stdint.h" -#include "ppapi/c/pp_var.h" - -#define PPB_TRANSPORT_DEV_INTERFACE_0_7 "PPB_Transport(Dev);0.7" -#define PPB_TRANSPORT_DEV_INTERFACE PPB_TRANSPORT_DEV_INTERFACE_0_7 - -/** - * @file - * This file defines the <code>PPB_Transport_Dev</code> interface. - */ - - -/** - * @addtogroup Enums - * @{ - */ -typedef enum { - PP_TRANSPORTTYPE_DATAGRAM = 0, - PP_TRANSPORTTYPE_STREAM = 1 -} PP_TransportType; -PP_COMPILE_ASSERT_SIZE_IN_BYTES(PP_TransportType, 4); - -typedef enum { - /** - * STUN server address and port, e.g "stun.example.com:19302". - */ - PP_TRANSPORTPROPERTY_STUN_SERVER = 0, - /** - * Relay server address and port, e.g. "relay.example.com:12344". - */ - PP_TRANSPORTPROPERTY_RELAY_SERVER = 1, - /** - * Username for the relay server. - */ - PP_TRANSPORTPROPERTY_RELAY_USERNAME = 2, - /** - * Password for the relay server. - */ - PP_TRANSPORTPROPERTY_RELAY_PASSWORD = 3, - /** - * Type of Relay server. Must be one of the PP_TransportRelayMode values. By - * default is set to PP_TRANSPORTRELAYMODE_TURN. - */ - PP_TRANSPORTPROPERTY_RELAY_MODE = 4, - /** - * TCP receive window in bytes. Takes effect only for PseudoTCP connections. - */ - PP_TRANSPORTPROPERTY_TCP_RECEIVE_WINDOW = 5, - /** - * TCP send window in bytes. Takes effect only for PseudoTCP connections. - */ - PP_TRANSPORTPROPERTY_TCP_SEND_WINDOW = 6, - /** - * Boolean value that disables Neagle's algorithm when set to true. When - * Neagle's algorithm is disabled, all outgoing packets are sent as soon as - * possible. When set to false (by default) data may be buffered until there - * is a sufficient amount to send. - */ - PP_TRANSPORTPROPERTY_TCP_NO_DELAY = 7, - /** - * Delay for ACK packets in milliseconds. By default set to 100ms. - */ - PP_TRANSPORTPROPERTY_TCP_ACK_DELAY = 8, - /** - * Boolean value that disables TCP-based transports when set to true. By - * default set to false. - */ - PP_TRANSPORTPROPERTY_DISABLE_TCP_TRANSPORT = 9 -} PP_TransportProperty; -PP_COMPILE_ASSERT_SIZE_IN_BYTES(PP_TransportProperty, 4); - -typedef enum { - /** - * RFC5766 compliant relay server. - */ - PP_TRANSPORTRELAYMODE_TURN = 0, - /** - * Legacy Google relay server. - */ - PP_TRANSPORTRELAYMODE_GOOGLE = 1 -} PP_TransportRelayMode; -PP_COMPILE_ASSERT_SIZE_IN_BYTES(PP_TransportRelayMode, 4); -/** - * @} - */ - -/** - * @addtogroup Interfaces - * @{ - */ -/** - * The transport interface provides peer-to-peer communication. - * - * TODO(juberti): other getters/setters - * connect state - * connect type, protocol - * RTT - */ -struct PPB_Transport_Dev_0_7 { - /** - * Creates a new transport object with the specified name using the - * specified protocol. - */ - PP_Resource (*CreateTransport)(PP_Instance instance, - const char* name, - PP_TransportType type); - /** - * Returns PP_TRUE if resource is a Transport, PP_FALSE otherwise. - */ - PP_Bool (*IsTransport)(PP_Resource resource); - /** - * Returns PP_TRUE if the transport is currently writable (i.e. can - * send data to the remote peer), PP_FALSE otherwise. - */ - PP_Bool (*IsWritable)(PP_Resource transport); - /** - * Sets various configuration properties of the transport. - */ - int32_t (*SetProperty)(PP_Resource transport, - PP_TransportProperty property, - struct PP_Var value); - /** - * Establishes a connection to the remote peer. Returns - * PP_OK_COMPLETIONPENDING and notifies on |cb| when connectivity is - * established (or timeout occurs). - */ - int32_t (*Connect)(PP_Resource transport, struct PP_CompletionCallback cb); - /** - * Obtains another ICE candidate address to be provided to the - * remote peer. Returns PP_OK_COMPLETIONPENDING if there are no more - * addresses to be sent. After the callback is called - * GetNextAddress() must be called again to get the address. - */ - int32_t (*GetNextAddress)(PP_Resource transport, - struct PP_Var* address, - struct PP_CompletionCallback cb); - /** - * Provides an ICE candidate address that was received from the remote peer. - */ - int32_t (*ReceiveRemoteAddress)(PP_Resource transport, struct PP_Var address); - /** - * Like recv(), receives data. Returns PP_OK_COMPLETIONPENDING if there is - * currently no data to receive. In that case, the |data| pointer should - * remain valid until the callback is called. - */ - int32_t (*Recv)(PP_Resource transport, - void* data, - uint32_t len, - struct PP_CompletionCallback cb); - /** - * Like send(), sends data. Returns PP_OK_COMPLETIONPENDING if the socket is - * currently flow-controlled. In that case, the |data| pointer should remain - * valid until the callback is called. - */ - int32_t (*Send)(PP_Resource transport, - const void* data, - uint32_t len, - struct PP_CompletionCallback cb); - /** - * Disconnects from the remote peer. - */ - int32_t (*Close)(PP_Resource transport); -}; - -typedef struct PPB_Transport_Dev_0_7 PPB_Transport_Dev; -/** - * @} - */ - -#endif /* PPAPI_C_DEV_PPB_TRANSPORT_DEV_H_ */ - diff --git a/ppapi/cpp/dev/transport_dev.cc b/ppapi/cpp/dev/transport_dev.cc deleted file mode 100644 index c1153b8..0000000 --- a/ppapi/cpp/dev/transport_dev.cc +++ /dev/null @@ -1,94 +0,0 @@ -// 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. - -#include "ppapi/cpp/dev/transport_dev.h" - -#include "ppapi/c/pp_errors.h" -#include "ppapi/cpp/instance_handle.h" -#include "ppapi/cpp/resource.h" -#include "ppapi/cpp/module.h" -#include "ppapi/cpp/module_impl.h" -#include "ppapi/cpp/var.h" - -namespace pp { - -namespace { - -template <> const char* interface_name<PPB_Transport_Dev>() { - return PPB_TRANSPORT_DEV_INTERFACE; -} - -} // namespace - -Transport_Dev::Transport_Dev(const InstanceHandle& instance, - const char* name, - PP_TransportType type) { - if (has_interface<PPB_Transport_Dev>()) - PassRefFromConstructor(get_interface<PPB_Transport_Dev>()->CreateTransport( - instance.pp_instance(), name, type)); -} - -bool Transport_Dev::IsWritable() { - if (!has_interface<PPB_Transport_Dev>()) - return false; - return PP_ToBool( - get_interface<PPB_Transport_Dev>()->IsWritable(pp_resource())); -} - -int32_t Transport_Dev::SetProperty(PP_TransportProperty property, - const Var& value) { - if (!has_interface<PPB_Transport_Dev>()) - return PP_ERROR_NOINTERFACE; - return get_interface<PPB_Transport_Dev>()->SetProperty( - pp_resource(), property, value.pp_var()); -} - -int32_t Transport_Dev::Connect(const CompletionCallback& cc) { - if (!has_interface<PPB_Transport_Dev>()) - return cc.MayForce(PP_ERROR_NOINTERFACE); - return get_interface<PPB_Transport_Dev>()->Connect( - pp_resource(), cc.pp_completion_callback()); -} - -int32_t Transport_Dev::GetNextAddress(Var* address, - const CompletionCallback& cc) { - if (!has_interface<PPB_Transport_Dev>()) - return cc.MayForce(PP_ERROR_NOINTERFACE); - PP_Var temp_address = PP_MakeUndefined(); - int32_t ret_val = get_interface<PPB_Transport_Dev>()->GetNextAddress( - pp_resource(), &temp_address, cc.pp_completion_callback()); - *address = Var(PASS_REF, temp_address); - return ret_val; -} - -int32_t Transport_Dev::ReceiveRemoteAddress(const pp::Var& address) { - if (!has_interface<PPB_Transport_Dev>()) - return PP_ERROR_NOINTERFACE; - return get_interface<PPB_Transport_Dev>()->ReceiveRemoteAddress( - pp_resource(), address.pp_var()); -} - -int32_t Transport_Dev::Recv(void* data, uint32_t len, - const CompletionCallback& cc) { - if (!has_interface<PPB_Transport_Dev>()) - return cc.MayForce(PP_ERROR_NOINTERFACE); - return get_interface<PPB_Transport_Dev>()->Recv( - pp_resource(), data, len, cc.pp_completion_callback()); -} - -int32_t Transport_Dev::Send(const void* data, uint32_t len, - const CompletionCallback& cc) { - if (!has_interface<PPB_Transport_Dev>()) - return cc.MayForce(PP_ERROR_NOINTERFACE); - return get_interface<PPB_Transport_Dev>()->Send( - pp_resource(), data, len, cc.pp_completion_callback()); -} - -int32_t Transport_Dev::Close() { - if (!has_interface<PPB_Transport_Dev>()) - return PP_ERROR_NOINTERFACE; - return get_interface<PPB_Transport_Dev>()->Close(pp_resource()); -} - -} // namespace pp diff --git a/ppapi/cpp/dev/transport_dev.h b/ppapi/cpp/dev/transport_dev.h deleted file mode 100644 index 8545583..0000000 --- a/ppapi/cpp/dev/transport_dev.h +++ /dev/null @@ -1,37 +0,0 @@ -// 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 PPAPI_CPP_DEV_TRANSPORT_DEV_H_ -#define PPAPI_CPP_DEV_TRANSPORT_DEV_H_ - -#include "ppapi/c/dev/ppb_transport_dev.h" -#include "ppapi/cpp/completion_callback.h" -#include "ppapi/cpp/resource.h" - -namespace pp { - -class InstanceHandle; -class Var; - -class Transport_Dev : public Resource { - public: - Transport_Dev(const InstanceHandle& instance, - const char* name, - PP_TransportType type); - - bool IsWritable(); - int32_t SetProperty(PP_TransportProperty property, const Var& value); - int32_t Connect(const CompletionCallback& cc); - int32_t GetNextAddress(pp::Var* address, const CompletionCallback& cc); - int32_t ReceiveRemoteAddress(const pp::Var& address); - int32_t Recv(void* data, uint32_t len, - const CompletionCallback& cc); - int32_t Send(const void* data, uint32_t len, - const CompletionCallback& cb); - int32_t Close(); -}; - -} // namespace pp - -#endif // PPAPI_CPP_DEV_TRANSPORT_DEV_H_ diff --git a/ppapi/ppapi_proxy_untrusted.gypi b/ppapi/ppapi_proxy_untrusted.gypi index c6d117a..4f86d63 100644 --- a/ppapi/ppapi_proxy_untrusted.gypi +++ b/ppapi/ppapi_proxy_untrusted.gypi @@ -323,7 +323,6 @@ # 'thunk/ppb_tcp_server_socket_private_thunk.cc', # 'thunk/ppb_tcp_socket_private_thunk.cc', 'thunk/ppb_text_input_thunk.cc', -# 'thunk/ppb_transport_thunk.cc', # 'thunk/ppb_udp_socket_private_thunk.cc', 'thunk/ppb_url_loader_thunk.cc', 'thunk/ppb_url_request_info_thunk.cc', diff --git a/ppapi/ppapi_shared.gypi b/ppapi/ppapi_shared.gypi index f04a0c6..d9d0140 100644 --- a/ppapi/ppapi_shared.gypi +++ b/ppapi/ppapi_shared.gypi @@ -231,8 +231,6 @@ 'thunk/ppb_tcp_socket_private_api.h', 'thunk/ppb_tcp_socket_private_thunk.cc', 'thunk/ppb_text_input_thunk.cc', - 'thunk/ppb_transport_api.h', - 'thunk/ppb_transport_thunk.cc', 'thunk/ppb_udp_socket_private_api.h', 'thunk/ppb_udp_socket_private_thunk.cc', 'thunk/ppb_url_loader_api.h', diff --git a/ppapi/ppapi_sources.gypi b/ppapi/ppapi_sources.gypi index 6e6d617..6b14eaf 100644 --- a/ppapi/ppapi_sources.gypi +++ b/ppapi/ppapi_sources.gypi @@ -443,17 +443,4 @@ 'tests/test_var_deprecated.h', ], }, - 'conditions': [ - ['p2p_apis==1', { - 'variables': { - 'c_source_files': [ - 'c/dev/ppb_transport_dev.h', - ], - 'cpp_source_files': [ - 'cpp/dev/transport_dev.cc', - 'cpp/dev/transport_dev.h', - ], - }, - }], - ], } diff --git a/ppapi/ppapi_tests.gypi b/ppapi/ppapi_tests.gypi index 10f30e6..9956c66 100644 --- a/ppapi/ppapi_tests.gypi +++ b/ppapi/ppapi_tests.gypi @@ -94,12 +94,6 @@ 'product_name': 'ppapi_tests', 'product_extension': 'plugin', }], - ['p2p_apis==1', { - 'sources': [ - 'tests/test_transport.cc', - 'tests/test_transport.h', - ], - }], ], # TODO(dmichael): Figure out what is wrong with the script on Windows and add # it as an automated action. diff --git a/ppapi/proxy/resource_creation_proxy.cc b/ppapi/proxy/resource_creation_proxy.cc index 41a6c7c..f25d9de 100644 --- a/ppapi/proxy/resource_creation_proxy.cc +++ b/ppapi/proxy/resource_creation_proxy.cc @@ -296,13 +296,6 @@ PP_Resource ResourceCreationProxy::CreateTCPSocketPrivate( return PPB_TCPSocket_Private_Proxy::CreateProxyResource(instance); } -PP_Resource ResourceCreationProxy::CreateTransport(PP_Instance instance, - const char* name, - PP_TransportType type) { - NOTIMPLEMENTED(); // Not proxied yet. - return 0; -} - PP_Resource ResourceCreationProxy::CreateUDPSocketPrivate( PP_Instance instance) { return PPB_UDPSocket_Private_Proxy::CreateProxyResource(instance); diff --git a/ppapi/proxy/resource_creation_proxy.h b/ppapi/proxy/resource_creation_proxy.h index d6a2e76..9c18f27 100644 --- a/ppapi/proxy/resource_creation_proxy.h +++ b/ppapi/proxy/resource_creation_proxy.h @@ -135,9 +135,6 @@ class ResourceCreationProxy : public InterfaceProxy, virtual PP_Resource CreateTCPServerSocketPrivate( PP_Instance instance) OVERRIDE; virtual PP_Resource CreateTCPSocketPrivate(PP_Instance instance) OVERRIDE; - virtual PP_Resource CreateTransport(PP_Instance instance, - const char* name, - PP_TransportType type) OVERRIDE; virtual PP_Resource CreateUDPSocketPrivate(PP_Instance instance) OVERRIDE; virtual PP_Resource CreateVideoCapture(PP_Instance instance) OVERRIDE; virtual PP_Resource CreateVideoDecoder( diff --git a/ppapi/shared_impl/resource.h b/ppapi/shared_impl/resource.h index 5b03f53..f920262 100644 --- a/ppapi/shared_impl/resource.h +++ b/ppapi/shared_impl/resource.h @@ -52,7 +52,6 @@ F(PPB_Talk_Private_API) \ F(PPB_TCPServerSocket_Private_API) \ F(PPB_TCPSocket_Private_API) \ - F(PPB_Transport_API) \ F(PPB_UDPSocket_Private_API) \ F(PPB_URLLoader_API) \ F(PPB_URLRequestInfo_API) \ diff --git a/ppapi/tests/all_c_includes.h b/ppapi/tests/all_c_includes.h index 0732ded..d4f3a0c 100644 --- a/ppapi/tests/all_c_includes.h +++ b/ppapi/tests/all_c_includes.h @@ -29,7 +29,6 @@ #include "ppapi/c/dev/ppb_scrollbar_dev.h" #include "ppapi/c/dev/ppb_testing_dev.h" #include "ppapi/c/dev/ppb_text_input_dev.h" -#include "ppapi/c/dev/ppb_transport_dev.h" #include "ppapi/c/dev/ppb_url_util_dev.h" #include "ppapi/c/dev/ppb_var_deprecated.h" #include "ppapi/c/dev/ppb_video_decoder_dev.h" diff --git a/ppapi/tests/all_cpp_includes.h b/ppapi/tests/all_cpp_includes.h index 0db1b77..0aca7aa 100644 --- a/ppapi/tests/all_cpp_includes.h +++ b/ppapi/tests/all_cpp_includes.h @@ -28,7 +28,6 @@ #include "ppapi/cpp/dev/scrollbar_dev.h" #include "ppapi/cpp/dev/selection_dev.h" #include "ppapi/cpp/dev/text_input_dev.h" -#include "ppapi/cpp/dev/transport_dev.h" #include "ppapi/cpp/dev/url_util_dev.h" #include "ppapi/cpp/dev/video_decoder_dev.h" #include "ppapi/cpp/dev/widget_client_dev.h" diff --git a/ppapi/tests/test_transport.cc b/ppapi/tests/test_transport.cc deleted file mode 100644 index d8bb134..0000000 --- a/ppapi/tests/test_transport.cc +++ /dev/null @@ -1,373 +0,0 @@ -// Copyright (c) 2012 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. - -#include "ppapi/tests/test_transport.h" - -#include <stdlib.h> -#include <string.h> - -#include <list> -#include <map> - -#include "ppapi/c/dev/ppb_testing_dev.h" -#include "ppapi/c/pp_errors.h" -#include "ppapi/c/pp_macros.h" -#include "ppapi/cpp/dev/transport_dev.h" -#include "ppapi/cpp/instance.h" -#include "ppapi/cpp/module.h" -#include "ppapi/cpp/var.h" -#include "ppapi/tests/test_utils.h" -#include "ppapi/tests/testing_instance.h" -#include "ppapi/utility/completion_callback_factory.h" - -REGISTER_TEST_CASE(Transport); - -namespace { - -const char kTestChannelName[] = "test"; -const int kReadBufferSize = 65536; - -class StreamReader { - public: - StreamReader(pp::Transport_Dev* transport, - int expected_size, - pp::CompletionCallback done_callback) - : expected_size_(expected_size), - done_callback_(done_callback), - PP_ALLOW_THIS_IN_INITIALIZER_LIST(callback_factory_(this)), - transport_(transport), - received_size_(0) { - Read(); - } - - const std::list<std::vector<char> >& received() { return received_; } - std::list<std::string> errors() { return errors_; } - - private: - void Read() { - while (true) { - buffer_.resize(kReadBufferSize); - int result = transport_->Recv( - &buffer_[0], buffer_.size(), - callback_factory_.NewOptionalCallback(&StreamReader::OnReadFinished)); - if (result > 0) - DidFinishRead(result); - else - break; - } - } - - void OnReadFinished(int result) { - DidFinishRead(result); - if (result > 0) - Read(); - } - - void DidFinishRead(int result) { - if (result > 0) { - if (result > static_cast<int>(buffer_.size())) { - errors_.push_back(TestCase::MakeFailureMessage( - __FILE__, __LINE__, - "Recv() returned value that is bigger than the buffer.")); - } - buffer_.resize(result); - received_.push_back(buffer_); - received_size_ += buffer_.size(); - if (received_size_ >= expected_size_) - done_callback_.Run(0); - } - } - - int expected_size_; - pp::CompletionCallback done_callback_; - pp::CompletionCallbackFactory<StreamReader> callback_factory_; - pp::Transport_Dev* transport_; - std::vector<char> buffer_; - std::list<std::vector<char> > received_; - int received_size_; - std::list<std::string> errors_; -}; - -} // namespace - -TestTransport::~TestTransport() { - delete transport1_; - delete transport2_; -} - -bool TestTransport::Init() { - transport_interface_ = static_cast<const PPB_Transport_Dev*>( - pp::Module::Get()->GetBrowserInterface(PPB_TRANSPORT_DEV_INTERFACE)); - return transport_interface_ && CheckTestingInterface(); -} - -void TestTransport::RunTests(const std::string& filter) { - RUN_TEST(Create, filter); - RUN_TEST_FORCEASYNC_AND_NOT(Connect, filter); - RUN_TEST(SetProperty, filter); - RUN_TEST_FORCEASYNC_AND_NOT(SendDataUdp, filter); - RUN_TEST_FORCEASYNC_AND_NOT(SendDataTcp, filter); - RUN_TEST_FORCEASYNC_AND_NOT(ConnectAndCloseUdp, filter); - RUN_TEST_FORCEASYNC_AND_NOT(ConnectAndCloseTcp, filter); -} - -std::string TestTransport::InitTargets(PP_TransportType type) { - transport1_ = new pp::Transport_Dev(instance_, kTestChannelName, type); - transport2_ = new pp::Transport_Dev(instance_, kTestChannelName, type); - - ASSERT_NE(NULL, transport1_); - ASSERT_NE(NULL, transport2_); - - PASS(); -} - -std::string TestTransport::Connect() { - TestCompletionCallback connect_cb1(instance_->pp_instance()); - TestCompletionCallback connect_cb2(instance_->pp_instance()); - ASSERT_EQ(transport1_->Connect(connect_cb1), PP_OK_COMPLETIONPENDING); - ASSERT_EQ(transport2_->Connect(connect_cb2), PP_OK_COMPLETIONPENDING); - - pp::Var address1; - pp::Var address2; - TestCompletionCallback next_address_cb1(instance_->pp_instance()); - TestCompletionCallback next_address_cb2(instance_->pp_instance()); - ASSERT_EQ(transport1_->GetNextAddress(&address1, next_address_cb1), - PP_OK_COMPLETIONPENDING); - ASSERT_EQ(transport2_->GetNextAddress(&address2, next_address_cb2), - PP_OK_COMPLETIONPENDING); - ASSERT_EQ(next_address_cb1.WaitForResult(), PP_OK); - ASSERT_EQ(next_address_cb2.WaitForResult(), PP_OK); - ASSERT_EQ(transport1_->GetNextAddress(&address1, next_address_cb1), PP_OK); - ASSERT_EQ(transport2_->GetNextAddress(&address2, next_address_cb2), PP_OK); - - ASSERT_EQ(transport1_->ReceiveRemoteAddress(address2), PP_OK); - ASSERT_EQ(transport2_->ReceiveRemoteAddress(address1), PP_OK); - - - ASSERT_EQ(connect_cb1.WaitForResult(), PP_OK); - ASSERT_EQ(connect_cb2.WaitForResult(), PP_OK); - - ASSERT_TRUE(transport1_->IsWritable()); - ASSERT_TRUE(transport2_->IsWritable()); - - PASS(); -} - -std::string TestTransport::Clean() { - delete transport1_; - transport1_ = NULL; - delete transport2_; - transport2_ = NULL; - - PASS(); -} - -std::string TestTransport::TestCreate() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_DATAGRAM)); - - Clean(); - - PASS(); -} - -std::string TestTransport::TestSetProperty() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_STREAM)); - - // Try settings STUN and Relay properties. - ASSERT_EQ(transport1_->SetProperty( - PP_TRANSPORTPROPERTY_STUN_SERVER, - pp::Var("stun.example.com:19302")), PP_OK); - - ASSERT_EQ(transport1_->SetProperty( - PP_TRANSPORTPROPERTY_RELAY_SERVER, - pp::Var("ralay.example.com:80")), PP_OK); - - ASSERT_EQ(transport1_->SetProperty( - PP_TRANSPORTPROPERTY_RELAY_USERNAME, - pp::Var("USERNAME")), PP_OK); - ASSERT_EQ(transport1_->SetProperty( - PP_TRANSPORTPROPERTY_RELAY_PASSWORD, - pp::Var("PASSWORD")), PP_OK); - - // Try changing TCP window size. - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_RECEIVE_WINDOW, - pp::Var(65536)), PP_OK); - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_RECEIVE_WINDOW, - pp::Var(10000000)), PP_ERROR_BADARGUMENT); - - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_SEND_WINDOW, - pp::Var(65536)), PP_OK); - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_SEND_WINDOW, - pp::Var(10000000)), PP_ERROR_BADARGUMENT); - - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_NO_DELAY, - pp::Var(true)), PP_OK); - - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_ACK_DELAY, - pp::Var(10)), PP_OK); - ASSERT_EQ(transport1_->SetProperty(PP_TRANSPORTPROPERTY_TCP_ACK_DELAY, - pp::Var(10000)), PP_ERROR_BADARGUMENT); - - TestCompletionCallback connect_cb(instance_->pp_instance()); - ASSERT_EQ(transport1_->Connect(connect_cb), PP_OK_COMPLETIONPENDING); - - // SetProperty() should fail after we've connected. - ASSERT_EQ(transport1_->SetProperty( - PP_TRANSPORTPROPERTY_STUN_SERVER, - pp::Var("stun.example.com:31323")), PP_ERROR_FAILED); - - Clean(); - ASSERT_EQ(connect_cb.WaitForResult(), PP_ERROR_ABORTED); - - PASS(); -} - -std::string TestTransport::TestConnect() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_DATAGRAM)); - ASSERT_SUBTEST_SUCCESS(Connect()); - - Clean(); - - PASS(); -} - -// Creating datagram connection and try sending data over it. Verify -// that at least some packets are received (some packets may be lost). -std::string TestTransport::TestSendDataUdp() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_DATAGRAM)); - ASSERT_SUBTEST_SUCCESS(Connect()); - - const int kNumPackets = 100; - const int kSendBufferSize = 1200; - const int kUdpWaitTimeMs = 1000; // 1 second. - - TestCompletionCallback done_cb(instance_->pp_instance()); - StreamReader reader(transport1_, kSendBufferSize * kNumPackets, done_cb); - - std::map<int, std::vector<char> > sent_packets; - for (int i = 0; i < kNumPackets; ++i) { - std::vector<char> send_buffer(kSendBufferSize); - for (size_t j = 0; j < send_buffer.size(); ++j) { - send_buffer[j] = rand() % 256; - } - // Put packet index in the beginning. - memcpy(&send_buffer[0], &i, sizeof(i)); - - TestCompletionCallback send_cb(instance_->pp_instance(), force_async_); - int32_t result = transport2_->Send(&send_buffer[0], send_buffer.size(), - send_cb); - if (force_async_) { - ASSERT_EQ(result, PP_OK_COMPLETIONPENDING); - ASSERT_EQ(send_cb.WaitForResult(), static_cast<int>(send_buffer.size())); - } else { - ASSERT_EQ(result, static_cast<int>(send_buffer.size())); - } - sent_packets[i] = send_buffer; - } - - // Limit waiting time. - TestCompletionCallback timeout_cb(instance_->pp_instance()); - pp::Module::Get()->core()->CallOnMainThread(kUdpWaitTimeMs, timeout_cb); - ASSERT_EQ(timeout_cb.WaitForResult(), PP_OK); - - ASSERT_TRUE(reader.errors().size() == 0); - ASSERT_TRUE(reader.received().size() > 0); - for (std::list<std::vector<char> >::const_iterator it = - reader.received().begin(); it != reader.received().end(); ++it) { - int index; - memcpy(&index, &(*it)[0], sizeof(index)); - ASSERT_TRUE(sent_packets[index] == *it); - } - - Clean(); - - PASS(); -} - -// Creating reliable (TCP-like) connection and try sending data over -// it. Verify that all data is received correctly. -std::string TestTransport::TestSendDataTcp() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_STREAM)); - ASSERT_SUBTEST_SUCCESS(Connect()); - - const int kTcpSendSize = 100000; - - TestCompletionCallback done_cb(instance_->pp_instance()); - StreamReader reader(transport1_, kTcpSendSize, done_cb); - - std::vector<char> send_buffer(kTcpSendSize); - for (size_t j = 0; j < send_buffer.size(); ++j) { - send_buffer[j] = rand() % 256; - } - - int pos = 0; - while (pos < static_cast<int>(send_buffer.size())) { - TestCompletionCallback send_cb(instance_->pp_instance(), force_async_); - int result = transport2_->Send( - &send_buffer[0] + pos, send_buffer.size() - pos, send_cb); - if (force_async_) - ASSERT_EQ(result, PP_OK_COMPLETIONPENDING); - if (result == PP_OK_COMPLETIONPENDING) - result = send_cb.WaitForResult(); - ASSERT_TRUE(result > 0); - pos += result; - } - - ASSERT_EQ(done_cb.WaitForResult(), PP_OK); - - ASSERT_TRUE(reader.errors().size() == 0); - - std::vector<char> received_data; - for (std::list<std::vector<char> >::const_iterator it = - reader.received().begin(); it != reader.received().end(); ++it) { - received_data.insert(received_data.end(), it->begin(), it->end()); - } - ASSERT_EQ(send_buffer, received_data); - - Clean(); - - PASS(); -} - -std::string TestTransport::TestConnectAndCloseUdp() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_DATAGRAM)); - ASSERT_SUBTEST_SUCCESS(Connect()); - - std::vector<char> recv_buffer(kReadBufferSize); - TestCompletionCallback recv_cb(instance_->pp_instance()); - ASSERT_EQ( - transport1_->Recv(&recv_buffer[0], recv_buffer.size(), recv_cb), - PP_OK_COMPLETIONPENDING); - - // Close the transport and verify that callback is aborted. - ASSERT_EQ(transport1_->Close(), PP_OK); - - ASSERT_EQ(recv_cb.run_count(), 1); - ASSERT_EQ(recv_cb.result(), PP_ERROR_ABORTED); - - Clean(); - - PASS(); -} - -std::string TestTransport::TestConnectAndCloseTcp() { - ASSERT_SUBTEST_SUCCESS(InitTargets(PP_TRANSPORTTYPE_STREAM)); - ASSERT_SUBTEST_SUCCESS(Connect()); - - std::vector<char> recv_buffer(kReadBufferSize); - TestCompletionCallback recv_cb(instance_->pp_instance()); - ASSERT_EQ( - transport1_->Recv(&recv_buffer[0], recv_buffer.size(), recv_cb), - PP_OK_COMPLETIONPENDING); - - // Close the transport and verify that callback is aborted. - ASSERT_EQ(transport1_->Close(), PP_OK); - - ASSERT_EQ(recv_cb.run_count(), 1); - ASSERT_EQ(recv_cb.result(), PP_ERROR_ABORTED); - - Clean(); - - PASS(); -} diff --git a/ppapi/tests/test_transport.h b/ppapi/tests/test_transport.h deleted file mode 100644 index eee1c2d..0000000 --- a/ppapi/tests/test_transport.h +++ /dev/null @@ -1,51 +0,0 @@ -// Copyright (c) 2012 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 PPAPI_TESTS_TEST_TRANSPORT_H_ -#define PPAPI_TESTS_TEST_TRANSPORT_H_ - -#include <string> - -#include "ppapi/c/dev/ppb_transport_dev.h" -#include "ppapi/tests/test_case.h" - -namespace pp { -class Transport_Dev; -} // namespace pp - -class TestTransport : public TestCase { - public: - explicit TestTransport(TestingInstance* instance) - : TestCase(instance), - transport1_(NULL), - transport2_(NULL) { - } - virtual ~TestTransport(); - - - // TestCase implementation. - virtual bool Init(); - virtual void RunTests(const std::string& filter); - - private: - std::string InitTargets(PP_TransportType type); - std::string Connect(); - std::string Clean(); - - std::string TestCreate(); - std::string TestConnect(); - std::string TestSetProperty(); - std::string TestSendDataTcp(); - std::string TestSendDataUdp(); - std::string TestConnectAndCloseTcp(); - std::string TestConnectAndCloseUdp(); - - // Used by the tests that access the C API directly. - const PPB_Transport_Dev* transport_interface_; - - pp::Transport_Dev* transport1_; - pp::Transport_Dev* transport2_; -}; - -#endif // PPAPI_TESTS_TEST_TRANSPORT_H_ diff --git a/ppapi/thunk/interfaces_ppb_public_dev.h b/ppapi/thunk/interfaces_ppb_public_dev.h index 692b4f3..f23bb48 100644 --- a/ppapi/thunk/interfaces_ppb_public_dev.h +++ b/ppapi/thunk/interfaces_ppb_public_dev.h @@ -14,7 +14,6 @@ PROXIED_API(PPB_FileChooser) PROXIED_API(PPB_Graphics3D) UNPROXIED_API(PPB_LayerCompositor) UNPROXIED_API(PPB_Scrollbar) -UNPROXIED_API(PPB_Transport) PROXIED_API(PPB_VideoCapture) PROXIED_API(PPB_VideoDecoder) UNPROXIED_API(PPB_WebSocket) @@ -60,8 +59,6 @@ PROXIED_IFACE(PPB_Instance, PPB_TEXTINPUT_DEV_INTERFACE_0_1, PPB_TextInput_Dev_0_1) PROXIED_IFACE(PPB_Instance, PPB_TEXTINPUT_DEV_INTERFACE_0_2, PPB_TextInput_Dev_0_2) -UNPROXIED_IFACE(PPB_Transport, PPB_TRANSPORT_DEV_INTERFACE_0_7, - PPB_Transport_Dev_0_7) PROXIED_IFACE(PPB_VideoCapture, PPB_VIDEOCAPTURE_DEV_INTERFACE_0_1, PPB_VideoCapture_Dev_0_1) PROXIED_IFACE(PPB_VideoCapture, PPB_VIDEOCAPTURE_DEV_INTERFACE_0_2, diff --git a/ppapi/thunk/ppb_transport_api.h b/ppapi/thunk/ppb_transport_api.h deleted file mode 100644 index 256d920..0000000 --- a/ppapi/thunk/ppb_transport_api.h +++ /dev/null @@ -1,33 +0,0 @@ -// 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 PPAPI_THUNK_PPB_TRANSPORT_API_H_ -#define PPAPI_THUNK_PPB_TRANSPORT_API_H_ - -#include "ppapi/c/dev/ppb_transport_dev.h" - -namespace ppapi { -namespace thunk { - -class PPB_Transport_API { - public: - virtual ~PPB_Transport_API() {} - - virtual PP_Bool IsWritable() = 0; - virtual int32_t SetProperty(PP_TransportProperty property, PP_Var value) = 0; - virtual int32_t Connect(PP_CompletionCallback callback) = 0; - virtual int32_t GetNextAddress(PP_Var* address, - PP_CompletionCallback callback) = 0; - virtual int32_t ReceiveRemoteAddress(PP_Var address) = 0; - virtual int32_t Recv(void* data, uint32_t len, - PP_CompletionCallback callback) = 0; - virtual int32_t Send(const void* data, uint32_t len, - PP_CompletionCallback callback) = 0; - virtual int32_t Close() = 0; -}; - -} // namespace thunk -} // namespace ppapi - -#endif // PPAPI_THUNK_PPB_TRANSPORT_API_H_ diff --git a/ppapi/thunk/ppb_transport_thunk.cc b/ppapi/thunk/ppb_transport_thunk.cc deleted file mode 100644 index d739e89..0000000 --- a/ppapi/thunk/ppb_transport_thunk.cc +++ /dev/null @@ -1,112 +0,0 @@ -// Copyright (c) 2012 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. - -#include "ppapi/c/pp_completion_callback.h" -#include "ppapi/c/pp_errors.h" -#include "ppapi/thunk/enter.h" -#include "ppapi/thunk/thunk.h" -#include "ppapi/thunk/ppb_transport_api.h" -#include "ppapi/thunk/resource_creation_api.h" - -namespace ppapi { -namespace thunk { - -namespace { - -typedef EnterResource<PPB_Transport_API> EnterTransport; - -PP_Resource Create(PP_Instance instance, const char* name, - PP_TransportType type) { - EnterResourceCreation enter(instance); - if (enter.failed()) - return 0; - return enter.functions()->CreateTransport(instance, name, type); -} - -PP_Bool IsTransport(PP_Resource resource) { - EnterTransport enter(resource, false); - return PP_FromBool(enter.succeeded()); -} - -PP_Bool IsWritable(PP_Resource transport) { - EnterTransport enter(transport, true); - if (enter.failed()) - return PP_FALSE; - return enter.object()->IsWritable(); -} - -int32_t SetProperty(PP_Resource transport, PP_TransportProperty property, - PP_Var value) { - EnterTransport enter(transport, true); - if (enter.failed()) - return enter.retval(); - return enter.object()->SetProperty(property, value); -} - -int32_t Connect(PP_Resource transport, PP_CompletionCallback callback) { - EnterTransport enter(transport, callback, true); - if (enter.failed()) - return enter.retval(); - return enter.SetResult(enter.object()->Connect(callback)); -} - -int32_t GetNextAddress(PP_Resource transport, PP_Var* address, - PP_CompletionCallback callback) { - EnterTransport enter(transport, callback, true); - if (enter.failed()) - return enter.retval(); - return enter.SetResult(enter.object()->GetNextAddress(address, callback)); -} - -int32_t ReceiveRemoteAddress(PP_Resource transport, PP_Var address) { - EnterTransport enter(transport, true); - if (enter.failed()) - return enter.retval(); - return enter.object()->ReceiveRemoteAddress(address); -} - -int32_t Recv(PP_Resource transport, void* data, uint32_t len, - PP_CompletionCallback callback) { - EnterTransport enter(transport, callback, true); - if (enter.failed()) - return enter.retval(); - return enter.SetResult(enter.object()->Recv(data, len, callback)); -} - -int32_t Send(PP_Resource transport, const void* data, uint32_t len, - PP_CompletionCallback callback) { - EnterTransport enter(transport, callback, true); - if (enter.failed()) - return enter.retval(); - return enter.SetResult(enter.object()->Send(data, len, callback)); -} - -int32_t Close(PP_Resource transport) { - EnterTransport enter(transport, true); - if (enter.failed()) - return enter.retval(); - return enter.object()->Close(); -} - -const PPB_Transport_Dev g_ppb_transport_thunk = { - &Create, - &IsTransport, - &IsWritable, - &SetProperty, - &Connect, - &GetNextAddress, - &ReceiveRemoteAddress, - &Recv, - &Send, - &Close, -}; - -} // namespace - -const PPB_Transport_Dev_0_7* GetPPB_Transport_Dev_0_7_Thunk() { - return &g_ppb_transport_thunk; -} - -} // namespace thunk -} // namespace ppapi diff --git a/ppapi/thunk/resource_creation_api.h b/ppapi/thunk/resource_creation_api.h index 2f214e7..3cd1752 100644 --- a/ppapi/thunk/resource_creation_api.h +++ b/ppapi/thunk/resource_creation_api.h @@ -19,7 +19,6 @@ #include "ppapi/c/ppb_input_event.h" #include "ppapi/c/ppb_websocket.h" #include "ppapi/c/dev/pp_video_dev.h" -#include "ppapi/c/dev/ppb_transport_dev.h" #include "ppapi/c/private/ppb_network_monitor_private.h" #include "ppapi/shared_impl/api_id.h" @@ -138,9 +137,6 @@ class ResourceCreationAPI { virtual PP_Resource CreateTalk(PP_Instance instance) = 0; virtual PP_Resource CreateTCPServerSocketPrivate(PP_Instance instance) = 0; virtual PP_Resource CreateTCPSocketPrivate(PP_Instance instace) = 0; - virtual PP_Resource CreateTransport(PP_Instance instance, - const char* name, - PP_TransportType type) = 0; virtual PP_Resource CreateUDPSocketPrivate(PP_Instance instace) = 0; virtual PP_Resource CreateVideoCapture(PP_Instance instance) = 0; virtual PP_Resource CreateVideoDecoder( diff --git a/webkit/glue/webkit_glue.gypi b/webkit/glue/webkit_glue.gypi index d2fca69..0f3e0c6 100644 --- a/webkit/glue/webkit_glue.gypi +++ b/webkit/glue/webkit_glue.gypi @@ -537,12 +537,6 @@ '<(DEPTH)/webkit/support/setup_third_party.gyp:third_party_headers', ], }], - ['p2p_apis==1', { - 'sources': [ - '../plugins/ppapi/ppb_transport_impl.cc', - '../plugins/ppapi/ppb_transport_impl.h', - ], - }], ], }, ], diff --git a/webkit/plugins/ppapi/plugin_module.cc b/webkit/plugins/ppapi/plugin_module.cc index 147511c..70989bd 100644 --- a/webkit/plugins/ppapi/plugin_module.cc +++ b/webkit/plugins/ppapi/plugin_module.cc @@ -33,7 +33,6 @@ #include "ppapi/c/dev/ppb_scrollbar_dev.h" #include "ppapi/c/dev/ppb_testing_dev.h" #include "ppapi/c/dev/ppb_text_input_dev.h" -#include "ppapi/c/dev/ppb_transport_dev.h" #include "ppapi/c/dev/ppb_url_util_dev.h" #include "ppapi/c/dev/ppb_var_deprecated.h" #include "ppapi/c/dev/ppb_video_capture_dev.h" diff --git a/webkit/plugins/ppapi/ppb_transport_impl.cc b/webkit/plugins/ppapi/ppb_transport_impl.cc deleted file mode 100644 index caa60e4..0000000 --- a/webkit/plugins/ppapi/ppb_transport_impl.cc +++ /dev/null @@ -1,404 +0,0 @@ -// Copyright (c) 2012 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. - -#include "webkit/plugins/ppapi/ppb_transport_impl.h" - -#include "base/message_loop.h" -#include "base/string_util.h" -#include "net/base/io_buffer.h" -#include "net/base/net_errors.h" -#include "net/base/net_util.h" -#include "net/socket/socket.h" -#include "ppapi/c/dev/ppb_transport_dev.h" -#include "ppapi/c/pp_completion_callback.h" -#include "ppapi/c/pp_errors.h" -#include "ppapi/shared_impl/callback_tracker.h" -#include "ppapi/shared_impl/ppapi_globals.h" -#include "ppapi/shared_impl/var.h" -#include "third_party/WebKit/Source/WebKit/chromium/public/WebDocument.h" -#include "third_party/WebKit/Source/WebKit/chromium/public/WebElement.h" -#include "third_party/WebKit/Source/WebKit/chromium/public/WebPluginContainer.h" -#include "webkit/plugins/ppapi/common.h" -#include "webkit/plugins/ppapi/plugin_module.h" -#include "webkit/plugins/ppapi/ppapi_plugin_instance.h" -#include "webkit/plugins/ppapi/resource_helper.h" - -using ppapi::StringVar; -using ppapi::thunk::PPB_Transport_API; -using ppapi::TrackedCallback; -using webkit_glue::P2PTransport; - -namespace webkit { -namespace ppapi { - -namespace { - -const char kUdpProtocolName[] = "udp"; -const char kTcpProtocolName[] = "tcp"; - -const int kMinBufferSize = 1024; -const int kMaxBufferSize = 1024 * 1024; -const int kMinAckDelay = 10; -const int kMaxAckDelay = 1000; - -int MapNetError(int result) { - if (result > 0) - return result; - - switch (result) { - case net::OK: - return PP_OK; - case net::ERR_IO_PENDING: - return PP_OK_COMPLETIONPENDING; - case net::ERR_INVALID_ARGUMENT: - return PP_ERROR_BADARGUMENT; - default: - return PP_ERROR_FAILED; - } -} - -WebKit::WebFrame* GetFrameForResource(const ::ppapi::Resource* resource) { - PluginInstance* plugin_instance = - ResourceHelper::GetPluginInstance(resource); - if (!plugin_instance) - return NULL; - return plugin_instance->container()->element().document().frame(); -} - -} // namespace - -PPB_Transport_Impl::PPB_Transport_Impl(PP_Instance instance) - : Resource(::ppapi::OBJECT_IS_IMPL, instance), - type_(PP_TRANSPORTTYPE_DATAGRAM), - started_(false), - writable_(false) { -} - -PPB_Transport_Impl::~PPB_Transport_Impl() { -} - -// static -PP_Resource PPB_Transport_Impl::Create(PP_Instance instance, - const char* name, - PP_TransportType type) { - scoped_refptr<PPB_Transport_Impl> t(new PPB_Transport_Impl(instance)); - if (!t->Init(name, type)) - return 0; - return t->GetReference(); -} - -PPB_Transport_API* PPB_Transport_Impl::AsPPB_Transport_API() { - return this; -} - -bool PPB_Transport_Impl::Init(const char* name, PP_TransportType type) { - name_ = name; - - if (type != PP_TRANSPORTTYPE_DATAGRAM && type != PP_TRANSPORTTYPE_STREAM) { - LOG(WARNING) << "Unknown transport type: " << type; - return false; - } - type_ = type; - - PluginDelegate* plugin_delegate = ResourceHelper::GetPluginDelegate(this); - if (!plugin_delegate) - return false; - p2p_transport_.reset(plugin_delegate->CreateP2PTransport()); - return p2p_transport_.get() != NULL; -} - -PP_Bool PPB_Transport_Impl::IsWritable() { - if (!p2p_transport_.get()) - return PP_FALSE; - - return PP_FromBool(writable_); -} - -int32_t PPB_Transport_Impl::SetProperty(PP_TransportProperty property, - PP_Var value) { - // SetProperty() may be called only before Connect(). - if (started_) - return PP_ERROR_FAILED; - - switch (property) { - case PP_TRANSPORTPROPERTY_STUN_SERVER: { - StringVar* value_str = StringVar::FromPPVar(value); - if (!value_str) - return PP_ERROR_BADARGUMENT; - if (!net::ParseHostAndPort(value_str->value(), &config_.stun_server, - &config_.stun_server_port)) { - return PP_ERROR_BADARGUMENT; - } - break; - } - - case PP_TRANSPORTPROPERTY_RELAY_SERVER: { - StringVar* value_str = StringVar::FromPPVar(value); - if (!value_str) - return PP_ERROR_BADARGUMENT; - if (!net::ParseHostAndPort(value_str->value(), &config_.relay_server, - &config_.relay_server_port)) { - return PP_ERROR_BADARGUMENT; - } - break; - } - - case PP_TRANSPORTPROPERTY_RELAY_USERNAME: { - StringVar* value_str = StringVar::FromPPVar(value); - if (!value_str) - return PP_ERROR_BADARGUMENT; - config_.relay_username = value_str->value(); - break; - } - - case PP_TRANSPORTPROPERTY_RELAY_PASSWORD: { - StringVar* value_str = StringVar::FromPPVar(value); - if (!value_str) - return PP_ERROR_BADARGUMENT; - config_.relay_password = value_str->value(); - break; - } - - case PP_TRANSPORTPROPERTY_RELAY_MODE: { - switch (value.value.as_int) { - case PP_TRANSPORTRELAYMODE_TURN: - config_.legacy_relay = false; - break; - case PP_TRANSPORTRELAYMODE_GOOGLE: - config_.legacy_relay = true; - break; - default: - return PP_ERROR_BADARGUMENT; - } - break; - } - - case PP_TRANSPORTPROPERTY_TCP_RECEIVE_WINDOW: { - if (type_ != PP_TRANSPORTTYPE_STREAM) - return PP_ERROR_BADARGUMENT; - - int32_t int_value = value.value.as_int; - if (value.type != PP_VARTYPE_INT32 || int_value < kMinBufferSize || - int_value > kMaxBufferSize) { - return PP_ERROR_BADARGUMENT; - } - config_.tcp_receive_window = int_value; - break; - } - - case PP_TRANSPORTPROPERTY_TCP_SEND_WINDOW: { - if (type_ != PP_TRANSPORTTYPE_STREAM) - return PP_ERROR_BADARGUMENT; - - int32_t int_value = value.value.as_int; - if (value.type != PP_VARTYPE_INT32 || int_value < kMinBufferSize || - int_value > kMaxBufferSize) { - return PP_ERROR_BADARGUMENT; - } - config_.tcp_send_window = int_value; - break; - } - - case PP_TRANSPORTPROPERTY_TCP_NO_DELAY: { - if (type_ != PP_TRANSPORTTYPE_STREAM) - return PP_ERROR_BADARGUMENT; - - if (value.type != PP_VARTYPE_BOOL) - return PP_ERROR_BADARGUMENT; - config_.tcp_no_delay = PP_ToBool(value.value.as_bool); - break; - } - - case PP_TRANSPORTPROPERTY_TCP_ACK_DELAY: { - if (type_ != PP_TRANSPORTTYPE_STREAM) - return PP_ERROR_BADARGUMENT; - - int32_t int_value = value.value.as_int; - if (value.type != PP_VARTYPE_INT32 || int_value < kMinAckDelay || - int_value > kMaxAckDelay) { - return PP_ERROR_BADARGUMENT; - } - config_.tcp_ack_delay_ms = int_value; - break; - } - - case PP_TRANSPORTPROPERTY_DISABLE_TCP_TRANSPORT: { - if (value.type != PP_VARTYPE_BOOL) - return PP_ERROR_BADARGUMENT; - config_.disable_tcp_transport = PP_ToBool(value.value.as_bool); - break; - } - - default: - return PP_ERROR_BADARGUMENT; - } - - return PP_OK; -} - -int32_t PPB_Transport_Impl::Connect(PP_CompletionCallback callback) { - if (!callback.func) - return PP_ERROR_BLOCKS_MAIN_THREAD; - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - // Connect() has already been called. - if (started_) - return PP_ERROR_INPROGRESS; - - P2PTransport::Protocol protocol = (type_ == PP_TRANSPORTTYPE_STREAM) ? - P2PTransport::PROTOCOL_TCP : P2PTransport::PROTOCOL_UDP; - - if (!p2p_transport_->Init( - GetFrameForResource(this), name_, protocol, config_, this)) { - return PP_ERROR_FAILED; - } - - started_ = true; - - PluginModule* plugin_module = ResourceHelper::GetPluginModule(this); - if (!plugin_module) - return PP_ERROR_FAILED; - - connect_callback_ = new TrackedCallback(this, callback); - return PP_OK_COMPLETIONPENDING; -} - -int32_t PPB_Transport_Impl::GetNextAddress(PP_Var* address, - PP_CompletionCallback callback) { - if (!callback.func) - return PP_ERROR_BLOCKS_MAIN_THREAD; - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - if (TrackedCallback::IsPending(next_address_callback_)) - return PP_ERROR_INPROGRESS; - - PluginModule* plugin_module = ResourceHelper::GetPluginModule(this); - if (!plugin_module) - return PP_ERROR_FAILED; - - if (!local_candidates_.empty()) { - *address = StringVar::StringToPPVar(local_candidates_.front()); - local_candidates_.pop_front(); - return PP_OK; - } - - next_address_callback_ = new TrackedCallback(this, callback); - return PP_OK_COMPLETIONPENDING; -} - -int32_t PPB_Transport_Impl::ReceiveRemoteAddress(PP_Var address) { - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - StringVar* address_str = StringVar::FromPPVar(address); - if (!address_str) - return PP_ERROR_BADARGUMENT; - - return p2p_transport_->AddRemoteCandidate(address_str->value()) ? - PP_OK : PP_ERROR_FAILED; -} - -int32_t PPB_Transport_Impl::Recv(void* data, uint32_t len, - PP_CompletionCallback callback) { - if (!callback.func) - return PP_ERROR_BLOCKS_MAIN_THREAD; - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - if (TrackedCallback::IsPending(recv_callback_)) - return PP_ERROR_INPROGRESS; - - net::Socket* channel = p2p_transport_->GetChannel(); - if (!channel) - return PP_ERROR_FAILED; - - PluginModule* plugin_module = ResourceHelper::GetPluginModule(this); - if (!plugin_module) - return PP_ERROR_FAILED; - - scoped_refptr<net::IOBuffer> buffer = - new net::WrappedIOBuffer(static_cast<const char*>(data)); - int result = MapNetError( - channel->Read(buffer, len, base::Bind(&PPB_Transport_Impl::OnRead, - base::Unretained(this)))); - if (result == PP_OK_COMPLETIONPENDING) - recv_callback_ = new TrackedCallback(this, callback); - - return result; -} - -int32_t PPB_Transport_Impl::Send(const void* data, uint32_t len, - PP_CompletionCallback callback) { - if (!callback.func) - return PP_ERROR_BLOCKS_MAIN_THREAD; - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - if (TrackedCallback::IsPending(send_callback_)) - return PP_ERROR_INPROGRESS; - - net::Socket* channel = p2p_transport_->GetChannel(); - if (!channel) - return PP_ERROR_FAILED; - - PluginModule* plugin_module = ResourceHelper::GetPluginModule(this); - if (!plugin_module) - return PP_ERROR_FAILED; - - scoped_refptr<net::IOBuffer> buffer = - new net::WrappedIOBuffer(static_cast<const char*>(data)); - int result = MapNetError( - channel->Write(buffer, len, base::Bind(&PPB_Transport_Impl::OnWritten, - base::Unretained(this)))); - if (result == PP_OK_COMPLETIONPENDING) - send_callback_ = new TrackedCallback(this, callback); - - return result; -} - -int32_t PPB_Transport_Impl::Close() { - if (!p2p_transport_.get()) - return PP_ERROR_FAILED; - - p2p_transport_.reset(); - - ::ppapi::PpapiGlobals::Get()->GetCallbackTrackerForInstance( - pp_instance())->PostAbortForResource(pp_resource()); - return PP_OK; -} - -void PPB_Transport_Impl::OnCandidateReady(const std::string& address) { - // Store the candidate first before calling the callback. - local_candidates_.push_back(address); - - if (TrackedCallback::IsPending(next_address_callback_)) - TrackedCallback::ClearAndRun(&next_address_callback_, PP_OK); -} - -void PPB_Transport_Impl::OnStateChange(webkit_glue::P2PTransport::State state) { - writable_ = (state | webkit_glue::P2PTransport::STATE_WRITABLE) != 0; - if (writable_ && TrackedCallback::IsPending(connect_callback_)) - TrackedCallback::ClearAndRun(&connect_callback_, PP_OK); -} - -void PPB_Transport_Impl::OnError(int error) { - writable_ = false; - if (TrackedCallback::IsPending(connect_callback_)) - TrackedCallback::ClearAndRun(&connect_callback_, PP_ERROR_FAILED); -} - -void PPB_Transport_Impl::OnRead(int result) { - DCHECK(TrackedCallback::IsPending(recv_callback_)); - TrackedCallback::ClearAndRun(&recv_callback_, MapNetError(result)); -} - -void PPB_Transport_Impl::OnWritten(int result) { - DCHECK(TrackedCallback::IsPending(send_callback_)); - TrackedCallback::ClearAndRun(&send_callback_, MapNetError(result)); -} - -} // namespace ppapi -} // namespace webkit diff --git a/webkit/plugins/ppapi/ppb_transport_impl.h b/webkit/plugins/ppapi/ppb_transport_impl.h deleted file mode 100644 index 34393e4..0000000 --- a/webkit/plugins/ppapi/ppb_transport_impl.h +++ /dev/null @@ -1,82 +0,0 @@ -// 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 WEBKIT_PLUGINS_PPAPI_PPB_TRANSPORT_IMPL_H_ -#define WEBKIT_PLUGINS_PPAPI_PPB_TRANSPORT_IMPL_H_ - -#include <list> -#include <string> - -#include "base/basictypes.h" -#include "base/memory/scoped_ptr.h" -#include "net/base/completion_callback.h" -#include "ppapi/shared_impl/tracked_callback.h" -#include "ppapi/shared_impl/resource.h" -#include "ppapi/thunk/ppb_transport_api.h" -#include "webkit/glue/p2p_transport.h" - -namespace webkit { -namespace ppapi { - -class PPB_Transport_Impl : public ::ppapi::Resource, - public ::ppapi::thunk::PPB_Transport_API, - public webkit_glue::P2PTransport::EventHandler { - public: - virtual ~PPB_Transport_Impl(); - - static PP_Resource Create(PP_Instance instance, - const char* name, - PP_TransportType type); - - // Resource override. - virtual ::ppapi::thunk::PPB_Transport_API* AsPPB_Transport_API() OVERRIDE; - - // PPB_Transport_API implementation. - virtual PP_Bool IsWritable() OVERRIDE; - virtual int32_t SetProperty(PP_TransportProperty property, - PP_Var value) OVERRIDE; - virtual int32_t Connect(PP_CompletionCallback callback) OVERRIDE; - virtual int32_t GetNextAddress(PP_Var* address, - PP_CompletionCallback callback) OVERRIDE; - virtual int32_t ReceiveRemoteAddress(PP_Var address) OVERRIDE; - virtual int32_t Recv(void* data, uint32_t len, - PP_CompletionCallback callback) OVERRIDE; - virtual int32_t Send(const void* data, uint32_t len, - PP_CompletionCallback callback) OVERRIDE; - virtual int32_t Close() OVERRIDE; - - // webkit_glue::P2PTransport::EventHandler implementation. - virtual void OnCandidateReady(const std::string& address) OVERRIDE; - virtual void OnStateChange(webkit_glue::P2PTransport::State state) OVERRIDE; - virtual void OnError(int error) OVERRIDE; - - private: - explicit PPB_Transport_Impl(PP_Instance instance); - - bool Init(const char* name, PP_TransportType type); - - void OnRead(int result); - void OnWritten(int result); - - std::string name_; - PP_TransportType type_; - webkit_glue::P2PTransport::Config config_; - bool started_; - scoped_ptr<webkit_glue::P2PTransport> p2p_transport_; - bool writable_; - std::list<std::string> local_candidates_; - - scoped_refptr< ::ppapi::TrackedCallback> connect_callback_; - scoped_refptr< ::ppapi::TrackedCallback> next_address_callback_; - - scoped_refptr< ::ppapi::TrackedCallback> recv_callback_; - scoped_refptr< ::ppapi::TrackedCallback> send_callback_; - - DISALLOW_COPY_AND_ASSIGN(PPB_Transport_Impl); -}; - -} // namespace ppapi -} // namespace webkit - -#endif // WEBKIT_PLUGINS_PPAPI_PPB_TRANSPORT_IMPL_H_ diff --git a/webkit/plugins/ppapi/resource_creation_impl.cc b/webkit/plugins/ppapi/resource_creation_impl.cc index e14030f..1d0905b 100644 --- a/webkit/plugins/ppapi/resource_creation_impl.cc +++ b/webkit/plugins/ppapi/resource_creation_impl.cc @@ -30,7 +30,6 @@ #include "webkit/plugins/ppapi/ppb_scrollbar_impl.h" #include "webkit/plugins/ppapi/ppb_tcp_server_socket_private_impl.h" #include "webkit/plugins/ppapi/ppb_tcp_socket_private_impl.h" -#include "webkit/plugins/ppapi/ppb_transport_impl.h" #include "webkit/plugins/ppapi/ppb_udp_socket_private_impl.h" #include "webkit/plugins/ppapi/ppb_url_loader_impl.h" #include "webkit/plugins/ppapi/ppb_url_request_info_impl.h" @@ -258,16 +257,6 @@ PP_Resource ResourceCreationImpl::CreateTCPSocketPrivate(PP_Instance instance) { return PPB_TCPSocket_Private_Impl::CreateResource(instance); } -PP_Resource ResourceCreationImpl::CreateTransport(PP_Instance instance, - const char* name, - PP_TransportType type) { -#if defined(ENABLE_P2P_APIS) - return PPB_Transport_Impl::Create(instance, name, type); -#else - return 0; -#endif -} - PP_Resource ResourceCreationImpl::CreateUDPSocketPrivate(PP_Instance instance) { return PPB_UDPSocket_Private_Impl::CreateResource(instance); } diff --git a/webkit/plugins/ppapi/resource_creation_impl.h b/webkit/plugins/ppapi/resource_creation_impl.h index 84f9b2e..4712c19 100644 --- a/webkit/plugins/ppapi/resource_creation_impl.h +++ b/webkit/plugins/ppapi/resource_creation_impl.h @@ -106,9 +106,6 @@ class ResourceCreationImpl : public ::ppapi::thunk::ResourceCreationAPI { PP_Instance instance) OVERRIDE; virtual PP_Resource CreateTCPSocketPrivate(PP_Instance instance) OVERRIDE; - virtual PP_Resource CreateTransport(PP_Instance instance, - const char* name, - PP_TransportType type) OVERRIDE; virtual PP_Resource CreateUDPSocketPrivate(PP_Instance instance) OVERRIDE; virtual PP_Resource CreateURLLoader(PP_Instance instance) OVERRIDE; virtual PP_Resource CreateURLRequestInfo( |