0xA537FD / hyper-json-stream

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Hyper JSON Stream

Deserialize an array of jsons asynchronously with hyper

The code in this library comes from the backblaze-b2-rs repo.

This library allows you to consume a hyper_util::client::legacy::ResponseFuture asynchronously while deserializing each element from a json array along the way.

The deserializing itself is done by the serde_json crate and is therefore not asynchronous.

This library allows you to process the elements of a big json without having to take everything into memory first and without blocking the entire thread.

Usage

Add the following dependencies to your Cargo.toml:

hyper = "1.2.0"
hyper-rustls = "0.26.0"
serde = { version = "1.0.197", features = ["derive"] }
futures-util = "0.3.30"

Create a stream you can iterate on:

let hyper_response_future = make_http_request();
let level = 1;
let capacity = 100;
let stream: JsonStream<T> = JsonStream::new(hyper_response_future, level, capacity);

The capacity sets the initial size of the buffer that will handle the response.

The level sets the number of braces ([ or {) to skip before reaching the elements you wish to deserialize.

To deserialize the "Shop" struct in the next example use level = 2

{
  "shops": [
    {
      "shop_id": 2322,
      "shop_name": "Shop1",
      "shop_state": "OPEN",
    },
    {
      "shop_id": 2422,
      "shop_name": "Shop2",
      "shop_state": "OPEN",
    },
    {
      "shop_id": 2021,
      "shop_name": "Shop3",
      "shop_state": "OPEN",
    },
    {
      "shop_id": 2022,
      "shop_name": "Shop4",
      "shop_state": "OPEN",
    },
  ]
}

Example

Check out Countries for a working example. The example uses the http2 feature of the hyper-rustls crate.

About


Languages

Language:Rust 100.0%