From e1542a609f99da770a65500333d922c58e39d179 Mon Sep 17 00:00:00 2001 From: Michael Date: Thu, 14 Jul 2016 21:47:27 -0400 Subject: [PATCH] feat(headers): add last-event-id header Add a Last-Event-ID header to properly work with Server-Sent Events Addresses # 723 --- src/header/common/last-event-id.rs | 30 ++++++++++++++++++++++++++++++ 1 file changed, 30 insertions(+) create mode 100644 src/header/common/last-event-id.rs diff --git a/src/header/common/last-event-id.rs b/src/header/common/last-event-id.rs new file mode 100644 index 0000000000..2c82d36342 --- /dev/null +++ b/src/header/common/last-event-id.rs @@ -0,0 +1,30 @@ +header! { + /// `Last-Event-ID` header, defined in + /// [RFC3864](https://html.spec.whatwg.org/multipage/references.html#refsRFC3864) + /// + /// The `Last-Event-ID` header contains information about + /// the last event in an http interaction so that it's easier to + /// track of event state. This is helpful when working + /// with [Server-Sent-Events](http://www.html5rocks.com/en/tutorials/eventsource/basics/). If the connection were to be dropped, for example, it'd + /// be useful to let the server know what the last event you + /// recieved was. + /// + /// The spec is a String with the id of the last event, it can be + /// an empty string which acts a sort of "reset". + /// + /// # Example + /// ``` + /// use hyper::header::{Headers, LastEventID}; + /// + /// let mut headers = Headers::new(); + /// headers.set(LastEventID("1".to_owned())); + /// ``` + (LastEventID, "Last-Event-ID") => [String] + + test_last_event_id { + // Initial state + test_header!(test1, vec![b""]); + // Own testcase + test_header!(test2, vec![b"1"], Some(LastEventID("1".to_owned()))); + } +}