http-signature-normalization/reqwest/examples/client.rs

54 lines
1.4 KiB
Rust
Raw Normal View History

2024-04-15 01:19:19 +00:00
use base64::{engine::general_purpose::STANDARD, Engine};
2023-08-17 17:34:51 +00:00
use http_signature_normalization_reqwest::{digest::ring::Sha256, prelude::*};
use reqwest::{
header::{ACCEPT, USER_AGENT},
Client,
};
async fn request(config: Config) -> Result<(), Box<dyn std::error::Error + Send + Sync>> {
let digest = Sha256::new();
2021-12-05 22:45:37 +00:00
let client = Client::new();
let request = client
.post("http://127.0.0.1:8010/")
.header(USER_AGENT, "Reqwest")
.header(ACCEPT, "text/plain")
.signature_with_digest(config, "my-key-id", digest, "Hewwo-owo", |s| {
println!("Signing String\n{}", s);
2024-04-15 01:19:19 +00:00
Ok(STANDARD.encode(s)) as Result<_, MyError>
})
.await?;
2021-12-05 22:45:37 +00:00
let body = client.execute(request).await?.bytes().await?;
println!("{:?}", body);
Ok(())
}
#[tokio::main]
async fn main() -> Result<(), Box<dyn std::error::Error + Send + Sync>> {
std::env::set_var("RUST_LOG", "info");
pretty_env_logger::init();
tokio::spawn(async move {
let config = Config::default().require_header("accept");
request(config.clone()).await?;
request(config.mastodon_compat()).await
})
.await?
}
#[derive(Debug, thiserror::Error)]
pub enum MyError {
#[error("Failed to create signing string, {0}")]
Convert(#[from] SignError),
#[error("Failed to send request")]
SendRequest(#[from] reqwest::Error),
#[error("Failed to retrieve request body")]
Body(reqwest::Error),
}