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

Side by Side Diff: content/browser/media/android/media_drm_credential_manager.cc

Issue 24152015: [Android] JNI binding for MediaDrmCredentialManager (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: rebase against trunk Created 7 years, 3 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 unified diff | Download patch
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/android/media_drm_credential_manager.h" 5 #include "content/browser/media/android/media_drm_credential_manager.h"
6 6
7 #include "base/android/jni_android.h"
8 #include "base/android/scoped_java_ref.h"
7 #include "base/bind.h" 9 #include "base/bind.h"
8 #include "base/callback_helpers.h" 10 #include "base/callback_helpers.h"
11 #include "jni/MediaDrmCredentialManager_jni.h"
9 #include "media/base/android/media_drm_bridge.h" 12 #include "media/base/android/media_drm_bridge.h"
13 #include "url/gurl.h"
14
15 using base::android::ScopedJavaGlobalRef;
16
17 namespace {
18
19 void MediaDrmCredentialManagerCallback(
20 const ScopedJavaGlobalRef<jobject>& j_media_drm_credential_manager_callback,
21 bool succeeded) {
22 JNIEnv* env = base::android::AttachCurrentThread();
23 content::Java_MediaDrmCredentialManagerCallback_onCredentialResetFinished(
24 env, j_media_drm_credential_manager_callback.obj(), succeeded);
25 }
26
27 } // namespace
10 28
11 namespace content { 29 namespace content {
12 30
13 // TODO(qinmin): Move the UUID definition to some common places. 31 // TODO(qinmin): Move the UUID definition to some common places.
14 static const uint8 kWidevineUuid[16] = { 32 static const uint8 kWidevineUuid[16] = {
15 0xED, 0xEF, 0x8B, 0xA9, 0x79, 0xD6, 0x4A, 0xCE, 33 0xED, 0xEF, 0x8B, 0xA9, 0x79, 0xD6, 0x4A, 0xCE,
16 0xA3, 0xC8, 0x27, 0xDC, 0xD5, 0x1D, 0x21, 0xED }; 34 0xA3, 0xC8, 0x27, 0xDC, 0xD5, 0x1D, 0x21, 0xED };
17 35
18 MediaDrmCredentialManager::MediaDrmCredentialManager() {} 36 MediaDrmCredentialManager::MediaDrmCredentialManager() {}
19 37
20 MediaDrmCredentialManager::~MediaDrmCredentialManager() {} 38 MediaDrmCredentialManager::~MediaDrmCredentialManager() {}
21 39
40 void MediaDrmCredentialManager::Destroy(JNIEnv* env, jobject obj) {
41 delete this;
42 }
43
22 void MediaDrmCredentialManager::ResetCredentials( 44 void MediaDrmCredentialManager::ResetCredentials(
23 const ResetCredentialsCB& callback) { 45 const ResetCredentialsCB& callback) {
24 // Ignore reset request if one is already in progress. 46 // Ignore reset request if one is already in progress.
25 if (!reset_credentials_cb_.is_null()) 47 if (!reset_credentials_cb_.is_null())
26 return; 48 return;
27 49
28 reset_credentials_cb_ = callback; 50 reset_credentials_cb_ = callback;
29 51
30 // First reset the L3 credential. 52 // First reset the L3 credential.
31 if (!ResetCredentialsInternal("L3")) { 53 if (!ResetCredentialsInternal("L3")) {
32 // TODO(qinmin): We should post a task instead. 54 // TODO(qinmin): We should post a task instead.
33 base::ResetAndReturn(&reset_credentials_cb_).Run(false); 55 base::ResetAndReturn(&reset_credentials_cb_).Run(false);
34 } 56 }
35 } 57 }
36 58
59 void MediaDrmCredentialManager::ResetCredentials(
60 JNIEnv* env,
61 jobject obj,
62 jobject j_media_drm_credential_manager_callback) {
63 ScopedJavaGlobalRef<jobject> j_scoped_media_drm_credential_manager_callback;
64 j_scoped_media_drm_credential_manager_callback.Reset(
65 env, j_media_drm_credential_manager_callback);
66 ResetCredentialsCB callback_runner =
67 base::Bind(&MediaDrmCredentialManagerCallback,
68 j_scoped_media_drm_credential_manager_callback);
69
70 ResetCredentials(callback_runner);
71 }
72
37 void MediaDrmCredentialManager::OnResetCredentialsCompleted( 73 void MediaDrmCredentialManager::OnResetCredentialsCompleted(
38 const std::string& security_level, bool success) { 74 const std::string& security_level, bool success) {
39 if (security_level == "L3" && success) { 75 if (security_level == "L3" && success) {
40 if (ResetCredentialsInternal("L1")) 76 if (ResetCredentialsInternal("L1"))
41 return; 77 return;
42 success = false; 78 success = false;
43 } 79 }
44 80
45 base::ResetAndReturn(&reset_credentials_cb_).Run(success); 81 base::ResetAndReturn(&reset_credentials_cb_).Run(success);
46 media_drm_bridge_.reset(); 82 media_drm_bridge_.reset();
47 } 83 }
48 84
49 bool MediaDrmCredentialManager::ResetCredentialsInternal( 85 bool MediaDrmCredentialManager::ResetCredentialsInternal(
50 const std::string& security_level) { 86 const std::string& security_level) {
51 std::vector<uint8> uuid(kWidevineUuid, kWidevineUuid + 16); 87 std::vector<uint8> uuid(kWidevineUuid, kWidevineUuid + 16);
52 media_drm_bridge_ = media::MediaDrmBridge::Create( 88 media_drm_bridge_ = media::MediaDrmBridge::Create(
53 0, uuid, security_level, NULL); 89 0, uuid, GURL(), security_level, NULL);
54 if (!media_drm_bridge_) 90 if (!media_drm_bridge_)
55 return false; 91 return false;
56 media_drm_bridge_->ResetDeviceCredentials( 92 media_drm_bridge_->ResetDeviceCredentials(
57 base::Bind(&MediaDrmCredentialManager::OnResetCredentialsCompleted, 93 base::Bind(&MediaDrmCredentialManager::OnResetCredentialsCompleted,
58 base::Unretained(this), security_level)); 94 base::Unretained(this), security_level));
59 return true; 95 return true;
60 } 96 }
61 97
98 static jint Init(JNIEnv* env, jclass clazz) {
99 return reinterpret_cast<jint>(new content::MediaDrmCredentialManager());
100 }
101
102 // static
103 bool MediaDrmCredentialManager::RegisterMediaDrmCredentialManager(JNIEnv* env) {
104 return RegisterNativesImpl(env);
105 }
106
62 } // namespace content 107 } // namespace content
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698