1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_QUIC_QUIC_HEADERS_STREAM_H_
6 #define NET_QUIC_QUIC_HEADERS_STREAM_H_
8 #include "base/basictypes.h"
9 #include "base/memory/scoped_ptr.h"
10 #include "net/base/net_export.h"
11 #include "net/quic/quic_protocol.h"
12 #include "net/quic/reliable_quic_stream.h"
13 #include "net/spdy/spdy_framer.h"
17 // Headers in QUIC are sent as SPDY SYN_STREAM or SYN_REPLY frames
18 // over a reserved reliable stream with the id 2. Each endpoint (client
19 // and server) will allocate an instance of QuicHeadersStream to send
20 // and receive headers.
21 class NET_EXPORT_PRIVATE QuicHeadersStream
: public ReliableQuicStream
{
23 explicit QuicHeadersStream(QuicSession
* session
);
24 ~QuicHeadersStream() override
;
26 // Writes |headers| for |stream_id| in a SYN_STREAM or SYN_REPLY
27 // frame to the peer. If |fin| is true, the fin flag will be set on
28 // the SPDY frame. Returns the size, in bytes, of the resulting
31 QuicStreamId stream_id
,
32 const SpdyHeaderBlock
& headers
,
34 QuicPriority priority
,
35 QuicAckNotifier::DelegateInterface
* ack_notifier_delegate
);
37 // ReliableQuicStream implementation
38 uint32
ProcessRawData(const char* data
, uint32 data_len
) override
;
39 QuicPriority
EffectivePriority() const override
;
42 class SpdyFramerVisitor
;
44 // The following methods are called by the SimpleVisitor.
46 // Called when a SYN_STREAM frame has been received.
47 void OnSynStream(SpdyStreamId stream_id
,
48 SpdyPriority priority
,
51 // Called when a SYN_REPLY frame been received.
52 void OnSynReply(SpdyStreamId stream_id
, bool fin
);
54 // Called when a chunk of header data is available. This is called
55 // after OnSynStream, or OnSynReply.
56 // |stream_id| The stream receiving the header data.
57 // |header_data| A buffer containing the header data chunk received.
58 // |len| The length of the header data buffer. A length of zero indicates
59 // that the header data block has been completely sent.
60 void OnControlFrameHeaderData(SpdyStreamId stream_id
,
61 const char* header_data
,
64 // Called when the size of the compressed frame payload is available.
65 void OnCompressedFrameSize(size_t frame_len
);
67 // Returns true if the session is still connected.
70 // Data about the stream whose headers are being processed.
71 QuicStreamId stream_id_
;
75 SpdyFramer spdy_framer_
;
76 scoped_ptr
<SpdyFramerVisitor
> spdy_framer_visitor_
;
78 DISALLOW_COPY_AND_ASSIGN(QuicHeadersStream
);
83 #endif // NET_QUIC_QUIC_HEADERS_STREAM_H_