Crates.io | elastictea |
lib.rs | elastictea |
version | 2.0.0 |
source | src |
created_at | 2019-08-05 23:31:38.879325 |
updated_at | 2020-01-11 03:44:33.814436 |
description | An Ingredient crate for working with Elasticsearch in rettle. |
homepage | |
repository | https://github.com/slaterb1/elastictea |
max_upload_size | |
id | 154419 |
size | 125,833 |
Generic Fill Pour Ingredient crate for the rettle
ETL.
#[derive(Serialize, Deserialize, Debug)]
struct ElasticTea {
name: Option<String>,
avg: Option<f32>,
}
impl Tea for ElasticTea {
fn as_any(&self) -> &dyn Any {
self
}
}
fn main() {
let es_client = Arc::new(EsClient::new("http://localhost:9200"));
let test_fill_esarg = FillEsArg::new(
"test-index1",
"_doc",
200,
json!({
"match_all": {}
}),
Arc::clone(&es_client),
);
let test_pour_esarg = PourEsArg::new(
"test-pour-index2",
"_doc",
Arc::clone(&es_client),
);
let brewery = Brewery::new(4, Instant::now());
let mut new_pot = Pot::new();
let fill_elastictea = FillEsTea::new::<ElasticTea>("elastic_tea_test", "test_index", test_fill_esarg);
let pour_elastictea = PourEsTea::new::<ElasticTea>("pour_elastic", test_pour_esarg);
new_pot = new_pot.add_source(fill_elastictea);
// Steep operations of choice
new_pot = new_pot.add_ingredient(pour_elastictea);
new_pot.brew(&brewery);
}