1
0
mirror of https://github.com/actix/examples synced 2024-11-23 14:31:07 +01:00

chore: distinguish reqwest types from actix types

This commit is contained in:
Rob Ede 2024-08-07 01:57:39 +01:00
parent 487567a216
commit b7b1005d2a
No known key found for this signature in database
GPG Key ID: 97C636207D3EF933
2 changed files with 17 additions and 8 deletions

View File

@ -1,6 +1,7 @@
{ {
"cSpell.words": [ "cSpell.words": [
"actix", "actix",
"addrs",
"apalis", "apalis",
"askama", "askama",
"autoclean", "autoclean",
@ -18,6 +19,7 @@
"pemfile", "pemfile",
"prost", "prost",
"protobuf", "protobuf",
"reqwest",
"rustls", "rustls",
"rustup", "rustup",
"sparklepost", "sparklepost",

View File

@ -1,8 +1,7 @@
use std::net::ToSocketAddrs; use std::{io, net::ToSocketAddrs as _};
use actix_web::{ use actix_web::{
dev::PeerAddr, error, http::Method, middleware, web, App, Error, HttpRequest, HttpResponse, dev::PeerAddr, error, middleware, web, App, Error, HttpRequest, HttpResponse, HttpServer,
HttpServer,
}; };
use awc::Client; use awc::Client;
use clap::Parser; use clap::Parser;
@ -57,7 +56,7 @@ async fn forward(
async fn forward_reqwest( async fn forward_reqwest(
req: HttpRequest, req: HttpRequest,
mut payload: web::Payload, mut payload: web::Payload,
method: Method, method: actix_web::http::Method,
peer_addr: Option<PeerAddr>, peer_addr: Option<PeerAddr>,
url: web::Data<Url>, url: web::Data<Url>,
client: web::Data<reqwest::Client>, client: web::Data<reqwest::Client>,
@ -81,7 +80,10 @@ async fn forward_reqwest(
}); });
let forwarded_req = client let forwarded_req = client
.request(method, new_url) .request(
reqwest::Method::from_bytes(method.as_str().as_bytes()).unwrap(),
new_url,
)
.body(reqwest::Body::wrap_stream(UnboundedReceiverStream::new(rx))); .body(reqwest::Body::wrap_stream(UnboundedReceiverStream::new(rx)));
// TODO: This forwarded implementation is incomplete as it only handles the unofficial // TODO: This forwarded implementation is incomplete as it only handles the unofficial
@ -96,11 +98,16 @@ async fn forward_reqwest(
.await .await
.map_err(error::ErrorInternalServerError)?; .map_err(error::ErrorInternalServerError)?;
let mut client_resp = HttpResponse::build(res.status()); let mut client_resp =
HttpResponse::build(actix_web::http::StatusCode::from_u16(res.status().as_u16()).unwrap());
// Remove `Connection` as per // Remove `Connection` as per
// https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Connection#Directives // https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Connection#Directives
for (header_name, header_value) in res.headers().iter().filter(|(h, _)| *h != "connection") { for (header_name, header_value) in res.headers().iter().filter(|(h, _)| *h != "connection") {
client_resp.insert_header((header_name.clone(), header_value.clone())); client_resp.insert_header((
actix_web::http::header::HeaderName::from_bytes(header_name.as_ref()).unwrap(),
actix_web::http::header::HeaderValue::from_bytes(header_value.as_ref()).unwrap(),
));
} }
Ok(client_resp.streaming(res.bytes_stream())) Ok(client_resp.streaming(res.bytes_stream()))
@ -115,7 +122,7 @@ struct CliArguments {
} }
#[actix_web::main] #[actix_web::main]
async fn main() -> std::io::Result<()> { async fn main() -> io::Result<()> {
env_logger::init_from_env(env_logger::Env::new().default_filter_or("info")); env_logger::init_from_env(env_logger::Env::new().default_filter_or("info"));
let args = CliArguments::parse(); let args = CliArguments::parse();