pub struct StrictTransportSecurity {
    pub include_subdomains: bool,
    pub preload: bool,
    /* private fields */
}
Expand description

HTTP Strict Transport Security (HSTS) configuration.

Care should be taken when setting up HSTS for your site; misconfiguration can potentially leave parts of your site in an unusable state.

Default

The Default implementation uses a 5 minute max-age and does not include subdomains or preloading. This default is intentionally conservative to prevent accidental misconfiguration causing irrecoverable problems for users.

Once you have configured and tested the default HSTS config, recommended can be used as a secure default for production.

References

See the HSTS page on MDN for more information.

Fields§

§include_subdomains: bool

The includeSubdomains directive.

§preload: bool

The preload directive.

Implementations§

source§

impl StrictTransportSecurity

source

pub fn new(duration: Duration) -> Self

Constructs a new HSTS configuration using the given duration.

Other values take their default.

source

pub fn recommended() -> Self

Constructs a secure, production-ready HSTS configuration.

Uses a max-age of 2 years and includes subdomains.

source

pub fn include_subdomains(self) -> Self

Send includeSubdomains directive with header.

source

pub fn preload(self) -> Self

Send preload directive with header.

See https://hstspreload.org/ for more information.

Trait Implementations§

source§

impl Clone for StrictTransportSecurity

source§

fn clone(&self) -> StrictTransportSecurity

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for StrictTransportSecurity

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for StrictTransportSecurity

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl FromStr for StrictTransportSecurity

§

type Err = ParseError

The associated error which can be returned from parsing.
source§

fn from_str(val: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl Header for StrictTransportSecurity

source§

fn name() -> HeaderName

Returns the name of the header field.
source§

fn parse<M: HttpMessage>(msg: &M) -> Result<Self, ParseError>

Parse the header from a HTTP message.
source§

impl PartialEq<StrictTransportSecurity> for StrictTransportSecurity

source§

fn eq(&self, other: &StrictTransportSecurity) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

fn ne(&self, other: &Rhs) -> bool

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl TryIntoHeaderValue for StrictTransportSecurity

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_into_value(self) -> Result<HeaderValue, Self::Error>

Try to convert value to a HeaderValue.
source§

impl Copy for StrictTransportSecurity

source§

impl Eq for StrictTransportSecurity

source§

impl StructuralEq for StrictTransportSecurity

source§

impl StructuralPartialEq for StrictTransportSecurity

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

const: unstable · source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T> Instrument for T

source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> TryIntoHeaderPair for Twhere T: Header,

§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V

source§

impl<T> WithSubscriber for T

source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more