# langfuse-client-base
[](https://crates.io/crates/langfuse-client-base)
[](https://docs.rs/langfuse-client-base)
[](https://github.com/genai-rs/langfuse-client-base/actions)
[](https://releases.rs/docs/1.82.0/)
[](./LICENSE-MIT)
Auto-generated Rust client for the [Langfuse](https://langfuse.com) API, based on the official OpenAPI specification.
## ⚠️ Note
This is a low-level, auto-generated client. For a more ergonomic API, use [langfuse-ergonomic](https://github.com/genai-rs/langfuse-ergonomic).
## Features
- Complete API coverage from OpenAPI specification
- Async/await support with Tokio
- Choice of TLS backend (rustls or native-tls)
- Strong typing with serde
## Installation
```toml
[dependencies]
langfuse-client-base = "0.1"
```
## Usage
This crate provides low-level API bindings. Most users should use the ergonomic wrapper instead.
### Basic Configuration
```rust
use langfuse_client_base::apis::configuration::Configuration;
use langfuse_client_base::apis::ingestion_api;
let config = Configuration {
base_path: "https://cloud.langfuse.com".to_string(),
basic_auth: Some(("your-public-key".to_string(), Some("your-secret-key".to_string()))),
..Default::default()
};
// Use the API...
```
### Using Environment Variables
```rust
use std::env;
use langfuse_client_base::apis::configuration::Configuration;
let config = Configuration {
base_path: env::var("LANGFUSE_HOST").unwrap_or_else(|_| "https://cloud.langfuse.com".to_string()),
basic_auth: Some((
env::var("LANGFUSE_PUBLIC_KEY").expect("LANGFUSE_PUBLIC_KEY not set"),
Some(env::var("LANGFUSE_SECRET_KEY").expect("LANGFUSE_SECRET_KEY not set"))
)),
..Default::default()
};
```
### Self-Hosted Instances
For self-hosted Langfuse instances:
```rust
let config = Configuration {
base_path: "https://your-domain.com/langfuse".to_string(), // Custom base path
basic_auth: Some(("your-public-key".to_string(), Some("your-secret-key".to_string()))),
..Default::default()
};
```
## Generation
This client is generated from the OpenAPI specification:
```bash
./scripts/generate-openapi-client.sh
```
## License
Licensed under either of:
- Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE))
- MIT license ([LICENSE-MIT](LICENSE-MIT))
## Contributing
This is auto-generated code. To make changes, please update the generation process or contribute to the [main repository](https://github.com/genai-rs/langfuse-ergonomic).