FeignHttp is a declarative HTTP client. Based on rust macros.
FeignHttp mark macros on asynchronous functions, you need a runtime for support async/await. You can use async-std or tokio.
async-std:
toml
[dependencies]
async-std = { version = "1", features = ["attributes", "tokio1"] }
The feature tokio1
is need when use reqwest as the HTTP backend.
tokio:
toml
[dependencies]
tokio = { version = "1", features = ["full"] }
Add feignhttp in your Cargo.toml
and use default feature:
toml
feignhttp = { version = "0.3" }
Then add the following code:
```rust use feignhttp::get;
async fn github() -> feignhttp::Result
async fn main() -> Result<(), Box
Ok(())
} ```
The get
attribute macro specifies get request, feignhttp::Result<String>
specifies the return result.
It will send get request to https://api.github.com
and receive a plain text body.
Using non-default HTTP backend:
toml
feignhttp = { version = "0.3", default-features = false, features = ["isahc-client"] }
The default-features = false
option disable default reqwest.
Serde is a framework for serializing and deserializing Rust data structures. When use json, you should add serde in Cargo.toml
:
toml
[dependencies]
serde = { version = "1", features = ["derive"] }
Here is an example of getting json:
```rust use feignhttp::get; use serde::Deserialize;
// Deserialize: Specifies deserialization
struct IssueItem {
pub id: u32,
pub number: u32,
pub title: String,
pub url: String,
pub repository_url: String,
pub state: String,
pub body: Option
const GITHUB_URL: &str = "https://api.github.com";
async fn issues(
#[path] owner: &str,
#[path] repo: &str,
page: u32,
per_page: u32,
) -> feignhttp::Result
async fn main() -> Result<(), Box
Ok(())
} ```
This issues function return Vec<IssueItem>
, it is deserialized according to the content of the response.
Send a json request:
```rust use feignhttp::post; use serde::Serialize;
struct User { id: i32, name: String, }
async fn post_user(#[body] user: User) -> feignhttp::Result
async fn main() -> Result<(), Box
Ok(())
} ```
See here for a complete example.
Structure is a good way to manage requests. Define a structure and then define a large number of request methods:
```rust use feignhttp::feign;
const GITHUB_URL: &str = "https://api.github.com";
struct Github;
impl Github {
#[get]
async fn home() -> feignhttp::Result
#[get("/repos/{owner}/{repo}")]
async fn repository(
#[path] owner: &str,
#[path] repo: &str,
) -> feignhttp::Result<String> {}
// ...
// Structure method still send request
#[get(path = "/repos/{owner}/{repo}/languages")]
async fn languages(
&self,
#[path] owner: &str,
#[path] repo: &str,
) -> feignhttp::Result<String> {}
} ```
See here for a complete example.
If you need to configure the timeout, use connect_timeout
and timeout
to specify connect timeout and read timeout.
Connect timeout:
```rust
async fn connect_timeout() -> feignhttp::Result
Read timeout:
```rust
async fn timeout() -> feignhttp::Result
FeignHttp is provided under the MIT license. See LICENSE.