blob: c69f9b8f92b4005f673e485db955ab7e1b6ab486 [file] [log] [blame] [edit]
// 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_PACKET_EXCHANGER_H_
#define QUICHE_QUIC_QBONE_QBONE_PACKET_EXCHANGER_H_
#include "absl/status/status.h"
#include "absl/strings/string_view.h"
#include "quiche/quic/core/quic_packets.h"
#include "quiche/quic/qbone/qbone_client_interface.h"
#include "quiche/quic/qbone/qbone_packet_writer.h"
namespace quic {
// Handles reading and writing on the local network and exchange packets between
// the local network with a QBONE connection.
class QbonePacketExchanger : public QbonePacketWriter {
public:
// The owner might want to receive notifications when read or write fails.
class Visitor {
public:
virtual ~Visitor() {}
virtual void OnReadError(const std::string& error) {}
virtual void OnWriteError(const std::string& error) {}
virtual absl::Status OnWrite(absl::string_view packet) {
return absl::OkStatus();
}
};
// Does not take ownership of visitor.
QbonePacketExchanger(Visitor* visitor, size_t max_pending_packets)
: visitor_(visitor), max_pending_packets_(max_pending_packets) {}
QbonePacketExchanger(const QbonePacketExchanger&) = delete;
QbonePacketExchanger& operator=(const QbonePacketExchanger&) = delete;
QbonePacketExchanger(QbonePacketExchanger&&) = delete;
QbonePacketExchanger& operator=(QbonePacketExchanger&&) = delete;
~QbonePacketExchanger() = default;
// Returns true if there may be more packets to read.
// Implementations handles the actual raw read and delivers the packet to
// qbone_client.
bool ReadAndDeliverPacket(QboneClientInterface* qbone_client);
// From QbonePacketWriter.
// Writes a packet to the local network. If the write would be blocked, the
// packet will be queued if the queue is smaller than max_pending_packets_.
void WritePacketToNetwork(const char* packet, size_t size) override;
// The caller signifies that the local network is no longer blocked.
void SetWritable();
private:
// The actual implementation that reads a packet from the local network.
// Returns the packet if one is successfully read. This might nullptr when a)
// there is no packet to read, b) the read failed. In the former case, blocked
// is set to true. error contains the error message.
virtual std::unique_ptr<QuicData> ReadPacket(bool* blocked,
std::string* error) = 0;
// The actual implementation that writes a packet to the local network.
// Returns true if the write succeeds. blocked will be set to true if the
// write failure is caused by the local network being blocked. error contains
// the error message.
virtual bool WritePacket(const char* packet, size_t size, bool* blocked,
std::string* error) = 0;
std::list<std::unique_ptr<QuicData>> packet_queue_;
Visitor* visitor_;
// The maximum number of packets that could be queued up when writing to local
// network is blocked.
size_t max_pending_packets_;
bool write_blocked_ = false;
};
} // namespace quic
#endif // QUICHE_QUIC_QBONE_QBONE_PACKET_EXCHANGER_H_