Index: chrome/browser/media/android/cdm/media_drm_storage_factory.cc |
diff --git a/chrome/browser/media/android/cdm/media_drm_storage_factory.cc b/chrome/browser/media/android/cdm/media_drm_storage_factory.cc |
new file mode 100644 |
index 0000000000000000000000000000000000000000..fc54ccc614f314b448618045d0111adee326521a |
--- /dev/null |
+++ b/chrome/browser/media/android/cdm/media_drm_storage_factory.cc |
@@ -0,0 +1,48 @@ |
+// Copyright 2017 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/android/cdm/media_drm_storage_factory.h" |
+ |
+#include "base/logging.h" |
+#include "base/memory/ptr_util.h" |
+#include "chrome/browser/profiles/profile.h" |
+#include "components/cdm/browser/media_drm_storage_impl.h" |
+#include "components/prefs/pref_service.h" |
+#include "content/public/browser/browser_context.h" |
+#include "content/public/browser/browser_thread.h" |
+#include "content/public/browser/render_frame_host.h" |
+#include "content/public/browser/web_contents.h" |
+#include "mojo/public/cpp/bindings/strong_binding.h" |
+ |
+namespace chrome { |
+ |
+void CreateMediaDrmStorage(content::RenderFrameHost* render_frame_host, |
+ media::mojom::MediaDrmStorageRequest request) { |
+ DVLOG(2) << __func__; |
+ DCHECK_CURRENTLY_ON(content::BrowserThread::UI); |
+ DCHECK(render_frame_host); |
+ |
+ content::WebContents* web_contents = |
+ content::WebContents::FromRenderFrameHost(render_frame_host); |
+ if (!web_contents) |
dcheng
2017/03/29 01:17:22
I'm curious how many of these early returns are ac
xhwang
2017/03/29 20:47:25
Well, I have the same question. But I'd rather cod
|
+ return; |
+ |
+ content::BrowserContext* browser_context = web_contents->GetBrowserContext(); |
dcheng
2017/03/29 01:17:22
Similarly, it doesn't seem like this should /ever/
xhwang
2017/03/29 20:47:25
Similarly, it's not clear to me whether this could
|
+ if (!browser_context) |
+ return; |
+ |
+ Profile* profile = Profile::FromBrowserContext(browser_context); |
+ if (!profile) |
+ return; |
+ |
+ PrefService* pref_service = profile->GetPrefs(); |
liberato (no reviews please)
2017/03/28 16:42:43
how does lifetime for |pref_service| work? for in
xhwang
2017/03/29 20:47:25
I don't really know. But I am following how PrefSe
|
+ if (!pref_service) |
+ return; |
yucliu1
2017/03/27 19:06:41
Are we able to launch the page if these early retu
xhwang
2017/03/27 20:28:46
All of these should never happen in practice :)
I
xhwang
2017/03/29 20:47:25
Done.
|
+ |
+ mojo::MakeStrongBinding( |
+ base::MakeUnique<cdm::MediaDrmStorageImpl>(pref_service), |
+ std::move(request)); |
dcheng
2017/03/29 01:17:22
Nit: #include <utility>
xhwang
2017/03/29 20:47:25
Done.
|
+} |
+ |
+} // namespace chrome |