elastic_responses
A crate to handle parsing and handling Elasticsearch search results which provides convenient iterators to step through the results returned.
Cargo.toml
[dependencies]
elastic_reqwest = "*"
elastic_responses = "*"
Query your Elasticsearch Cluster, then iterate through the results:
``rust
// Send a request (omitted, see
samples/basic`, and read the response.
let mut res = client.elasticreq(¶ms, SearchRequest::forindex("_all", body)).unwrap();
// Parse body to JSON
let response = parse::
// Use hits() or aggs() iterators // Hits for hit in response.hits() { println!("{:?}", hit); }
// Agregations for agg in response.aggs() { println!("{:?}", agg); } ```
Bulk response operations are split by whether they succeeded or failed:
``rust
// Send a request (omitted, see
samples/bulk`, and read the response.
let mut res = client.elastic_req(¶ms, BulkRequest::new(body)).unwrap();
// Parse body to JSON
let response = parse::
for op in response.into_iter() { match op { Ok(ok) => { // Do something with successful operations println!("ok: {:?}", op); }, Err(err) => { // Do something with failed operations println!("{:?}", op); } } } ```