A high-level library for consuming RESTful APIs.
Add this to your Cargo.toml
:
toml
[dependencies]
roy = "0.1"
To use any of the methods on the roy::Client
struct, it has to be instantiated as follows:
rust
// import into scope
use roy::Client;
// Instantiate `Client` with your API's base URL
let c = roy::Client::new("https://httpbin.org".to_string());
All of the examples below assume that the struct has already been instantiated.
rust
c.get("/get", false); // Make a GET request to your endpoint
rust
c.post("/post", "{some: data}"); // Make a POST request to your endpoint
rust
c.patch("/patch", "{some: data}"); // Make a PATCH request to your endpoint
rust
c.put("/put", "{some: data}"); // Make a PUT request to your endpoint
rust
c.delete("/delete"); // Make a DELETE request to your endpoint
Roy is distributed under the terms of both the MIT license and the Apache License (Version 2.0).
See LICENSE-APACHE and LICENSE-MIT, and COPYRIGHT for details.
This crate is named after Roy Fielding, who defined Representational State Transfer. According to Wikipedia:
Roy Fielding defined REST in his 2000 PhD dissertation "Architectural Styles and the Design of Network-based Software Architectures" at UC Irvine. He developed the REST architectural style in parallel with HTTP 1.1 of 1996–1999, based on the existing design of HTTP 1.0 of 1996.