1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51
use ::HeaderValue; /// `Content-Location` header, defined in /// [RFC7231](https://tools.ietf.org/html/rfc7231#section-3.1.4.2) /// /// The header can be used by both the client in requests and the server /// in responses with different semantics. Client sets `Content-Location` /// to refer to the URI where original representation of the body was /// obtained. /// /// In responses `Content-Location` represents URI for the representation /// that was content negotiated, created or for the response payload. /// /// # ABNF /// /// ```text /// Content-Location = absolute-URI / partial-URI /// ``` /// /// # Example values /// /// * `/hypertext/Overview.html` /// * `http://www.example.org/hypertext/Overview.html` /// /// # Examples /// //TODO: make this a `Uri`? #[derive(Clone, Debug, PartialEq, Header)] pub struct ContentLocation(HeaderValue); #[cfg(test)] mod tests { use super::*; use super::super::test_decode; #[test] fn absolute_uri() { let s = "http://www.example.net/index.html"; let loc = test_decode::<ContentLocation>(&[s]).unwrap(); assert_eq!(loc, ContentLocation(HeaderValue::from_static(s))); } #[test] fn relative_uri_with_fragment() { let s = "/People.html#tim"; let loc = test_decode::<ContentLocation>(&[s]).unwrap(); assert_eq!(loc, ContentLocation(HeaderValue::from_static(s))); } }