| 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 #ifndef CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ | 5 #ifndef CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ |
| 6 #define CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ | 6 #define CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ |
| 7 | 7 |
| 8 #include "base/android/jni_weak_ref.h" | 8 #include "base/android/jni_weak_ref.h" |
| 9 #include "base/android/scoped_java_ref.h" | 9 #include "base/android/scoped_java_ref.h" |
| 10 #include "base/macros.h" | 10 #include "base/macros.h" |
| 11 #include "components/autofill/core/browser/personal_data_manager.h" | 11 #include "components/autofill/core/browser/personal_data_manager.h" |
| 12 #include "components/autofill/core/browser/personal_data_manager_observer.h" | 12 #include "components/autofill/core/browser/personal_data_manager_observer.h" |
| 13 | 13 |
| 14 namespace autofill { | 14 namespace autofill { |
| 15 | 15 |
| 16 // Android wrapper of the PersonalDataManager which provides access from the | 16 // Android wrapper of the PersonalDataManager which provides access from the |
| 17 // Java layer. Note that on Android, there's only a single profile, and | 17 // Java layer. Note that on Android, there's only a single profile, and |
| 18 // therefore a single instance of this wrapper. | 18 // therefore a single instance of this wrapper. |
| 19 class PersonalDataManagerAndroid : public PersonalDataManagerObserver { | 19 class PersonalDataManagerAndroid : public PersonalDataManagerObserver { |
| 20 public: | 20 public: |
| 21 PersonalDataManagerAndroid(JNIEnv* env, jobject obj); | 21 PersonalDataManagerAndroid(JNIEnv* env, jobject obj); |
| 22 | 22 |
| 23 // These functions act on "web profiles" aka "LOCAL_PROFILE" profiles. | 23 // These functions act on "web profiles" aka "LOCAL_PROFILE" profiles. |
| 24 // ------------------------- | 24 // ------------------------- |
| 25 | 25 |
| 26 // Returns the GUIDs of all profiles. | 26 // Returns the number of web and auxiliary profiles. |
| 27 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileGUIDsForSettings( | 27 jint GetProfileCount(JNIEnv* unused_env, |
| 28 const base::android::JavaParamRef<jobject>& unused_obj); |
| 29 |
| 30 // Returns the profile as indexed by |index| in the PersonalDataManager's |
| 31 // |GetProfiles()| collection. |
| 32 base::android::ScopedJavaLocalRef<jobject> GetProfileByIndex( |
| 28 JNIEnv* env, | 33 JNIEnv* env, |
| 29 const base::android::JavaParamRef<jobject>& unused_obj); | 34 const base::android::JavaParamRef<jobject>& unused_obj, |
| 30 | 35 jint index); |
| 31 // Returns the GUIDs of the profiles to suggest to the user. See | |
| 32 // PersonalDataManager::GetProfilesToSuggest for more details. | |
| 33 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileGUIDsToSuggest( | |
| 34 JNIEnv* env, | |
| 35 const base::android::JavaParamRef<jobject>& unused_obj); | |
| 36 | 36 |
| 37 // Returns the profile with the specified |jguid|, or NULL if there is no | 37 // Returns the profile with the specified |jguid|, or NULL if there is no |
| 38 // profile with the specified |jguid|. Both web and auxiliary profiles may | 38 // profile with the specified |jguid|. Both web and auxiliary profiles may |
| 39 // be returned. | 39 // be returned. |
| 40 base::android::ScopedJavaLocalRef<jobject> GetProfileByGUID( | 40 base::android::ScopedJavaLocalRef<jobject> GetProfileByGUID( |
| 41 JNIEnv* env, | 41 JNIEnv* env, |
| 42 const base::android::JavaParamRef<jobject>& unused_obj, | 42 const base::android::JavaParamRef<jobject>& unused_obj, |
| 43 const base::android::JavaParamRef<jstring>& jguid); | 43 const base::android::JavaParamRef<jstring>& jguid); |
| 44 | 44 |
| 45 // Adds or modifies a profile. If |jguid| is an empty string, we are creating | 45 // Adds or modifies a profile. If |jguid| is an empty string, we are creating |
| 46 // a new profile. Else we are updating an existing profile. Always returns | 46 // a new profile. Else we are updating an existing profile. Always returns |
| 47 // the GUID for this profile; the GUID it may have just been created. | 47 // the GUID for this profile; the GUID it may have just been created. |
| 48 base::android::ScopedJavaLocalRef<jstring> SetProfile( | 48 base::android::ScopedJavaLocalRef<jstring> SetProfile( |
| 49 JNIEnv* env, | 49 JNIEnv* env, |
| 50 const base::android::JavaParamRef<jobject>& unused_obj, | 50 const base::android::JavaParamRef<jobject>& unused_obj, |
| 51 const base::android::JavaParamRef<jobject>& jprofile); | 51 const base::android::JavaParamRef<jobject>& jprofile); |
| 52 | 52 |
| 53 // Gets the labels for all known profiles. These labels are useful for | 53 // Gets the labels for all known profiles. These labels are useful for |
| 54 // distinguishing the profiles from one another. | 54 // distinguishing the profiles from one another. |
| 55 // | 55 // |
| 56 // The labels never contain the full name and include at least 2 fields. | 56 // The labels never contain the full name and include at least 2 fields. |
| 57 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileLabelsForSettings( | 57 // |
| 58 // If |address_only| is true, then such fields as phone number and email |
| 59 // address are also omitted, but all fields are included in the label. |
| 60 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileLabels( |
| 58 JNIEnv* env, | 61 JNIEnv* env, |
| 59 const base::android::JavaParamRef<jobject>& unused_obj); | 62 const base::android::JavaParamRef<jobject>& unused_obj, |
| 60 | 63 bool address_only); |
| 61 // Gets the labels for the profiles to suggest to the user. These labels are | |
| 62 // useful for distinguishing the profiles from one another. | |
| 63 // | |
| 64 // The labels never contain the full name. Fields such as phone number and | |
| 65 // email address are also omitted, but all other fields are included in the | |
| 66 // label. | |
| 67 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileLabelsToSuggest( | |
| 68 JNIEnv* env, | |
| 69 const base::android::JavaParamRef<jobject>& unused_obj); | |
| 70 | 64 |
| 71 // These functions act on local credit cards. | 65 // These functions act on local credit cards. |
| 72 // -------------------- | 66 // -------------------- |
| 73 | 67 |
| 74 // Returns the GUIDs of all the credit cards. | 68 // Returns the number of credit cards. |
| 75 base::android::ScopedJavaLocalRef<jobjectArray> GetCreditCardGUIDsForSettings( | 69 jint GetCreditCardCount( |
| 76 JNIEnv* env, | 70 JNIEnv* unused_env, |
| 77 const base::android::JavaParamRef<jobject>& unused_obj); | 71 const base::android::JavaParamRef<jobject>& unused_obj); |
| 78 | 72 |
| 79 // Returns the GUIDs of the credit cards to suggest to the user. See | 73 // Returns the credit card as indexed by |index| in the PersonalDataManager's |
| 80 // PersonalDataManager::GetCreditCardsToSuggest for more details. | 74 // |GetCreditCards()| collection. |
| 81 base::android::ScopedJavaLocalRef<jobjectArray> GetCreditCardGUIDsToSuggest( | 75 base::android::ScopedJavaLocalRef<jobject> GetCreditCardByIndex( |
| 82 JNIEnv* env, | 76 JNIEnv* env, |
| 83 const base::android::JavaParamRef<jobject>& unused_obj); | 77 const base::android::JavaParamRef<jobject>& unused_obj, |
| 78 jint index); |
| 84 | 79 |
| 85 // Returns the credit card with the specified |jguid|, or NULL if there is | 80 // Returns the credit card with the specified |jguid|, or NULL if there is |
| 86 // no credit card with the specified |jguid|. | 81 // no credit card with the specified |jguid|. |
| 87 base::android::ScopedJavaLocalRef<jobject> GetCreditCardByGUID( | 82 base::android::ScopedJavaLocalRef<jobject> GetCreditCardByGUID( |
| 88 JNIEnv* env, | 83 JNIEnv* env, |
| 89 const base::android::JavaParamRef<jobject>& unused_obj, | 84 const base::android::JavaParamRef<jobject>& unused_obj, |
| 90 const base::android::JavaParamRef<jstring>& jguid); | 85 const base::android::JavaParamRef<jstring>& jguid); |
| 91 | 86 |
| 92 // Adds or modifies a local credit card. If |jguid| is an empty string, we | 87 // Adds or modifies a local credit card. If |jguid| is an empty string, we |
| 93 // are creating a new card. Else we are updating an existing profile. Always | 88 // are creating a new card. Else we are updating an existing profile. Always |
| (...skipping 27 matching lines...) Expand all Loading... |
| 121 const base::android::JavaParamRef<jobject>& jweb_contents, | 116 const base::android::JavaParamRef<jobject>& jweb_contents, |
| 122 const base::android::JavaParamRef<jstring>& jguid, | 117 const base::android::JavaParamRef<jstring>& jguid, |
| 123 const base::android::JavaParamRef<jobject>& jdelegate); | 118 const base::android::JavaParamRef<jobject>& jdelegate); |
| 124 | 119 |
| 125 // PersonalDataManagerObserver: | 120 // PersonalDataManagerObserver: |
| 126 void OnPersonalDataChanged() override; | 121 void OnPersonalDataChanged() override; |
| 127 | 122 |
| 128 // Registers the JNI bindings for this class. | 123 // Registers the JNI bindings for this class. |
| 129 static bool Register(JNIEnv* env); | 124 static bool Register(JNIEnv* env); |
| 130 | 125 |
| 131 // Sets the use count and use date of the profile associated to the |jguid|. | |
| 132 // Both |count| and |date| should be non-negative. |date| represents an | |
| 133 // absolute point in coordinated universal time (UTC) represented as | |
| 134 // microseconds since the Windows epoch. For more details see the comment | |
| 135 // header in time.h. | |
| 136 void SetProfileUseStatsForTesting( | |
| 137 JNIEnv* env, | |
| 138 const base::android::JavaParamRef<jobject>& unused_obj, | |
| 139 const base::android::JavaParamRef<jstring>& jguid, | |
| 140 jint count, | |
| 141 jint date); | |
| 142 | |
| 143 // Sets the use count and use date of the credit card associated to the | |
| 144 // |jguid|. Both |count| and |date| should be non-negative. |date| represents | |
| 145 // an absolute point in coordinated universal time (UTC) represented as | |
| 146 // microseconds since the Windows epoch. For more details see the comment | |
| 147 // header in time.h. | |
| 148 void SetCreditCardUseStatsForTesting( | |
| 149 JNIEnv* env, | |
| 150 const base::android::JavaParamRef<jobject>& unused_obj, | |
| 151 const base::android::JavaParamRef<jstring>& jguid, | |
| 152 jint count, | |
| 153 jint date); | |
| 154 | |
| 155 private: | 126 private: |
| 156 ~PersonalDataManagerAndroid() override; | 127 ~PersonalDataManagerAndroid() override; |
| 157 | 128 |
| 158 // Returns the GUIDs of the |profiles| passed as parameter. | |
| 159 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileGUIDs( | |
| 160 JNIEnv* env, | |
| 161 const std::vector<AutofillProfile*>& profiles); | |
| 162 | |
| 163 // Returns the GUIDs of the |credit_cards| passed as parameter. | |
| 164 base::android::ScopedJavaLocalRef<jobjectArray> GetCreditCardGUIDs( | |
| 165 JNIEnv* env, | |
| 166 const std::vector<CreditCard*>& credit_cards); | |
| 167 | |
| 168 // Gets the labels for the |profiles| passed as parameters. These labels are | |
| 169 // useful for distinguishing the profiles from one another. | |
| 170 // | |
| 171 // The labels never contain the full name and include at least 2 fields. | |
| 172 // | |
| 173 // If |address_only| is true, then such fields as phone number and email | |
| 174 // address are also omitted, but all fields are included in the label. | |
| 175 base::android::ScopedJavaLocalRef<jobjectArray> GetProfileLabels( | |
| 176 JNIEnv* env, | |
| 177 bool address_only, | |
| 178 std::vector<AutofillProfile*> profiles); | |
| 179 | |
| 180 // Pointer to the java counterpart. | 129 // Pointer to the java counterpart. |
| 181 JavaObjectWeakGlobalRef weak_java_obj_; | 130 JavaObjectWeakGlobalRef weak_java_obj_; |
| 182 | 131 |
| 183 // Pointer to the PersonalDataManager for the main profile. | 132 // Pointer to the PersonalDataManager for the main profile. |
| 184 PersonalDataManager* personal_data_manager_; | 133 PersonalDataManager* personal_data_manager_; |
| 185 | 134 |
| 186 DISALLOW_COPY_AND_ASSIGN(PersonalDataManagerAndroid); | 135 DISALLOW_COPY_AND_ASSIGN(PersonalDataManagerAndroid); |
| 187 }; | 136 }; |
| 188 | 137 |
| 189 } // namespace autofill | 138 } // namespace autofill |
| 190 | 139 |
| 191 #endif // CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ | 140 #endif // CHROME_BROWSER_AUTOFILL_ANDROID_PERSONAL_DATA_MANAGER_ANDROID_H_ |
| OLD | NEW |