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 |