Chromium Code Reviews| Index: chrome/browser/media/output_protection_proxy.cc |
| diff --git a/chrome/browser/media/output_protection_proxy.cc b/chrome/browser/media/output_protection_proxy.cc |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..49fdefd69ef2989ea435e9ab2f00fd158f03533e |
| --- /dev/null |
| +++ b/chrome/browser/media/output_protection_proxy.cc |
| @@ -0,0 +1,97 @@ |
| +// Copyright 2016 The Chromium Authors. All rights reserved. |
| +// Use of this source code is governed by a BSD-style license that can be |
| +// found in the LICENSE file. |
| + |
| +#include "chrome/browser/media/output_protection_proxy.h" |
| + |
| +#include "build/build_config.h" |
| +#include "chrome/browser/media/media_capture_devices_dispatcher.h" |
| +#include "content/public/browser/browser_thread.h" |
| +#include "content/public/browser/render_frame_host.h" |
| +#include "content/public/browser/web_contents.h" |
| +#include "ui/display/types/display_constants.h" |
| + |
| +namespace chrome { |
| + |
| +OutputProtectionProxy::OutputProtectionProxy(int render_process_id, |
| + int render_frame_id) |
| + : render_process_id_(render_process_id), |
| + render_frame_id_(render_frame_id), |
| +#if defined(OS_CHROMEOS) |
| + output_protection_delegate_(render_process_id, render_frame_id), |
| +#endif // defined(OS_CHROMEOS) |
| + weak_ptr_factory_(this) { |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::IO); |
| +} |
| + |
| +OutputProtectionProxy::~OutputProtectionProxy() { |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| +} |
| + |
| +void OutputProtectionProxy::QueryStatus(const QueryStatusCallback& callback) { |
| + DVLOG(1) << __FUNCTION__; |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| + |
| + content::RenderFrameHost* rfh = |
| + content::RenderFrameHost::FromID(render_process_id_, render_frame_id_); |
|
jrummell
2016/06/23 18:07:57
It appears you just copied the code, but why check
xhwang
2016/06/23 20:53:49
Makes sense. Done.
|
| + if (!rfh) { |
| + LOG(WARNING) << "RenderFrameHost is not alive."; |
| + callback.Run(false, 0, 0); |
| + return; |
| + } |
| + |
| +#if defined(OS_CHROMEOS) |
| + output_protection_delegate_.QueryStatus( |
| + base::Bind(&OutputProtectionProxy::QueryStatusComplete, |
| + weak_ptr_factory_.GetWeakPtr(), callback)); |
| +#else // defined(OS_CHROMEOS) |
| + QueryStatusComplete(callback, true, 0, 0); |
| +#endif // defined(OS_CHROMEOS) |
| +} |
| + |
| +void OutputProtectionProxy::EnableProtection( |
| + uint32_t desired_method_mask, |
| + const EnableProtectionCallback& callback) { |
| + DVLOG(1) << __FUNCTION__; |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| + |
| +#if defined(OS_CHROMEOS) |
| + output_protection_delegate_.EnableProtection(desired_method_mask, callback); |
| +#else // defined(OS_CHROMEOS) |
| + callback.Run(false); |
|
ddorwin
2016/06/23 19:24:28
NOTIMPLEMENTED()?
xhwang
2016/06/23 20:53:49
Done.
|
| +#endif // defined(OS_CHROMEOS) |
| +} |
| + |
| +void OutputProtectionProxy::QueryStatusComplete( |
| + const QueryStatusCallback& callback, |
| + bool success, |
| + uint32_t link_mask, |
| + uint32_t protection_mask) { |
| + DVLOG(1) << __FUNCTION__ << ": " << success << ", " << link_mask; |
| + DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
| + |
| + content::RenderFrameHost* rfh = |
| + content::RenderFrameHost::FromID(render_process_id_, render_frame_id_); |
| + // TODO(xjz): Investigate whether this check (and the other one above) should |
|
ddorwin
2016/06/23 19:24:28
It definitely seems weird that we have to protect
xhwang
2016/06/23 20:53:49
Agreed. But I'd like to keep this TODO here and ad
|
| + // be removed. |
| + if (!rfh) { |
| + LOG(WARNING) << "RenderFrameHost is not alive."; |
| + callback.Run(false, 0, 0); |
| + return; |
| + } |
| + |
| + uint32_t new_link_mask = link_mask; |
| + // If we successfully retrieved the device level status, check for capturers. |
| + if (success) { |
| + const bool insecure_capture_detected = |
|
ddorwin
2016/06/23 19:24:28
nit: is_...
xhwang
2016/06/23 20:53:49
Done.
|
| + MediaCaptureDevicesDispatcher::GetInstance() |
| + ->IsInsecureCapturingInProgress(render_process_id_, |
| + render_frame_id_); |
| + if (insecure_capture_detected) |
| + new_link_mask |= ui::DISPLAY_CONNECTION_TYPE_NETWORK; |
| + } |
| + |
| + callback.Run(success, new_link_mask, protection_mask); |
| +} |
| + |
| +} // namespace chrome |