OLD | NEW |
---|---|
1 // Copyright 2016 The Chromium Authors. All rights reserved. | 1 // Copyright 2016 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/session/media_session_service_impl.h" | 5 #include "content/browser/media/session/media_session_service_impl.h" |
6 | 6 |
7 #include "content/browser/media/session/media_metadata_sanitizer.h" | 7 #include "content/browser/media/session/media_metadata_sanitizer.h" |
8 #include "content/browser/media/session/media_session_impl.h" | 8 #include "content/browser/media/session/media_session_impl.h" |
9 #include "content/browser/web_contents/web_contents_impl.h" | 9 #include "content/browser/web_contents/web_contents_impl.h" |
10 #include "content/public/browser/browser_thread.h" | 10 #include "content/public/browser/browser_thread.h" |
11 #include "content/public/browser/web_contents.h" | 11 #include "content/public/browser/web_contents.h" |
12 | 12 |
13 namespace content { | 13 namespace content { |
14 | 14 |
15 MediaSessionServiceImpl::MediaSessionServiceImpl( | 15 MediaSessionServiceImpl::MediaSessionServiceImpl( |
16 RenderFrameHost* render_frame_host) | 16 RenderFrameHost* render_frame_host) |
17 : render_frame_host_(render_frame_host) {} | 17 : render_frame_host_(render_frame_host) { |
18 if (MediaSessionImpl* session = GetMediaSession()) | |
19 session->SetMediaSessionService(this); | |
20 } | |
18 | 21 |
19 MediaSessionServiceImpl::~MediaSessionServiceImpl() = default; | 22 MediaSessionServiceImpl::~MediaSessionServiceImpl() { |
23 if (MediaSessionImpl* session = GetMediaSession()) | |
whywhat
2016/10/28 16:10:23
nit: can this be null here and below?
I'd avoid in
Zhiqiang Zhang (Slow)
2016/11/01 15:24:15
Yes, currently we only bind the top-level frame se
| |
24 session->SetMediaSessionService(nullptr); | |
25 } | |
20 | 26 |
21 // static | 27 // static |
22 void MediaSessionServiceImpl::Create( | 28 void MediaSessionServiceImpl::Create( |
23 RenderFrameHost* render_frame_host, | 29 RenderFrameHost* render_frame_host, |
24 blink::mojom::MediaSessionServiceRequest request) { | 30 blink::mojom::MediaSessionServiceRequest request) { |
25 MediaSessionServiceImpl* impl = | 31 MediaSessionServiceImpl* impl = |
26 new MediaSessionServiceImpl(render_frame_host); | 32 new MediaSessionServiceImpl(render_frame_host); |
27 impl->Bind(std::move(request)); | 33 impl->Bind(std::move(request)); |
28 } | 34 } |
29 | 35 |
30 void MediaSessionServiceImpl::SetClient( | 36 void MediaSessionServiceImpl::SetClient( |
31 blink::mojom::MediaSessionClientPtr client) { | 37 blink::mojom::MediaSessionClientPtr client) { |
32 client_ = std::move(client); | 38 client_ = std::move(client); |
33 } | 39 } |
34 | 40 |
35 void MediaSessionServiceImpl::SetMetadata( | 41 void MediaSessionServiceImpl::SetMetadata( |
36 const base::Optional<content::MediaMetadata>& metadata) { | 42 const base::Optional<content::MediaMetadata>& metadata) { |
37 // When receiving a MediaMetadata, the browser process can't trust that it is | 43 // When receiving a MediaMetadata, the browser process can't trust that it is |
38 // coming from a known and secure source. It must be processed accordingly. | 44 // coming from a known and secure source. It must be processed accordingly. |
39 if (metadata.has_value() && | 45 if (metadata.has_value() && |
40 !MediaMetadataSanitizer::CheckSanity(metadata.value())) { | 46 !MediaMetadataSanitizer::CheckSanity(metadata.value())) { |
41 render_frame_host_->GetProcess()->ShutdownForBadMessage( | 47 render_frame_host_->GetProcess()->ShutdownForBadMessage( |
42 RenderProcessHost::CrashReportMode::GENERATE_CRASH_DUMP); | 48 RenderProcessHost::CrashReportMode::GENERATE_CRASH_DUMP); |
43 return; | 49 return; |
44 } | 50 } |
45 | 51 |
46 WebContentsImpl* contents = static_cast<WebContentsImpl*>( | 52 if (MediaSessionImpl* session = GetMediaSession()) |
47 WebContentsImpl::FromRenderFrameHost(render_frame_host_)); | 53 session->SetMetadata(metadata); |
48 if (contents) | |
49 MediaSessionImpl::Get(contents)->SetMetadata(metadata); | |
50 } | 54 } |
51 | 55 |
52 void MediaSessionServiceImpl::EnableAction( | 56 void MediaSessionServiceImpl::EnableAction( |
53 blink::mojom::MediaSessionAction action) { | 57 blink::mojom::MediaSessionAction action) { |
54 // TODO(zqzhang): Plumb this signal to Java. See https://crbug.com/656563 | 58 if (MediaSessionImpl* session = GetMediaSession()) |
55 NOTIMPLEMENTED(); | 59 session->OnMediaSessionEnabledAction(action); |
56 } | 60 } |
57 | 61 |
58 void MediaSessionServiceImpl::DisableAction( | 62 void MediaSessionServiceImpl::DisableAction( |
59 blink::mojom::MediaSessionAction action) { | 63 blink::mojom::MediaSessionAction action) { |
60 // TODO(zqzhang): Plumb this signal to Java. See https://crbug.com/656563 | 64 if (MediaSessionImpl* session = GetMediaSession()) |
61 NOTIMPLEMENTED(); | 65 session->OnMediaSessionDisabledAction(action); |
66 } | |
67 | |
68 MediaSessionImpl* MediaSessionServiceImpl::GetMediaSession() { | |
69 WebContentsImpl* contents = static_cast<WebContentsImpl*>( | |
70 WebContentsImpl::FromRenderFrameHost(render_frame_host_)); | |
71 if (!contents) | |
72 return nullptr; | |
73 if (render_frame_host_ != contents->GetMainFrame()) | |
74 return nullptr; | |
75 return MediaSessionImpl::Get(contents); | |
62 } | 76 } |
63 | 77 |
64 void MediaSessionServiceImpl::Bind( | 78 void MediaSessionServiceImpl::Bind( |
65 blink::mojom::MediaSessionServiceRequest request) { | 79 blink::mojom::MediaSessionServiceRequest request) { |
66 binding_.reset(new mojo::Binding<blink::mojom::MediaSessionService>( | 80 binding_.reset(new mojo::Binding<blink::mojom::MediaSessionService>( |
67 this, std::move(request))); | 81 this, std::move(request))); |
68 } | 82 } |
69 | 83 |
70 } // namespace content | 84 } // namespace content |
OLD | NEW |