blob: 1ae74e495bb1a823af9d5fa541e640416cff1cba [file] [log] [blame]
// Copyright 2016 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 NET_FILTER_SOURCE_STREAM_H_
#define NET_FILTER_SOURCE_STREAM_H_
#include <string>
#include "base/callback.h"
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "net/base/completion_once_callback.h"
#include "net/base/net_errors.h"
#include "net/base/net_export.h"
namespace net {
class IOBuffer;
// The SourceStream class implements a producer of bytes.
class NET_EXPORT_PRIVATE SourceStream {
public:
enum SourceType {
#define SOURCE_STREAM_TYPE(label) TYPE_##label,
#include "net/filter/source_stream_type_list.h"
#undef SOURCE_STREAM_TYPE
// Used for UMA.
TYPE_MAX,
};
// |type| is the type of the SourceStream.
explicit SourceStream(SourceType type);
virtual ~SourceStream();
// Initiaties a read from the stream.
// If it completes synchronously, it:
// - Returns an int representing the number of bytes read. If 0, EOF has
// been reached
// - Bytes will be written into |*dest_buffer|
// - Does not call |callback|
// If it completes asynchronously, it:
// - Returns ERR_IO_PENDING
// - Calls |callback| when it does complete, with an error code or a count
// of bytes read and written into |*dest_buffer|.
// This method takes a reference to |*dest_buffer| if it completes
// asynchronously to ensure it does not get freed mid-read.
virtual int Read(IOBuffer* dest_buffer,
int buffer_size,
CompletionOnceCallback callback) = 0;
// Returns a string that represents stream. This is for UMA and NetLog
// logging.
virtual std::string Description() const = 0;
// Returns true if there may be more bytes to read in this source stream.
// This is not a guarantee that there are more bytes (in the case that
// the stream doesn't know). However, if this returns false, then the stream
// is guaranteed to be complete.
virtual bool MayHaveMoreBytes() const = 0;
SourceType type() const { return type_; }
private:
SourceType type_;
DISALLOW_COPY_AND_ASSIGN(SourceStream);
};
} // namespace net
#endif // NET_FILTER_SOURCE_STREAM_H_