| Crates.io | data-gov-ckan |
| lib.rs | data-gov-ckan |
| version | 0.3.1 |
| created_at | 2025-09-25 14:12:53.445632+00 |
| updated_at | 2025-10-25 05:53:55.036933+00 |
| description | Client for Data.Gov CKAN |
| homepage | https://github.com/dspadea/data-gov-rs |
| repository | https://github.com/dspadea/data-gov-rs |
| max_upload_size | |
| id | 1854676 |
| size | 200,904 |
Async Rust client for CKAN APIs with first-class support for data.gov. It provides typed models, ergonomic helpers, and works with any CKAN-compatible portal.
Note: The client targets data.gov and its public API first. The code should work with other CKAN deployments that follow the same API surface, but those combinations have not been officially tested.
rustup toolchain install stable
rustup default stable
Use the published crate from crates.io:
[dependencies]
data-gov-ckan = "0.2.0"
tokio = { version = "1", features = ["full"] }
Working inside this repository? Point to the local path instead: data-gov-ckan = { path = "../data-gov-ckan" }. If you need the bleeding edge between releases, swap in the git dependency form: data-gov-ckan = { git = "https://github.com/dspadea/data-gov-rs", package = "data-gov-ckan" }.
action/* endpoints used by data.govreqwest + tokiouse data_gov_ckan::{CkanClient, Configuration};
use std::sync::Arc;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let client = CkanClient::new(Arc::new(Configuration::default()));
let results = client.package_search(Some("climate"), Some(10), Some(0), None).await?;
println!("Found {} datasets", results.count.unwrap_or(0));
if let Some(datasets) = results.results {
for dataset in datasets.iter().take(3) {
let title = dataset.title.as_deref().unwrap_or(&dataset.name);
println!("โข {title}");
}
}
Ok(())
}
use data_gov_ckan::{ApiKey, CkanClient, Configuration};
use std::sync::Arc;
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error>> {
let config = Configuration {
base_path: "https://demo.ckan.org/api/3".to_string(),
api_key: Some(ApiKey {
prefix: None,
key: "your-api-key".to_string(),
}),
..Configuration::default()
};
let client = CkanClient::new(Arc::new(config));
let dataset = client.package_show("example-dataset").await?;
println!("Dataset: {}", dataset.title.as_deref().unwrap_or(&dataset.name));
Ok(())
}
Filtering with Solr-style query strings:
let fq = r#"organization:"gsa-gov" AND res_format:"CSV""#;
let results = client.package_search(Some("budget"), Some(20), Some(0), Some(fq)).await?;
The q (full-text) and fq (filter query) parameters are passed directly to
CKAN's Solr-backed package_search endpoint. Typical patterns:
q=climat*q="air quality"fq=organization:epa-gov AND res_format:CSVfq=metadata_modified:[2020-01-01T00:00:00Z TO NOW]Use fq for structured filtering and q for free-text searches. When building
fq strings programmatically, quote values containing spaces to ensure correct
Solr parsing.
Core methods include package_search, package_show, organization_list, group_list, tag_list, and user_list. Autocomplete helpers cover datasets, organisations, groups, tags, and users. Errors are surfaced through the CkanError enum with variants for request, parse, and API failures.
git clone https://github.com/dspadea/data-gov-rs.git
cd data-gov-rs/data-gov-ckan
cargo build
cargo test # includes integration tests hitting data.gov
cargo run --example debug_search
cargo run --example raw_response
Integration tests require network access. Use cargo test -- --ignored to skip or select them as needed.
Configuration.api_key = Some(ApiKey { .. })Configuration.basic_authreqwest::Client before passing the configuration into CkanClientReuse the same CkanClient for multiple requests to benefit from connection pooling. Combine async calls with tokio::try_join! for improved throughput.
This is an independent project and is not affiliated with data.gov or any government agency. For authoritative information, refer to the official data.gov portal.
Licensed under the Apache License 2.0.