| // 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_QUIC_TRANSPORT_QUIC_TRANSPORT_STREAM_H_ |
| #define QUICHE_QUIC_QUIC_TRANSPORT_QUIC_TRANSPORT_STREAM_H_ |
| |
| #include <cstddef> |
| #include <memory> |
| |
| #include "absl/base/attributes.h" |
| #include "absl/strings/string_view.h" |
| #include "quic/core/quic_session.h" |
| #include "quic/core/quic_stream.h" |
| #include "quic/core/quic_types.h" |
| #include "quic/quic_transport/quic_transport_session_interface.h" |
| |
| namespace quic { |
| |
| // QuicTransportStream is an extension of QuicStream that provides I/O interface |
| // that is safe to use in the QuicTransport context. The interface ensures no |
| // application data is processed before the client indication is processed. |
| class QUIC_EXPORT_PRIVATE QuicTransportStream : public QuicStream { |
| public: |
| class QUIC_EXPORT_PRIVATE Visitor { |
| public: |
| virtual ~Visitor() {} |
| virtual void OnCanRead() = 0; |
| virtual void OnFinRead() = 0; |
| virtual void OnCanWrite() = 0; |
| }; |
| |
| QuicTransportStream(QuicStreamId id, |
| QuicSession* session, |
| QuicTransportSessionInterface* session_interface); |
| |
| // Reads at most |buffer_size| bytes into |buffer| and returns the number of |
| // bytes actually read. |
| size_t Read(char* buffer, size_t buffer_size); |
| // Reads all available data and appends it to the end of |output|. |
| size_t Read(std::string* output); |
| // Writes |data| into the stream. Returns true on success. |
| ABSL_MUST_USE_RESULT bool Write(absl::string_view data); |
| // Sends the FIN on the stream. Returns true on success. |
| ABSL_MUST_USE_RESULT bool SendFin(); |
| |
| // Indicates whether it is possible to write into stream right now. |
| bool CanWrite() const; |
| // Indicates the number of bytes that can be read from the stream. |
| size_t ReadableBytes() const; |
| |
| // QuicSession method implementations. |
| void OnDataAvailable() override; |
| void OnCanWriteNewData() override; |
| |
| Visitor* visitor() { return visitor_.get(); } |
| void set_visitor(std::unique_ptr<Visitor> visitor) { |
| visitor_ = std::move(visitor); |
| } |
| |
| protected: |
| // Hide the methods that allow writing data without checking IsSessionReady(). |
| using QuicStream::WriteMemSlices; |
| using QuicStream::WriteOrBufferData; |
| |
| void MaybeNotifyFinRead(); |
| |
| QuicTransportSessionInterface* session_interface_; |
| std::unique_ptr<Visitor> visitor_ = nullptr; |
| bool fin_read_notified_ = false; |
| }; |
| |
| } // namespace quic |
| |
| #endif // QUICHE_QUIC_QUIC_TRANSPORT_QUIC_TRANSPORT_STREAM_H_ |