| 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 "net/http/disk_cache_based_ssl_host_info.h" | 5 #include "net/http/disk_cache_based_ssl_host_info.h" |
| 6 | 6 |
| 7 #include "base/callback.h" | 7 #include "base/callback.h" |
| 8 #include "base/logging.h" | 8 #include "base/logging.h" |
| 9 #include "net/base/io_buffer.h" | 9 #include "net/base/io_buffer.h" |
| 10 #include "net/base/net_errors.h" | 10 #include "net/base/net_errors.h" |
| (...skipping 30 matching lines...) Expand all Loading... |
| 41 : SSLHostInfo(hostname, ssl_config, cert_verifier), | 41 : SSLHostInfo(hostname, ssl_config, cert_verifier), |
| 42 weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), | 42 weak_ptr_factory_(ALLOW_THIS_IN_INITIALIZER_LIST(this)), |
| 43 callback_(new CallbackImpl(weak_ptr_factory_.GetWeakPtr(), | 43 callback_(new CallbackImpl(weak_ptr_factory_.GetWeakPtr(), |
| 44 &DiskCacheBasedSSLHostInfo::OnIOComplete)), | 44 &DiskCacheBasedSSLHostInfo::OnIOComplete)), |
| 45 state_(GET_BACKEND), | 45 state_(GET_BACKEND), |
| 46 ready_(false), | 46 ready_(false), |
| 47 found_entry_(false), | 47 found_entry_(false), |
| 48 hostname_(hostname), | 48 hostname_(hostname), |
| 49 http_cache_(http_cache), | 49 http_cache_(http_cache), |
| 50 backend_(NULL), | 50 backend_(NULL), |
| 51 entry_(NULL), | 51 entry_(NULL) { |
| 52 user_callback_(NULL) { | |
| 53 } | 52 } |
| 54 | 53 |
| 55 void DiskCacheBasedSSLHostInfo::Start() { | 54 void DiskCacheBasedSSLHostInfo::Start() { |
| 56 DCHECK(CalledOnValidThread()); | 55 DCHECK(CalledOnValidThread()); |
| 57 DCHECK_EQ(GET_BACKEND, state_); | 56 DCHECK_EQ(GET_BACKEND, state_); |
| 58 DoLoop(OK); | 57 DoLoop(OK); |
| 59 } | 58 } |
| 60 | 59 |
| 61 int DiskCacheBasedSSLHostInfo::WaitForDataReady(OldCompletionCallback* callback)
{ | 60 int DiskCacheBasedSSLHostInfo::WaitForDataReady( |
| 61 const CompletionCallback& callback) { |
| 62 DCHECK(CalledOnValidThread()); | 62 DCHECK(CalledOnValidThread()); |
| 63 DCHECK(state_ != GET_BACKEND); | 63 DCHECK(state_ != GET_BACKEND); |
| 64 | 64 |
| 65 if (ready_) | 65 if (ready_) |
| 66 return OK; | 66 return OK; |
| 67 if (callback) { | 67 |
| 68 DCHECK(!user_callback_); | 68 if (!callback.is_null()) { |
| 69 DCHECK(user_callback_.is_null()); |
| 69 user_callback_ = callback; | 70 user_callback_ = callback; |
| 70 } | 71 } |
| 72 |
| 71 return ERR_IO_PENDING; | 73 return ERR_IO_PENDING; |
| 72 } | 74 } |
| 73 | 75 |
| 74 void DiskCacheBasedSSLHostInfo::Persist() { | 76 void DiskCacheBasedSSLHostInfo::Persist() { |
| 75 DCHECK(CalledOnValidThread()); | 77 DCHECK(CalledOnValidThread()); |
| 76 DCHECK(state_ != GET_BACKEND); | 78 DCHECK(state_ != GET_BACKEND); |
| 77 | 79 |
| 78 DCHECK(new_data_.empty()); | 80 DCHECK(new_data_.empty()); |
| 79 CHECK(ready_); | 81 CHECK(ready_); |
| 80 DCHECK(user_callback_ == NULL); | 82 DCHECK(user_callback_.is_null()); |
| 81 new_data_ = Serialize(); | 83 new_data_ = Serialize(); |
| 82 | 84 |
| 83 if (!backend_) | 85 if (!backend_) |
| 84 return; | 86 return; |
| 85 | 87 |
| 86 state_ = CREATE_OR_OPEN; | 88 state_ = CREATE_OR_OPEN; |
| 87 DoLoop(OK); | 89 DoLoop(OK); |
| 88 } | 90 } |
| 89 | 91 |
| 90 DiskCacheBasedSSLHostInfo::~DiskCacheBasedSSLHostInfo() { | 92 DiskCacheBasedSSLHostInfo::~DiskCacheBasedSSLHostInfo() { |
| 91 DCHECK(!user_callback_); | 93 DCHECK(user_callback_.is_null()); |
| 92 if (entry_) | 94 if (entry_) |
| 93 entry_->Close(); | 95 entry_->Close(); |
| 94 if (!IsCallbackPending()) | 96 if (!IsCallbackPending()) |
| 95 delete callback_; | 97 delete callback_; |
| 96 } | 98 } |
| 97 | 99 |
| 98 std::string DiskCacheBasedSSLHostInfo::key() const { | 100 std::string DiskCacheBasedSSLHostInfo::key() const { |
| 99 return "sslhostinfo:" + hostname_; | 101 return "sslhostinfo:" + hostname_; |
| 100 } | 102 } |
| 101 | 103 |
| 102 void DiskCacheBasedSSLHostInfo::OnIOComplete(int rv) { | 104 void DiskCacheBasedSSLHostInfo::OnIOComplete(int rv) { |
| 103 rv = DoLoop(rv); | 105 rv = DoLoop(rv); |
| 104 if (rv != ERR_IO_PENDING) { | 106 if (rv != ERR_IO_PENDING && !user_callback_.is_null()) { |
| 105 OldCompletionCallback* callback = user_callback_; | 107 CompletionCallback callback = user_callback_; |
| 106 user_callback_ = NULL; | 108 user_callback_.Reset(); |
| 107 if (callback) | 109 callback.Run(rv); |
| 108 callback->Run(rv); | |
| 109 } | 110 } |
| 110 } | 111 } |
| 111 | 112 |
| 112 int DiskCacheBasedSSLHostInfo::DoLoop(int rv) { | 113 int DiskCacheBasedSSLHostInfo::DoLoop(int rv) { |
| 113 do { | 114 do { |
| 114 switch (state_) { | 115 switch (state_) { |
| 115 case GET_BACKEND: | 116 case GET_BACKEND: |
| 116 rv = DoGetBackend(); | 117 rv = DoGetBackend(); |
| 117 break; | 118 break; |
| 118 case GET_BACKEND_COMPLETE: | 119 case GET_BACKEND_COMPLETE: |
| (...skipping 152 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 271 case READ_COMPLETE: | 272 case READ_COMPLETE: |
| 272 case CREATE_OR_OPEN_COMPLETE: | 273 case CREATE_OR_OPEN_COMPLETE: |
| 273 case WRITE_COMPLETE: | 274 case WRITE_COMPLETE: |
| 274 return true; | 275 return true; |
| 275 default: | 276 default: |
| 276 return false; | 277 return false; |
| 277 } | 278 } |
| 278 } | 279 } |
| 279 | 280 |
| 280 } // namespace net | 281 } // namespace net |
| OLD | NEW |