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

Unified Diff: net/quic/chromium/quic_chromium_client_session.cc

Issue 2948143002: Add an async method to QuicChromiumClientSession::Handle for (Closed)
Patch Set: cleanup Created 3 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 side-by-side diff with in-line comments
Download patch
Index: net/quic/chromium/quic_chromium_client_session.cc
diff --git a/net/quic/chromium/quic_chromium_client_session.cc b/net/quic/chromium/quic_chromium_client_session.cc
index 51a5068392d7237f4a0e77dbf07d34fe245eb678..fb7ad76229576fa95ba5396dc86697dc06945117 100644
--- a/net/quic/chromium/quic_chromium_client_session.cc
+++ b/net/quic/chromium/quic_chromium_client_session.cc
@@ -199,12 +199,19 @@ QuicChromiumClientSession::Handle::Handle(
error_(OK),
port_migration_detected_(false),
server_id_(session_->server_id()),
- quic_version_(session->connection()->version()) {
+ quic_version_(session->connection()->version()),
+ push_handle_(nullptr) {
DCHECK(session_);
session_->AddHandle(this);
}
QuicChromiumClientSession::Handle::~Handle() {
+ if (push_handle_) {
+ auto* push_handle = push_handle_;
+ push_handle_ = nullptr;
+ push_handle->Cancel();
+ }
+
if (session_)
session_->RemoveHandle(this);
}
@@ -223,6 +230,7 @@ void QuicChromiumClientSession::Handle::OnSessionClosed(
error_ = error;
quic_version_ = quic_version;
connect_timing_ = connect_timing;
+ push_handle_ = nullptr;
}
bool QuicChromiumClientSession::Handle::IsConnected() const {
@@ -304,6 +312,79 @@ int QuicChromiumClientSession::Handle::RequestStream(
return stream_request_->StartRequest(callback);
}
+int QuicChromiumClientSession::Handle::RendezvousWithPromised(
+ const SpdyHeaderBlock& headers,
+ const CompletionCallback& callback) {
+ if (!session_)
+ return ERR_CONNECTION_CLOSED;
+
+ QuicAsyncStatus push_status =
+ session_->push_promise_index()->Try(headers, this, &push_handle_);
+
+ switch (push_status) {
+ case QUIC_FAILURE:
+ return ERR_FAILED;
+ case QUIC_SUCCESS:
+ return OK;
+ case QUIC_PENDING:
+ push_callback_ = callback;
+ return ERR_IO_PENDING;
+ }
+ NOTREACHED();
+ return ERR_UNEXPECTED;
+}
+
+bool QuicChromiumClientSession::Handle::CheckVary(
+ const SpdyHeaderBlock& client_request,
+ const SpdyHeaderBlock& promise_request,
+ const SpdyHeaderBlock& promise_response) {
+ HttpResponseInfo promise_response_info;
xunjieli 2017/06/21 20:55:28 optional nit: Move this closer to where it's neede
Ryan Hamilton 2017/06/21 22:24:50 Done.
+
+ HttpRequestInfo promise_request_info;
+ ConvertHeaderBlockToHttpRequestHeaders(promise_request,
+ &promise_request_info.extra_headers);
+ HttpRequestInfo client_request_info;
+ ConvertHeaderBlockToHttpRequestHeaders(client_request,
+ &client_request_info.extra_headers);
+
+ if (!SpdyHeadersToHttpResponse(promise_response, &promise_response_info)) {
+ DLOG(WARNING) << "Invalid headers";
+ return false;
+ }
+
+ HttpVaryData vary_data;
+ if (!vary_data.Init(promise_request_info,
+ *promise_response_info.headers.get())) {
+ // Promise didn't contain valid vary info, so URL match was sufficient.
+ return true;
+ }
+ // Now compare the client request for matching.
+ return vary_data.MatchesRequest(client_request_info,
+ *promise_response_info.headers.get());
+}
+
+void QuicChromiumClientSession::Handle::OnRendezvousResult(
xunjieli 2017/06/21 20:55:28 nit: these four new methods should in the same ord
Ryan Hamilton 2017/06/21 22:24:51 Done.
+ QuicSpdyStream* stream) {
+ DCHECK(!push_stream_);
+ int rv = ERR_FAILED;
+ if (stream) {
+ rv = OK;
+ push_stream_ =
+ static_cast<QuicChromiumClientStream*>(stream)->CreateHandle();
+ }
+
+ if (push_callback_) {
+ DCHECK(push_handle_);
+ push_handle_ = nullptr;
+ base::ResetAndReturn(&push_callback_).Run(rv);
+ }
+}
+
+std::unique_ptr<QuicChromiumClientStream::Handle>
+QuicChromiumClientSession::Handle::ReleasePromisedStream() {
xunjieli 2017/06/21 20:55:28 nit: Add a DCHECK(push_stream_) to make sure that
Ryan Hamilton 2017/06/21 22:24:50 Done.
+ return std::move(push_stream_);
+}
+
std::unique_ptr<QuicChromiumClientStream::Handle>
QuicChromiumClientSession::Handle::ReleaseStream() {
DCHECK(stream_request_);

Powered by Google App Engine
This is Rietveld 408576698