Merge pull request #500 from pyfisch/acceptranges
feat(headers): Add Accept-Ranges header field
This commit is contained in:
71
src/header/common/accept_ranges.rs
Normal file
71
src/header/common/accept_ranges.rs
Normal file
@@ -0,0 +1,71 @@
|
|||||||
|
use std::fmt::{self, Display};
|
||||||
|
use std::str::FromStr;
|
||||||
|
|
||||||
|
header! {
|
||||||
|
#[doc="`Accept-Ranges` header, defined in"]
|
||||||
|
#[doc="[RFC7233](http://tools.ietf.org/html/rfc7233#section-2.3)"]
|
||||||
|
#[doc=""]
|
||||||
|
#[doc="The `Accept-Ranges` header field allows a server to indicate that it"]
|
||||||
|
#[doc="supports range requests for the target resource."]
|
||||||
|
#[doc=""]
|
||||||
|
#[doc="# ABNF"]
|
||||||
|
#[doc="```plain"]
|
||||||
|
#[doc="Accept-Ranges = acceptable-ranges"]
|
||||||
|
#[doc="acceptable-ranges = 1#range-unit / \"none\""]
|
||||||
|
#[doc=""]
|
||||||
|
#[doc="# Example values"]
|
||||||
|
#[doc="* `bytes`"]
|
||||||
|
#[doc="* `none`"]
|
||||||
|
#[doc="```"]
|
||||||
|
(AcceptRanges, "Accept-Ranges") => (RangeUnit)+
|
||||||
|
|
||||||
|
test_acccept_ranges {
|
||||||
|
test_header!(test1, vec![b"bytes"]);
|
||||||
|
test_header!(test2, vec![b"none"]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Range Units, described in [RFC7233](http://tools.ietf.org/html/rfc7233#section-2)
|
||||||
|
///
|
||||||
|
/// A representation can be partitioned into subranges according to
|
||||||
|
/// various structural units, depending on the structure inherent in the
|
||||||
|
/// representation's media type.
|
||||||
|
///
|
||||||
|
/// # ABNF
|
||||||
|
/// ```plain
|
||||||
|
/// range-unit = bytes-unit / other-range-unit
|
||||||
|
/// bytes-unit = "bytes"
|
||||||
|
/// other-range-unit = token
|
||||||
|
/// ```
|
||||||
|
#[derive(Clone, Debug, Eq, PartialEq)]
|
||||||
|
pub enum RangeUnit {
|
||||||
|
/// Indicating byte-range requests are supported.
|
||||||
|
Bytes,
|
||||||
|
/// Reserved as keyword, indicating no ranges are supported.
|
||||||
|
None,
|
||||||
|
/// The given range unit is not registered at IANA.
|
||||||
|
Unregistered(String),
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
impl FromStr for RangeUnit {
|
||||||
|
type Err = ();
|
||||||
|
fn from_str(s: &str) -> Result<Self, ()> {
|
||||||
|
match s {
|
||||||
|
"bytes" => Ok(RangeUnit::Bytes),
|
||||||
|
"none" => Ok(RangeUnit::None),
|
||||||
|
// FIXME: Check if s is really a Token
|
||||||
|
_ => Ok(RangeUnit::Unregistered(s.to_string())),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl Display for RangeUnit {
|
||||||
|
fn fmt(&self, f: &mut fmt::Formatter) -> fmt::Result {
|
||||||
|
match *self {
|
||||||
|
RangeUnit::Bytes => f.write_str("bytes"),
|
||||||
|
RangeUnit::None => f.write_str("none"),
|
||||||
|
RangeUnit::Unregistered(ref x) => f.write_str(&x),
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -16,6 +16,7 @@ pub use self::access_control_request_method::AccessControlRequestMethod;
|
|||||||
pub use self::accept_charset::AcceptCharset;
|
pub use self::accept_charset::AcceptCharset;
|
||||||
pub use self::accept_encoding::AcceptEncoding;
|
pub use self::accept_encoding::AcceptEncoding;
|
||||||
pub use self::accept_language::AcceptLanguage;
|
pub use self::accept_language::AcceptLanguage;
|
||||||
|
pub use self::accept_ranges::AcceptRanges;
|
||||||
pub use self::allow::Allow;
|
pub use self::allow::Allow;
|
||||||
pub use self::authorization::{Authorization, Scheme, Basic};
|
pub use self::authorization::{Authorization, Scheme, Basic};
|
||||||
pub use self::cache_control::{CacheControl, CacheDirective};
|
pub use self::cache_control::{CacheControl, CacheDirective};
|
||||||
@@ -315,6 +316,7 @@ mod access_control_request_method;
|
|||||||
mod accept_charset;
|
mod accept_charset;
|
||||||
mod accept_encoding;
|
mod accept_encoding;
|
||||||
mod accept_language;
|
mod accept_language;
|
||||||
|
mod accept_ranges;
|
||||||
mod allow;
|
mod allow;
|
||||||
mod authorization;
|
mod authorization;
|
||||||
mod cache_control;
|
mod cache_control;
|
||||||
|
|||||||
Reference in New Issue
Block a user