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" | |
nyquist
2017/04/19 06:35:56
Nit: Which of the conversions is this for again?
Yusuf
2017/04/26 00:51:36
Removed. I dont think we need this anymore.
| |
10 #include "base/values.h" | |
11 #include "chrome/browser/browser_process.h" | |
12 #include "chrome/browser/profiles/profile_manager.h" | |
13 #include "jni/OriginVerifier_jni.h" | |
14 | |
15 using base::android::ConvertJavaStringToUTF16; | |
16 using base::android::JavaParamRef; | |
17 | |
18 namespace customtabs { | |
19 | |
20 OriginVerifier::OriginVerifier(JNIEnv* env, jobject obj) { | |
21 jobject_.Reset(env, obj); | |
22 Profile* profile = ProfileManager::GetLastUsedProfile()->GetOriginalProfile(); | |
nyquist
2017/04/19 06:35:56
I don't know how profiles interact with custom tab
Yusuf
2017/04/26 00:51:36
Done.
| |
23 DCHECK(profile); | |
24 asset_link_handler_ = | |
25 base::MakeUnique<digital_asset_links::DigitalAssetLinksHandler>( | |
26 profile->GetRequestContext()); | |
27 } | |
28 | |
29 OriginVerifier::~OriginVerifier() {} | |
nyquist
2017/04/19 06:35:56
Nit: = default?
Yusuf
2017/04/26 00:51:36
Done.
| |
30 | |
31 void OriginVerifier::VerifyOrigin( | |
32 JNIEnv* env, | |
33 const JavaParamRef<jobject>& obj, | |
34 const JavaParamRef<jstring>& j_package_name, | |
35 const base::android::JavaParamRef<jstring>& j_fingerprint, | |
36 const JavaParamRef<jstring>& j_origin) { | |
37 if (!j_package_name || !j_fingerprint || !j_origin) | |
38 return; | |
nyquist
2017/04/19 06:35:56
It looks like this leads to the Java listener neve
Yusuf
2017/04/26 00:51:36
Done.
| |
39 std::string package_name = ConvertJavaStringToUTF8(env, j_package_name); | |
40 std::string fingerprint = ConvertJavaStringToUTF8(env, j_fingerprint); | |
41 std::string origin = ConvertJavaStringToUTF8(env, j_origin); | |
42 | |
43 asset_link_handler_->CheckDigitalAssetLinkRelationship( | |
44 base::Bind(&customtabs::OriginVerifier::OnRelationshipCheckComplete, | |
45 base::Unretained(this)), | |
nyquist
2017/04/19 06:35:56
Should you be giving away a WeakPtr instead here?
Yusuf
2017/04/26 00:51:36
The latter and added a comment here as well.
nyquist
2017/04/27 04:38:25
Acknowledged.
| |
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 if (!g_browser_process) | |
72 return 0; | |
nyquist
2017/04/19 06:35:56
Nit: Empty line after early return?
Yusuf
2017/04/26 00:51:35
Done.
| |
73 OriginVerifier* native_verifier = new OriginVerifier(env, obj); | |
74 return reinterpret_cast<intptr_t>(native_verifier); | |
75 } | |
76 | |
77 bool RegisterOriginVerifier(JNIEnv* env) { | |
78 return RegisterNativesImpl(env); | |
79 } | |
80 | |
81 } // namespace customtabs | |
OLD | NEW |