Skip to content

Commit

Permalink
Start sending scaphandre data to ES
Browse files Browse the repository at this point in the history
  • Loading branch information
papey committed Nov 26, 2022
1 parent a4fe763 commit ec80dfe
Showing 1 changed file with 41 additions and 18 deletions.
59 changes: 41 additions & 18 deletions src/exporters/elastic.rs
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,9 @@
//! `ElasticExporter` implementation, exposes metrics to
//! an [ElasticSearch](https://www.elastic.co/fr/elasticsearch/) server.
use crate::exporters::Exporter;
use super::get_scaphandre_version;
use crate::sensors::Sensor;
use crate::{exporters::Exporter, sensors::Topology};
use clap::{Arg, ArgMatches};
use elasticsearch::{
auth::Credentials,
Expand All @@ -13,7 +14,10 @@ use elasticsearch::{
};
use hyper::StatusCode;
use serde::{Deserialize, Serialize};
use std::thread;
use std::time::Duration;
use url::Url;
use uuid::Uuid;

/// Default url for Elastic endpoint
const DEFAULT_HOST: &str = "localhost";
Expand All @@ -24,9 +28,7 @@ const DEFAULT_SCHEME: &str = "http";

/// Exporter that pushes metrics to an ElasticSearch endpoint
pub struct ElasticExporter {
/// Sensor instance that is used to generate the Topology and
/// thus get power consumption metrics.
_sensor: Box<dyn Sensor>,
topology: Topology,
}

impl Exporter for ElasticExporter {
Expand Down Expand Up @@ -118,30 +120,51 @@ const ES_INDEX_NAME: &str = "scaphandre";

#[derive(Debug, Serialize, Deserialize, PartialEq)]
pub struct ScaphandreData {
pub wip: i32,
pub scaphandre_version: String,
}

impl ElasticExporter {
/// Instantiates and returns a new ElasticExporter
// TODO: make sensor mutable
pub fn new(sensor: Box<dyn Sensor>) -> ElasticExporter {
ElasticExporter { _sensor: sensor }
pub fn new(mut sensor: Box<dyn Sensor>) -> ElasticExporter {
ElasticExporter {
topology: sensor
.get_topology()
.expect("Could'nt generate the Topology."),
}
}

#[tokio::main]
pub async fn runner(&self, client: Elasticsearch) -> Result<(), Error> {
pub async fn runner(&mut self, client: Elasticsearch) -> Result<(), Error> {
self.ensure_index(&client).await?;

// WIP
let create_test_resp = client
.create(CreateParts::IndexId(ES_INDEX_NAME, "42"))
.body(ScaphandreData { wip: 42 })
.send()
.await?;

println!("create test resp {}", create_test_resp.status_code());

Ok(())
loop {
self.topology.refresh();

match client
.create(CreateParts::IndexId(
ES_INDEX_NAME,
// Looks like rust ES Library do not support autogenerated ids
// for both insert and bulk insert
// https://github.com/elastic/elasticsearch-rs/issues/174
// forced to create an ID on our side
&Uuid::new_v4().to_string(),
))
.body(ScaphandreData {
scaphandre_version: get_scaphandre_version(),
})
.send()
.await
{
Ok(resp) => println!("create test resp {}", resp.status_code()),
Err(e) => println!("Error: {}", e),
}

println!("loop tick");

// TODO @papey: add custom duration
thread::sleep(Duration::new(2, 0));
}
}

async fn ensure_index(&self, client: &Elasticsearch) -> Result<(), Error> {
Expand Down

0 comments on commit ec80dfe

Please sign in to comment.