1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
// Copyright 2024 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "net/quic/quic_session_pool_job.h"
#include "base/memory/weak_ptr.h"
#include "net/base/completion_once_callback.h"
#include "net/base/network_change_notifier.h"
#include "net/base/network_handle.h"
#include "net/base/proxy_chain.h"
#include "net/base/request_priority.h"
#include "net/base/trace_constants.h"
#include "net/base/tracing.h"
#include "net/dns/host_resolver.h"
#include "net/log/net_log_with_source.h"
#include "net/quic/address_utils.h"
#include "net/quic/quic_crypto_client_config_handle.h"
#include "net/quic/quic_http_stream.h"
#include "net/quic/quic_session_pool.h"
#include "net/third_party/quiche/src/quiche/quic/core/quic_versions.h"
namespace net {
namespace {
base::Value::Dict NetLogQuicSessionPoolJobParams(
const QuicSessionAliasKey* key) {
const ProxyChain& proxy_chain = key->session_key().proxy_chain();
return base::Value::Dict()
.Set("host", key->server_id().host())
.Set("port", key->server_id().port())
.Set("privacy_mode",
PrivacyModeToDebugString(key->session_key().privacy_mode()))
.Set("proxy_chain",
proxy_chain.IsValid() ? proxy_chain.ToDebugString() : "invalid")
.Set("network_anonymization_key",
key->session_key().network_anonymization_key().ToDebugString());
}
} // namespace
QuicSessionPool::Job::Job(
QuicSessionPool* pool,
QuicSessionAliasKey key,
std::unique_ptr<CryptoClientConfigHandle> client_config_handle,
RequestPriority priority,
const NetLogWithSource& net_log)
: pool_(pool),
key_(std::move(key)),
client_config_handle_(std::move(client_config_handle)),
priority_(priority),
net_log_(net_log) {
net_log_.BeginEvent(NetLogEventType::QUIC_SESSION_POOL_JOB,
[&] { return NetLogQuicSessionPoolJobParams(&key_); });
}
QuicSessionPool::Job::~Job() {
net_log_.EndEvent(NetLogEventType::QUIC_SESSION_POOL_JOB);
}
void QuicSessionPool::Job::AddRequest(QuicSessionRequest* request) {
request->AddedToJob();
requests_.insert(request);
SetRequestExpectations(request);
}
void QuicSessionPool::Job::RemoveRequest(QuicSessionRequest* request) {
request->RemovedFromJob();
auto request_iter = requests_.find(request);
CHECK(request_iter != requests_.end());
requests_.erase(request_iter);
}
void QuicSessionPool::Job::SetPriority(RequestPriority priority) {
UpdatePriority(priority_, priority);
priority_ = priority;
}
void QuicSessionPool::Job::AssociateWithNetLogSource(
const NetLogWithSource& http_stream_job_net_log) const {
net_log().AddEventReferencingSource(
NetLogEventType::QUIC_SESSION_POOL_JOB_BOUND_TO,
http_stream_job_net_log.source());
http_stream_job_net_log.AddEventReferencingSource(
NetLogEventType::BOUND_TO_QUIC_SESSION_POOL_JOB, net_log().source());
}
QuicSessionPool* QuicSessionPool::Job::GetQuicSessionPool() {
return pool();
}
const QuicSessionAliasKey& QuicSessionPool::Job::GetKey() {
return key();
}
const NetLogWithSource& QuicSessionPool::Job::GetNetLog() {
return net_log();
}
void QuicSessionPool::Job::OnConnectionFailedOnDefaultNetwork() {
for (QuicSessionRequest* request : requests()) {
request->OnConnectionFailedOnDefaultNetwork();
}
}
void QuicSessionPool::Job::OnQuicSessionCreationComplete(int rv) {
for (QuicSessionRequest* request : requests()) {
request->OnQuicSessionCreationComplete(rv);
}
}
void QuicSessionPool::Job::UpdatePriority(RequestPriority old_priority,
RequestPriority new_priority) {}
} // namespace net
|