| 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 <ostream> | 5 #include <ostream> |
| 6 | 6 |
| 7 #include "base/strings/string16.h" | 7 #include "base/strings/string16.h" |
| 8 #include "base/strings/string_util.h" | 8 #include "base/strings/string_util.h" |
| 9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
| 10 #include "components/autofill/core/common/password_form.h" | 10 #include "components/autofill/core/common/password_form.h" |
| 11 | 11 |
| 12 #if defined(OS_ANDROID) |
| 13 #include "base/android/jni_string.h" |
| 14 #include "jni/Credential_jni.h" |
| 15 #endif |
| 16 |
| 12 namespace autofill { | 17 namespace autofill { |
| 13 | 18 |
| 14 PasswordForm::PasswordForm() | 19 PasswordForm::PasswordForm() |
| 15 : scheme(SCHEME_HTML), | 20 : scheme(SCHEME_HTML), |
| 16 username_marked_by_site(false), | 21 username_marked_by_site(false), |
| 17 password_autocomplete_set(true), | 22 password_autocomplete_set(true), |
| 18 ssl_valid(false), | 23 ssl_valid(false), |
| 19 preferred(false), | 24 preferred(false), |
| 20 blacklisted_by_user(false), | 25 blacklisted_by_user(false), |
| 21 type(TYPE_MANUAL), | 26 type(TYPE_MANUAL), |
| (...skipping 35 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 57 display_name == form.display_name && | 62 display_name == form.display_name && |
| 58 avatar_url == form.avatar_url && | 63 avatar_url == form.avatar_url && |
| 59 federation_url == form.federation_url && | 64 federation_url == form.federation_url && |
| 60 skip_zero_click == form.skip_zero_click; | 65 skip_zero_click == form.skip_zero_click; |
| 61 } | 66 } |
| 62 | 67 |
| 63 bool PasswordForm::operator!=(const PasswordForm& form) const { | 68 bool PasswordForm::operator!=(const PasswordForm& form) const { |
| 64 return !operator==(form); | 69 return !operator==(form); |
| 65 } | 70 } |
| 66 | 71 |
| 72 #if defined(OS_ANDROID) |
| 73 base::android::ScopedJavaLocalRef<jobject> PasswordForm::createNativeCredential( |
| 74 JNIEnv* env, |
| 75 int type) { |
| 76 return createNativeCredential(env, 0, type); |
| 77 } |
| 78 |
| 79 base::android::ScopedJavaLocalRef<jobject> |
| 80 PasswordForm::createNativeCredential(JNIEnv* env, int position, int type) { |
| 81 return Java_Credential_createCredential( |
| 82 env, base::android::ConvertUTF16ToJavaString(env, username_value).obj(), |
| 83 base::android::ConvertUTF16ToJavaString(env, display_name).obj(), |
| 84 base::android::ConvertUTF8ToJavaString(env, avatar_url.path()).obj(), |
| 85 type, position); |
| 86 } |
| 87 #endif |
| 88 |
| 67 std::ostream& operator<<(std::ostream& os, const PasswordForm& form) { | 89 std::ostream& operator<<(std::ostream& os, const PasswordForm& form) { |
| 68 return os << "scheme: " << form.scheme | 90 return os << "scheme: " << form.scheme |
| 69 << " signon_realm: " << form.signon_realm | 91 << " signon_realm: " << form.signon_realm |
| 70 << " origin: " << form.origin | 92 << " origin: " << form.origin |
| 71 << " action: " << form.action | 93 << " action: " << form.action |
| 72 << " submit_element: " << base::UTF16ToUTF8(form.submit_element) | 94 << " submit_element: " << base::UTF16ToUTF8(form.submit_element) |
| 73 << " username_elem: " << base::UTF16ToUTF8(form.username_element) | 95 << " username_elem: " << base::UTF16ToUTF8(form.username_element) |
| 74 << " username_marked_by_site: " << form.username_marked_by_site | 96 << " username_marked_by_site: " << form.username_marked_by_site |
| 75 << " username_value: " << base::UTF16ToUTF8(form.username_value) | 97 << " username_value: " << base::UTF16ToUTF8(form.username_value) |
| 76 << " password_elem: " << base::UTF16ToUTF8(form.password_element) | 98 << " password_elem: " << base::UTF16ToUTF8(form.password_element) |
| (...skipping 13 matching lines...) Expand all Loading... |
| 90 << " type: " << form.type | 112 << " type: " << form.type |
| 91 << " times_used: " << form.times_used | 113 << " times_used: " << form.times_used |
| 92 << " form_data: " << form.form_data | 114 << " form_data: " << form.form_data |
| 93 << " generation_upload_status: " << form.generation_upload_status | 115 << " generation_upload_status: " << form.generation_upload_status |
| 94 << " display_name: " << base::UTF16ToUTF8(form.display_name) | 116 << " display_name: " << base::UTF16ToUTF8(form.display_name) |
| 95 << " avatar_url: " << form.avatar_url | 117 << " avatar_url: " << form.avatar_url |
| 96 << " federation_url: " << form.federation_url | 118 << " federation_url: " << form.federation_url |
| 97 << " skip_next_zero_click: " << form.skip_zero_click; | 119 << " skip_next_zero_click: " << form.skip_zero_click; |
| 98 } | 120 } |
| 99 | 121 |
| 122 #if defined(OS_ANDROID) |
| 123 base::android::ScopedJavaLocalRef<jobjectArray> CreateNativeCredentialArray( |
| 124 JNIEnv* env, |
| 125 size_t size) { |
| 126 return Java_Credential_createCredentialArray(env, static_cast<int>(size)); |
| 127 } |
| 128 |
| 129 bool RegisterCredential(JNIEnv* env) { |
| 130 return RegisterNativesImpl(env); |
| 131 } |
| 132 #endif |
| 133 |
| 100 } // namespace autofill | 134 } // namespace autofill |
| OLD | NEW |