Skip to content

Commit

Permalink
Update example reverse-proxy to axum 0.7 (#2395)
Browse files Browse the repository at this point in the history
  • Loading branch information
markussilvan authored Dec 2, 2023
1 parent 801a78a commit b02ce30
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 49 deletions.
1 change: 1 addition & 0 deletions examples/reverse-proxy/Cargo.toml
Original file line number Diff line number Diff line change
Expand Up @@ -6,4 +6,5 @@ edition = "2021"
[dependencies]
axum = { path = "../../axum" }
hyper = { version = "1.0.0", features = ["full"] }
hyper-util = { version = "0.1.1", features = ["client-legacy"] }
tokio = { version = "1", features = ["full"] }
96 changes: 47 additions & 49 deletions examples/reverse-proxy/src/main.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,63 +7,61 @@
//! cargo run -p example-reverse-proxy
//! ```
// TODO
fn main() {
eprint!("this example has not yet been updated to hyper 1.0");
}

// use axum::{
// body::Body,
// extract::{Request, State},
// http::uri::Uri,
// response::{IntoResponse, Response},
// routing::get,
// Router,
// };
// use hyper::{client::HttpConnector, StatusCode};
use axum::{
body::Body,
extract::{Request, State},
http::uri::Uri,
response::{IntoResponse, Response},
routing::get,
Router,
};
use hyper::StatusCode;
use hyper_util::{client::legacy::connect::HttpConnector, rt::TokioExecutor};

// type Client = hyper::client::Client<HttpConnector, Body>;
type Client = hyper_util::client::legacy::Client<HttpConnector, Body>;

// #[tokio::main]
// async fn main() {
// tokio::spawn(server());
#[tokio::main]
async fn main() {
tokio::spawn(server());

// let client: Client = hyper::Client::builder().build(HttpConnector::new());
let client: Client =
hyper_util::client::legacy::Client::<(), ()>::builder(TokioExecutor::new())
.build(HttpConnector::new());

// let app = Router::new().route("/", get(handler)).with_state(client);
let app = Router::new().route("/", get(handler)).with_state(client);

// let listener = tokio::net::TcpListener::bind("127.0.0.1:4000")
// .await
// .unwrap();
// println!("listening on {}", listener.local_addr().unwrap());
// axum::serve(listener, app).await.unwrap();
// }
let listener = tokio::net::TcpListener::bind("127.0.0.1:4000")
.await
.unwrap();
println!("listening on {}", listener.local_addr().unwrap());
axum::serve(listener, app).await.unwrap();
}

// async fn handler(State(client): State<Client>, mut req: Request) -> Result<Response, StatusCode> {
// let path = req.uri().path();
// let path_query = req
// .uri()
// .path_and_query()
// .map(|v| v.as_str())
// .unwrap_or(path);
async fn handler(State(client): State<Client>, mut req: Request) -> Result<Response, StatusCode> {
let path = req.uri().path();
let path_query = req
.uri()
.path_and_query()
.map(|v| v.as_str())
.unwrap_or(path);

// let uri = format!("http://127.0.0.1:3000{}", path_query);
let uri = format!("http://127.0.0.1:3000{}", path_query);

// *req.uri_mut() = Uri::try_from(uri).unwrap();
*req.uri_mut() = Uri::try_from(uri).unwrap();

// Ok(client
// .request(req)
// .await
// .map_err(|_| StatusCode::BAD_REQUEST)?
// .into_response())
// }
Ok(client
.request(req)
.await
.map_err(|_| StatusCode::BAD_REQUEST)?
.into_response())
}

// async fn server() {
// let app = Router::new().route("/", get(|| async { "Hello, world!" }));
async fn server() {
let app = Router::new().route("/", get(|| async { "Hello, world!" }));

// let listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
// .await
// .unwrap();
// println!("listening on {}", listener.local_addr().unwrap());
// axum::serve(listener, app).await.unwrap();
// }
let listener = tokio::net::TcpListener::bind("127.0.0.1:3000")
.await
.unwrap();
println!("listening on {}", listener.local_addr().unwrap());
axum::serve(listener, app).await.unwrap();
}

0 comments on commit b02ce30

Please sign in to comment.