1*6777b538SAndroid Build Coastguard Worker // Copyright 2011 The Chromium Authors 2*6777b538SAndroid Build Coastguard Worker // Use of this source code is governed by a BSD-style license that can be 3*6777b538SAndroid Build Coastguard Worker // found in the LICENSE file. 4*6777b538SAndroid Build Coastguard Worker 5*6777b538SAndroid Build Coastguard Worker #ifndef NET_HTTP_HTTP_BYTE_RANGE_H_ 6*6777b538SAndroid Build Coastguard Worker #define NET_HTTP_HTTP_BYTE_RANGE_H_ 7*6777b538SAndroid Build Coastguard Worker 8*6777b538SAndroid Build Coastguard Worker #include <stdint.h> 9*6777b538SAndroid Build Coastguard Worker 10*6777b538SAndroid Build Coastguard Worker #include <string> 11*6777b538SAndroid Build Coastguard Worker 12*6777b538SAndroid Build Coastguard Worker #include "net/base/net_export.h" 13*6777b538SAndroid Build Coastguard Worker 14*6777b538SAndroid Build Coastguard Worker namespace net { 15*6777b538SAndroid Build Coastguard Worker 16*6777b538SAndroid Build Coastguard Worker // A container class that represents a "range" specified for range request 17*6777b538SAndroid Build Coastguard Worker // specified by RFC 7233 Section 2.1. 18*6777b538SAndroid Build Coastguard Worker // https://tools.ietf.org/html/rfc7233#section-2.1 19*6777b538SAndroid Build Coastguard Worker class NET_EXPORT HttpByteRange { 20*6777b538SAndroid Build Coastguard Worker public: 21*6777b538SAndroid Build Coastguard Worker HttpByteRange(); 22*6777b538SAndroid Build Coastguard Worker 23*6777b538SAndroid Build Coastguard Worker // Convenience constructors. 24*6777b538SAndroid Build Coastguard Worker static HttpByteRange Bounded(int64_t first_byte_position, 25*6777b538SAndroid Build Coastguard Worker int64_t last_byte_position); 26*6777b538SAndroid Build Coastguard Worker static HttpByteRange RightUnbounded(int64_t first_byte_position); 27*6777b538SAndroid Build Coastguard Worker static HttpByteRange Suffix(int64_t suffix_length); 28*6777b538SAndroid Build Coastguard Worker 29*6777b538SAndroid Build Coastguard Worker // Since this class is POD, we use constructor, assignment operator 30*6777b538SAndroid Build Coastguard Worker // and destructor provided by compiler. first_byte_position()31*6777b538SAndroid Build Coastguard Worker int64_t first_byte_position() const { return first_byte_position_; } set_first_byte_position(int64_t value)32*6777b538SAndroid Build Coastguard Worker void set_first_byte_position(int64_t value) { first_byte_position_ = value; } 33*6777b538SAndroid Build Coastguard Worker last_byte_position()34*6777b538SAndroid Build Coastguard Worker int64_t last_byte_position() const { return last_byte_position_; } set_last_byte_position(int64_t value)35*6777b538SAndroid Build Coastguard Worker void set_last_byte_position(int64_t value) { last_byte_position_ = value; } 36*6777b538SAndroid Build Coastguard Worker suffix_length()37*6777b538SAndroid Build Coastguard Worker int64_t suffix_length() const { return suffix_length_; } set_suffix_length(int64_t value)38*6777b538SAndroid Build Coastguard Worker void set_suffix_length(int64_t value) { suffix_length_ = value; } 39*6777b538SAndroid Build Coastguard Worker 40*6777b538SAndroid Build Coastguard Worker // Returns true if this is a suffix byte range. 41*6777b538SAndroid Build Coastguard Worker bool IsSuffixByteRange() const; 42*6777b538SAndroid Build Coastguard Worker // Returns true if the first byte position is specified in this request. 43*6777b538SAndroid Build Coastguard Worker bool HasFirstBytePosition() const; 44*6777b538SAndroid Build Coastguard Worker // Returns true if the last byte position is specified in this request. 45*6777b538SAndroid Build Coastguard Worker bool HasLastBytePosition() const; 46*6777b538SAndroid Build Coastguard Worker 47*6777b538SAndroid Build Coastguard Worker // Returns true if this range is valid. 48*6777b538SAndroid Build Coastguard Worker bool IsValid() const; 49*6777b538SAndroid Build Coastguard Worker 50*6777b538SAndroid Build Coastguard Worker // Gets the header string, e.g. "bytes=0-100", "bytes=100-", "bytes=-100". 51*6777b538SAndroid Build Coastguard Worker // Assumes range is valid. 52*6777b538SAndroid Build Coastguard Worker std::string GetHeaderValue() const; 53*6777b538SAndroid Build Coastguard Worker 54*6777b538SAndroid Build Coastguard Worker // A method that when given the size in bytes of a file, adjust the internal 55*6777b538SAndroid Build Coastguard Worker // |first_byte_position_| and |last_byte_position_| values according to the 56*6777b538SAndroid Build Coastguard Worker // range specified by this object. If the range specified is invalid with 57*6777b538SAndroid Build Coastguard Worker // regard to the size or |size| is negative, returns false and there will be 58*6777b538SAndroid Build Coastguard Worker // no side effect. 59*6777b538SAndroid Build Coastguard Worker // Returns false if this method is called more than once and there will be 60*6777b538SAndroid Build Coastguard Worker // no side effect. 61*6777b538SAndroid Build Coastguard Worker bool ComputeBounds(int64_t size); 62*6777b538SAndroid Build Coastguard Worker 63*6777b538SAndroid Build Coastguard Worker private: 64*6777b538SAndroid Build Coastguard Worker int64_t first_byte_position_; 65*6777b538SAndroid Build Coastguard Worker int64_t last_byte_position_; 66*6777b538SAndroid Build Coastguard Worker int64_t suffix_length_; 67*6777b538SAndroid Build Coastguard Worker bool has_computed_bounds_ = false; 68*6777b538SAndroid Build Coastguard Worker }; 69*6777b538SAndroid Build Coastguard Worker 70*6777b538SAndroid Build Coastguard Worker } // namespace net 71*6777b538SAndroid Build Coastguard Worker 72*6777b538SAndroid Build Coastguard Worker #endif // NET_HTTP_HTTP_BYTE_RANGE_H_ 73