22 releases (12 stable)
2.0.5 | Dec 27, 2024 |
---|---|
1.2.0 | Dec 26, 2024 |
0.8.0 | Dec 25, 2024 |
#118 in Database interfaces
1,879 downloads per month
110KB
2K
SLoC
Baserow-rs
Baserow-rs is a Rust client for the Baserow API. It provides a comprehensive set of features for interacting with Baserow tables, including CRUD operations and file management.
Authentication
Baserow supports two authentication methods:
- API Key (for server-to-server communication)
- JWT Token (for client-to-server communication)
Note: Some endpoints require a JWT token, some require an API key, and some require both.
Authentication (API Key)
let configuration = ConfigBuilder::new()
.base_url(endpoint.as_str())
.api_key(api_key.as_str())
.build();
let baserow = Baserow::with_configuration(configuration);
Authentication (JWT Token)
let configuration = ConfigBuilder::new()
.base_url(endpoint.as_str())
.email("test@example.com")
.password("password")
.build();
let baserow = Baserow::with_configuration(configuration);
baserow.token_auth().await?;
Table Operations
Retrieve Table Rows
let baserow = Baserow::with_configuration(configuration);
// retrieve rows from a table
let rows = baserow
.table_by_id(176)
.rows()
.filter_by("field_1529", Filter::Equal, "testaaaaaaaaaa")
.order_by("field_1529", OrderDirection::Asc)
.get()
.await?;
Create a Row
let mut record: HashMap<String, Value> = HashMap::new();
record.insert("field_1529".to_string(), Value::String("test".to_string()));
let row = baserow.table_by_id(176).create_one(record).await?;
Update a Row
let mut record: HashMap<String, Value> = HashMap::new();
record.insert("field_1529".to_string(), Value::String("updated".to_string()));
let updated_row = baserow.table_by_id(176).update(row_id, record).await?;
Get Table Fields
let fields = baserow.table_fields(table_id).await?;
Map Rows to Structs
You can map table rows directly to your own structs using serde's Deserialize:
use serde::Deserialize;
use baserow_rs::{OrderDirection, filter::Filter};
#[derive(Debug, Deserialize)]
struct User {
id: u64,
name: String,
email: String,
age: Option<i32>,
}
// First auto_map the table to ensure field mappings are available
let table = baserow.table_by_id(1234).auto_map().await?;
// Get a single row and deserialize it into your struct
let user: User = table.clone().get_one_typed::<User>(1).await?;
println!("Found user: {:?}", user);
// Query multiple rows with filtering, sorting, and pagination
let response = table.clone()
.rows()
.page_size(10) // Get 10 rows per page
.filter_by("age", Filter::HigherThan, "18") // Only users over 18
.order_by("name", OrderDirection::Asc) // Sort by name
.get_typed::<User>()
.await?;
println!("Found {} total users", response.count);
for user in response.results {
println!("User: {:?}", user);
}
The field names in your struct should match the column names in your Baserow table. Use Option<T>
for nullable fields. Remember to clone the table when using it multiple times, as operations consume the table instance.
File Operations
Upload a File
let file = File::open("path/to/file").unwrap();
let result = baserow.upload_file(file, "filename.png".to_string()).await?;
Upload a File via URL
let result = baserow.upload_file_via_url("https://example.com/image.png").await?;
Tracing Support
This library is instrumented with the tracing
crate to provide detailed insights into API operations. All key operations emit spans and events that can help you understand and debug your application's interaction with Baserow.
Instrumented Operations
The following operations are instrumented with tracing:
- HTTP requests and responses
- Table operations (create, read, update, delete)
- Authentication flows
- Error paths with detailed context
- Field mapping operations
Using Tracing in Your Application
The library provides tracing instrumentation but does not configure any subscribers. This follows the best practice of letting applications control their logging configuration. To capture the tracing data in your application, configure a subscriber of your choice:
// Example using tracing-subscriber (add it to your application's dependencies)
use tracing_subscriber::{fmt, EnvFilter};
// Configure subscriber in your application's main function
tracing_subscriber::fmt()
.with_env_filter(EnvFilter::from_default_env())
.init();
See the tracing example for a complete demonstration of using tracing with this library.
License
Apache 2.0
Dependencies
~7–19MB
~242K SLoC