OLD | NEW |
---|---|
(Empty) | |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | |
mark a. foltz
2016/10/08 00:33:41
Update copyright
zhaobin
2016/10/12 02:27:33
Done.
| |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 #include "chrome/browser/media/router/receiver_presentation_service_delegate_imp l.h" | |
6 | |
7 #include "chrome/browser/profiles/profile.h" | |
8 #include "content/public/browser/render_frame_host.h" | |
9 #include "content/public/browser/render_process_host.h" | |
10 #include "url/gurl.h" | |
11 | |
12 DEFINE_WEB_CONTENTS_USER_DATA_KEY( | |
13 media_router::ReceiverPresentationServiceDelegateImpl); | |
14 | |
15 using content::PresentationServiceDelegate; | |
16 using content::RenderFrameHost; | |
17 | |
18 namespace media_router { | |
19 | |
20 // static | |
21 void ReceiverPresentationServiceDelegateImpl::CreateForWebContents( | |
22 content::WebContents* web_contents, | |
23 const std::string& presentation_id) { | |
24 DCHECK(web_contents); | |
25 | |
26 if (FromWebContents(web_contents)) | |
27 return; | |
28 | |
29 web_contents->SetUserData(UserDataKey(), | |
30 new ReceiverPresentationServiceDelegateImpl( | |
31 web_contents, presentation_id)); | |
32 } | |
33 | |
34 ReceiverPresentationServiceDelegateImpl:: | |
35 ~ReceiverPresentationServiceDelegateImpl() { | |
36 for (auto& observer_pair : observers_) | |
37 observer_pair.second->OnDelegateDestroyed(); | |
38 } | |
39 | |
40 void ReceiverPresentationServiceDelegateImpl::AddObserver( | |
mark a. foltz
2016/10/08 00:33:42
IMO it would be worth having a base class for the
zhaobin
2016/10/12 02:27:33
Done.
| |
41 int render_process_id, | |
42 int render_frame_id, | |
43 content::PresentationServiceDelegate::Observer* observer) { | |
44 DCHECK(observer); | |
45 | |
46 RenderFrameHostId rfh_id(render_process_id, render_frame_id); | |
47 DCHECK(!base::ContainsKey(observers_, rfh_id)); | |
48 observers_[rfh_id] = observer; | |
49 } | |
50 | |
51 void ReceiverPresentationServiceDelegateImpl::RemoveObserver( | |
52 int render_process_id, | |
53 int render_frame_id) { | |
54 observers_.erase(RenderFrameHostId(render_process_id, render_frame_id)); | |
55 } | |
56 | |
57 bool ReceiverPresentationServiceDelegateImpl::AddScreenAvailabilityListener( | |
58 int render_process_id, | |
59 int render_frame_id, | |
60 content::PresentationScreenAvailabilityListener* listener) { | |
61 NOTIMPLEMENTED(); | |
62 return false; | |
63 } | |
64 | |
65 void ReceiverPresentationServiceDelegateImpl::RemoveScreenAvailabilityListener( | |
66 int render_process_id, | |
67 int render_frame_id, | |
68 content::PresentationScreenAvailabilityListener* listener) { | |
69 NOTIMPLEMENTED(); | |
70 } | |
71 | |
72 void ReceiverPresentationServiceDelegateImpl::Reset(int render_process_id, | |
73 int render_frame_id) { | |
74 DVLOG(2) << __FUNCTION__ << render_process_id << ", " << render_frame_id; | |
75 offscreen_presentation_manager_->OnOffscreenPresentationReceiverTerminated( | |
76 presentation_id_); | |
77 } | |
78 | |
79 void ReceiverPresentationServiceDelegateImpl::SetDefaultPresentationUrls( | |
80 int render_process_id, | |
81 int render_frame_id, | |
82 const std::vector<std::string>& default_presentation_urls, | |
83 const content::PresentationSessionStartedCallback& callback) { | |
84 NOTIMPLEMENTED(); | |
85 } | |
86 | |
87 void ReceiverPresentationServiceDelegateImpl::StartSession( | |
88 int render_process_id, | |
89 int render_frame_id, | |
90 const std::vector<std::string>& presentation_urls, | |
91 const content::PresentationSessionStartedCallback& success_cb, | |
92 const content::PresentationSessionErrorCallback& error_cb) { | |
93 NOTIMPLEMENTED(); | |
94 error_cb.Run(content::PresentationError(content::PRESENTATION_ERROR_UNKNOWN, | |
95 "Not implemented")); | |
96 } | |
97 | |
98 void ReceiverPresentationServiceDelegateImpl::JoinSession( | |
99 int render_process_id, | |
100 int render_frame_id, | |
101 const std::vector<std::string>& presentation_urls, | |
102 const std::string& presentation_id, | |
103 const content::PresentationSessionStartedCallback& success_cb, | |
104 const content::PresentationSessionErrorCallback& error_cb) { | |
105 NOTIMPLEMENTED(); | |
106 error_cb.Run(content::PresentationError(content::PRESENTATION_ERROR_UNKNOWN, | |
107 "Not implemented")); | |
108 } | |
109 | |
110 void ReceiverPresentationServiceDelegateImpl::CloseConnection( | |
111 int render_process_id, | |
112 int render_frame_id, | |
113 const std::string& presentation_id) { | |
114 NOTIMPLEMENTED(); | |
mark a. foltz
2016/10/08 00:33:41
This should be implemented eventually right?
zhaobin
2016/10/12 02:27:33
Maybe not if close/terminate can be handled at ren
| |
115 } | |
116 | |
117 void ReceiverPresentationServiceDelegateImpl::Terminate( | |
118 int render_process_id, | |
119 int render_frame_id, | |
120 const std::string& presentation_id) { | |
121 NOTIMPLEMENTED(); | |
mark a. foltz
2016/10/08 00:33:41
Should be implemented in the future?
zhaobin
2016/10/12 02:27:33
Same as above.
| |
122 } | |
123 | |
124 void ReceiverPresentationServiceDelegateImpl::ListenForSessionMessages( | |
125 int render_process_id, | |
126 int render_frame_id, | |
127 const content::PresentationSessionInfo& session_info, | |
128 const content::PresentationSessionMessageCallback& message_cb) { | |
129 NOTIMPLEMENTED(); | |
130 } | |
131 | |
132 void ReceiverPresentationServiceDelegateImpl::SendMessage( | |
133 int render_process_id, | |
134 int render_frame_id, | |
135 const content::PresentationSessionInfo& session_info, | |
136 std::unique_ptr<content::PresentationSessionMessage> message, | |
137 const SendMessageCallback& send_message_cb) { | |
138 NOTIMPLEMENTED(); | |
139 } | |
140 | |
141 void ReceiverPresentationServiceDelegateImpl::ListenForConnectionStateChange( | |
142 int render_process_id, | |
143 int render_frame_id, | |
144 const content::PresentationSessionInfo& connection, | |
145 const content::PresentationConnectionStateChangedCallback& | |
146 state_changed_cb) { | |
147 NOTIMPLEMENTED(); | |
148 } | |
149 | |
150 ReceiverPresentationServiceDelegateImpl:: | |
151 ReceiverPresentationServiceDelegateImpl(content::WebContents* web_contents, | |
152 const std::string& presentation_id) | |
153 : web_contents_(web_contents), | |
154 presentation_id_(presentation_id), | |
155 offscreen_presentation_manager_( | |
156 OffscreenPresentationManagerFactory::GetOrCreateForBrowserContext( | |
157 Profile::FromBrowserContext(web_contents_->GetBrowserContext()) | |
158 ->GetOriginalProfile())) { | |
159 DCHECK(web_contents_); | |
160 DCHECK(!presentation_id.empty()); | |
161 DCHECK(offscreen_presentation_manager_); | |
162 DCHECK(web_contents_->GetBrowserContext()->IsOffTheRecord()); | |
163 } | |
164 | |
165 void ReceiverPresentationServiceDelegateImpl::RegisterReceiverAvailableCallback( | |
166 const content::ReceiverConnectionAvailableCallback& | |
167 receiver_available_callback) { | |
168 std::string presentation_url = web_contents_->GetURL().spec(); | |
mark a. foltz
2016/10/08 00:33:41
Can you just pass the URL directly?
zhaobin
2016/10/12 02:27:33
Done.
| |
169 offscreen_presentation_manager_->OnOffscreenPresentationReceiverCreated( | |
170 presentation_id_, GURL(presentation_url), receiver_available_callback); | |
171 } | |
172 | |
173 void ReceiverPresentationServiceDelegateImpl:: | |
174 RegisterOffscreenPresentationConnection( | |
175 int render_process_id, | |
176 int render_frame_id, | |
177 const content::PresentationSessionInfo& session, | |
178 content::PresentationConnectionPtr connection) { | |
179 NOTREACHED(); | |
180 } | |
181 | |
182 } // namespace media_router | |
OLD | NEW |