blob: 870997758be548ad33146331f5f80cb3decf8d1f [file] [log] [blame] [edit]
// Copyright 2015 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_SPDY_CORE_SPDY_HEADERS_HANDLER_INTERFACE_H_
#define QUICHE_SPDY_CORE_SPDY_HEADERS_HANDLER_INTERFACE_H_
#include <stddef.h>
#include "net/third_party/quiche/src/common/platform/api/quiche_export.h"
#include "net/third_party/quiche/src/common/platform/api/quiche_string_piece.h"
namespace spdy {
// This interface defines how an object that accepts header data should behave.
// It is used by both SpdyHeadersBlockParser and HpackDecoder.
class QUICHE_EXPORT_PRIVATE SpdyHeadersHandlerInterface {
public:
virtual ~SpdyHeadersHandlerInterface() {}
// A callback method which notifies when the parser starts handling a new
// header block. Will only be called once per block, even if it extends into
// CONTINUATION frames.
virtual void OnHeaderBlockStart() = 0;
// A callback method which notifies on a header key value pair. Multiple
// values for a given key will be emitted as multiple calls to OnHeader.
virtual void OnHeader(quiche::QuicheStringPiece key,
quiche::QuicheStringPiece value) = 0;
// A callback method which notifies when the parser finishes handling a
// header block (i.e. the containing frame has the END_HEADERS flag set).
// Also indicates the total number of bytes in this block.
virtual void OnHeaderBlockEnd(size_t uncompressed_header_bytes,
size_t compressed_header_bytes) = 0;
};
} // namespace spdy
#endif // QUICHE_SPDY_CORE_SPDY_HEADERS_HANDLER_INTERFACE_H_