Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
2013
apiccion
2013/02/26 23:51:51
Done.
| |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 // Populates default autofill profile from user's own Android contact. | |
| 6 | |
| 7 #include <vector> | |
| 8 | |
| 9 #include "base/android/jni_android.h" | |
| 10 #include "base/android/jni_array.h" | |
| 11 #include "base/android/jni_string.h" | |
| 12 #include "base/guid.h" | |
| 13 #include "base/logging.h" | |
| 14 #include "base/memory/scoped_ptr.h" | |
| 15 #include "base/string16.h" | |
| 16 #include "base/utf_string_conversions.h" | |
| 17 | |
| 18 #include "chrome/browser/autofill/personal_data_manager.h" | |
| 19 #include "chrome/browser/autofill/phone_number.h" | |
| 20 | |
| 21 #include "jni/PersonalAutofillPopulator_jni.h" | |
| 22 | |
| 23 static const std::string ANDROID_ME_CONTACT_AUOTFILL_PROFILE_GUID = | |
|
Ilya Sherman
2013/02/16 04:14:37
nit: This should be "const char kAndroidMeContactA
apiccion
2013/02/26 23:51:51
Done.
apiccion
2013/02/26 23:51:51
Done.
| |
| 24 "9A9E1C06-7A3B-48FA-AA4F-135CA6FC25D9"; | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
Where is this specified?
apiccion
2013/02/26 23:51:51
Randomly generated guid. We need a consistent guid
| |
| 25 | |
| 26 bool RegisterPersonalDataManager(JNIEnv* env) { | |
| 27 return RegisterNativesImpl(env); | |
| 28 } | |
| 29 | |
| 30 void LoadAddressWithPopulator(JNIEnv * env, | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
Should all of these functions live in some sort of
apiccion
2013/02/26 23:51:51
Done.
| |
| 31 ScopedJavaLocalRef<jobject> populator, | |
| 32 AutofillProfile * profile) { | |
|
Ilya Sherman
2013/02/16 04:14:37
nit: No space before the asterisk. (Applies throu
apiccion
2013/02/26 23:51:51
Done.
| |
| 33 ScopedJavaLocalRef<jstring> street = | |
| 34 Java_PersonalAutofillPopulator_getStreet(env, populator.obj()); | |
| 35 ScopedJavaLocalRef<jstring> pobox = | |
| 36 Java_PersonalAutofillPopulator_getPobox(env, populator.obj()); | |
| 37 ScopedJavaLocalRef<jstring> neighborhood = | |
| 38 Java_PersonalAutofillPopulator_getNeighborhood(env, populator.obj()); | |
| 39 ScopedJavaLocalRef<jstring> city = | |
| 40 Java_PersonalAutofillPopulator_getCity(env, populator.obj()); | |
| 41 ScopedJavaLocalRef<jstring> region = | |
| 42 Java_PersonalAutofillPopulator_getRegion(env, populator.obj()); | |
| 43 ScopedJavaLocalRef<jstring> postalCode = | |
| 44 Java_PersonalAutofillPopulator_getPostalCode(env, populator.obj()); | |
| 45 ScopedJavaLocalRef<jstring> country = | |
| 46 Java_PersonalAutofillPopulator_getCountry(env, populator.obj()); | |
| 47 | |
| 48 if (!street.is_null()) | |
| 49 profile->SetRawInfo(ADDRESS_HOME_LINE1, | |
| 50 ConvertJavaStringToUTF16(street)); | |
|
Ilya Sherman
2013/02/16 04:14:37
Android addresses can't have address line 2 data?
apiccion
2013/02/26 23:51:51
Added function to build address line 2 from misc d
| |
| 51 if (!city.is_null()) | |
| 52 profile->SetRawInfo(ADDRESS_HOME_CITY, | |
| 53 ConvertJavaStringToUTF16(city)); | |
|
Ilya Sherman
2013/02/16 04:14:37
nit: Curly braces, since this if-stmt's body spans
apiccion
2013/02/26 23:51:51
Done.
| |
| 54 if (!region.is_null()) | |
| 55 profile->SetRawInfo(ADDRESS_HOME_STATE, | |
| 56 ConvertJavaStringToUTF16(region)); | |
| 57 if (!postalCode.is_null()) | |
| 58 profile->SetRawInfo(ADDRESS_HOME_ZIP, | |
| 59 ConvertJavaStringToUTF16(postalCode)); | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
Align with ADDRESS_HOME_ZIP
apiccion
2013/02/26 23:51:51
Done.
| |
| 60 if (!country.is_null()) | |
| 61 profile->SetRawInfo(ADDRESS_HOME_COUNTRY, | |
| 62 ConvertJavaStringToUTF16(country)); | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
Align with ADDRESS_HOME_COUNTRY
apiccion
2013/02/26 23:51:51
Done.
| |
| 63 } | |
| 64 | |
| 65 void LoadNameWithPopulator(JNIEnv * env, | |
| 66 ScopedJavaLocalRef<jobject> populator, | |
| 67 AutofillProfile * profile) { | |
| 68 ScopedJavaLocalRef<jstring> firstName = | |
| 69 Java_PersonalAutofillPopulator_getFirstName(env, populator.obj()); | |
| 70 ScopedJavaLocalRef<jstring> middleName= | |
| 71 Java_PersonalAutofillPopulator_getMiddleName(env, populator.obj()); | |
| 72 ScopedJavaLocalRef<jstring> lastName = | |
| 73 Java_PersonalAutofillPopulator_getLastName(env, populator.obj()); | |
| 74 ScopedJavaLocalRef<jstring> suffix = | |
| 75 Java_PersonalAutofillPopulator_getSuffix(env, populator.obj()); | |
| 76 ScopedJavaLocalRef<jstring> fullName = | |
| 77 Java_PersonalAutofillPopulator_getFullName(env, populator.obj()); | |
| 78 | |
| 79 if (!firstName.is_null()) | |
| 80 profile->SetRawInfo(NAME_FIRST, ConvertJavaStringToUTF16(firstName)); | |
| 81 if (!middleName.is_null()) | |
| 82 profile->SetRawInfo(NAME_MIDDLE, ConvertJavaStringToUTF16(middleName)); | |
| 83 if (!lastName.is_null()) | |
| 84 profile->SetRawInfo(NAME_LAST, ConvertJavaStringToUTF16(lastName)); | |
| 85 if (!fullName.is_null()) | |
| 86 profile->SetRawInfo(NAME_FULL, ConvertJavaStringToUTF16(fullName)); | |
|
Ilya Sherman
2013/02/16 04:14:37
You should either set the first, middle, and last
apiccion
2013/02/26 23:51:51
Done.
| |
| 87 if (!suffix.is_null()) | |
| 88 profile->SetRawInfo(NAME_SUFFIX, ConvertJavaStringToUTF16(suffix)); | |
| 89 } | |
| 90 | |
| 91 void LoadEmailAddressWithPopulator(JNIEnv * env, | |
| 92 ScopedJavaLocalRef<jobject> populator, | |
| 93 AutofillProfile * profile) { | |
| 94 ScopedJavaLocalRef<jobjectArray> emailAddresses = | |
| 95 Java_PersonalAutofillPopulator_getEmailAddresses(env, populator.obj()); | |
| 96 std::vector<string16> emailAddressVector; | |
| 97 if (!emailAddresses.is_null()) { | |
| 98 base::android::AppendJavaStringArrayToStringVector(env, | |
| 99 emailAddresses.obj(), | |
| 100 &emailAddressVector); | |
| 101 profile->SetRawMultiInfo(EMAIL_ADDRESS, emailAddressVector); | |
| 102 } | |
| 103 } | |
| 104 | |
| 105 void LoadPhoneNumbersWithPopulator(JNIEnv * env, | |
| 106 ScopedJavaLocalRef<jobject> populator, | |
| 107 AutofillProfile * profile) { | |
| 108 ScopedJavaLocalRef<jobjectArray> phoneNumbers = | |
| 109 Java_PersonalAutofillPopulator_getPhoneNumbers(env, populator.obj()); | |
| 110 | |
| 111 std::vector<string16> phoneNumberVector; | |
| 112 if (!phoneNumbers.is_null()) { | |
| 113 base::android::AppendJavaStringArrayToStringVector(env, | |
| 114 phoneNumbers.obj(), | |
| 115 &phoneNumberVector); | |
| 116 profile->SetRawMultiInfo(PHONE_HOME_WHOLE_NUMBER, phoneNumberVector); | |
| 117 } | |
| 118 } | |
| 119 | |
| 120 void PersonalDataManager::LoadAuxiliaryProfiles() { | |
| 121 auxiliary_profiles_.clear(); | |
| 122 | |
| 123 std::string guid(ANDROID_ME_CONTACT_AUOTFILL_PROFILE_GUID); | |
|
Ilya Sherman
2013/02/16 04:14:37
nit: No need to make a copy here.
apiccion
2013/02/26 23:51:51
Done.
| |
| 124 scoped_ptr<AutofillProfile> profile(new AutofillProfile(guid)); | |
| 125 DCHECK(base::IsValidGUID(profile->guid())); | |
| 126 JNIEnv* env = base::android::AttachCurrentThread(); | |
| 127 ScopedJavaLocalRef<jobject> populator = | |
| 128 Java_PersonalAutofillPopulator_create(env, | |
|
David Trainor- moved to gerrit
2013/02/19 19:03:13
I'm not sure about the formatting here. You might
apiccion
2013/02/26 23:51:51
Done.
| |
| 129 base::android::GetApplicationContext()); | |
| 130 | |
| 131 LoadNameWithPopulator(env, populator, profile.get()); | |
| 132 LoadEmailAddressWithPopulator(env, populator, profile.get()); | |
| 133 LoadPhoneNumbersWithPopulator(env, populator, profile.get()); | |
| 134 // LoadAddressWithPopulator(env, populator, profile.get()); | |
|
aurimas (slooooooooow)
2013/02/15 19:08:35
Why is this like commented out?
David Trainor- moved to gerrit
2013/02/19 19:03:13
I think Address parsing isn't working. Can we jus
apiccion
2013/02/26 23:51:51
Done.
| |
| 135 /* Disable address loading until we can parse the big address | |
| 136 blob into its constituent fields */ | |
| 137 auxiliary_profiles_.push_back(profile.release()); | |
| 138 } | |
| OLD | NEW |