#analytics #message #client #user #batcher #june

june-analytics

June analytics client for Rust

6 releases

0.2.2 Aug 26, 2023
0.2.1 Aug 26, 2023
0.1.0 Aug 24, 2023
0.0.2 Aug 24, 2023

#216 in HTTP client

Download history 115/week @ 2024-03-11 86/week @ 2024-03-18 21/week @ 2024-03-25 85/week @ 2024-04-01 71/week @ 2024-04-08 67/week @ 2024-04-15 61/week @ 2024-04-22 100/week @ 2024-04-29 77/week @ 2024-05-06 30/week @ 2024-05-13 33/week @ 2024-05-20 23/week @ 2024-05-27 29/week @ 2024-06-03 22/week @ 2024-06-10 44/week @ 2024-06-17 47/week @ 2024-06-24

142 downloads per month

MIT license

32KB
592 lines

June Analytics Rust   Latest Version

Analytics Rust is a June analytics client for Rust.


[dependencies]
june-analytics = "0.2"

Example usage(s)

use june_analytics::{HttpClient, Client, AutoBatcher, Batcher};
use june_analytics::message::{Track, User};
use serde_json::json;

#[tokio::main(flavor = "current_thread")]
async fn main() {
    let write_key = "YOUR_WRITE_KEY";

    let client = HttpClient::default();
    let batcher = Batcher::new(None);
    let mut batcher = AutoBatcher::new(client, batcher, write_key.to_string());

    // Pretend this is reading off of a queue, a file, or some other data
    // source.
    for i in 0..100 {
        let msg = Track {
            user: User::UserId { user_id: format!("user-{}", i) },
            event: "Example Event".to_owned(),
            properties: json!({
                "foo": format!("bar-{}", i),
            }),
            ..Default::default()
        };

        // An error here indicates a message is too large. In real life, you
        // would probably want to put this message in a deadletter queue or some
        // equivalent.
        batcher.push(msg).await.unwrap();
    }

    batcher.flush().await.unwrap();
}

or when you want to do struct to struct transformations

use june_analytics::{HttpClient, Client};
use june_analytics::message::{Track, Message, User};
use serde_json::json;

#[tokio::main(flavor = "current_thread")]
async fn main() {
    let write_key = "YOUR_WRITE_KEY";

    let client = HttpClient::default();
    client.send(write_key.to_string(), Message::from(Track {
        user: User::UserId { user_id: "some_user_id".to_owned() },
        event: "Example Event".to_owned(),
        properties: json!({
            "some property": "some value",
            "some other property": "some other value",
        }),
        ..Default::default()
    })).await.expect("could not send to June");
}

License

Licensed under MIT license.

Dependencies

~4–19MB
~300K SLoC