Index: chrome/browser/media/media_capture_devices_dispatcher.cc |
diff --git a/chrome/browser/media/media_capture_devices_dispatcher.cc b/chrome/browser/media/media_capture_devices_dispatcher.cc |
index 29c7afbec8d820c24b7dbcf33b752af116bfd7db..5b1cf143372c193d61f80e3c748e28daf592d0ec 100644 |
--- a/chrome/browser/media/media_capture_devices_dispatcher.cc |
+++ b/chrome/browser/media/media_capture_devices_dispatcher.cc |
@@ -105,6 +105,30 @@ bool IsOriginWhitelistedForScreenCapture(const GURL& origin) { |
#endif |
} |
+#if defined(OS_CHROMEOS) |
+// Returns true of the security origin is associated with casting. |
+bool IsOriginForCasting(const GURL& origin) { |
+#if defined(OFFICIAL_BUILD) |
+ // Whitelisted tab casting extensions. |
+ if (origin.spec() == "chrome-extension://pkedcjkdefgpdelpbcmbmeomcjbeemfm/" || |
+ origin.spec() == "chrome-extension://fmfcbgogabcbclcofgocippekhfcmgfj/" || |
+ origin.spec() == "chrome-extension://hfaagokkkhdbgiakmmlclaapfelnkoah/") { |
+ return true; |
+ } |
+ // Check against hashed origins. |
+ const std::string origin_hash = base::SHA1HashString(origin.spec()); |
+ DCHECK_EQ(origin_hash.length(), base::kSHA1Length); |
+ const std::string hexencoded_origin_hash = |
+ base::HexEncode(origin_hash.data(), origin_hash.length()); |
+ return |
+ hexencoded_origin_hash == "3C2705BC432E7C51CA8553FDC5BEE873FF2468EE" || |
Sergey Ulanov
2014/01/17 18:39:32
These do not need to be hashed anymore.
hshi1
2014/01/17 19:31:28
Done (removed hash for public release ID; left a T
|
+ hexencoded_origin_hash == "50F02B8A668CAB274527D58356F07C2143080FCC"; |
+#else |
+ return false; |
+#endif |
+} |
+#endif |
+ |
// Helper to get title of the calling application shown in the screen capture |
// notification. |
base::string16 GetApplicationTitle(content::WebContents* web_contents, |
@@ -395,7 +419,7 @@ void MediaCaptureDevicesDispatcher::ProcessScreenCaptureAccessRequest( |
// display the notification for stream capture. |
bool display_notification = !component_extension; |
- ui = GetDevicesForDesktopCapture(devices, screen_id, capture_audio, |
+ ui = GetDevicesForDesktopCapture(devices, screen_id, capture_audio, |
display_notification, application_title); |
} |
} |
@@ -657,6 +681,7 @@ void MediaCaptureDevicesDispatcher::OnMediaRequestStateChanged( |
int render_process_id, |
int render_view_id, |
int page_request_id, |
+ const GURL& security_origin, |
const content::MediaStreamDevice& device, |
content::MediaRequestState state) { |
DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
@@ -665,7 +690,7 @@ void MediaCaptureDevicesDispatcher::OnMediaRequestStateChanged( |
base::Bind( |
&MediaCaptureDevicesDispatcher::UpdateMediaRequestStateOnUIThread, |
base::Unretained(this), render_process_id, render_view_id, |
- page_request_id, device, state)); |
+ page_request_id, security_origin, device, state)); |
} |
void MediaCaptureDevicesDispatcher::OnAudioStreamPlayingChanged( |
@@ -709,6 +734,7 @@ void MediaCaptureDevicesDispatcher::UpdateMediaRequestStateOnUIThread( |
int render_process_id, |
int render_view_id, |
int page_request_id, |
+ const GURL& security_origin, |
const content::MediaStreamDevice& device, |
content::MediaRequestState state) { |
// Track desktop capture sessions. Tracking is necessary to avoid unbalanced |
@@ -755,6 +781,17 @@ void MediaCaptureDevicesDispatcher::UpdateMediaRequestStateOnUIThread( |
} |
} |
+#if defined(OS_CHROMEOS) |
+ if (IsOriginForCasting(security_origin) && IsVideoMediaType(device.type)) { |
+ // Notify ash that casting state has changed. |
+ if (state == content::MEDIA_REQUEST_STATE_DONE) { |
+ ash::Shell::GetInstance()->OnCastingStateChanged(true); |
+ } else if (state == content::MEDIA_REQUEST_STATE_CLOSING) { |
+ ash::Shell::GetInstance()->OnCastingStateChanged(false); |
+ } |
+ } |
+#endif |
+ |
FOR_EACH_OBSERVER(Observer, observers_, |
OnRequestUpdate(render_process_id, |
render_view_id, |