#subdomain #warp #middleware #server-framework #web-server

warp_subdomain

A simple subdomain parser for Warp web server framework with nano second processing time

2 stable releases

1.2.0 Aug 10, 2022
1.1.0 Aug 10, 2022
1.0.0 Aug 9, 2022

#1537 in HTTP server

MIT license

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