2 stable releases
1.2.0 | Aug 10, 2022 |
---|---|
1.1.0 |
|
1.0.0 | Aug 9, 2022 |
#1537 in HTTP server
7KB
71 lines
warp_subdomain
A simple subdomain parser middleware for Warp web server framework with nano second processing time. 🚀🚀
Usage
... warp route
.and(warp_subdomain::with_subdomain)`
... route handler
Example
use std::collections::HashMap;
use std::sync::Arc;
use warp::Filter;
use warp_subdomain::with_subdomain;
async fn query(
_query: HashMap<String, String>,
subdomain: Arc<Vec<String>>,
) -> Result<impl warp::Reply, warp::Rejection> {
// get last subdomain
let subdomain_0 = subdomain.get(0);
Ok(warp::reply::with_status(
subdomain_0.unwrap().to_string(),
warp::http::StatusCode::FOUND,
))
}
#[tokio::main]
async fn main() {
let route = warp::path!("home")
.and(warp::get())
.and(warp::query::<HashMap<String, String>>())
.and(with_subdomain())
.and_then(query);
warp::serve(route).run(([127, 0, 0, 1], 3030)).await
}
/// If host eg. super-alloy.api.cilen.com.
/// This middleware will return
vec!["super-alloy", "api"]
/// This middleware also works for localhost that have port in host header.
/// eg. api.localhost:3999
Note
This middlewares will return value with type Arc<Vec<String>>
Misc
Dependencies
~9–18MB
~243K SLoC