2021-07-12 16:55:41 +01:00
|
|
|
//! Lower-level types and re-exports.
|
2021-06-27 02:44:56 -04:00
|
|
|
//!
|
2021-07-12 16:55:41 +01:00
|
|
|
//! Most users will not have to interact with the types in this module, but it is useful for those
|
|
|
|
//! writing extractors, middleware and libraries, or interacting with the service API directly.
|
2021-06-27 02:44:56 -04:00
|
|
|
|
|
|
|
pub use crate::config::{AppConfig, AppService};
|
|
|
|
#[doc(hidden)]
|
|
|
|
pub use crate::handler::Handler;
|
|
|
|
pub use crate::info::{ConnectionInfo, PeerAddr};
|
|
|
|
pub use crate::rmap::ResourceMap;
|
|
|
|
pub use crate::service::{HttpServiceFactory, ServiceRequest, ServiceResponse, WebService};
|
|
|
|
|
|
|
|
pub use crate::types::form::UrlEncoded;
|
|
|
|
pub use crate::types::json::JsonBody;
|
|
|
|
pub use crate::types::readlines::Readlines;
|
|
|
|
|
2021-11-16 22:10:30 +00:00
|
|
|
#[allow(deprecated)]
|
2021-11-16 21:41:35 +00:00
|
|
|
pub use actix_http::body::{AnyBody, Body, BodySize, MessageBody, SizedStream};
|
2021-06-27 02:44:56 -04:00
|
|
|
|
|
|
|
#[cfg(feature = "__compress")]
|
|
|
|
pub use actix_http::encoding::Decoder as Decompress;
|
2021-09-03 18:00:43 +01:00
|
|
|
pub use actix_http::{Extensions, Payload, PayloadStream, RequestHead, Response, ResponseHead};
|
2021-06-27 02:44:56 -04:00
|
|
|
pub use actix_router::{Path, ResourceDef, ResourcePath, Url};
|
2021-11-15 04:03:33 +00:00
|
|
|
pub use actix_server::{Server, ServerHandle};
|
2021-06-27 02:44:56 -04:00
|
|
|
pub use actix_service::{
|
2021-07-12 16:55:41 +01:00
|
|
|
always_ready, fn_factory, fn_service, forward_ready, Service, ServiceFactory, Transform,
|
2021-06-27 02:44:56 -04:00
|
|
|
};
|
|
|
|
|
2021-07-12 16:55:41 +01:00
|
|
|
use crate::http::header::ContentEncoding;
|
2021-09-03 18:00:43 +01:00
|
|
|
use actix_http::ResponseBuilder;
|
2021-07-12 16:55:41 +01:00
|
|
|
|
2021-08-06 22:42:31 +01:00
|
|
|
use actix_router::Patterns;
|
|
|
|
|
|
|
|
pub(crate) fn ensure_leading_slash(mut patterns: Patterns) -> Patterns {
|
|
|
|
match &mut patterns {
|
|
|
|
Patterns::Single(pat) => {
|
|
|
|
if !pat.is_empty() && !pat.starts_with('/') {
|
|
|
|
pat.insert(0, '/');
|
|
|
|
};
|
|
|
|
}
|
|
|
|
Patterns::List(pats) => {
|
|
|
|
for pat in pats {
|
|
|
|
if !pat.is_empty() && !pat.starts_with('/') {
|
|
|
|
pat.insert(0, '/');
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|
2021-06-27 02:44:56 -04:00
|
|
|
}
|
2021-07-12 16:55:41 +01:00
|
|
|
|
2021-06-27 02:44:56 -04:00
|
|
|
patterns
|
|
|
|
}
|
|
|
|
struct Enc(ContentEncoding);
|
|
|
|
|
|
|
|
/// Helper trait that allows to set specific encoding for response.
|
|
|
|
pub trait BodyEncoding {
|
|
|
|
/// Get content encoding
|
|
|
|
fn get_encoding(&self) -> Option<ContentEncoding>;
|
|
|
|
|
|
|
|
/// Set content encoding
|
|
|
|
///
|
|
|
|
/// Must be used with [`crate::middleware::Compress`] to take effect.
|
|
|
|
fn encoding(&mut self, encoding: ContentEncoding) -> &mut Self;
|
|
|
|
}
|
|
|
|
|
|
|
|
impl BodyEncoding for ResponseBuilder {
|
|
|
|
fn get_encoding(&self) -> Option<ContentEncoding> {
|
|
|
|
self.extensions().get::<Enc>().map(|enc| enc.0)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn encoding(&mut self, encoding: ContentEncoding) -> &mut Self {
|
|
|
|
self.extensions_mut().insert(Enc(encoding));
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<B> BodyEncoding for Response<B> {
|
|
|
|
fn get_encoding(&self) -> Option<ContentEncoding> {
|
|
|
|
self.extensions().get::<Enc>().map(|enc| enc.0)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn encoding(&mut self, encoding: ContentEncoding) -> &mut Self {
|
|
|
|
self.extensions_mut().insert(Enc(encoding));
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl BodyEncoding for crate::HttpResponseBuilder {
|
|
|
|
fn get_encoding(&self) -> Option<ContentEncoding> {
|
|
|
|
self.extensions().get::<Enc>().map(|enc| enc.0)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn encoding(&mut self, encoding: ContentEncoding) -> &mut Self {
|
|
|
|
self.extensions_mut().insert(Enc(encoding));
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl<B> BodyEncoding for crate::HttpResponse<B> {
|
|
|
|
fn get_encoding(&self) -> Option<ContentEncoding> {
|
|
|
|
self.extensions().get::<Enc>().map(|enc| enc.0)
|
|
|
|
}
|
|
|
|
|
|
|
|
fn encoding(&mut self, encoding: ContentEncoding) -> &mut Self {
|
|
|
|
self.extensions_mut().insert(Enc(encoding));
|
|
|
|
self
|
|
|
|
}
|
|
|
|
}
|