AWS Event Stream Parser

Rust implementation of the vnd.amazon.event-stream-binary format

Implementation is based on following: - https://docs.aws.amazon.com/AmazonS3/latest/API/RESTObjectSELECTContent.html#RESTObjectSELECTContent-responses - https://github.com/awslabs/aws-c-event-stream - https://github.com/aws/aws-sdk-ruby/ - https://github.com/lifion/lifion-aws-event-stream

Installation

Add this to your Cargo.toml:

toml [dependencies] aws_event_stream_parser = "0.0.5"

Usage

Plain parser

```rust extern crate awseventstream_parser;

use awseventstreamparser::parsemessage; let res = parse_message(&hex!("0000003d0000002007fd83960c636f6e74656e742d747970650700106170706c69636174696f6e2f6a736f6e7b27666f6f273a27626172277d8d9c08b1")).unwrap();

println!("{:?}", res); /* ([], Message { prelude: PreludeBlock { totallength: 61, - headerslength: 32, checksum: 134054806 }, headers: HeaderBlock { headers: [ Header { key: "content-type", value: String("application/json") } ] }, body: [123, 39, 102, 111, 111, 39, 58, 39, 98, 97, 114, 39, 125], checksum: 2375813297 }) */ println!("{:?}", res.1.valid()); // true

```

Framed codec

(more information from https://tokio.rs/docs/going-deeper/frames/ )

```rust use awseventstream_parser::EventStreamCodec;

TcpStream::connect(&addr).andthen(|sock| { let framedsock = Framed::new(sock, EventStreamCodec::new()); framedsock.foreach(|line| { println!("Received line {}", line); Ok(()) }) }); ```

Specification

This parser has been modeled based on AWS documentation and other protocol implementations. We have also documented the format for future implementations.

block diagram

Header diagrams

bool and byte header diagram bytes and string header diagram integer header diagram int64 and timestamp header diagram UUID header diagram

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

License

MIT