Chromium Code Reviews| 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 "content/browser/media/midi_dispatcher_host.h" | 5 #include "content/browser/media/midi_dispatcher_host.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "content/browser/child_process_security_policy_impl.h" | 8 #include "content/browser/child_process_security_policy_impl.h" |
| 9 #include "content/browser/frame_host/render_frame_host_impl.h" | 9 #include "content/browser/frame_host/render_frame_host_impl.h" |
| 10 #include "content/common/media/midi_messages.h" | 10 #include "content/common/media/midi_messages.h" |
| 11 #include "content/public/browser/browser_context.h" | 11 #include "content/public/browser/browser_context.h" |
| 12 #include "content/public/browser/browser_thread.h" | 12 #include "content/public/browser/browser_thread.h" |
| 13 #include "content/public/browser/content_browser_client.h" | 13 #include "content/public/browser/content_browser_client.h" |
| 14 #include "content/public/browser/navigation_details.h" | |
| 14 #include "content/public/browser/render_frame_host.h" | 15 #include "content/public/browser/render_frame_host.h" |
| 15 #include "content/public/browser/render_process_host.h" | 16 #include "content/public/browser/render_process_host.h" |
| 16 #include "content/public/browser/web_contents.h" | 17 #include "content/public/browser/web_contents.h" |
| 17 #include "url/gurl.h" | 18 #include "url/gurl.h" |
| 18 | 19 |
| 19 namespace content { | 20 namespace content { |
| 20 | 21 |
| 21 MidiDispatcherHost::PendingPermission::PendingPermission( | 22 MidiDispatcherHost::PendingPermission::PendingPermission( |
| 22 int render_process_id, | 23 int render_process_id, |
| 23 int render_frame_id, | 24 int render_frame_id, |
| 24 int bridge_id) | 25 int bridge_id) |
| 25 : render_process_id(render_process_id), | 26 : render_process_id(render_process_id), |
| 26 render_frame_id(render_frame_id), | 27 render_frame_id(render_frame_id), |
| 27 bridge_id(bridge_id) { | 28 bridge_id(bridge_id) { |
| 28 } | 29 } |
| 29 | 30 |
| 30 MidiDispatcherHost::PendingPermission::~PendingPermission() { | 31 MidiDispatcherHost::PendingPermission::~PendingPermission() { |
| 31 } | 32 } |
| 32 | 33 |
| 33 MidiDispatcherHost::MidiDispatcherHost(WebContents* web_contents) | 34 MidiDispatcherHost::MidiDispatcherHost(WebContents* web_contents) |
| 34 : WebContentsObserver(web_contents), | 35 : WebContentsObserver(web_contents), |
| 35 weak_factory_(this) { | 36 weak_factory_(this) { |
| 36 } | 37 } |
| 37 | 38 |
| 38 MidiDispatcherHost::~MidiDispatcherHost() { | 39 MidiDispatcherHost::~MidiDispatcherHost() { |
| 39 } | 40 } |
| 40 | 41 |
| 42 void MidiDispatcherHost::RenderFrameDeleted( | |
| 43 RenderFrameHost* render_frame_host) { | |
| 44 CancelPermissionRequestsForFrame(render_frame_host); | |
| 45 } | |
| 46 | |
| 47 void MidiDispatcherHost::DidNavigateAnyFrame( | |
| 48 RenderFrameHost* render_frame_host, | |
| 49 const LoadCommittedDetails& details, | |
| 50 const FrameNavigateParams& params) { | |
| 51 if (details.is_in_page) | |
| 52 return; | |
| 53 | |
| 54 CancelPermissionRequestsForFrame(render_frame_host); | |
| 55 } | |
| 56 | |
| 41 bool MidiDispatcherHost::OnMessageReceived(const IPC::Message& message, | 57 bool MidiDispatcherHost::OnMessageReceived(const IPC::Message& message, |
| 42 RenderFrameHost* render_frame_host) { | 58 RenderFrameHost* render_frame_host) { |
| 43 bool handled = true; | 59 bool handled = true; |
| 44 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MidiDispatcherHost, message, | 60 IPC_BEGIN_MESSAGE_MAP_WITH_PARAM(MidiDispatcherHost, message, |
| 45 render_frame_host) | 61 render_frame_host) |
| 46 IPC_MESSAGE_HANDLER(MidiHostMsg_RequestSysExPermission, | 62 IPC_MESSAGE_HANDLER(MidiHostMsg_RequestSysExPermission, |
| 47 OnRequestSysExPermission) | 63 OnRequestSysExPermission) |
| 48 IPC_MESSAGE_HANDLER(MidiHostMsg_CancelSysExPermissionRequest, | |
| 49 OnCancelSysExPermissionRequest) | |
| 50 IPC_MESSAGE_UNHANDLED(handled = false) | 64 IPC_MESSAGE_UNHANDLED(handled = false) |
| 51 IPC_END_MESSAGE_MAP() | 65 IPC_END_MESSAGE_MAP() |
| 52 return handled; | 66 return handled; |
| 53 } | 67 } |
| 54 | 68 |
| 55 void MidiDispatcherHost::OnRequestSysExPermission( | 69 void MidiDispatcherHost::OnRequestSysExPermission( |
| 56 RenderFrameHost* render_frame_host, | 70 RenderFrameHost* render_frame_host, |
| 57 int bridge_id, | 71 int bridge_id, |
| 58 const GURL& origin, | 72 const GURL& origin, |
| 59 bool user_gesture) { | 73 bool user_gesture) { |
| 60 int render_process_id = render_frame_host->GetProcess()->GetID(); | 74 int render_process_id = render_frame_host->GetProcess()->GetID(); |
| 61 int render_frame_id = render_frame_host->GetRoutingID(); | 75 int render_frame_id = render_frame_host->GetRoutingID(); |
| 62 | 76 |
| 63 PendingPermission pending_permission( | 77 PendingPermission pending_permission( |
| 64 render_process_id, render_frame_id, bridge_id); | 78 render_process_id, render_frame_id, bridge_id); |
| 65 pending_permissions_.push_back(pending_permission); | 79 pending_permissions_.push_back(pending_permission); |
| 66 | 80 |
| 67 GetContentClient()->browser()->RequestMidiSysExPermission( | 81 GetContentClient()->browser()->RequestMidiSysExPermission( |
| 68 web_contents(), | 82 web_contents(), |
| 69 bridge_id, | 83 bridge_id, |
| 70 origin, | 84 origin, |
| 71 user_gesture, | 85 user_gesture, |
| 72 base::Bind(&MidiDispatcherHost::WasSysExPermissionGranted, | 86 base::Bind(&MidiDispatcherHost::WasSysExPermissionGranted, |
| 73 weak_factory_.GetWeakPtr(), | 87 weak_factory_.GetWeakPtr(), |
| 74 render_process_id, render_frame_id, bridge_id), | 88 render_process_id, render_frame_id, bridge_id), |
| 75 &pending_permissions_.back().cancel); | 89 &pending_permissions_.back().cancel); |
| 76 } | 90 } |
| 77 | 91 |
| 78 void MidiDispatcherHost::OnCancelSysExPermissionRequest( | 92 void MidiDispatcherHost::CancelPermissionRequestsForFrame( |
| 79 RenderFrameHost* render_frame_host, | 93 RenderFrameHost* render_frame_host) { |
| 80 int bridge_id, | |
| 81 const GURL& requesting_frame) { | |
| 82 int render_process_id = render_frame_host->GetProcess()->GetID(); | 94 int render_process_id = render_frame_host->GetProcess()->GetID(); |
| 83 int render_frame_id = render_frame_host->GetRoutingID(); | 95 int render_frame_id = render_frame_host->GetRoutingID(); |
| 84 | 96 |
| 85 for (size_t i = 0; i < pending_permissions_.size(); ++i) { | 97 for (size_t i = 0; i < pending_permissions_.size(); ++i) { |
|
Mike West
2014/10/09 13:07:38
Nit: If you like, you could convert this to an awe
mlamouri (slow - plz ping)
2014/10/09 13:21:43
The index is used for erase. I could change the co
| |
| 86 if (pending_permissions_[i].render_process_id == render_process_id && | 98 if (pending_permissions_[i].render_process_id == render_process_id && |
| 87 pending_permissions_[i].render_frame_id == render_frame_id && | 99 pending_permissions_[i].render_frame_id == render_frame_id) { |
| 88 pending_permissions_[i].bridge_id == bridge_id) { | |
| 89 if (!pending_permissions_[i].cancel.is_null()) | 100 if (!pending_permissions_[i].cancel.is_null()) |
| 90 pending_permissions_[i].cancel.Run(); | 101 pending_permissions_[i].cancel.Run(); |
| 91 pending_permissions_.erase(pending_permissions_.begin() + i); | 102 pending_permissions_.erase(pending_permissions_.begin() + i); |
| 92 return; | 103 return; |
| 93 } | 104 } |
| 94 } | 105 } |
| 95 } | 106 } |
| 96 | 107 |
| 97 void MidiDispatcherHost::WasSysExPermissionGranted(int render_process_id, | 108 void MidiDispatcherHost::WasSysExPermissionGranted(int render_process_id, |
| 98 int render_frame_id, | 109 int render_frame_id, |
| (...skipping 15 matching lines...) Expand all Loading... | |
| 114 GrantSendMidiSysExMessage(render_process_id); | 125 GrantSendMidiSysExMessage(render_process_id); |
| 115 } | 126 } |
| 116 | 127 |
| 117 pending_permissions_.erase(pending_permissions_.begin() + i); | 128 pending_permissions_.erase(pending_permissions_.begin() + i); |
| 118 return; | 129 return; |
| 119 } | 130 } |
| 120 } | 131 } |
| 121 } | 132 } |
| 122 | 133 |
| 123 } // namespace content | 134 } // namespace content |
| OLD | NEW |