Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/renderer/media/media_permission_dispatcher.h" | 5 #include "content/renderer/media/media_permission_dispatcher.h" |
| 6 | 6 |
| 7 #include "base/bind.h" | 7 #include "base/bind.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "content/public/common/service_registry.h" | 9 #include "content/public/common/service_registry.h" |
| 10 #include "content/public/renderer/render_frame.h" | 10 #include "content/public/renderer/render_frame.h" |
| 11 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h" | 11 #include "third_party/WebKit/public/web/WebUserGestureIndicator.h" |
| 12 #include "url/gurl.h" | 12 #include "url/gurl.h" |
| 13 | 13 |
| 14 namespace { | |
| 15 | |
| 16 using Type = media::MediaPermission::Type; | |
| 17 | |
| 18 content::PermissionName MediaPermissionTypeToPermissionName(Type type) { | |
| 19 switch (type) { | |
| 20 case Type::PROTECTED_MEDIA_IDENTIFIER: | |
| 21 return content::PERMISSION_NAME_PROTECTED_MEDIA_IDENTIFIER; | |
| 22 case Type::AUDIO_RECORDING: | |
| 23 return content::PERMISSION_NAME_AUDIO_RECORDING; | |
| 24 case Type::VIDEO_RECORDING: | |
| 25 return content::PERMISSION_NAME_VIDEO_RECORDING; | |
| 26 default: | |
| 27 NOTREACHED(); | |
| 28 return content::PERMISSION_NAME_PROTECTED_MEDIA_IDENTIFIER; | |
| 29 } | |
|
xhwang
2015/08/28 05:08:41
remove "default" and move l.27-28 out of the "swit
| |
| 30 } | |
| 31 | |
| 32 } // namespace | |
| 33 | |
| 14 namespace content { | 34 namespace content { |
| 15 | 35 |
| 16 MediaPermissionDispatcher::MediaPermissionDispatcher(RenderFrame* render_frame) | 36 MediaPermissionDispatcher::MediaPermissionDispatcher(RenderFrame* render_frame) |
| 17 : RenderFrameObserver(render_frame), next_request_id_(0) { | 37 : RenderFrameObserver(render_frame), next_request_id_(0) { |
| 18 } | 38 } |
| 19 | 39 |
| 20 MediaPermissionDispatcher::~MediaPermissionDispatcher() { | 40 MediaPermissionDispatcher::~MediaPermissionDispatcher() { |
| 21 DCHECK(thread_checker_.CalledOnValidThread()); | 41 DCHECK(thread_checker_.CalledOnValidThread()); |
| 22 | 42 |
| 23 // Fire all pending callbacks with |false|. | 43 // Fire all pending callbacks with |false|. |
| 24 for (auto& request : requests_) | 44 for (auto& request : requests_) |
| 25 request.second.Run(false); | 45 request.second.Run(false); |
| 26 | 46 |
| 27 requests_.clear(); | 47 requests_.clear(); |
| 28 } | 48 } |
| 29 | 49 |
| 30 void MediaPermissionDispatcher::HasPermission( | 50 void MediaPermissionDispatcher::HasPermission( |
| 31 Type type, | 51 Type type, |
| 32 const GURL& security_origin, | 52 const GURL& security_origin, |
| 33 const PermissionStatusCB& permission_status_cb) { | 53 const PermissionStatusCB& permission_status_cb) { |
| 34 DCHECK(thread_checker_.CalledOnValidThread()); | 54 DCHECK(thread_checker_.CalledOnValidThread()); |
| 35 CHECK_EQ(PROTECTED_MEDIA_IDENTIFIER, type); | |
| 36 | 55 |
| 37 if (!permission_service_.get()) { | 56 if (!permission_service_.get()) { |
| 38 render_frame()->GetServiceRegistry()->ConnectToRemoteService( | 57 render_frame()->GetServiceRegistry()->ConnectToRemoteService( |
| 39 mojo::GetProxy(&permission_service_)); | 58 mojo::GetProxy(&permission_service_)); |
| 40 } | 59 } |
| 41 | 60 |
| 42 uint32_t request_id = next_request_id_++; | 61 uint32_t request_id = next_request_id_++; |
| 43 DCHECK(!requests_.count(request_id)); | 62 DCHECK(!requests_.count(request_id)); |
| 44 requests_[request_id] = permission_status_cb; | 63 requests_[request_id] = permission_status_cb; |
| 45 | 64 |
| 46 DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; | 65 DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; |
| 47 | 66 |
| 48 permission_service_->HasPermission( | 67 permission_service_->HasPermission( |
| 49 PERMISSION_NAME_PROTECTED_MEDIA_IDENTIFIER, security_origin.spec(), | 68 MediaPermissionTypeToPermissionName(type), security_origin.spec(), |
| 50 base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, | 69 base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, |
| 51 base::Unretained(this), request_id)); | 70 base::Unretained(this), request_id)); |
| 52 } | 71 } |
| 53 | 72 |
| 54 void MediaPermissionDispatcher::RequestPermission( | 73 void MediaPermissionDispatcher::RequestPermission( |
| 55 Type type, | 74 Type type, |
| 56 const GURL& security_origin, | 75 const GURL& security_origin, |
| 57 const PermissionStatusCB& permission_status_cb) { | 76 const PermissionStatusCB& permission_status_cb) { |
| 58 DCHECK(thread_checker_.CalledOnValidThread()); | 77 DCHECK(thread_checker_.CalledOnValidThread()); |
| 59 CHECK_EQ(PROTECTED_MEDIA_IDENTIFIER, type); | |
| 60 | 78 |
| 61 if (!permission_service_.get()) { | 79 if (!permission_service_.get()) { |
| 62 render_frame()->GetServiceRegistry()->ConnectToRemoteService( | 80 render_frame()->GetServiceRegistry()->ConnectToRemoteService( |
| 63 mojo::GetProxy(&permission_service_)); | 81 mojo::GetProxy(&permission_service_)); |
| 64 } | 82 } |
| 65 | 83 |
| 66 uint32_t request_id = next_request_id_++; | 84 uint32_t request_id = next_request_id_++; |
| 67 DCHECK(!requests_.count(request_id)); | 85 DCHECK(!requests_.count(request_id)); |
| 68 requests_[request_id] = permission_status_cb; | 86 requests_[request_id] = permission_status_cb; |
| 69 | 87 |
| 70 DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; | 88 DVLOG(2) << __FUNCTION__ << ": request ID " << request_id; |
| 71 | 89 |
| 72 permission_service_->RequestPermission( | 90 permission_service_->RequestPermission( |
| 73 PERMISSION_NAME_PROTECTED_MEDIA_IDENTIFIER, security_origin.spec(), | 91 MediaPermissionTypeToPermissionName(type), security_origin.spec(), |
| 74 blink::WebUserGestureIndicator::isProcessingUserGesture(), | 92 blink::WebUserGestureIndicator::isProcessingUserGesture(), |
| 75 base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, | 93 base::Bind(&MediaPermissionDispatcher::OnPermissionStatus, |
| 76 base::Unretained(this), request_id)); | 94 base::Unretained(this), request_id)); |
| 77 } | 95 } |
| 78 | 96 |
| 79 void MediaPermissionDispatcher::OnPermissionStatus(uint32_t request_id, | 97 void MediaPermissionDispatcher::OnPermissionStatus(uint32_t request_id, |
| 80 PermissionStatus status) { | 98 PermissionStatus status) { |
| 81 DVLOG(2) << __FUNCTION__ << ": (" << request_id << ", " << status << ")"; | 99 DVLOG(2) << __FUNCTION__ << ": (" << request_id << ", " << status << ")"; |
| 82 DCHECK(thread_checker_.CalledOnValidThread()); | 100 DCHECK(thread_checker_.CalledOnValidThread()); |
| 83 | 101 |
| 84 RequestMap::iterator iter = requests_.find(request_id); | 102 RequestMap::iterator iter = requests_.find(request_id); |
| 85 if (iter == requests_.end()) { | 103 if (iter == requests_.end()) { |
| 86 DVLOG(2) << "Request not found."; | 104 DVLOG(2) << "Request not found."; |
| 87 return; | 105 return; |
| 88 } | 106 } |
| 89 | 107 |
| 90 PermissionStatusCB permission_status_cb = iter->second; | 108 PermissionStatusCB permission_status_cb = iter->second; |
| 91 requests_.erase(iter); | 109 requests_.erase(iter); |
| 92 | 110 |
| 93 permission_status_cb.Run(status == PERMISSION_STATUS_GRANTED); | 111 permission_status_cb.Run(status == PERMISSION_STATUS_GRANTED); |
| 94 } | 112 } |
| 95 | 113 |
| 96 } // namespace content | 114 } // namespace content |
| OLD | NEW |