eppo

Crates.ioeppo
lib.rseppo
version4.0.1
sourcesrc
created_at2024-05-14 17:52:16.071473
updated_at2024-10-16 18:56:38.420939
descriptionEppo SDK for Rust
homepagehttps://docs.geteppo.com/sdks/server-sdks/rust
repositoryhttps://github.com/Eppo-exp/rust-sdk
max_upload_size
id1239879
size81,945
Leo Romanovsky (leoromanovsky)

documentation

README

Eppo Rust SDK

Crates.io Version Crates.io MSRV docs.rs

Eppo is a modular flagging and experimentation analysis tool. Eppo's Rust SDK is designed to facilitate assignments in multi-user server-side contexts. You will need an Eppo account before proceeding.

Refer to SDK documentation for how to install and use the SDK.

Features

  • Feature gates
  • Kill switches
  • Progressive rollouts
  • A/B/n experiments
  • Mutually exclusive experiments (Layers)
  • Dynamic configuration

Installation

Add it with cargo:

cargo add eppo

Or add it to Cargo.toml manually:

[dependencies]
eppo = "0.1.0"

Quick Start

Initialize an instance of Eppo's client. Once initialized, the client can be used to make assignments in your app.

Initialize Client

use eppo::ClientConfig;

let mut client = ClientConfig::from_api_key("api-key").to_client();
client.start_poller_thread();

Assign Anywhere

let user = get_current_user();

let assignment = client.get_assignment(
    "show-new-feature",
    &user.id,
    &user.attributes,
);

Assignment Logger

Pass a logging callback function to the assignment_logger method in ClientConfig when initializing the SDK to capture assignment data for analysis.

struct MyAssignmentLogger;

impl AssignmentLogger for MyAssignmentLogger {
    fn log_assignment(&self, event: AssignmentEvent) {
        // Implement assignment logging logic here
    }
}
Commit count: 96

cargo fmt