| // Copyright (c) 2017 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_QUARTC_QUARTC_PACKET_WRITER_H_ | 
 | #define QUICHE_QUIC_QUARTC_QUARTC_PACKET_WRITER_H_ | 
 |  | 
 | #include "net/third_party/quiche/src/quic/core/quic_connection.h" | 
 | #include "net/third_party/quiche/src/quic/core/quic_packet_writer.h" | 
 | #include "net/third_party/quiche/src/quic/core/quic_types.h" | 
 |  | 
 | namespace quic { | 
 |  | 
 | // Send and receive packets, like a virtual UDP socket. For example, this | 
 | // could be implemented by WebRTC's IceTransport. | 
 | class QuartcPacketTransport { | 
 |  public: | 
 |   // Additional metadata provided for each packet written. | 
 |   struct PacketInfo { | 
 |     QuicPacketNumber packet_number; | 
 |   }; | 
 |  | 
 |   // Delegate for packet transport callbacks.  Note that the delegate is not | 
 |   // thread-safe.  Packet transport implementations must ensure that callbacks | 
 |   // are synchronized with all other work done by QUIC. | 
 |   class Delegate { | 
 |    public: | 
 |     virtual ~Delegate() = default; | 
 |  | 
 |     // Called whenever the transport can write. | 
 |     virtual void OnTransportCanWrite() = 0; | 
 |  | 
 |     // Called when the transport receives a packet. | 
 |     virtual void OnTransportReceived(const char* data, size_t data_len) = 0; | 
 |   }; | 
 |  | 
 |   virtual ~QuartcPacketTransport() {} | 
 |  | 
 |   // Called by the QuartcPacketWriter when writing packets to the network. | 
 |   // Return the number of written bytes. Return 0 if the write is blocked. | 
 |   virtual int Write(const char* buffer, | 
 |                     size_t buf_len, | 
 |                     const PacketInfo& info) = 0; | 
 |  | 
 |   // Sets the delegate which must be called when the transport can write or | 
 |   // a packet is received.  QUIC sets |delegate| to a nonnull pointer when it | 
 |   // is ready to process incoming packets and sets |delegate| to nullptr before | 
 |   // QUIC is deleted.  Implementations may assume |delegate| remains valid until | 
 |   // it is set to nullptr. | 
 |   virtual void SetDelegate(Delegate* delegate) = 0; | 
 | }; | 
 |  | 
 | struct QuartcPerPacketOptions : public PerPacketOptions { | 
 |   std::unique_ptr<PerPacketOptions> Clone() const override; | 
 |  | 
 |   // The connection which is sending this packet. | 
 |   QuicConnection* connection = nullptr; | 
 | }; | 
 |  | 
 | // Implements a QuicPacketWriter using a QuartcPacketTransport, which allows a | 
 | // QuicConnection to use (for example), a WebRTC IceTransport. | 
 | class QuartcPacketWriter : public QuicPacketWriter { | 
 |  public: | 
 |   QuartcPacketWriter(QuartcPacketTransport* packet_transport, | 
 |                      QuicByteCount max_packet_size); | 
 |   ~QuartcPacketWriter() override {} | 
 |  | 
 |   // The QuicConnection calls WritePacket and the QuicPacketWriter writes them | 
 |   // to the QuartcSession::PacketTransport. | 
 |   WriteResult WritePacket(const char* buffer, | 
 |                           size_t buf_len, | 
 |                           const QuicIpAddress& self_address, | 
 |                           const QuicSocketAddress& peer_address, | 
 |                           PerPacketOptions* options) override; | 
 |  | 
 |   // Whether the underneath |transport_| is blocked. If this returns true, | 
 |   // outgoing QUIC packets are queued by QuicConnection until SetWritable() is | 
 |   // called. | 
 |   bool IsWriteBlocked() const override; | 
 |  | 
 |   // Maximum size of the QUIC packet which can be written. Users such as WebRTC | 
 |   // can set the value through the QuartcFactoryConfig without updating the QUIC | 
 |   // code. | 
 |   QuicByteCount GetMaxPacketSize( | 
 |       const QuicSocketAddress& peer_address) const override; | 
 |  | 
 |   // Sets the packet writer to a writable (non-blocked) state. | 
 |   void SetWritable() override; | 
 |  | 
 |   bool SupportsReleaseTime() const override; | 
 |  | 
 |   bool IsBatchMode() const override; | 
 |  | 
 |   char* GetNextWriteLocation(const QuicIpAddress& self_address, | 
 |                              const QuicSocketAddress& peer_address) override; | 
 |  | 
 |   WriteResult Flush() override; | 
 |  | 
 |   void SetPacketTransportDelegate(QuartcPacketTransport::Delegate* delegate); | 
 |  | 
 |  private: | 
 |   // QuartcPacketWriter will not own the transport. | 
 |   QuartcPacketTransport* packet_transport_; | 
 |   // The maximum size of the packet can be written by this writer. | 
 |   QuicByteCount max_packet_size_; | 
 |  | 
 |   // Whether packets can be written. | 
 |   bool writable_ = false; | 
 | }; | 
 |  | 
 | }  // namespace quic | 
 |  | 
 | #endif  // QUICHE_QUIC_QUARTC_QUARTC_PACKET_WRITER_H_ |