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

Side by Side Diff: chrome/browser/android/customtabs/origin_verifier.cc

Issue 2767333006: Add Digital Asset Links verification for postMessage API (Closed)
Patch Set: lizeb@ commetns 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 unified diff | Download patch
OLDNEW
(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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698