Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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/transport_security_persister.h" | 5 #include "chrome/browser/transport_security_persister.h" |
| 6 | 6 |
| 7 #include "base/file_path.h" | 7 #include "base/file_path.h" |
| 8 #include "base/file_util.h" | 8 #include "base/file_util.h" |
| 9 #include "base/message_loop.h" | 9 #include "base/message_loop.h" |
| 10 #include "base/path_service.h" | 10 #include "base/path_service.h" |
| 11 #include "chrome/common/chrome_paths.h" | 11 #include "chrome/common/chrome_paths.h" |
| 12 #include "content/browser/browser_thread.h" | 12 #include "content/browser/browser_thread.h" |
| 13 #include "net/base/transport_security_state.h" | 13 #include "net/base/transport_security_state.h" |
| 14 | 14 |
| 15 TransportSecurityPersister::TransportSecurityPersister( | 15 TransportSecurityPersister::TransportSecurityPersister( |
| 16 net::TransportSecurityState* state, | 16 net::TransportSecurityState* state, |
| 17 const FilePath& profile_path, | 17 const FilePath& profile_path, |
| 18 bool readonly) | 18 bool readonly) |
| 19 : transport_security_state_(state), | 19 : transport_security_state_(state), |
| 20 writer_(profile_path.AppendASCII("TransportSecurity"), | 20 writer_(profile_path.AppendASCII("TransportSecurity"), |
| 21 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::FILE)), | 21 BrowserThread::GetMessageLoopProxyForThread(BrowserThread::FILE)), |
| 22 readonly_(readonly) { | 22 readonly_(readonly) { |
| 23 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 23 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 24 | 24 |
| 25 transport_security_state_->SetDelegate(this); | 25 transport_security_state_->SetDelegate(this); |
| 26 } | 26 } |
| 27 | 27 |
| 28 TransportSecurityPersister::~TransportSecurityPersister() { | 28 TransportSecurityPersister::~TransportSecurityPersister() { |
| 29 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | |
| 30 | |
| 29 if (writer_.HasPendingWrite()) | 31 if (writer_.HasPendingWrite()) |
| 30 writer_.DoScheduledWrite(); | 32 writer_.DoScheduledWrite(); |
| 31 | 33 |
| 32 transport_security_state_->SetDelegate(NULL); | 34 transport_security_state_->SetDelegate(NULL); |
| 33 } | 35 } |
| 34 | 36 |
| 35 void TransportSecurityPersister::Init() { | 37 void TransportSecurityPersister::Init() { |
| 36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::UI)); | 38 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 37 BrowserThread::PostTask( | 39 BrowserThread::PostTask( |
|
willchan no longer on Chromium
2011/09/20 01:29:51
Can you use BrowserThread::PostTaskAndReply() and
| |
| 38 BrowserThread::FILE, FROM_HERE, | 40 BrowserThread::FILE, FROM_HERE, |
| 39 NewRunnableMethod(this, &TransportSecurityPersister::Load)); | 41 NewRunnableMethod(this, &TransportSecurityPersister::Load)); |
| 40 } | 42 } |
| 41 | 43 |
| 42 void TransportSecurityPersister::Load() { | 44 void TransportSecurityPersister::Load() { |
| 43 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); | 45 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::FILE)); |
| 44 | 46 |
| 45 std::string state; | 47 std::string state; |
| 46 if (!file_util::ReadFileToString(writer_.path(), &state)) | 48 if (!file_util::ReadFileToString(writer_.path(), &state)) |
| 47 return; | 49 return; |
| (...skipping 20 matching lines...) Expand all Loading... | |
| 68 void TransportSecurityPersister::StateIsDirty( | 70 void TransportSecurityPersister::StateIsDirty( |
| 69 net::TransportSecurityState* state) { | 71 net::TransportSecurityState* state) { |
| 70 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | 72 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); |
| 71 DCHECK_EQ(transport_security_state_, state); | 73 DCHECK_EQ(transport_security_state_, state); |
| 72 | 74 |
| 73 if (!readonly_) | 75 if (!readonly_) |
| 74 writer_.ScheduleWrite(this); | 76 writer_.ScheduleWrite(this); |
| 75 } | 77 } |
| 76 | 78 |
| 77 bool TransportSecurityPersister::SerializeData(std::string* data) { | 79 bool TransportSecurityPersister::SerializeData(std::string* data) { |
| 80 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); | |
| 78 return transport_security_state_->Serialise(data); | 81 return transport_security_state_->Serialise(data); |
| 79 } | 82 } |
| OLD | NEW |