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

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@ test comments 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"
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
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698