3 releases
0.1.2 | Jun 7, 2024 |
---|---|
0.1.1 | Jun 5, 2024 |
0.1.0 | Dec 20, 2023 |
#473 in Web programming
32 downloads per month
72KB
973 lines
Rust GBFS Language Bindings
Rust types for parsing and working with General Bikeshare Feed Specification (GBFS) data, ensuring type safety and code consistency in Rust projects.
Most fields required by the GBFS specification are marked as Option
in this crate, as they may not always present in the data provided by the GBFS feeds.
Some helper functions are provided to fetch the data from the GBFS feeds.
Installation
To use gbfs_types
in your own project, you need to install the dependencies
cargo add gbfs_types
Versions
Currently only version 3.0 of GBFS is supported
Example Code (Types)
use reqwest::Error;
use tokio;
use gbfs_types::v3_0::files::SystemInformationFile;
#[tokio::main]
async fn main() -> Result<(), Error> {
let gbfs_url = "https://example-gbfs-feed/gbfs/3.0/system-information";
let client = reqwest::Client::new();
let response = client.get(url).header("User-Agent", "rust-reqwest").send().await?;
if response.status().is_success() {
let system_information: SystemInformationFile = response.json().await?;
println!("systemInformation version: {}", system_information.version);
println!("systemInformation data: {}", system_information.data.system_id);
}
Ok(())
}
Example Code (Helper Functions)
use gbfs_types::v3_0::files::gbfs::GbfsDataFeeds;
use gbfs_types::v3_0::files::{GbfsData, SystemInformationFile};
use reqwest::Error;
use tokio;
use gbfs_types::v3_0::urls::SystemInformationFileUrl;
use gbfs_types::v3_0::GbfsObjects;
#[tokio::main]
async fn main() -> Result<(), Error> {
let gbfs_data: GbfsData = GbfsData {
feeds: vec![
GbfsDataFeeds {
name: "system_information".to_string(),
url: "https://example-gbfs-feed/gbfs/3.0/system-information".to_string(),
},
// ... all other feeds
GbfsDataFeeds{
name: "gbfs_versions".to_string(),
url: "https://example-gbfs-feed/gbfs/3.0/versions".to_string()
}
],
};
let system_information = gbfs_data.get_system_information().await;
match system_information {
Ok(Some(info)) => {
// Successfully retrieved SystemInformationFile
println!("System Information: {:?}", info.data.email);
}
Ok(None) => {
// SystemInformationFile was not present
println!("No system information available.");
}
Err(e) => {
// Handle the error
eprintln!("Error retrieving system information: {}", e);
}
}
Ok(())
}
Contributions
We extend our gratitude to Fluctuo for generously providing us with this repository. Their support and contribution have been instrumental in advancing our project and fostering collaboration within the community. Thank you, Fluctuo, for your dedication to open source and for empowering developers worldwide.
Dependencies
~11–23MB
~377K SLoC