2024-06-11 03:52:45 +01:00
|
|
|
use actix_web::{
|
|
|
|
dev::ServiceRequest, error, get, middleware::Logger, App, Error, HttpServer, Responder,
|
|
|
|
};
|
|
|
|
use actix_web_httpauth::{extractors::bearer::BearerAuth, middleware::HttpAuthentication};
|
|
|
|
use tracing::level_filters::LevelFilter;
|
|
|
|
use tracing_subscriber::EnvFilter;
|
2019-06-08 00:20:55 +03:00
|
|
|
|
2024-06-11 03:52:45 +01:00
|
|
|
/// Validator that:
|
|
|
|
/// - accepts Bearer auth;
|
|
|
|
/// - returns a custom response for requests without a valid Bearer Authorization header;
|
|
|
|
/// - rejects tokens containing an "x" (for quick testing using command line HTTP clients).
|
2022-07-19 08:40:01 +08:00
|
|
|
async fn validator(
|
|
|
|
req: ServiceRequest,
|
2024-06-11 03:52:45 +01:00
|
|
|
credentials: Option<BearerAuth>,
|
2022-07-19 08:40:01 +08:00
|
|
|
) -> Result<ServiceRequest, (Error, ServiceRequest)> {
|
2024-06-11 03:52:45 +01:00
|
|
|
let Some(credentials) = credentials else {
|
|
|
|
return Err((error::ErrorBadRequest("no bearer header"), req));
|
|
|
|
};
|
|
|
|
|
|
|
|
eprintln!("{credentials:?}");
|
|
|
|
|
|
|
|
if credentials.token().contains('x') {
|
|
|
|
return Err((error::ErrorBadRequest("token contains x"), req));
|
|
|
|
}
|
|
|
|
|
2020-01-07 01:00:43 +09:00
|
|
|
Ok(req)
|
2019-06-08 00:20:55 +03:00
|
|
|
}
|
|
|
|
|
2024-06-11 03:52:45 +01:00
|
|
|
#[get("/")]
|
|
|
|
async fn index(auth: BearerAuth) -> impl Responder {
|
|
|
|
format!("authenticated for token: {}", auth.token().to_owned())
|
|
|
|
}
|
|
|
|
|
2020-11-18 15:08:03 +00:00
|
|
|
#[actix_web::main]
|
2020-01-07 01:00:43 +09:00
|
|
|
async fn main() -> std::io::Result<()> {
|
2024-06-11 03:52:45 +01:00
|
|
|
tracing_subscriber::fmt()
|
|
|
|
.with_env_filter(
|
|
|
|
EnvFilter::builder()
|
|
|
|
.with_default_directive(LevelFilter::INFO.into())
|
|
|
|
.from_env_lossy(),
|
|
|
|
)
|
|
|
|
.without_time()
|
|
|
|
.init();
|
|
|
|
|
2019-06-08 00:20:55 +03:00
|
|
|
HttpServer::new(|| {
|
2024-06-11 03:52:45 +01:00
|
|
|
let auth = HttpAuthentication::with_fn(validator);
|
|
|
|
|
2019-06-08 00:20:55 +03:00
|
|
|
App::new()
|
2024-06-11 03:52:45 +01:00
|
|
|
.service(index)
|
2019-06-08 00:20:55 +03:00
|
|
|
.wrap(auth)
|
2024-06-11 03:52:45 +01:00
|
|
|
.wrap(Logger::default().log_target("@"))
|
2019-06-08 00:20:55 +03:00
|
|
|
})
|
|
|
|
.bind("127.0.0.1:8080")?
|
2024-06-11 03:52:45 +01:00
|
|
|
.workers(2)
|
2019-06-08 00:20:55 +03:00
|
|
|
.run()
|
2020-01-07 01:00:43 +09:00
|
|
|
.await
|
2019-06-08 00:20:55 +03:00
|
|
|
}
|