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

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

Issue 2948143002: Add an async method to QuicChromiumClientSession::Handle for (Closed)
Patch Set: Address comments 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..7eec53a345489b74655b94f4e82186749848fd43 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_;
xunjieli 2017/06/22 14:43:30 Is saving |push_handle_| on to the stack still nec
Ryan Hamilton 2017/06/22 20:40:38 So it "should" work, but I'm nervous. As you point
+ 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 {
@@ -289,6 +297,28 @@ bool QuicChromiumClientSession::Handle::SharesSameSession(
return session_.get() == other.session_.get();
}
+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;
+}
+
int QuicChromiumClientSession::Handle::RequestStream(
bool requires_confirmation,
const CompletionCallback& callback) {
@@ -313,6 +343,12 @@ QuicChromiumClientSession::Handle::ReleaseStream() {
return handle;
}
+std::unique_ptr<QuicChromiumClientStream::Handle>
+QuicChromiumClientSession::Handle::ReleasePromisedStream() {
+ DCHECK(push_stream_);
+ return std::move(push_stream_);
+}
+
int QuicChromiumClientSession::Handle::WaitForHandshakeConfirmation(
const CompletionCallback& callback) {
if (!session_)
@@ -350,6 +386,51 @@ int QuicChromiumClientSession::Handle::GetPeerAddress(
return OK;
}
+bool QuicChromiumClientSession::Handle::CheckVary(
+ const SpdyHeaderBlock& client_request,
+ const SpdyHeaderBlock& promise_request,
+ const SpdyHeaderBlock& promise_response) {
+ HttpRequestInfo promise_request_info;
+ ConvertHeaderBlockToHttpRequestHeaders(promise_request,
+ &promise_request_info.extra_headers);
+ HttpRequestInfo client_request_info;
+ ConvertHeaderBlockToHttpRequestHeaders(client_request,
+ &client_request_info.extra_headers);
+
+ HttpResponseInfo promise_response_info;
+ 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(
+ 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);
+ }
+}
+
QuicChromiumClientSession::StreamRequest::StreamRequest(
QuicChromiumClientSession::Handle* session,
bool requires_confirmation)

Powered by Google App Engine
This is Rietveld 408576698