// Copyright 2012 The Chromium Authors // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef NET_BASE_ELEMENTS_UPLOAD_DATA_STREAM_H_ #define NET_BASE_ELEMENTS_UPLOAD_DATA_STREAM_H_ #include #include #include #include #include "base/memory/scoped_refptr.h" #include "base/memory/weak_ptr.h" #include "net/base/net_errors.h" #include "net/base/net_export.h" #include "net/base/upload_data_stream.h" namespace net { class DrainableIOBuffer; class IOBuffer; class UploadElementReader; // A non-chunked UploadDataStream consisting of one or more UploadElements. class NET_EXPORT ElementsUploadDataStream : public UploadDataStream { public: ElementsUploadDataStream( std::vector> element_readers, int64_t identifier); ElementsUploadDataStream(const ElementsUploadDataStream&) = delete; ElementsUploadDataStream& operator=(const ElementsUploadDataStream&) = delete; ~ElementsUploadDataStream() override; // Creates an ElementsUploadDataStream with a single reader. Returns a // std::unique_ptr for ease of use. static std::unique_ptr CreateWithReader( std::unique_ptr reader, int64_t identifier); private: // UploadDataStream implementation. bool IsInMemory() const override; const std::vector>* GetElementReaders() const override; int InitInternal(const NetLogWithSource& net_log) override; int ReadInternal(IOBuffer* buf, int buf_len) override; void ResetInternal() override; // Runs Init() for all element readers. // This method is used to implement InitInternal(). int InitElements(size_t start_index); // Called when the |index| element finishes initialization. If it succeeded, // continues with the |index + 1| element. Calls OnInitCompleted on error or // when all elements have been initialized. void OnInitElementCompleted(size_t index, int result); // Reads data from the element readers. // This method is used to implement Read(). int ReadElements(const scoped_refptr& buf); // Resumes pending read and calls OnReadCompleted with a result when // necessary. void OnReadElementCompleted(const scoped_refptr& buf, int result); // Processes result of UploadElementReader::Read(). If |result| indicates // success, updates |buf|'s offset. Otherwise, sets |read_failed_| to true. void ProcessReadResult(const scoped_refptr& buf, int result); std::vector> element_readers_; // Index of the current upload element (i.e. the element currently being // read). The index is used as a cursor to iterate over elements in // |upload_data_|. size_t element_index_ = 0; // Set to actual error if read fails, otherwise set to net::OK. int read_error_ = OK; base::WeakPtrFactory weak_ptr_factory_{this}; }; } // namespace net #endif // NET_BASE_ELEMENTS_UPLOAD_DATA_STREAM_H_