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

Side by Side Diff: chrome/browser/password_manager/password_store_mac.cc

Issue 1414463004: Implement origin-based deletion for passwords in PasswordDefaultMac. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@lkgr
Patch Set: Created 5 years, 2 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
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2012 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/password_manager/password_store_mac.h" 5 #include "chrome/browser/password_manager/password_store_mac.h"
6 #include "chrome/browser/password_manager/password_store_mac_internal.h" 6 #include "chrome/browser/password_manager/password_store_mac_internal.h"
7 7
8 #include <CoreServices/CoreServices.h> 8 #include <CoreServices/CoreServices.h>
9 #include <set> 9 #include <set>
10 #include <string> 10 #include <string>
11 #include <utility> 11 #include <utility>
12 #include <vector> 12 #include <vector>
13 13
14 #include "base/callback.h" 14 #include "base/callback.h"
15 #include "base/logging.h" 15 #include "base/logging.h"
16 #include "base/mac/foundation_util.h" 16 #include "base/mac/foundation_util.h"
17 #include "base/mac/mac_logging.h" 17 #include "base/mac/mac_logging.h"
18 #include "base/message_loop/message_loop.h" 18 #include "base/message_loop/message_loop.h"
19 #include "base/metrics/histogram_macros.h" 19 #include "base/metrics/histogram_macros.h"
20 #include "base/stl_util.h" 20 #include "base/stl_util.h"
21 #include "base/strings/string_util.h" 21 #include "base/strings/string_util.h"
22 #include "base/strings/utf_string_conversions.h" 22 #include "base/strings/utf_string_conversions.h"
23 #include "chrome/browser/mac/security_wrappers.h" 23 #include "chrome/browser/mac/security_wrappers.h"
24 #include "components/os_crypt/os_crypt.h" 24 #include "components/os_crypt/os_crypt.h"
25 #include "components/password_manager/core/browser/affiliation_utils.h" 25 #include "components/password_manager/core/browser/affiliation_utils.h"
26 #include "components/password_manager/core/browser/login_database.h" 26 #include "components/password_manager/core/browser/login_database.h"
27 #include "components/password_manager/core/browser/password_store_change.h" 27 #include "components/password_manager/core/browser/password_store_change.h"
28 #include "content/public/browser/browser_thread.h" 28 #include "content/public/browser/browser_thread.h"
29 #include "crypto/apple_keychain.h" 29 #include "crypto/apple_keychain.h"
30 #include "url/origin.h"
30 31
31 using autofill::PasswordForm; 32 using autofill::PasswordForm;
32 using crypto::AppleKeychain; 33 using crypto::AppleKeychain;
33 using password_manager::PasswordStoreChange; 34 using password_manager::PasswordStoreChange;
34 using password_manager::PasswordStoreChangeList; 35 using password_manager::PasswordStoreChangeList;
35 36
36 namespace { 37 namespace {
37 38
38 // Utility class to handle the details of constructing and running a keychain 39 // Utility class to handle the details of constructing and running a keychain
39 // search from a set of attributes. 40 // search from a set of attributes.
(...skipping 1080 matching lines...) Expand 10 before | Expand all | Expand 10 after
1120 if (!DatabaseHasFormMatchingKeychainForm(form)) { 1121 if (!DatabaseHasFormMatchingKeychainForm(form)) {
1121 owned_keychain_adapter.RemovePassword(form); 1122 owned_keychain_adapter.RemovePassword(form);
1122 } 1123 }
1123 } 1124 }
1124 1125
1125 changes.push_back(PasswordStoreChange(PasswordStoreChange::REMOVE, form)); 1126 changes.push_back(PasswordStoreChange(PasswordStoreChange::REMOVE, form));
1126 } 1127 }
1127 return changes; 1128 return changes;
1128 } 1129 }
1129 1130
1131 PasswordStoreChangeList PasswordStoreMac::RemoveLoginsByOriginAndTimeImpl(
1132 const url::Origin& origin,
1133 base::Time delete_begin,
1134 base::Time delete_end) {
1135 PasswordStoreChangeList changes;
1136 ScopedVector<PasswordForm> forms_to_consider;
1137 ScopedVector<PasswordForm> forms_to_remove;
1138 if (login_metadata_db_ &&
1139 login_metadata_db_->GetLoginsCreatedBetween(delete_begin, delete_end,
1140 &forms_to_consider)) {
1141 MoveAllFormsOut(
1142 &forms_to_consider,
1143 [this, &origin, &forms_to_remove](
1144 scoped_ptr<autofill::PasswordForm> form_to_consider) {
1145 if (origin.IsSameOriginWith(url::Origin(form_to_consider->origin)) &&
1146 login_metadata_db_->RemoveLogin(*form_to_consider))
1147 forms_to_remove.push_back(form_to_consider.Pass());
1148 });
1149 if (!forms_to_remove.empty()) {
1150 RemoveKeychainForms(forms_to_remove.get());
1151 CleanOrphanedForms(&forms_to_remove); // Add the orphaned forms.
Timo Reimann 2015/10/20 20:47:09 Note that I did not implement tests to verify that
vasilii 2015/10/21 16:47:56 You can proceed with the option 4. I don't think w
1152 changes = FormsToRemoveChangeList(forms_to_remove.get());
1153 LogStatsForBulkDeletion(changes.size());
1154 }
1155 }
1156 return changes;
1157 }
1158
1130 PasswordStoreChangeList PasswordStoreMac::RemoveLoginsCreatedBetweenImpl( 1159 PasswordStoreChangeList PasswordStoreMac::RemoveLoginsCreatedBetweenImpl(
1131 base::Time delete_begin, 1160 base::Time delete_begin,
1132 base::Time delete_end) { 1161 base::Time delete_end) {
1133 PasswordStoreChangeList changes; 1162 PasswordStoreChangeList changes;
1134 ScopedVector<PasswordForm> forms_to_remove; 1163 ScopedVector<PasswordForm> forms_to_remove;
1135 if (login_metadata_db_ && 1164 if (login_metadata_db_ &&
1136 login_metadata_db_->GetLoginsCreatedBetween(delete_begin, delete_end, 1165 login_metadata_db_->GetLoginsCreatedBetween(delete_begin, delete_end,
1137 &forms_to_remove) && 1166 &forms_to_remove) &&
1138 login_metadata_db_->RemoveLoginsCreatedBetween(delete_begin, 1167 login_metadata_db_->RemoveLoginsCreatedBetween(delete_begin,
1139 delete_end)) { 1168 delete_end)) {
(...skipping 183 matching lines...) Expand 10 before | Expand all | Expand 10 after
1323 ScopedVector<PasswordForm> forms_with_keychain_entry; 1352 ScopedVector<PasswordForm> forms_with_keychain_entry;
1324 internal_keychain_helpers::GetPasswordsForForms(*keychain_, &database_forms, 1353 internal_keychain_helpers::GetPasswordsForForms(*keychain_, &database_forms,
1325 &forms_with_keychain_entry); 1354 &forms_with_keychain_entry);
1326 1355
1327 // Clean up any orphaned database entries. 1356 // Clean up any orphaned database entries.
1328 RemoveDatabaseForms(&database_forms); 1357 RemoveDatabaseForms(&database_forms);
1329 1358
1330 // Move the orphaned DB forms to the output parameter. 1359 // Move the orphaned DB forms to the output parameter.
1331 AppendSecondToFirst(orphaned_forms, &database_forms); 1360 AppendSecondToFirst(orphaned_forms, &database_forms);
1332 } 1361 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698