OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "content/browser/renderer_host/pepper/content_browser_pepper_host_facto ry.h" | 5 #include "content/browser/renderer_host/pepper/content_browser_pepper_host_facto ry.h" |
6 | 6 |
7 #include "content/browser/renderer_host/pepper/browser_ppapi_host_impl.h" | 7 #include "content/browser/renderer_host/pepper/browser_ppapi_host_impl.h" |
8 #include "content/browser/renderer_host/pepper/pepper_browser_font_singleton_hos t.h" | 8 #include "content/browser/renderer_host/pepper/pepper_browser_font_singleton_hos t.h" |
9 #include "content/browser/renderer_host/pepper/pepper_file_ref_host.h" | 9 #include "content/browser/renderer_host/pepper/pepper_file_ref_host.h" |
10 #include "content/browser/renderer_host/pepper/pepper_file_system_browser_host.h " | 10 #include "content/browser/renderer_host/pepper/pepper_file_system_browser_host.h " |
11 #include "content/browser/renderer_host/pepper/pepper_flash_file_message_filter. h" | 11 #include "content/browser/renderer_host/pepper/pepper_flash_file_message_filter. h" |
12 #include "content/browser/renderer_host/pepper/pepper_gamepad_host.h" | 12 #include "content/browser/renderer_host/pepper/pepper_gamepad_host.h" |
13 #include "content/browser/renderer_host/pepper/pepper_host_resolver_message_filt er.h" | 13 #include "content/browser/renderer_host/pepper/pepper_host_resolver_message_filt er.h" |
14 #include "content/browser/renderer_host/pepper/pepper_network_proxy_host.h" | 14 #include "content/browser/renderer_host/pepper/pepper_network_proxy_host.h" |
15 #include "content/browser/renderer_host/pepper/pepper_print_settings_manager.h" | 15 #include "content/browser/renderer_host/pepper/pepper_print_settings_manager.h" |
16 #include "content/browser/renderer_host/pepper/pepper_printing_host.h" | 16 #include "content/browser/renderer_host/pepper/pepper_printing_host.h" |
17 #include "content/browser/renderer_host/pepper/pepper_tcp_server_socket_message_ filter.h" | 17 #include "content/browser/renderer_host/pepper/pepper_tcp_server_socket_message_ filter.h" |
18 #include "content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter. h" | 18 #include "content/browser/renderer_host/pepper/pepper_tcp_socket_message_filter. h" |
19 #include "content/browser/renderer_host/pepper/pepper_truetype_font_list_host.h" | 19 #include "content/browser/renderer_host/pepper/pepper_truetype_font_list_host.h" |
20 #include "content/browser/renderer_host/pepper/pepper_udp_socket_message_filter. h" | 20 #include "content/browser/renderer_host/pepper/pepper_udp_socket_message_filter. h" |
21 #include "net/socket/stream_socket.h" | 21 #include "ppapi/c/ppb_net_address.h" |
22 #include "ppapi/host/message_filter_host.h" | 22 #include "ppapi/host/message_filter_host.h" |
23 #include "ppapi/host/ppapi_host.h" | 23 #include "ppapi/host/ppapi_host.h" |
24 #include "ppapi/host/resource_host.h" | 24 #include "ppapi/host/resource_host.h" |
25 #include "ppapi/proxy/ppapi_messages.h" | 25 #include "ppapi/proxy/ppapi_messages.h" |
26 #include "ppapi/shared_impl/ppapi_permissions.h" | 26 #include "ppapi/shared_impl/ppapi_permissions.h" |
27 | 27 |
28 using ppapi::host::MessageFilterHost; | 28 using ppapi::host::MessageFilterHost; |
29 using ppapi::host::ResourceHost; | 29 using ppapi::host::ResourceHost; |
30 using ppapi::host::ResourceMessageFilter; | 30 using ppapi::host::ResourceMessageFilter; |
31 using ppapi::UnpackMessage; | 31 using ppapi::UnpackMessage; |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
97 std::string internal_path; | 97 std::string internal_path; |
98 if (!UnpackMessage<PpapiHostMsg_FileRef_CreateInternal>( | 98 if (!UnpackMessage<PpapiHostMsg_FileRef_CreateInternal>( |
99 message, &file_system, &internal_path)) { | 99 message, &file_system, &internal_path)) { |
100 NOTREACHED(); | 100 NOTREACHED(); |
101 return scoped_ptr<ResourceHost>(); | 101 return scoped_ptr<ResourceHost>(); |
102 } | 102 } |
103 return scoped_ptr<ResourceHost>(new PepperFileRefHost( | 103 return scoped_ptr<ResourceHost>(new PepperFileRefHost( |
104 host_, instance, params.pp_resource(), file_system, internal_path)); | 104 host_, instance, params.pp_resource(), file_system, internal_path)); |
105 } | 105 } |
106 case PpapiHostMsg_TCPSocket_Create::ID: { | 106 case PpapiHostMsg_TCPSocket_Create::ID: { |
107 if (CanCreateSocket()) { | 107 ppapi::TCPSocketVersion version; |
108 scoped_refptr<ResourceMessageFilter> tcp_socket( | 108 PP_NetAddress_Family family; |
109 new PepperTCPSocketMessageFilter(host_, | 109 if (!CanCreateSocket() || |
110 instance, | 110 !UnpackMessage<PpapiHostMsg_TCPSocket_Create>( |
111 false)); | 111 message, &version, &family)) { |
112 return scoped_ptr<ResourceHost>(new MessageFilterHost( | |
113 host_->GetPpapiHost(), instance, params.pp_resource(), tcp_socket)); | |
114 } else { | |
115 return scoped_ptr<ResourceHost>(); | 112 return scoped_ptr<ResourceHost>(); |
116 } | 113 } |
114 | |
115 scoped_refptr<ResourceMessageFilter> tcp_socket( | |
116 PepperTCPSocketMessageFilter::Create(this, host_, instance, version, | |
117 family)); | |
118 if (!tcp_socket) | |
119 return scoped_ptr<ResourceHost>(); | |
120 | |
121 return scoped_ptr<ResourceHost>(new MessageFilterHost( | |
122 host_->GetPpapiHost(), instance, params.pp_resource(), tcp_socket)); | |
117 } | 123 } |
118 case PpapiHostMsg_UDPSocket_Create::ID: { | 124 case PpapiHostMsg_UDPSocket_Create::ID: { |
119 if (CanCreateSocket()) { | 125 if (CanCreateSocket()) { |
120 scoped_refptr<ResourceMessageFilter> udp_socket( | 126 scoped_refptr<ResourceMessageFilter> udp_socket( |
121 new PepperUDPSocketMessageFilter(host_, instance, false)); | 127 new PepperUDPSocketMessageFilter(host_, instance, false)); |
122 return scoped_ptr<ResourceHost>(new MessageFilterHost( | 128 return scoped_ptr<ResourceHost>(new MessageFilterHost( |
123 host_->GetPpapiHost(), instance, params.pp_resource(), udp_socket)); | 129 host_->GetPpapiHost(), instance, params.pp_resource(), udp_socket)); |
124 } else { | 130 } else { |
125 return scoped_ptr<ResourceHost>(); | 131 return scoped_ptr<ResourceHost>(); |
126 } | 132 } |
(...skipping 43 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
170 scoped_refptr<ResourceMessageFilter> tcp_server_socket( | 176 scoped_refptr<ResourceMessageFilter> tcp_server_socket( |
171 new PepperTCPServerSocketMessageFilter(this, host_, instance, true)); | 177 new PepperTCPServerSocketMessageFilter(this, host_, instance, true)); |
172 return scoped_ptr<ResourceHost>(new MessageFilterHost( | 178 return scoped_ptr<ResourceHost>(new MessageFilterHost( |
173 host_->GetPpapiHost(), instance, params.pp_resource(), | 179 host_->GetPpapiHost(), instance, params.pp_resource(), |
174 tcp_server_socket)); | 180 tcp_server_socket)); |
175 } else { | 181 } else { |
176 return scoped_ptr<ResourceHost>(); | 182 return scoped_ptr<ResourceHost>(); |
177 } | 183 } |
178 } | 184 } |
179 if (message.type() == PpapiHostMsg_TCPSocket_CreatePrivate::ID) { | 185 if (message.type() == PpapiHostMsg_TCPSocket_CreatePrivate::ID) { |
180 if (CanCreateSocket()) { | 186 if (!CanCreateSocket()) |
181 scoped_refptr<ResourceMessageFilter> tcp_socket( | |
182 new PepperTCPSocketMessageFilter(host_, | |
183 instance, | |
184 true)); | |
185 return scoped_ptr<ResourceHost>(new MessageFilterHost( | |
186 host_->GetPpapiHost(), instance, params.pp_resource(), tcp_socket)); | |
187 } else { | |
188 return scoped_ptr<ResourceHost>(); | 187 return scoped_ptr<ResourceHost>(); |
189 } | 188 |
189 scoped_refptr<ResourceMessageFilter> tcp_socket( | |
190 PepperTCPSocketMessageFilter::Create( | |
191 this, host_, instance, ppapi::TCP_SOCKET_VERSION_PRIVATE, | |
192 PP_NETADDRESS_FAMILY_UNSPECIFIED)); | |
193 if (!tcp_socket) | |
194 return scoped_ptr<ResourceHost>(); | |
195 | |
196 return scoped_ptr<ResourceHost>(new MessageFilterHost( | |
197 host_->GetPpapiHost(), instance, params.pp_resource(), tcp_socket)); | |
bbudge
2013/09/17 19:42:18
There's a lot of code in common here and above. Co
yzshen1
2013/09/18 16:56:26
Done.
| |
190 } | 198 } |
191 if (message.type() == PpapiHostMsg_UDPSocket_CreatePrivate::ID) { | 199 if (message.type() == PpapiHostMsg_UDPSocket_CreatePrivate::ID) { |
192 if (CanCreateSocket()) { | 200 if (CanCreateSocket()) { |
193 scoped_refptr<ResourceMessageFilter> udp_socket( | 201 scoped_refptr<ResourceMessageFilter> udp_socket( |
194 new PepperUDPSocketMessageFilter(host_, instance, true)); | 202 new PepperUDPSocketMessageFilter(host_, instance, true)); |
195 return scoped_ptr<ResourceHost>(new MessageFilterHost( | 203 return scoped_ptr<ResourceHost>(new MessageFilterHost( |
196 host_->GetPpapiHost(), instance, params.pp_resource(), udp_socket)); | 204 host_->GetPpapiHost(), instance, params.pp_resource(), udp_socket)); |
197 } else { | 205 } else { |
198 return scoped_ptr<ResourceHost>(); | 206 return scoped_ptr<ResourceHost>(); |
199 } | 207 } |
(...skipping 11 matching lines...) Expand all Loading... | |
211 } | 219 } |
212 } | 220 } |
213 } | 221 } |
214 | 222 |
215 return scoped_ptr<ResourceHost>(); | 223 return scoped_ptr<ResourceHost>(); |
216 } | 224 } |
217 | 225 |
218 scoped_ptr<ppapi::host::ResourceHost> | 226 scoped_ptr<ppapi::host::ResourceHost> |
219 ContentBrowserPepperHostFactory::CreateAcceptedTCPSocket( | 227 ContentBrowserPepperHostFactory::CreateAcceptedTCPSocket( |
220 PP_Instance instance, | 228 PP_Instance instance, |
221 bool private_api, | 229 ppapi::TCPSocketVersion version, |
222 net::StreamSocket* socket) { | 230 scoped_ptr<net::TCPSocket> socket) { |
223 scoped_ptr<net::StreamSocket> s(socket); | |
224 | |
225 if (!CanCreateSocket()) | 231 if (!CanCreateSocket()) |
226 return scoped_ptr<ResourceHost>(); | 232 return scoped_ptr<ResourceHost>(); |
227 scoped_refptr<ResourceMessageFilter> tcp_socket( | 233 scoped_refptr<ResourceMessageFilter> tcp_socket( |
228 new PepperTCPSocketMessageFilter(host_, | 234 new PepperTCPSocketMessageFilter(host_, instance, version, |
bbudge
2013/09/17 19:42:18
Why don't you call PepperTCPSocketMessageFilter::C
yzshen1
2013/09/18 16:56:26
Because this class has a static Create() method fo
| |
229 instance, | 235 socket.Pass())); |
230 private_api, | |
231 s.release())); | |
232 return scoped_ptr<ResourceHost>(new MessageFilterHost( | 236 return scoped_ptr<ResourceHost>(new MessageFilterHost( |
233 host_->GetPpapiHost(), instance, 0, tcp_socket)); | 237 host_->GetPpapiHost(), instance, 0, tcp_socket)); |
234 } | 238 } |
235 | 239 |
236 const ppapi::PpapiPermissions& | 240 const ppapi::PpapiPermissions& |
237 ContentBrowserPepperHostFactory::GetPermissions() const { | 241 ContentBrowserPepperHostFactory::GetPermissions() const { |
238 return host_->GetPpapiHost()->permissions(); | 242 return host_->GetPpapiHost()->permissions(); |
239 } | 243 } |
240 | 244 |
241 } // namespace content | 245 } // namespace content |
OLD | NEW |