1*e7b1675dSTing-Kang Chang // Copyright 2019 Google Inc. 2*e7b1675dSTing-Kang Chang // 3*e7b1675dSTing-Kang Chang // Licensed under the Apache License, Version 2.0 (the "License"); 4*e7b1675dSTing-Kang Chang // you may not use this file except in compliance with the License. 5*e7b1675dSTing-Kang Chang // You may obtain a copy of the License at 6*e7b1675dSTing-Kang Chang // 7*e7b1675dSTing-Kang Chang // http://www.apache.org/licenses/LICENSE-2.0 8*e7b1675dSTing-Kang Chang // 9*e7b1675dSTing-Kang Chang // Unless required by applicable law or agreed to in writing, software 10*e7b1675dSTing-Kang Chang // distributed under the License is distributed on an "AS IS" BASIS, 11*e7b1675dSTing-Kang Chang // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12*e7b1675dSTing-Kang Chang // See the License for the specific language governing permissions and 13*e7b1675dSTing-Kang Chang // limitations under the License. 14*e7b1675dSTing-Kang Chang // 15*e7b1675dSTing-Kang Chang /////////////////////////////////////////////////////////////////////////////// 16*e7b1675dSTing-Kang Chang 17*e7b1675dSTing-Kang Chang #ifndef TINK_STREAMINGAEAD_BUFFERED_INPUT_STREAM_H_ 18*e7b1675dSTing-Kang Chang #define TINK_STREAMINGAEAD_BUFFERED_INPUT_STREAM_H_ 19*e7b1675dSTing-Kang Chang 20*e7b1675dSTing-Kang Chang #include <memory> 21*e7b1675dSTing-Kang Chang #include <vector> 22*e7b1675dSTing-Kang Chang 23*e7b1675dSTing-Kang Chang #include "tink/input_stream.h" 24*e7b1675dSTing-Kang Chang #include "tink/util/status.h" 25*e7b1675dSTing-Kang Chang #include "tink/util/statusor.h" 26*e7b1675dSTing-Kang Chang 27*e7b1675dSTing-Kang Chang namespace crypto { 28*e7b1675dSTing-Kang Chang namespace tink { 29*e7b1675dSTing-Kang Chang namespace streamingaead { 30*e7b1675dSTing-Kang Chang 31*e7b1675dSTing-Kang Chang // An InputStream that initially buffers all the read bytes, and offers 32*e7b1675dSTing-Kang Chang // rewind-functionality, until explicitly instructed to disable 33*e7b1675dSTing-Kang Chang // rewinding (and stop buffering). 34*e7b1675dSTing-Kang Chang class BufferedInputStream : public crypto::tink::InputStream { 35*e7b1675dSTing-Kang Chang public: 36*e7b1675dSTing-Kang Chang // Constructs an InputStream that will read from 'input_stream', 37*e7b1675dSTing-Kang Chang // buffering all the read bytes in memory, and offering rewinding 38*e7b1675dSTing-Kang Chang // to the beginning of the stream (as long as rewinding is enabled). 39*e7b1675dSTing-Kang Chang explicit BufferedInputStream( 40*e7b1675dSTing-Kang Chang std::unique_ptr<crypto::tink::InputStream> input_stream); 41*e7b1675dSTing-Kang Chang 42*e7b1675dSTing-Kang Chang ~BufferedInputStream() override; 43*e7b1675dSTing-Kang Chang 44*e7b1675dSTing-Kang Chang crypto::tink::util::StatusOr<int> Next(const void** data) override; 45*e7b1675dSTing-Kang Chang 46*e7b1675dSTing-Kang Chang void BackUp(int count) override; 47*e7b1675dSTing-Kang Chang 48*e7b1675dSTing-Kang Chang int64_t Position() const override; 49*e7b1675dSTing-Kang Chang 50*e7b1675dSTing-Kang Chang // Rewinds this stream to the beginning (if rewinding is still enabled). 51*e7b1675dSTing-Kang Chang crypto::tink::util::Status Rewind(); 52*e7b1675dSTing-Kang Chang 53*e7b1675dSTing-Kang Chang // Disables rewinding. 54*e7b1675dSTing-Kang Chang void DisableRewinding(); 55*e7b1675dSTing-Kang Chang 56*e7b1675dSTing-Kang Chang private: 57*e7b1675dSTing-Kang Chang std::unique_ptr<crypto::tink::InputStream> input_stream_; 58*e7b1675dSTing-Kang Chang bool direct_access_; // true iff we don't buffer any data any more 59*e7b1675dSTing-Kang Chang 60*e7b1675dSTing-Kang Chang // The fields below are valid and in use iff direct_access_ is false. 61*e7b1675dSTing-Kang Chang // Once direct_access_ becomes true, all the calls to this stream's methods 62*e7b1675dSTing-Kang Chang // are directly relayed to methods of input_stream_. 63*e7b1675dSTing-Kang Chang crypto::tink::util::Status status_; 64*e7b1675dSTing-Kang Chang std::vector<uint8_t> buffer_; 65*e7b1675dSTing-Kang Chang bool after_rewind_; // true iff no Next has been called after rewind 66*e7b1675dSTing-Kang Chang bool rewinding_enabled_; // true iff this stream can be rewound 67*e7b1675dSTing-Kang Chang int64_t position_; // current position in the stream (from the beginning) 68*e7b1675dSTing-Kang Chang 69*e7b1675dSTing-Kang Chang // Counters that describe the state of the data in buffer_. 70*e7b1675dSTing-Kang Chang int count_in_buffer_; // # of bytes available in buffer_ 71*e7b1675dSTing-Kang Chang int count_backedup_; // # of bytes available in buffer_ that were backed up 72*e7b1675dSTing-Kang Chang int buffer_offset_; // offset at which the returned bytes start in buffer_ 73*e7b1675dSTing-Kang Chang }; 74*e7b1675dSTing-Kang Chang 75*e7b1675dSTing-Kang Chang } // namespace streamingaead 76*e7b1675dSTing-Kang Chang } // namespace tink 77*e7b1675dSTing-Kang Chang } // namespace crypto 78*e7b1675dSTing-Kang Chang 79*e7b1675dSTing-Kang Chang #endif // TINK_STREAMINGAEAD_BUFFERED_INPUT_STREAM_H_ 80