| OLD | NEW |
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 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 "chrome/common/render_messages.h" | 5 #include "chrome/common/render_messages.h" |
| 6 #include "chrome/renderer/worker_permission_client_proxy.h" | 6 #include "chrome/renderer/worker_permission_client_proxy.h" |
| 7 #include "content/public/renderer/render_frame.h" | 7 #include "content/public/renderer/render_frame.h" |
| 8 #include "content/public/renderer/render_thread.h" | 8 #include "content/public/renderer/render_thread.h" |
| 9 #include "ipc/ipc_sync_message_filter.h" | 9 #include "ipc/ipc_sync_message_filter.h" |
| 10 #include "third_party/WebKit/public/platform/WebPermissionCallbacks.h" |
| 10 #include "third_party/WebKit/public/web/WebDocument.h" | 11 #include "third_party/WebKit/public/web/WebDocument.h" |
| 11 #include "third_party/WebKit/public/web/WebFrame.h" | 12 #include "third_party/WebKit/public/web/WebFrame.h" |
| 12 #include "third_party/WebKit/public/web/WebSecurityOrigin.h" | 13 #include "third_party/WebKit/public/web/WebSecurityOrigin.h" |
| 13 | 14 |
| 14 WorkerPermissionClientProxy::WorkerPermissionClientProxy( | 15 WorkerPermissionClientProxy::WorkerPermissionClientProxy( |
| 15 content::RenderFrame* render_frame, | 16 content::RenderFrame* render_frame, |
| 16 blink::WebFrame* frame) | 17 blink::WebFrame* frame) |
| 17 : routing_id_(render_frame->GetRoutingID()), | 18 : routing_id_(render_frame->GetRoutingID()), |
| 18 is_unique_origin_(false) { | 19 is_unique_origin_(false) { |
| 19 if (frame->document().securityOrigin().isUnique() || | 20 if (frame->document().securityOrigin().isUnique() || |
| (...skipping 19 matching lines...) Expand all Loading... |
| 39 routing_id_, document_origin_url_, top_frame_origin_url_, | 40 routing_id_, document_origin_url_, top_frame_origin_url_, |
| 40 name, display_name, &result)); | 41 name, display_name, &result)); |
| 41 return result; | 42 return result; |
| 42 } | 43 } |
| 43 | 44 |
| 44 bool WorkerPermissionClientProxy::allowFileSystem() { | 45 bool WorkerPermissionClientProxy::allowFileSystem() { |
| 45 if (is_unique_origin_) | 46 if (is_unique_origin_) |
| 46 return false; | 47 return false; |
| 47 | 48 |
| 48 bool result = false; | 49 bool result = false; |
| 49 sync_message_filter_->Send(new ChromeViewHostMsg_AllowFileSystem( | 50 sync_message_filter_->Send(new ChromeViewHostMsg_RequestFileSystemAccessSync( |
| 50 routing_id_, document_origin_url_, top_frame_origin_url_, &result)); | 51 routing_id_, document_origin_url_, top_frame_origin_url_, &result)); |
| 51 return result; | 52 return result; |
| 52 } | 53 } |
| 54 |
| 55 bool WorkerPermissionClientProxy::requestFileSystemAccessSync() { |
| 56 if (is_unique_origin_) |
| 57 return false; |
| 58 |
| 59 bool result = false; |
| 60 sync_message_filter_->Send(new ChromeViewHostMsg_RequestFileSystemAccessSync( |
| 61 routing_id_, document_origin_url_, top_frame_origin_url_, &result)); |
| 62 return result; |
| 63 } |
| 53 | 64 |
| 54 bool WorkerPermissionClientProxy::allowIndexedDB( | 65 bool WorkerPermissionClientProxy::allowIndexedDB( |
| 55 const blink::WebString& name) { | 66 const blink::WebString& name) { |
| 56 if (is_unique_origin_) | 67 if (is_unique_origin_) |
| 57 return false; | 68 return false; |
| 58 | 69 |
| 59 bool result = false; | 70 bool result = false; |
| 60 sync_message_filter_->Send(new ChromeViewHostMsg_AllowIndexedDB( | 71 sync_message_filter_->Send(new ChromeViewHostMsg_AllowIndexedDB( |
| 61 routing_id_, document_origin_url_, top_frame_origin_url_, name, &result)); | 72 routing_id_, document_origin_url_, top_frame_origin_url_, name, &result)); |
| 62 return result; | 73 return result; |
| 63 } | 74 } |
| OLD | NEW |