Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2013 The Chromium Authors. All rights reserved. | 1 // Copyright 2013 The Chromium Authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "chrome/browser/autofill/android/personal_data_manager_android.h" | 5 #include "chrome/browser/autofill/android/personal_data_manager_android.h" |
| 6 | 6 |
| 7 #include <stddef.h> | 7 #include <stddef.h> |
| 8 #include <algorithm> | 8 #include <algorithm> |
| 9 #include <memory> | 9 #include <memory> |
| 10 #include <utility> | 10 #include <utility> |
| 11 | 11 |
| 12 #include "base/android/jni_array.h" | 12 #include "base/android/jni_array.h" |
| 13 #include "base/android/jni_string.h" | 13 #include "base/android/jni_string.h" |
| 14 #include "base/command_line.h" | 14 #include "base/command_line.h" |
| 15 #include "base/format_macros.h" | 15 #include "base/format_macros.h" |
| 16 #include "base/memory/ptr_util.h" | |
| 16 #include "base/strings/utf_string_conversions.h" | 17 #include "base/strings/utf_string_conversions.h" |
| 17 #include "base/time/time.h" | 18 #include "base/time/time.h" |
| 18 #include "chrome/browser/android/resource_mapper.h" | 19 #include "chrome/browser/android/resource_mapper.h" |
| 19 #include "chrome/browser/autofill/personal_data_manager_factory.h" | 20 #include "chrome/browser/autofill/personal_data_manager_factory.h" |
| 20 #include "chrome/browser/autofill/validation_rules_storage_factory.h" | 21 #include "chrome/browser/autofill/validation_rules_storage_factory.h" |
| 21 #include "chrome/browser/browser_process.h" | 22 #include "chrome/browser/browser_process.h" |
| 22 #include "chrome/browser/profiles/profile.h" | 23 #include "chrome/browser/profiles/profile.h" |
| 23 #include "chrome/browser/profiles/profile_manager.h" | 24 #include "chrome/browser/profiles/profile_manager.h" |
| 24 #include "chrome/common/pref_names.h" | 25 #include "chrome/common/pref_names.h" |
| 25 #include "components/autofill/content/browser/content_autofill_driver.h" | 26 #include "components/autofill/content/browser/content_autofill_driver.h" |
| (...skipping 272 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 298 } | 299 } |
| 299 | 300 |
| 300 private: | 301 private: |
| 301 ~AndroidAddressNormalizerDelegate() override {} | 302 ~AndroidAddressNormalizerDelegate() override {} |
| 302 | 303 |
| 303 ScopedJavaGlobalRef<jobject> jdelegate_; | 304 ScopedJavaGlobalRef<jobject> jdelegate_; |
| 304 | 305 |
| 305 DISALLOW_COPY_AND_ASSIGN(AndroidAddressNormalizerDelegate); | 306 DISALLOW_COPY_AND_ASSIGN(AndroidAddressNormalizerDelegate); |
| 306 }; | 307 }; |
| 307 | 308 |
| 309 class AndroidSubKeyRequesterDelegate | |
| 310 : public PersonalDataManagerAndroid::SubKeyRequestDelegate, | |
| 311 public base::SupportsWeakPtr<AndroidSubKeyRequesterDelegate> { | |
| 312 public: | |
| 313 AndroidSubKeyRequesterDelegate( | |
| 314 JNIEnv* env, | |
| 315 const base::android::JavaParamRef<jobject>& jdelegate, | |
| 316 const std::string& region_code, | |
| 317 base::WeakPtr<PersonalDataManagerAndroid> personal_data_manager_android) { | |
| 318 jdelegate_.Reset(env, jdelegate); | |
| 319 region_code_ = region_code; | |
| 320 personal_data_manager_android_ = personal_data_manager_android; | |
| 321 } | |
| 322 | |
| 323 ~AndroidSubKeyRequesterDelegate() override {} | |
| 324 | |
| 325 private: | |
| 326 // PersonalDataManagerAndroid::SubKeyRequestDelegate: | |
| 327 void OnRulesSuccessfullyLoaded() override { | |
| 328 if (personal_data_manager_android_) { | |
| 329 JNIEnv* env = base::android::AttachCurrentThread(); | |
| 330 Java_GetSubKeysRequestDelegate_onSubKeysReceived( | |
| 331 env, jdelegate_, | |
| 332 personal_data_manager_android_->GetSubKeys(env, region_code_)); | |
| 333 } | |
| 334 } | |
| 335 | |
| 336 ScopedJavaGlobalRef<jobject> jdelegate_; | |
| 337 std::string region_code_; | |
| 338 base::WeakPtr<PersonalDataManagerAndroid> personal_data_manager_android_; | |
| 339 | |
| 340 DISALLOW_COPY_AND_ASSIGN(AndroidSubKeyRequesterDelegate); | |
| 341 }; | |
| 342 | |
| 308 } // namespace | 343 } // namespace |
| 309 | 344 |
| 310 PersonalDataManagerAndroid::PersonalDataManagerAndroid(JNIEnv* env, jobject obj) | 345 PersonalDataManagerAndroid::PersonalDataManagerAndroid(JNIEnv* env, jobject obj) |
| 311 : weak_java_obj_(env, obj), | 346 : weak_java_obj_(env, obj), |
| 312 personal_data_manager_(PersonalDataManagerFactory::GetForProfile( | 347 personal_data_manager_(PersonalDataManagerFactory::GetForProfile( |
| 313 ProfileManager::GetActiveUserProfile())), | 348 ProfileManager::GetActiveUserProfile())), |
| 314 address_normalizer_( | 349 address_normalizer_( |
| 315 std::unique_ptr<::i18n::addressinput::Source>( | 350 std::unique_ptr<::i18n::addressinput::Source>( |
| 316 new autofill::ChromeMetadataSource( | 351 new autofill::ChromeMetadataSource( |
| 317 I18N_ADDRESS_VALIDATION_DATA_URL, | 352 I18N_ADDRESS_VALIDATION_DATA_URL, |
| 318 personal_data_manager_->GetURLRequestContextGetter())), | 353 personal_data_manager_->GetURLRequestContextGetter())), |
| 319 ValidationRulesStorageFactory::CreateStorage()) { | 354 ValidationRulesStorageFactory::CreateStorage()), |
| 355 address_validator_( | |
| 356 base::MakeUnique<autofill::ChromeMetadataSource>( | |
| 357 I18N_ADDRESS_VALIDATION_DATA_URL, | |
| 358 personal_data_manager_->GetURLRequestContextGetter()), | |
| 359 ValidationRulesStorageFactory::CreateStorage(), | |
| 360 this) { | |
| 320 personal_data_manager_->AddObserver(this); | 361 personal_data_manager_->AddObserver(this); |
| 321 } | 362 } |
| 322 | 363 |
| 323 PersonalDataManagerAndroid::~PersonalDataManagerAndroid() { | 364 PersonalDataManagerAndroid::~PersonalDataManagerAndroid() { |
| 324 personal_data_manager_->RemoveObserver(this); | 365 personal_data_manager_->RemoveObserver(this); |
| 325 } | 366 } |
| 326 | 367 |
| 327 jboolean PersonalDataManagerAndroid::IsDataLoaded( | 368 jboolean PersonalDataManagerAndroid::IsDataLoaded( |
| 328 JNIEnv* env, | 369 JNIEnv* env, |
| 329 const base::android::JavaParamRef<jobject>& unused_obj) const { | 370 const base::android::JavaParamRef<jobject>& unused_obj) const { |
| (...skipping 360 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 690 return card->use_date().ToTimeT(); | 731 return card->use_date().ToTimeT(); |
| 691 } | 732 } |
| 692 | 733 |
| 693 // TODO(crbug.com/629507): Use a mock clock for testing. | 734 // TODO(crbug.com/629507): Use a mock clock for testing. |
| 694 jlong PersonalDataManagerAndroid::GetCurrentDateForTesting( | 735 jlong PersonalDataManagerAndroid::GetCurrentDateForTesting( |
| 695 JNIEnv* env, | 736 JNIEnv* env, |
| 696 const base::android::JavaParamRef<jobject>& unused_obj) { | 737 const base::android::JavaParamRef<jobject>& unused_obj) { |
| 697 return base::Time::Now().ToTimeT(); | 738 return base::Time::Now().ToTimeT(); |
| 698 } | 739 } |
| 699 | 740 |
| 700 void PersonalDataManagerAndroid::LoadRulesForRegion( | 741 void PersonalDataManagerAndroid::LoadRulesForAddressNormalization( |
| 701 JNIEnv* env, | 742 JNIEnv* env, |
| 702 const base::android::JavaParamRef<jobject>& unused_obj, | 743 const base::android::JavaParamRef<jobject>& unused_obj, |
| 703 const base::android::JavaParamRef<jstring>& jregion_code) { | 744 const base::android::JavaParamRef<jstring>& jregion_code) { |
| 704 address_normalizer_.LoadRulesForRegion( | 745 address_normalizer_.LoadRulesForRegion( |
| 705 ConvertJavaStringToUTF8(env, jregion_code)); | 746 ConvertJavaStringToUTF8(env, jregion_code)); |
| 706 } | 747 } |
| 707 | 748 |
| 749 void PersonalDataManagerAndroid::LoadRulesForSubKeys( | |
| 750 JNIEnv* env, | |
| 751 const base::android::JavaParamRef<jobject>& unused_obj, | |
| 752 const base::android::JavaParamRef<jstring>& jregion_code) { | |
| 753 address_validator_.LoadRules(ConvertJavaStringToUTF8(env, jregion_code)); | |
| 754 } | |
| 755 | |
| 708 void PersonalDataManagerAndroid::StartAddressNormalization( | 756 void PersonalDataManagerAndroid::StartAddressNormalization( |
| 709 JNIEnv* env, | 757 JNIEnv* env, |
| 710 const JavaParamRef<jobject>& unused_obj, | 758 const JavaParamRef<jobject>& unused_obj, |
| 711 const JavaParamRef<jobject>& jprofile, | 759 const JavaParamRef<jobject>& jprofile, |
| 712 const JavaParamRef<jstring>& jregion_code, | 760 const JavaParamRef<jstring>& jregion_code, |
| 713 jint jtimeout_seconds, | 761 jint jtimeout_seconds, |
| 714 const JavaParamRef<jobject>& jdelegate) { | 762 const JavaParamRef<jobject>& jdelegate) { |
| 715 const std::string region_code = ConvertJavaStringToUTF8(env, jregion_code); | 763 const std::string region_code = ConvertJavaStringToUTF8(env, jregion_code); |
| 716 | 764 |
| 717 AutofillProfile profile; | 765 AutofillProfile profile; |
| (...skipping 13 matching lines...) Expand all Loading... | |
| 731 const base::android::JavaParamRef<jobject>& unused_obj) { | 779 const base::android::JavaParamRef<jobject>& unused_obj) { |
| 732 return !personal_data_manager_->GetProfiles().empty(); | 780 return !personal_data_manager_->GetProfiles().empty(); |
| 733 } | 781 } |
| 734 | 782 |
| 735 jboolean PersonalDataManagerAndroid::HasCreditCards( | 783 jboolean PersonalDataManagerAndroid::HasCreditCards( |
| 736 JNIEnv* env, | 784 JNIEnv* env, |
| 737 const base::android::JavaParamRef<jobject>& unused_obj) { | 785 const base::android::JavaParamRef<jobject>& unused_obj) { |
| 738 return !personal_data_manager_->GetCreditCards().empty(); | 786 return !personal_data_manager_->GetCreditCards().empty(); |
| 739 } | 787 } |
| 740 | 788 |
| 789 base::android::ScopedJavaLocalRef<jobjectArray> | |
| 790 PersonalDataManagerAndroid::GetSubKeys(JNIEnv* env, | |
| 791 const std::string& region_code) { | |
| 792 std::vector<std::string> sub_keys = | |
| 793 address_validator_.GetRegionSubKeys(region_code); | |
| 794 return base::android::ToJavaArrayOfStrings(env, sub_keys); | |
| 795 } | |
| 796 | |
| 797 void PersonalDataManagerAndroid::OnAddressRulesLoaded( | |
| 798 const std::string& region_code, | |
| 799 bool success) { | |
| 800 // if |success| == false, an empty list of sub-keys will be returned. | |
|
please use gerrit instead
2017/04/03 18:47:39
Clarify the comment by naming the method that retu
Parastoo
2017/04/03 18:55:05
Done.
| |
| 801 // => No need to check for |success|. | |
| 802 // Check if there is any sub-key request for that region code. | |
| 803 if (!pending_subkey_region_code_.compare(region_code)) | |
| 804 pending_subkey_request_->OnRulesSuccessfullyLoaded(); | |
| 805 pending_subkey_region_code_.clear(); | |
| 806 pending_subkey_request_.reset(); | |
| 807 } | |
| 808 | |
| 809 void PersonalDataManagerAndroid::StartRegionSubKeysRequest( | |
| 810 JNIEnv* env, | |
| 811 const JavaParamRef<jobject>& unused_obj, | |
| 812 const JavaParamRef<jstring>& jregion_code, | |
| 813 const JavaParamRef<jobject>& jdelegate) { | |
| 814 const std::string region_code = ConvertJavaStringToUTF8(env, jregion_code); | |
| 815 std::unique_ptr<SubKeyRequestDelegate> requester = | |
| 816 base::MakeUnique<AndroidSubKeyRequesterDelegate>( | |
| 817 env, jdelegate, region_code, AsWeakPtr()); | |
| 818 | |
| 819 if (AreRulesLoadedForRegion(region_code)) { | |
| 820 requester->OnRulesSuccessfullyLoaded(); | |
| 821 } else { | |
| 822 // Setup the variables so that the sub-keys request is sent, when the rules | |
| 823 // are loaded. | |
| 824 pending_subkey_region_code_ = region_code; | |
| 825 pending_subkey_request_ = std::move(requester); | |
| 826 } | |
| 827 } | |
| 828 | |
| 829 void PersonalDataManagerAndroid::CancelPendingGetSubKeys( | |
| 830 JNIEnv* env, | |
| 831 const base::android::JavaParamRef<jobject>& unused_obj) { | |
| 832 pending_subkey_region_code_.clear(); | |
| 833 pending_subkey_request_.reset(); | |
| 834 } | |
| 835 | |
| 741 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetProfileGUIDs( | 836 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetProfileGUIDs( |
| 742 JNIEnv* env, | 837 JNIEnv* env, |
| 743 const std::vector<AutofillProfile*>& profiles) { | 838 const std::vector<AutofillProfile*>& profiles) { |
| 744 std::vector<base::string16> guids; | 839 std::vector<base::string16> guids; |
| 745 for (AutofillProfile* profile : profiles) | 840 for (AutofillProfile* profile : profiles) |
| 746 guids.push_back(base::UTF8ToUTF16(profile->guid())); | 841 guids.push_back(base::UTF8ToUTF16(profile->guid())); |
| 747 | 842 |
| 748 return base::android::ToJavaArrayOfStrings(env, guids); | 843 return base::android::ToJavaArrayOfStrings(env, guids); |
| 749 } | 844 } |
| 750 | 845 |
| 751 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetCreditCardGUIDs( | 846 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetCreditCardGUIDs( |
| 752 JNIEnv* env, | 847 JNIEnv* env, |
| 753 const std::vector<CreditCard*>& credit_cards) { | 848 const std::vector<CreditCard*>& credit_cards) { |
| 754 std::vector<base::string16> guids; | 849 std::vector<base::string16> guids; |
| 755 for (CreditCard* credit_card : credit_cards) | 850 for (CreditCard* credit_card : credit_cards) |
| 756 guids.push_back(base::UTF8ToUTF16(credit_card->guid())); | 851 guids.push_back(base::UTF8ToUTF16(credit_card->guid())); |
| 757 | 852 |
| 758 return base::android::ToJavaArrayOfStrings(env, guids); | 853 return base::android::ToJavaArrayOfStrings(env, guids); |
| 759 } | 854 } |
| 760 | 855 |
| 761 bool PersonalDataManagerAndroid::AreRulesLoadedForRegion( | 856 bool PersonalDataManagerAndroid::AreRulesLoadedForRegion( |
| 762 const std::string& region_code) { | 857 const std::string& region_code) { |
| 763 return address_normalizer_.AreRulesLoadedForRegion(region_code); | 858 return address_validator_.AreRulesLoadedForRegion(region_code); |
| 764 } | 859 } |
| 765 | 860 |
| 766 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetProfileLabels( | 861 ScopedJavaLocalRef<jobjectArray> PersonalDataManagerAndroid::GetProfileLabels( |
| 767 JNIEnv* env, | 862 JNIEnv* env, |
| 768 bool address_only, | 863 bool address_only, |
| 769 bool include_name_in_label, | 864 bool include_name_in_label, |
| 770 bool include_organization_in_label, | 865 bool include_organization_in_label, |
| 771 bool include_country_in_label, | 866 bool include_country_in_label, |
| 772 std::vector<AutofillProfile*> profiles) { | 867 std::vector<AutofillProfile*> profiles) { |
| 773 std::unique_ptr<std::vector<ServerFieldType>> suggested_fields; | 868 std::unique_ptr<std::vector<ServerFieldType>> suggested_fields; |
| (...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 873 base::android::ConvertJavaStringToUTF16(env, jcountry_name))); | 968 base::android::ConvertJavaStringToUTF16(env, jcountry_name))); |
| 874 } | 969 } |
| 875 | 970 |
| 876 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { | 971 static jlong Init(JNIEnv* env, const JavaParamRef<jobject>& obj) { |
| 877 PersonalDataManagerAndroid* personal_data_manager_android = | 972 PersonalDataManagerAndroid* personal_data_manager_android = |
| 878 new PersonalDataManagerAndroid(env, obj); | 973 new PersonalDataManagerAndroid(env, obj); |
| 879 return reinterpret_cast<intptr_t>(personal_data_manager_android); | 974 return reinterpret_cast<intptr_t>(personal_data_manager_android); |
| 880 } | 975 } |
| 881 | 976 |
| 882 } // namespace autofill | 977 } // namespace autofill |
| OLD | NEW |