blob: dbeb08b9034b8bd6e64329827f79536e22c58b59 [file] [log] [blame]
// Copyright (c) 2019 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.
#ifndef QUICHE_QUIC_QBONE_QBONE_SERVER_SESSION_H_
#define QUICHE_QUIC_QBONE_QBONE_SERVER_SESSION_H_
#include "absl/strings/string_view.h"
#include "quiche/quic/core/quic_crypto_server_stream_base.h"
#include "quiche/quic/core/quic_crypto_stream.h"
#include "quiche/quic/platform/api/quic_export.h"
#include "quiche/quic/qbone/qbone_control.pb.h"
#include "quiche/quic/qbone/qbone_control_stream.h"
#include "quiche/quic/qbone/qbone_packet_processor.h"
#include "quiche/quic/qbone/qbone_packet_writer.h"
#include "quiche/quic/qbone/qbone_session_base.h"
namespace quic {
// A helper class is used by the QuicCryptoServerStream.
class QboneCryptoServerStreamHelper
: public QuicCryptoServerStreamBase::Helper {
public:
// This will look for the QBONE alpn.
bool CanAcceptClientHello(const CryptoHandshakeMessage& chlo,
const QuicSocketAddress& client_address,
const QuicSocketAddress& peer_address,
const QuicSocketAddress& self_address,
std::string* error_details) const override;
};
class QUIC_EXPORT_PRIVATE QboneServerSession
: public QboneSessionBase,
public QbonePacketProcessor::OutputInterface,
public QbonePacketProcessor::StatsInterface {
public:
QboneServerSession(const quic::ParsedQuicVersionVector& supported_versions,
QuicConnection* connection, Visitor* owner,
const QuicConfig& config,
const QuicCryptoServerConfig* quic_crypto_server_config,
QuicCompressedCertsCache* compressed_certs_cache,
QbonePacketWriter* writer, QuicIpAddress self_ip,
QuicIpAddress client_ip, size_t client_ip_subnet_length,
QboneServerControlStream::Handler* handler);
QboneServerSession(const QboneServerSession&) = delete;
QboneServerSession& operator=(const QboneServerSession&) = delete;
~QboneServerSession() override;
void Initialize() override;
// Override to create control stream at FORWARD_SECURE encryption level.
void SetDefaultEncryptionLevel(quic::EncryptionLevel level) override;
virtual bool SendClientRequest(const QboneClientRequest& request);
void ProcessPacketFromNetwork(absl::string_view packet) override;
void ProcessPacketFromPeer(absl::string_view packet) override;
// QbonePacketProcessor::OutputInterface implementation.
void SendPacketToClient(absl::string_view packet) override;
void SendPacketToNetwork(absl::string_view packet) override;
// QbonePacketProcessor::StatsInterface implementation.
void OnPacketForwarded(QbonePacketProcessor::Direction direction) override {}
void OnPacketDroppedSilently(
QbonePacketProcessor::Direction direction) override {}
void OnPacketDroppedWithIcmp(
QbonePacketProcessor::Direction direction) override {}
void OnPacketDroppedWithTcpReset(
QbonePacketProcessor::Direction direction) override {}
void OnPacketDeferred(QbonePacketProcessor::Direction direction) override {}
protected:
// QboneSessionBase interface implementation.
std::unique_ptr<QuicCryptoStream> CreateCryptoStream() override;
// Instantiates QboneServerControlStream.
void CreateControlStream();
// Instantiates QboneServerControlStream from the pending stream and returns a
// pointer to it.
QuicStream* CreateControlStreamFromPendingStream(PendingStream* pending);
// The packet processor.
QbonePacketProcessor processor_;
// Config for QUIC crypto server stream, used by the server.
const QuicCryptoServerConfig* quic_crypto_server_config_;
private:
// Used by QUIC crypto server stream to track most recently compressed certs.
QuicCompressedCertsCache* compressed_certs_cache_;
// This helper is needed when create QuicCryptoServerStream.
QboneCryptoServerStreamHelper stream_helper_;
// Passed to the control stream.
QboneServerControlStream::Handler* handler_;
// The unowned control stream.
QboneServerControlStream* control_stream_ = nullptr;
};
} // namespace quic
#endif // QUICHE_QUIC_QBONE_QBONE_SERVER_SESSION_H_