Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2017 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chrome/browser/android/customtabs/origin_verifier.h" | |
| 6 | |
| 7 #include "base/android/jni_android.h" | |
| 8 #include "base/android/jni_string.h" | |
| 9 #include "base/strings/string_number_conversions.h" | |
| 10 #include "base/values.h" | |
| 11 #include "chrome/browser/profiles/profile_manager.h" | |
| 12 #include "jni/OriginVerifier_jni.h" | |
| 13 | |
| 14 using base::android::ConvertJavaStringToUTF16; | |
| 15 using base::android::JavaParamRef; | |
| 16 | |
| 17 namespace customtabs { | |
| 18 | |
| 19 OriginVerifier::OriginVerifier(JNIEnv* env, jobject obj) { | |
| 20 jobject_.Reset(env, obj); | |
| 21 Profile* profile = ProfileManager::GetPrimaryUserProfile(); | |
|
Benoit L
2017/04/04 18:44:12
The documentation for this function says:
// This
Yusuf
2017/04/05 00:20:42
Switched to using GetLastUsedProfile->GetOriginalP
| |
| 22 asset_link_handler_.reset(new digital_asset_links::DigitalAssetLinksHandler( | |
|
Benoit L
2017/04/04 18:44:11
tiny nit:
What about:
asset_link_handler_ = base
Yusuf
2017/04/05 00:20:42
Done.
| |
| 23 profile->GetRequestContext())); | |
| 24 } | |
| 25 | |
| 26 OriginVerifier::~OriginVerifier() {} | |
| 27 | |
| 28 void OriginVerifier::VerifyOrigin( | |
| 29 JNIEnv* env, | |
| 30 const JavaParamRef<jobject>& obj, | |
| 31 const JavaParamRef<jstring>& j_package_name, | |
| 32 const base::android::JavaParamRef<jstring>& j_fingerprint, | |
| 33 const JavaParamRef<jstring>& j_origin) { | |
| 34 if (!j_package_name || !j_fingerprint || !j_origin) | |
| 35 return; | |
| 36 std::string package_name = ConvertJavaStringToUTF8(env, j_package_name); | |
| 37 std::string fingerprint = ConvertJavaStringToUTF8(env, j_fingerprint); | |
| 38 std::string origin = ConvertJavaStringToUTF8(env, j_origin); | |
| 39 | |
| 40 digital_asset_links ::RelationshipCheckResultCallback callback( | |
| 41 base::Bind(&customtabs::OriginVerifier::OnRelationshipCheckComplete, | |
| 42 base::Unretained(this))); | |
| 43 asset_link_handler_.get()->CheckDigitalAssetLinkRelationship( | |
|
Benoit L
2017/04/04 18:44:11
nit: asset_link_handler->Check...
Yusuf
2017/04/05 00:20:42
Done.
| |
| 44 std::unique_ptr<digital_asset_links::RelationshipCheckResultCallback>( | |
| 45 &callback), | |
|
Benoit L
2017/04/04 18:44:11
This doesn't work, as this is taking the address o
Yusuf
2017/04/05 00:20:42
not using unique ptr anymore.
| |
| 46 origin, package_name, fingerprint, | |
| 47 "delegate_permission/common.use_as_origin"); | |
| 48 } | |
| 49 | |
| 50 void OriginVerifier::OnRelationshipCheckComplete( | |
| 51 std::unique_ptr<base::DictionaryValue> response) { | |
| 52 JNIEnv* env = base::android::AttachCurrentThread(); | |
| 53 | |
| 54 bool verified = false; | |
| 55 | |
| 56 if (response) { | |
| 57 response->GetBoolean( | |
| 58 digital_asset_links::kDigitalAssetLinksCheckResponseKeyLinked, | |
| 59 &verified); | |
| 60 } | |
| 61 Java_OriginVerifier_originVerified(env, jobject_, verified); | |
| 62 } | |
| 63 | |
| 64 void OriginVerifier::Destroy(JNIEnv* env, | |
| 65 const base::android::JavaRef<jobject>& obj) { | |
| 66 delete this; | |
| 67 } | |
| 68 | |
| 69 static jlong Init(JNIEnv* env, | |
| 70 const base::android::JavaParamRef<jobject>& obj) { | |
| 71 OriginVerifier* native_verifier = new OriginVerifier(env, obj); | |
| 72 return reinterpret_cast<intptr_t>(native_verifier); | |
| 73 } | |
| 74 | |
| 75 bool RegisterOriginVerifier(JNIEnv* env) { | |
| 76 return RegisterNativesImpl(env); | |
| 77 } | |
| 78 | |
| 79 } // namespace customtabs | |
| OLD | NEW |