2020-10-30 03:19:56 +01:00
|
|
|
//! HTTP primitives for the Actix ecosystem.
|
2020-09-10 15:46:35 +02:00
|
|
|
|
|
|
|
#![deny(rust_2018_idioms)]
|
2019-04-08 08:06:21 +02:00
|
|
|
#![allow(
|
|
|
|
clippy::type_complexity,
|
2019-07-17 09:55:44 +02:00
|
|
|
clippy::too_many_arguments,
|
2019-04-08 08:06:21 +02:00
|
|
|
clippy::new_without_default,
|
2019-12-13 05:59:02 +01:00
|
|
|
clippy::borrow_interior_mutable_const
|
2019-04-08 08:06:21 +02:00
|
|
|
)]
|
2020-10-30 03:19:56 +01:00
|
|
|
#![doc(html_logo_url = "https://actix.rs/img/logo.png")]
|
|
|
|
#![doc(html_favicon_url = "https://actix.rs/favicon.ico")]
|
2019-03-26 19:54:35 +01:00
|
|
|
|
|
|
|
#[macro_use]
|
|
|
|
extern crate log;
|
|
|
|
|
2020-02-21 05:31:51 +01:00
|
|
|
#[macro_use]
|
|
|
|
mod macros;
|
|
|
|
|
2019-03-26 19:54:35 +01:00
|
|
|
pub mod body;
|
|
|
|
mod builder;
|
2019-11-18 13:42:27 +01:00
|
|
|
pub mod client;
|
2019-03-26 19:54:35 +01:00
|
|
|
mod config;
|
2019-12-12 10:08:08 +01:00
|
|
|
#[cfg(feature = "compress")]
|
2019-03-26 23:14:32 +01:00
|
|
|
pub mod encoding;
|
2019-03-26 19:54:35 +01:00
|
|
|
mod extensions;
|
|
|
|
mod header;
|
|
|
|
mod helpers;
|
|
|
|
mod httpcodes;
|
|
|
|
pub mod httpmessage;
|
|
|
|
mod message;
|
|
|
|
mod payload;
|
|
|
|
mod request;
|
|
|
|
mod response;
|
|
|
|
mod service;
|
Upgrade `time` to 0.2.5 (#1254)
* Use `OffsetDateTime` instead of `PrimitiveDateTime`
* Parse time strings with `PrimitiveDateTime::parse` instead of `OffsetDateTime::parse`
* Remove unused `time` dependency from actix-multipart
* Fix a few errors with time related tests from the `time` upgrade
* Implement logic to convert a RFC 850 two-digit year into a full length year, and organize time parsing related functions
* Upgrade `time` to 0.2.2
* Correctly parse C's asctime time format using time 0.2's new format patterns
* Update CHANGES.md
* Use `time` without any of its deprecated functions
* Enforce a UTC time offset when converting an `OffsetDateTime` into a Header value
* Use the more readable version of `Duration::seconds(0)`, `Duration::zero()`
* Remove unneeded conversion of time::Duration to std::time::Duration
* Use `OffsetDateTime::as_seconds_f64` instead of manually calculating the amount of seconds from nanoseconds
* Replace a few additional instances of `Duration::seconds(0)` with `Duration::zero()`
* Truncate any nanoseconds from a supplied `Duration` within `Cookie::set_max_age` to ensure two Cookies with the same amount whole seconds equate to one another
* Fix the actix-http::cookie::do_not_panic_on_large_max_ages test
* Convert `Cookie::max_age` and `Cookie::expires` examples to `time` 0.2
Mainly minor changes. Type inference can be used alongside the new
`time::parse` method, such that the type doesn't need to be specified.
This will be useful if a refactoring takes place that changes the type.
There are also new macros, which are used where possible.
One change that is not immediately obvious, in `HttpDate`, there was an
unnecessary conditional. As the time crate allows for negative durations
(and can perform arithmetic with such), the if/else can be removed
entirely.
Time v0.2.3 also has some bug fixes, which is why I am not using a more
general v0.2 in Cargo.toml.
v0.2.3 has been yanked, as it was backwards imcompatible. This version
reverts the breaking change, while still supporting rustc back to
1.34.0.
* Add missing `time::offset` macro import
* Fix type confusion when using `time::parse` followed by `using_offset`
* Update `time` to 0.2.5
* Update CHANGES.md
Co-authored-by: Jacob Pratt <the.z.cuber@gmail.com>
2020-01-28 12:44:22 +01:00
|
|
|
mod time_parser;
|
2019-03-26 19:54:35 +01:00
|
|
|
|
2020-06-19 15:34:14 +02:00
|
|
|
pub use cookie;
|
2019-03-26 19:54:35 +01:00
|
|
|
pub mod error;
|
|
|
|
pub mod h1;
|
|
|
|
pub mod h2;
|
2019-11-18 13:42:27 +01:00
|
|
|
pub mod test;
|
|
|
|
pub mod ws;
|
2019-03-26 19:54:35 +01:00
|
|
|
|
|
|
|
pub use self::builder::HttpServiceBuilder;
|
|
|
|
pub use self::config::{KeepAlive, ServiceConfig};
|
|
|
|
pub use self::error::{Error, ResponseError, Result};
|
|
|
|
pub use self::extensions::Extensions;
|
|
|
|
pub use self::httpmessage::HttpMessage;
|
2019-09-10 06:29:32 +02:00
|
|
|
pub use self::message::{Message, RequestHead, RequestHeadType, ResponseHead};
|
2019-03-26 19:54:35 +01:00
|
|
|
pub use self::payload::{Payload, PayloadStream};
|
|
|
|
pub use self::request::Request;
|
|
|
|
pub use self::response::{Response, ResponseBuilder};
|
2019-04-05 20:29:42 +02:00
|
|
|
pub use self::service::HttpService;
|
2019-03-26 19:54:35 +01:00
|
|
|
|
|
|
|
pub mod http {
|
2021-01-15 03:11:10 +01:00
|
|
|
//! Various HTTP related types.
|
2019-03-26 19:54:35 +01:00
|
|
|
|
|
|
|
// re-exports
|
|
|
|
pub use http::header::{HeaderName, HeaderValue};
|
|
|
|
pub use http::uri::PathAndQuery;
|
2019-12-05 18:35:43 +01:00
|
|
|
pub use http::{uri, Error, Uri};
|
2019-03-30 05:13:39 +01:00
|
|
|
pub use http::{Method, StatusCode, Version};
|
2019-03-26 19:54:35 +01:00
|
|
|
|
2019-03-30 05:13:39 +01:00
|
|
|
pub use crate::cookie::{Cookie, CookieBuilder};
|
2019-04-07 00:02:02 +02:00
|
|
|
pub use crate::header::HeaderMap;
|
2019-03-26 19:54:35 +01:00
|
|
|
|
2021-01-15 03:11:10 +01:00
|
|
|
/// A collection of HTTP headers and helpers.
|
2019-03-26 19:54:35 +01:00
|
|
|
pub mod header {
|
|
|
|
pub use crate::header::*;
|
|
|
|
}
|
|
|
|
pub use crate::header::ContentEncoding;
|
|
|
|
pub use crate::message::ConnectionType;
|
|
|
|
}
|
2019-12-02 12:33:11 +01:00
|
|
|
|
2021-01-06 19:58:24 +01:00
|
|
|
/// A major HTTP protocol version.
|
2019-12-02 12:33:11 +01:00
|
|
|
#[derive(Copy, Clone, Debug, PartialEq, Eq, Hash)]
|
2021-01-06 19:58:24 +01:00
|
|
|
#[non_exhaustive]
|
2019-12-02 12:33:11 +01:00
|
|
|
pub enum Protocol {
|
|
|
|
Http1,
|
|
|
|
Http2,
|
2021-01-06 19:58:24 +01:00
|
|
|
Http3,
|
2019-12-02 12:33:11 +01:00
|
|
|
}
|
2020-10-30 03:03:26 +01:00
|
|
|
|
|
|
|
type ConnectCallback<IO> = dyn Fn(&IO, &mut Extensions);
|
2021-01-06 19:43:52 +01:00
|
|
|
|
|
|
|
/// Container for data that extract with ConnectCallback.
|
2021-01-06 19:52:06 +01:00
|
|
|
///
|
|
|
|
/// # Implementation Details
|
|
|
|
/// Uses Option to reduce necessary allocations when merging with request extensions.
|
2021-01-06 19:43:52 +01:00
|
|
|
pub(crate) struct OnConnectData(Option<Extensions>);
|
|
|
|
|
|
|
|
impl Default for OnConnectData {
|
|
|
|
fn default() -> Self {
|
|
|
|
Self(None)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl OnConnectData {
|
2021-01-06 19:52:06 +01:00
|
|
|
/// Construct by calling the on-connect callback with the underlying transport I/O.
|
2021-01-06 19:43:52 +01:00
|
|
|
pub(crate) fn from_io<T>(
|
|
|
|
io: &T,
|
|
|
|
on_connect_ext: Option<&ConnectCallback<T>>,
|
|
|
|
) -> Self {
|
|
|
|
let ext = on_connect_ext.map(|handler| {
|
|
|
|
let mut extensions = Extensions::new();
|
|
|
|
handler(io, &mut extensions);
|
|
|
|
extensions
|
|
|
|
});
|
|
|
|
|
|
|
|
Self(ext)
|
|
|
|
}
|
|
|
|
|
2021-01-06 19:52:06 +01:00
|
|
|
/// Merge self into given request's extensions.
|
2021-01-06 19:43:52 +01:00
|
|
|
#[inline]
|
|
|
|
pub(crate) fn merge_into(&mut self, req: &mut Request) {
|
|
|
|
if let Some(ref mut ext) = self.0 {
|
|
|
|
req.head.extensions.get_mut().drain_from(ext);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|