naiveproxy/net/quic/quic_stream_factory_peer.cc

186 lines
6.2 KiB
C++
Raw Normal View History

2018-12-10 05:59:24 +03:00
// Copyright 2015 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include "net/quic/quic_stream_factory_peer.h"
#include <string>
#include <vector>
#include "net/cert/x509_certificate.h"
#include "net/cert/x509_util.h"
#include "net/quic/quic_chromium_client_session.h"
#include "net/quic/quic_http_stream.h"
#include "net/quic/quic_stream_factory.h"
#include "net/test/cert_test_util.h"
#include "net/test/test_data_directory.h"
#include "net/third_party/quic/core/crypto/quic_crypto_client_config.h"
#include "net/third_party/quic/platform/impl/quic_chromium_clock.h"
using std::string;
namespace net {
namespace test {
const quic::QuicConfig* QuicStreamFactoryPeer::GetConfig(
QuicStreamFactory* factory) {
return &factory->config_;
}
quic::QuicCryptoClientConfig* QuicStreamFactoryPeer::GetCryptoConfig(
QuicStreamFactory* factory) {
return &factory->crypto_config_;
}
bool QuicStreamFactoryPeer::HasActiveSession(
QuicStreamFactory* factory,
const quic::QuicServerId& server_id) {
return factory->HasActiveSession(QuicSessionKey(server_id, SocketTag()));
}
bool QuicStreamFactoryPeer::HasActiveJob(QuicStreamFactory* factory,
const quic::QuicServerId& server_id) {
return factory->HasActiveJob(QuicSessionKey(server_id, SocketTag()));
}
bool QuicStreamFactoryPeer::HasActiveCertVerifierJob(
QuicStreamFactory* factory,
const quic::QuicServerId& server_id) {
return factory->HasActiveCertVerifierJob(server_id);
}
// static
QuicChromiumClientSession* QuicStreamFactoryPeer::GetPendingSession(
QuicStreamFactory* factory,
const quic::QuicServerId& server_id,
const HostPortPair& destination) {
QuicSessionKey session_key(server_id, SocketTag());
QuicStreamFactory::QuicSessionAliasKey key(destination, session_key);
DCHECK(factory->HasActiveJob(session_key));
DCHECK_EQ(factory->all_sessions_.size(), 1u);
DCHECK(key == factory->all_sessions_.begin()->second);
return factory->all_sessions_.begin()->first;
}
QuicChromiumClientSession* QuicStreamFactoryPeer::GetActiveSession(
QuicStreamFactory* factory,
const quic::QuicServerId& server_id) {
QuicSessionKey session_key(server_id, SocketTag());
DCHECK(factory->HasActiveSession(session_key));
return factory->active_sessions_[session_key];
}
bool QuicStreamFactoryPeer::IsLiveSession(QuicStreamFactory* factory,
QuicChromiumClientSession* session) {
for (QuicStreamFactory::SessionIdMap::iterator it =
factory->all_sessions_.begin();
it != factory->all_sessions_.end(); ++it) {
if (it->first == session)
return true;
}
return false;
}
void QuicStreamFactoryPeer::SetTaskRunner(
QuicStreamFactory* factory,
base::SequencedTaskRunner* task_runner) {
factory->task_runner_ = task_runner;
}
quic::QuicTime::Delta QuicStreamFactoryPeer::GetPingTimeout(
QuicStreamFactory* factory) {
return factory->ping_timeout_;
}
bool QuicStreamFactoryPeer::GetRaceCertVerification(
QuicStreamFactory* factory) {
return factory->race_cert_verification_;
}
void QuicStreamFactoryPeer::SetRaceCertVerification(
QuicStreamFactory* factory,
bool race_cert_verification) {
factory->race_cert_verification_ = race_cert_verification;
}
quic::QuicAsyncStatus QuicStreamFactoryPeer::StartCertVerifyJob(
QuicStreamFactory* factory,
const quic::QuicServerId& server_id,
int cert_verify_flags,
const NetLogWithSource& net_log) {
return factory->StartCertVerifyJob(server_id, cert_verify_flags, net_log);
}
void QuicStreamFactoryPeer::SetYieldAfterPackets(QuicStreamFactory* factory,
int yield_after_packets) {
factory->yield_after_packets_ = yield_after_packets;
}
void QuicStreamFactoryPeer::SetYieldAfterDuration(
QuicStreamFactory* factory,
quic::QuicTime::Delta yield_after_duration) {
factory->yield_after_duration_ = yield_after_duration;
}
bool QuicStreamFactoryPeer::CryptoConfigCacheIsEmpty(
QuicStreamFactory* factory,
const quic::QuicServerId& quic_server_id) {
return factory->CryptoConfigCacheIsEmpty(quic_server_id);
}
void QuicStreamFactoryPeer::CacheDummyServerConfig(
QuicStreamFactory* factory,
const quic::QuicServerId& quic_server_id) {
// Minimum SCFG that passes config validation checks.
const char scfg[] = {// SCFG
0x53, 0x43, 0x46, 0x47,
// num entries
0x01, 0x00,
// padding
0x00, 0x00,
// EXPY
0x45, 0x58, 0x50, 0x59,
// EXPY end offset
0x08, 0x00, 0x00, 0x00,
// Value
'1', '2', '3', '4', '5', '6', '7', '8'};
string server_config(reinterpret_cast<const char*>(&scfg), sizeof(scfg));
string source_address_token("test_source_address_token");
string signature("test_signature");
std::vector<string> certs;
// Load a certificate that is valid for *.example.org
scoped_refptr<X509Certificate> cert(
ImportCertFromFile(GetTestCertsDirectory(), "wildcard.pem"));
DCHECK(cert);
certs.emplace_back(x509_util::CryptoBufferAsStringPiece(cert->cert_buffer()));
quic::QuicCryptoClientConfig* crypto_config = &factory->crypto_config_;
quic::QuicCryptoClientConfig::CachedState* cached =
crypto_config->LookupOrCreate(quic_server_id);
quic::QuicChromiumClock clock;
cached->Initialize(server_config, source_address_token, certs, "", "",
signature, clock.WallNow(), quic::QuicWallTime::Zero());
DCHECK(!cached->certs().empty());
}
quic::QuicClientPushPromiseIndex* QuicStreamFactoryPeer::GetPushPromiseIndex(
QuicStreamFactory* factory) {
return &factory->push_promise_index_;
}
int QuicStreamFactoryPeer::GetNumPushStreamsCreated(
QuicStreamFactory* factory) {
return factory->num_push_streams_created_;
}
void QuicStreamFactoryPeer::SetAlarmFactory(
QuicStreamFactory* factory,
std::unique_ptr<quic::QuicAlarmFactory> alarm_factory) {
factory->alarm_factory_ = std::move(alarm_factory);
}
} // namespace test
} // namespace net