blob: 07e759453f97aadfb674753a89e7dd8c2b3042f6 [file] [log] [blame]
// Copyright 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_CORE_QPACK_QPACK_RECEIVE_STREAM_H_
#define QUICHE_QUIC_CORE_QPACK_QPACK_RECEIVE_STREAM_H_
#include "quiche/quic/core/qpack/qpack_stream_receiver.h"
#include "quiche/quic/core/quic_stream.h"
#include "quiche/quic/platform/api/quic_export.h"
namespace quic {
class QuicSession;
// QPACK 4.2.1 Encoder and Decoder Streams.
// The QPACK receive stream is peer initiated and is read only.
class QUICHE_EXPORT QpackReceiveStream : public QuicStream {
public:
// Construct receive stream from pending stream, the |pending| object needs
// to be deleted after the construction.
QpackReceiveStream(PendingStream* pending, QuicSession* session,
QpackStreamReceiver* receiver);
QpackReceiveStream(const QpackReceiveStream&) = delete;
QpackReceiveStream& operator=(const QpackReceiveStream&) = delete;
~QpackReceiveStream() override = default;
// Overriding QuicStream::OnStreamReset to make sure QPACK stream is never
// closed before connection.
void OnStreamReset(const QuicRstStreamFrame& frame) override;
// Implementation of QuicStream.
void OnDataAvailable() override;
// Number of incoming bytes that have been consumed on this stream.
QuicStreamOffset NumBytesConsumed() const {
return sequencer()->NumBytesConsumed();
}
private:
QpackStreamReceiver* receiver_;
};
} // namespace quic
#endif // QUICHE_QUIC_CORE_QPACK_QPACK_RECEIVE_STREAM_H_