Index: content/renderer/media/media_permission_dispatcher_impl.cc |
diff --git a/content/renderer/media/media_permission_dispatcher.cc b/content/renderer/media/media_permission_dispatcher_impl.cc |
similarity index 54% |
copy from content/renderer/media/media_permission_dispatcher.cc |
copy to content/renderer/media/media_permission_dispatcher_impl.cc |
index ad2c825506252f3d3dc5f6408e1ecfa26c57e962..e0a6fa6db74d0a92142d5c89b7cb6f10f9ee03ae 100644 |
--- a/content/renderer/media/media_permission_dispatcher.cc |
+++ b/content/renderer/media/media_permission_dispatcher_impl.cc |
@@ -2,12 +2,14 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#include "content/renderer/media/media_permission_dispatcher.h" |
+#include "content/renderer/media/media_permission_dispatcher_impl.h" |
#include "base/bind.h" |
#include "base/logging.h" |
+#include "base/thread_task_runner_handle.h" |
#include "content/public/common/service_registry.h" |
#include "content/public/renderer/render_frame.h" |
+#include "content/renderer/media/media_permission_dispatcher_proxy.h" |
#include "third_party/WebKit/public/web/WebUserGestureIndicator.h" |
#include "url/gurl.h" |
@@ -32,21 +34,16 @@ content::PermissionName MediaPermissionTypeToPermissionName(Type type) { |
namespace content { |
-MediaPermissionDispatcher::MediaPermissionDispatcher(RenderFrame* render_frame) |
- : RenderFrameObserver(render_frame), next_request_id_(0) { |
-} |
+MediaPermissionDispatcherImpl::MediaPermissionDispatcherImpl( |
+ RenderFrame* render_frame) |
+ : RenderFrameObserver(render_frame), |
+ task_runner_(base::ThreadTaskRunnerHandle::Get()) {} |
-MediaPermissionDispatcher::~MediaPermissionDispatcher() { |
+MediaPermissionDispatcherImpl::~MediaPermissionDispatcherImpl() { |
DCHECK(thread_checker_.CalledOnValidThread()); |
- |
- // Fire all pending callbacks with |false|. |
- for (auto& request : requests_) |
- request.second.Run(false); |
- |
- requests_.clear(); |
} |
-void MediaPermissionDispatcher::HasPermission( |
+void MediaPermissionDispatcherImpl::HasPermission( |
Type type, |
const GURL& security_origin, |
const PermissionStatusCB& permission_status_cb) { |
@@ -57,19 +54,14 @@ void MediaPermissionDispatcher::HasPermission( |
mojo::GetProxy(&permission_service_)); |
} |
- uint32_t request_id = next_request_id_++; |
- DCHECK(!requests_.count(request_id)); |
- requests_[request_id] = permission_status_cb; |
- |
- DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; |
- |
permission_service_->HasPermission( |
MediaPermissionTypeToPermissionName(type), security_origin.spec(), |
- base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, |
- base::Unretained(this), request_id)); |
+ base::Bind(&MediaPermissionDispatcherImpl::OnPermissionStatus, |
+ base::Unretained(this), |
perkj_chrome
2015/09/22 08:24:16
Why is it safe to use Unretained? Looks scary to
guoweis_left_chromium
2015/09/22 18:48:49
Done.
|
+ RegisterCallback(permission_status_cb))); |
} |
-void MediaPermissionDispatcher::RequestPermission( |
+void MediaPermissionDispatcherImpl::RequestPermission( |
Type type, |
const GURL& security_origin, |
const PermissionStatusCB& permission_status_cb) { |
@@ -80,34 +72,27 @@ void MediaPermissionDispatcher::RequestPermission( |
mojo::GetProxy(&permission_service_)); |
} |
- uint32_t request_id = next_request_id_++; |
- DCHECK(!requests_.count(request_id)); |
- requests_[request_id] = permission_status_cb; |
- |
- DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; |
- |
permission_service_->RequestPermission( |
MediaPermissionTypeToPermissionName(type), security_origin.spec(), |
blink::WebUserGestureIndicator::isProcessingUserGesture(), |
- base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, |
- base::Unretained(this), request_id)); |
+ base::Bind(&MediaPermissionDispatcherImpl::OnPermissionStatus, |
+ base::Unretained(this), |
+ RegisterCallback(permission_status_cb))); |
} |
-void MediaPermissionDispatcher::OnPermissionStatus(uint32_t request_id, |
- PermissionStatus status) { |
- DVLOG(2) << __FUNCTION__ << ": (" << request_id << ", " << status << ")"; |
- DCHECK(thread_checker_.CalledOnValidThread()); |
- |
- RequestMap::iterator iter = requests_.find(request_id); |
- if (iter == requests_.end()) { |
- DVLOG(2) << "Request not found."; |
- return; |
- } |
- |
- PermissionStatusCB permission_status_cb = iter->second; |
- requests_.erase(iter); |
+scoped_ptr<media::MediaPermission> MediaPermissionDispatcherImpl::CreateProxy( |
+ scoped_refptr<base::SingleThreadTaskRunner> caller_task_runner) { |
+ scoped_ptr<media::MediaPermission> media_permission_proxy( |
+ new MediaPermissionDispatcherProxy(task_runner_, caller_task_runner, |
+ base::AsWeakPtr(this))); |
+ return media_permission_proxy.Pass(); |
+} |
- permission_status_cb.Run(status == PERMISSION_STATUS_GRANTED); |
+void MediaPermissionDispatcherImpl::OnPermissionStatus( |
+ uint32_t request_id, |
+ PermissionStatus status) { |
+ DCHECK(thread_checker_.CalledOnValidThread()); |
+ DeliverResult(request_id, status == PERMISSION_STATUS_GRANTED); |
} |
} // namespace content |