Crates.io | segment |
lib.rs | segment |
version | |
source | src |
created_at | 2021-09-30 17:35:32.840308+00 |
updated_at | 2025-03-05 12:42:40.824067+00 |
description | Segment analytics client for Rust. Forked for Meilisearch: https://github.com/meilisearch |
homepage | |
repository | https://github.com/irevoire/segment |
max_upload_size | |
id | 458801 |
Cargo.toml error: | TOML parse error at line 22, column 1 | 22 | autolib = false | ^^^^^^^ unknown field `autolib`, expected one of `name`, `version`, `edition`, `authors`, `description`, `readme`, `license`, `repository`, `homepage`, `documentation`, `build`, `resolver`, `links`, `default-run`, `default_dash_run`, `rust-version`, `rust_dash_version`, `rust_version`, `license-file`, `license_dash_file`, `license_file`, `licenseFile`, `license_capital_file`, `forced-target`, `forced_dash_target`, `autobins`, `autotests`, `autoexamples`, `autobenches`, `publish`, `metadata`, `keywords`, `categories`, `exclude`, `include` |
size | 0 |
This crate is an unofficial segment analytics client for Rust used by Meilisearch
use segment::{HttpClient, Client, AutoBatcher, Batcher};
use segment::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 segment::{HttpClient, Client};
use segment::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 Segment");
}