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

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

Issue 118131: Change PasswordStoreDefault to access the WebDataService from the UI thread o... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: Created 11 years, 6 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 | Annotate | Revision Log
Property Changes:
Added: svn:eol-style
+ LF
OLDNEW
1 // Copyright (c) 2009 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2009 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_win.h" 5 #include "chrome/browser/password_manager/password_store_win.h"
6 6
7 #include "base/logging.h" 7 #include "base/logging.h"
8 #include "base/string_util.h" 8 #include "base/string_util.h"
9 #include "chrome/browser/password_manager/ie7_password.h" 9 #include "chrome/browser/password_manager/ie7_password.h"
10 #include "chrome/browser/password_manager/password_manager.h" 10 #include "chrome/browser/password_manager/password_manager.h"
11 #include "chrome/browser/profile.h" 11 #include "chrome/browser/profile.h"
12 12
13 using std::map; 13 using std::map;
14 using std::vector; 14 using std::vector;
15 15
16 PasswordStoreWin::PasswordStoreWin(WebDataService* web_data_service) 16 PasswordStoreWin::PasswordStoreWin(WebDataService* web_data_service)
17 : PasswordStoreDefault(web_data_service) { 17 : PasswordStoreDefault(web_data_service) {
18 } 18 }
19 19
20 void PasswordStoreWin::OnWebDataServiceRequestDone( 20 void PasswordStoreWin::OnWebDataServiceRequestDone(
21 WebDataService::Handle h, const WDTypedResult *result) { 21 WebDataService::Handle h, const WDTypedResult *result) {
22 // Look up this handle in our request map to get the original 22 // Look up this handle in our request map to get the original
23 // GetLoginsRequest. 23 // GetLoginsRequest.
24 GetLoginsRequest* request = GetLoginsRequestForWebDataServiceRequest(h); 24 PendingRequestMap::iterator it(pending_requests_.find(h));
25 DCHECK(request); 25 // If the request was cancelled, we are done.
26 // Remove our pending request, but make sure that we won't be destroyed until 26 if (it == pending_requests_.end())
27 // we're done with this function. 27 return;
28 scoped_refptr<PasswordStoreWin> life_preserver(this); 28
29 RemovePendingWebDataServiceRequest(h); 29 scoped_ptr<GetLoginsRequest> request(it->second);
30 pending_requests_.erase(it);
30 31
31 DCHECK(result); 32 DCHECK(result);
32 if (!result) 33 if (!result)
33 return; 34 return;
34 35
35 switch (result->GetType()) { 36 switch (result->GetType()) {
36 case PASSWORD_RESULT: { 37 case PASSWORD_RESULT: {
37 // This is a response from WebDataService::GetLogins. 38 // This is a response from WebDataService::GetLogins.
38 const WDResult<std::vector<PasswordForm*> >* r = 39 const WDResult<std::vector<PasswordForm*> >* r =
39 static_cast<const WDResult<std::vector<PasswordForm*> >*>(result); 40 static_cast<const WDResult<std::vector<PasswordForm*> >*>(result);
40 std::vector<PasswordForm*> result_value = r->GetValue(); 41 std::vector<PasswordForm*> result_value = r->GetValue();
41 42
42 if (result_value.size()) { 43 if (result_value.size()) {
43 // If we found some results then return them now. 44 // If we found some results then return them now.
44 NotifyConsumer(request, result_value); 45 request->consumer->OnPasswordStoreRequestDone(request->handle,
46 result_value);
45 return; 47 return;
46 } else { 48 } else {
47 // Otherwise try finding IE7 logins. 49 // Otherwise try finding IE7 logins.
48 IE7PasswordInfo info; 50 IE7PasswordInfo info;
49 std::wstring url = ASCIIToWide(request->form.origin.spec()); 51 std::wstring url = ASCIIToWide(request->form.origin.spec());
50 info.url_hash = ie7_password::GetUrlHash(url); 52 info.url_hash = ie7_password::GetUrlHash(url);
51 53
52 if (web_data_service_->IsRunning()) { 54 if (web_data_service_->IsRunning()) {
53 WebDataService::Handle web_data_handle = 55 WebDataService::Handle web_data_handle =
54 web_data_service_->GetIE7Login(info, this); 56 web_data_service_->GetIE7Login(info, this);
55 AddPendingWebDataServiceRequest(web_data_handle, request); 57 pending_requests_.insert(PendingRequestMap::value_type(
58 web_data_handle, request.release()));
56 } 59 }
57 } 60 }
58 break; 61 break;
59 } 62 }
60 63
61 case PASSWORD_IE7_RESULT: { 64 case PASSWORD_IE7_RESULT: {
62 // This is a response from WebDataService::GetIE7Login. 65 // This is a response from WebDataService::GetIE7Login.
63 PasswordForm* ie7_form = GetIE7Result(result, request->form); 66 PasswordForm* ie7_form = GetIE7Result(result, request->form);
64 67
65 std::vector<PasswordForm*> forms; 68 std::vector<PasswordForm*> forms;
66 if (ie7_form) 69 if (ie7_form)
67 forms.push_back(ie7_form); 70 forms.push_back(ie7_form);
68 71
69 NotifyConsumer(request, forms); 72 request->consumer->OnPasswordStoreRequestDone(request->handle,
73 forms);
70 break; 74 break;
71 } 75 }
72 } 76 }
73 } 77 }
74 78
75 PasswordForm* PasswordStoreWin::GetIE7Result(const WDTypedResult *result, 79 PasswordForm* PasswordStoreWin::GetIE7Result(const WDTypedResult *result,
76 const PasswordForm& form) { 80 const PasswordForm& form) {
77 const WDResult<IE7PasswordInfo>* r = 81 const WDResult<IE7PasswordInfo>* r =
78 static_cast<const WDResult<IE7PasswordInfo>*>(result); 82 static_cast<const WDResult<IE7PasswordInfo>*>(result);
79 IE7PasswordInfo info = r->GetValue(); 83 IE7PasswordInfo info = r->GetValue();
(...skipping 16 matching lines...) Expand all
96 auto_fill->password_value = password; 100 auto_fill->password_value = password;
97 auto_fill->preferred = true; 101 auto_fill->preferred = true;
98 auto_fill->ssl_valid = form.origin.SchemeIsSecure(); 102 auto_fill->ssl_valid = form.origin.SchemeIsSecure();
99 auto_fill->date_created = info.date_created; 103 auto_fill->date_created = info.date_created;
100 // Add this PasswordForm to the saved password table. 104 // Add this PasswordForm to the saved password table.
101 AddLogin(*auto_fill); 105 AddLogin(*auto_fill);
102 return auto_fill; 106 return auto_fill;
103 } 107 }
104 return NULL; 108 return NULL;
105 } 109 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698