1 stable release
1.0.1 | Oct 30, 2024 |
---|
#850 in Web programming
120KB
2.5K
SLoC
Pinboard API
This library provides an interface to communicate with the Pinboard.in bookmarking service.
The endpoint structures are organized into two parts representing the V1 and V2 versions of the API. Please note that at this time, the V2 API is not live.
This library has synchronous and asychronous clients. The latter is available
with the async
feature.
Installation
Install pinboard-rs via cargo. The default installation includes the
async
feature.
cargo add pinboard-rs
Usage/Examples
This library approaches API interaction in a different way. Each endpoint connection starts with a builder to put together the parameters and data required to query the endpoint.
The client that does the querying is created as a separate object and then passed to the query function of the endpoint.
use pinboard_rs::api::{v1::posts::Recent, Query};
use pinboard_rs::types::v1::PostsRecent;
use pinboard_rs::Pinboard;
fn main() {
/// Set the parameters to be used in the builder
let token = "<TOKEN>";
let x = 5;
let tags = vec!["tags","for","filtering"];
// Build the endpoint with the necessary parameters
let recent_endpoint = Recent::builder()
.count(x)
.tags(&tags)
.build()
.expect("building endpoint");
// Create a client to query the endpoints
let pb = Pinboard::new("api.pinboard.in", token).expect("Pinboard client");
// Query the endpoint and store the results
let recent_posts: PostsRecent = recent_endpoint.query(&pb).unwrap();
// Print out the results (debug view of structure)
println!("Recent posts: {:?}", recent_posts)
}
The data returned through the query of the endoint is derserialized through serde, meaning that the query method can be used with any data structure that can deserialize the returned json.
Additional examples are available to run in the examples directory. Run them with cargo:
cargo run --example recent
Running Tests
This library tests all endpoints and builders extensively. Run the tests with cargo as follows:
cargo test
Acknowledgements
The structure for this library is based heavily on the work of Ben Boeckel and the gitlab crate.
Read Ben's article on Designing Rust bindings for REST APIs.
License
Licensed under MIT or Apache 2.0 at your discretion.
Copyright © 2021-2024, Lunar Studio
Dependencies
~6–18MB
~255K SLoC