Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(5874)

Unified Diff: chrome/browser/media/protected_media_identifier_permission_context.cc

Issue 2816773002: Added switch for bypassing protected media identifier permission (Closed)
Patch Set: Added switch for bypassing permissions Created 3 years, 8 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « no previous file | media/base/media_switches.h » ('j') | media/base/media_switches.h » ('J')
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: chrome/browser/media/protected_media_identifier_permission_context.cc
diff --git a/chrome/browser/media/protected_media_identifier_permission_context.cc b/chrome/browser/media/protected_media_identifier_permission_context.cc
index 50c2dc51ec53a1f4269eff81c038c44fc6eb40bc..13514a2af890e398410da926fabf8acde6e64ac5 100644
--- a/chrome/browser/media/protected_media_identifier_permission_context.cc
+++ b/chrome/browser/media/protected_media_identifier_permission_context.cc
@@ -6,6 +6,7 @@
#include "base/command_line.h"
#include "base/metrics/user_metrics.h"
+#include "base/strings/string_split.h"
#include "build/build_config.h"
#include "chrome/browser/content_settings/tab_specific_content_settings.h"
#include "chrome/browser/permissions/permission_util.h"
@@ -15,6 +16,8 @@
#include "content/public/browser/browser_thread.h"
#include "content/public/browser/render_frame_host.h"
#include "content/public/browser/web_contents.h"
+#include "media/base/media_switches.h"
+#include "net/base/url_util.h"
#if defined(OS_CHROMEOS)
#include <utility>
@@ -101,6 +104,37 @@ ProtectedMediaIdentifierPermissionContext::GetPermissionStatusInternal(
content_setting == CONTENT_SETTING_BLOCK ||
content_setting == CONTENT_SETTING_ASK);
+ // For automated testing of protected content - having a prompt that requires
+ // user intervention is problematic. If the domain has been whitelisted as
+ // safe - suppress the request and allow.
raymes 2017/04/20 23:12:42 I think we should link to a bug or something that
Joey Parrish 2017/04/20 23:25:56 We've got b/35045892 filed internally, if that's h
+ const base::CommandLine& command_line =
+ *base::CommandLine::ForCurrentProcess();
+ if (content_setting == CONTENT_SETTING_ASK &&
+ command_line.HasSwitch(
+ switches::kDisableInfobarForProtectedMediaIdentifierForDomain)) {
assareh1 2017/04/19 18:13:34 As we had discussed offline, can you also verify t
assareh1 2017/04/19 18:15:08 *less* likely :)
+ // Convert the switch value to a vector of URLs
+ std::vector<std::string> origins;
+ std::string whitelist = command_line.GetSwitchValueASCII(
+ switches::kDisableInfobarForProtectedMediaIdentifierForDomain);
+ for (const std::string& origin : base::SplitString(
+ whitelist, ",", base::TRIM_WHITESPACE, base::SPLIT_WANT_ALL)) {
+ origins.push_back(origin);
+ }
raymes 2017/04/19 23:05:47 Is this extra complexity really necessary? Was the
assareh1 2017/04/20 15:37:07 By whitelisting a user-specified domain vs only lo
raymes 2017/04/20 23:12:42 Ok. I would suggest rather than comparing the host
+
+ // Only if both requesting and embedding are allowed, allow the prompt to
+ // be skipped.
+ bool found_requesting = false;
+ bool found_embedding = false;
+ for (size_t i = 0; i < origins.size(); i++) {
raymes 2017/04/20 23:12:42 Rather than looping through everything again, can
+ found_requesting |= origins.at(i) == requesting_origin.host();
+ found_embedding |= origins.at(i) == embedding_origin.host();
+ }
raymes 2017/04/20 23:12:42 I would suggest just we just compare the requestin
+
+ if (found_requesting && found_embedding) {
+ content_setting = CONTENT_SETTING_ALLOW;
+ }
+ }
+
return content_setting;
}
« no previous file with comments | « no previous file | media/base/media_switches.h » ('j') | media/base/media_switches.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698