| 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 "chrome/browser/webdata/token_web_data.h" | 5 #include "chrome/browser/webdata/token_web_data.h" |
| 6 | 6 |
| 7 #include "base/bind.h" |
| 7 #include "base/stl_util.h" | 8 #include "base/stl_util.h" |
| 8 #include "chrome/browser/webdata/token_service_table.h" | 9 #include "chrome/browser/webdata/token_service_table.h" |
| 9 #include "components/webdata/common/web_database_service.h" | 10 #include "components/webdata/common/web_database_service.h" |
| 11 #include "content/public/browser/browser_thread.h" |
| 10 | 12 |
| 11 using base::Bind; | 13 using base::Bind; |
| 12 using base::Time; | 14 using base::Time; |
| 13 using content::BrowserThread; | 15 using content::BrowserThread; |
| 14 | 16 |
| 15 class TokenWebDataBackend | 17 class TokenWebDataBackend |
| 16 : public base::RefCountedThreadSafe<TokenWebDataBackend, | 18 : public base::RefCountedThreadSafe<TokenWebDataBackend, |
| 17 BrowserThread::DeleteOnDBThread> { | 19 BrowserThread::DeleteOnDBThread> { |
| 18 | 20 |
| 19 public: | 21 public: |
| (...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 52 friend class base::DeleteHelper<TokenWebDataBackend>; | 54 friend class base::DeleteHelper<TokenWebDataBackend>; |
| 53 // We have to friend RCTS<> so WIN shared-lib build is happy | 55 // We have to friend RCTS<> so WIN shared-lib build is happy |
| 54 // (http://crbug/112250). | 56 // (http://crbug/112250). |
| 55 friend class base::RefCountedThreadSafe<TokenWebDataBackend, | 57 friend class base::RefCountedThreadSafe<TokenWebDataBackend, |
| 56 BrowserThread::DeleteOnDBThread>; | 58 BrowserThread::DeleteOnDBThread>; |
| 57 | 59 |
| 58 }; | 60 }; |
| 59 | 61 |
| 60 TokenWebData::TokenWebData(scoped_refptr<WebDatabaseService> wdbs, | 62 TokenWebData::TokenWebData(scoped_refptr<WebDatabaseService> wdbs, |
| 61 const ProfileErrorCallback& callback) | 63 const ProfileErrorCallback& callback) |
| 62 : WebDataServiceBase(wdbs, callback), | 64 : WebDataServiceBase(wdbs, callback, |
| 65 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI)), |
| 63 token_backend_(new TokenWebDataBackend()) { | 66 token_backend_(new TokenWebDataBackend()) { |
| 64 } | 67 } |
| 65 | 68 |
| 66 void TokenWebData::SetTokenForService(const std::string& service, | 69 void TokenWebData::SetTokenForService(const std::string& service, |
| 67 const std::string& token) { | 70 const std::string& token) { |
| 68 wdbs_->ScheduleDBTask(FROM_HERE, | 71 wdbs_->ScheduleDBTask(FROM_HERE, |
| 69 Bind(&TokenWebDataBackend::SetTokenForService, token_backend_, | 72 Bind(&TokenWebDataBackend::SetTokenForService, token_backend_, |
| 70 service, token)); | 73 service, token)); |
| 71 } | 74 } |
| 72 | 75 |
| 73 void TokenWebData::RemoveAllTokens() { | 76 void TokenWebData::RemoveAllTokens() { |
| 74 wdbs_->ScheduleDBTask(FROM_HERE, | 77 wdbs_->ScheduleDBTask(FROM_HERE, |
| 75 Bind(&TokenWebDataBackend::RemoveAllTokens, token_backend_)); | 78 Bind(&TokenWebDataBackend::RemoveAllTokens, token_backend_)); |
| 76 } | 79 } |
| 77 | 80 |
| 78 // Null on failure. Success is WDResult<std::string> | 81 // Null on failure. Success is WDResult<std::string> |
| 79 WebDataServiceBase::Handle TokenWebData::GetAllTokens( | 82 WebDataServiceBase::Handle TokenWebData::GetAllTokens( |
| 80 WebDataServiceConsumer* consumer) { | 83 WebDataServiceConsumer* consumer) { |
| 81 return wdbs_->ScheduleDBTaskWithResult(FROM_HERE, | 84 return wdbs_->ScheduleDBTaskWithResult(FROM_HERE, |
| 82 Bind(&TokenWebDataBackend::GetAllTokens, token_backend_), consumer); | 85 Bind(&TokenWebDataBackend::GetAllTokens, token_backend_), consumer); |
| 83 } | 86 } |
| 84 | 87 |
| 85 TokenWebData::TokenWebData() | 88 TokenWebData::TokenWebData() |
| 86 : WebDataServiceBase(NULL, ProfileErrorCallback()), | 89 : WebDataServiceBase(NULL, ProfileErrorCallback(), |
| 90 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::UI)), |
| 87 token_backend_(new TokenWebDataBackend()) { | 91 token_backend_(new TokenWebDataBackend()) { |
| 88 } | 92 } |
| 89 | 93 |
| 90 TokenWebData::~TokenWebData() { | 94 TokenWebData::~TokenWebData() { |
| 91 } | 95 } |
| OLD | NEW |