| OLD | NEW |
| 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/browsing_data/browsing_data_cookie_helper.h" | 5 #include "chrome/browser/browsing_data/browsing_data_cookie_helper.h" |
| 6 | 6 |
| 7 #include "utility" | 7 #include "utility" |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/logging.h" | 10 #include "base/logging.h" |
| (...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 56 BrowserThread::IO, FROM_HERE, | 56 BrowserThread::IO, FROM_HERE, |
| 57 base::Bind(&BrowsingDataCookieHelper::DeleteCookieOnIOThread, | 57 base::Bind(&BrowsingDataCookieHelper::DeleteCookieOnIOThread, |
| 58 this, cookie)); | 58 this, cookie)); |
| 59 } | 59 } |
| 60 | 60 |
| 61 void BrowsingDataCookieHelper::FetchCookiesOnIOThread() { | 61 void BrowsingDataCookieHelper::FetchCookiesOnIOThread() { |
| 62 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 62 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 63 scoped_refptr<net::CookieMonster> cookie_monster = | 63 scoped_refptr<net::CookieMonster> cookie_monster = |
| 64 request_context_getter_->GetURLRequestContext()-> | 64 request_context_getter_->GetURLRequestContext()-> |
| 65 cookie_store()->GetCookieMonster(); | 65 cookie_store()->GetCookieMonster(); |
| 66 if (cookie_monster) { | 66 if (cookie_monster.get()) { |
| 67 cookie_monster->GetAllCookiesAsync( | 67 cookie_monster->GetAllCookiesAsync( |
| 68 base::Bind(&BrowsingDataCookieHelper::OnFetchComplete, this)); | 68 base::Bind(&BrowsingDataCookieHelper::OnFetchComplete, this)); |
| 69 } else { | 69 } else { |
| 70 OnFetchComplete(net::CookieList()); | 70 OnFetchComplete(net::CookieList()); |
| 71 } | 71 } |
| 72 } | 72 } |
| 73 | 73 |
| 74 void BrowsingDataCookieHelper::OnFetchComplete(const net::CookieList& cookies) { | 74 void BrowsingDataCookieHelper::OnFetchComplete(const net::CookieList& cookies) { |
| 75 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 75 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 76 BrowserThread::PostTask( | 76 BrowserThread::PostTask( |
| 77 BrowserThread::UI, FROM_HERE, | 77 BrowserThread::UI, FROM_HERE, |
| 78 base::Bind(&BrowsingDataCookieHelper::NotifyInUIThread, this, cookies)); | 78 base::Bind(&BrowsingDataCookieHelper::NotifyInUIThread, this, cookies)); |
| 79 } | 79 } |
| 80 | 80 |
| 81 void BrowsingDataCookieHelper::NotifyInUIThread( | 81 void BrowsingDataCookieHelper::NotifyInUIThread( |
| 82 const net::CookieList& cookies) { | 82 const net::CookieList& cookies) { |
| 83 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 83 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); |
| 84 DCHECK(is_fetching_); | 84 DCHECK(is_fetching_); |
| 85 is_fetching_ = false; | 85 is_fetching_ = false; |
| 86 completion_callback_.Run(cookies); | 86 completion_callback_.Run(cookies); |
| 87 completion_callback_.Reset(); | 87 completion_callback_.Reset(); |
| 88 } | 88 } |
| 89 | 89 |
| 90 void BrowsingDataCookieHelper::DeleteCookieOnIOThread( | 90 void BrowsingDataCookieHelper::DeleteCookieOnIOThread( |
| 91 const net::CanonicalCookie& cookie) { | 91 const net::CanonicalCookie& cookie) { |
| 92 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 92 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 93 scoped_refptr<net::CookieMonster> cookie_monster = | 93 scoped_refptr<net::CookieMonster> cookie_monster = |
| 94 request_context_getter_->GetURLRequestContext()-> | 94 request_context_getter_->GetURLRequestContext()-> |
| 95 cookie_store()->GetCookieMonster(); | 95 cookie_store()->GetCookieMonster(); |
| 96 if (cookie_monster) { | 96 if (cookie_monster.get()) { |
| 97 cookie_monster->DeleteCanonicalCookieAsync( | 97 cookie_monster->DeleteCanonicalCookieAsync( |
| 98 cookie, net::CookieMonster::DeleteCookieCallback()); | 98 cookie, net::CookieMonster::DeleteCookieCallback()); |
| 99 } | 99 } |
| 100 } | 100 } |
| 101 | 101 |
| 102 CannedBrowsingDataCookieHelper::CannedBrowsingDataCookieHelper( | 102 CannedBrowsingDataCookieHelper::CannedBrowsingDataCookieHelper( |
| 103 net::URLRequestContextGetter* request_context_getter) | 103 net::URLRequestContextGetter* request_context_getter) |
| 104 : BrowsingDataCookieHelper(request_context_getter) { | 104 : BrowsingDataCookieHelper(request_context_getter) { |
| 105 } | 105 } |
| 106 | 106 |
| (...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 232 // collecting cookies per origin in redirect chains. | 232 // collecting cookies per origin in redirect chains. |
| 233 // TODO(markusheintz): A) Change the GetCookiesCount method to prevent | 233 // TODO(markusheintz): A) Change the GetCookiesCount method to prevent |
| 234 // counting cookies multiple times if they are stored in multiple cookie | 234 // counting cookies multiple times if they are stored in multiple cookie |
| 235 // lists. B) Replace the GetCookieFor method call below with: | 235 // lists. B) Replace the GetCookieFor method call below with: |
| 236 // "GetCookiesFor(frame_url.GetOrigin());" | 236 // "GetCookiesFor(frame_url.GetOrigin());" |
| 237 net::CookieList* cookie_list = | 237 net::CookieList* cookie_list = |
| 238 GetCookiesFor(GURL(kGlobalCookieListURL)); | 238 GetCookiesFor(GURL(kGlobalCookieListURL)); |
| 239 DeleteMatchingCookie(cookie, cookie_list); | 239 DeleteMatchingCookie(cookie, cookie_list); |
| 240 cookie_list->push_back(cookie); | 240 cookie_list->push_back(cookie); |
| 241 } | 241 } |
| OLD | NEW |