[][src]Struct tide::http::security::ContentSecurityPolicy

pub struct ContentSecurityPolicy { /* fields omitted */ }

Build a Content-Security-Policy header.

Content-Security-Policy (CSP) HTTP headers are used to prevent cross-site injections. Read more

Mozilla Developer Network

Examples

use http_types::{headers, security, Response, StatusCode};

let mut policy = security::ContentSecurityPolicy::new();
policy
    .default_src(security::Source::SameOrigin)
    .default_src("areweasyncyet.rs")
    .script_src(security::Source::SameOrigin)
    .script_src(security::Source::UnsafeInline)
    .object_src(security::Source::None)
    .base_uri(security::Source::None)
    .upgrade_insecure_requests();

let mut res = Response::new(StatusCode::Ok);
res.set_body("Hello, Chashu!");

security::default(&mut res);
policy.apply(&mut res);

assert_eq!(res["content-security-policy"], "base-uri 'none'; default-src 'self' areweasyncyet.rs; object-src 'none'; script-src 'self' 'unsafe-inline'; upgrade-insecure-requests");

Implementations

impl ContentSecurityPolicy[src]

pub fn new() -> ContentSecurityPolicy[src]

Create a new instance.

pub fn base_uri<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy base-uri directive

MDN | base-uri

pub fn block_all_mixed_content(&mut self) -> &mut ContentSecurityPolicy[src]

Defines the Content-Security-Policy block-all-mixed-content directive

MDN | block-all-mixed-content

pub fn connect_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy connect-src directive

MDN | connect-src

pub fn default_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy default-src directive

MDN | default-src

pub fn font_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy font-src directive

MDN | font-src

pub fn form_action<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy form-action directive

MDN | form-action

pub fn frame_ancestors<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy frame-ancestors directive

MDN | frame-ancestors

pub fn frame_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy frame-src directive

MDN | frame-src

pub fn img_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy img-src directive

MDN | img-src

pub fn media_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy media-src directive

MDN | media-src

pub fn object_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy object-src directive

MDN | object-src

pub fn plugin_types<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy plugin-types directive

MDN | plugin-types

pub fn require_sri_for<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy require-sri-for directive

MDN | require-sri-for

pub fn report_uri<T>(&mut self, uri: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy report-uri directive

MDN | report-uri

pub fn report_to(
    &mut self,
    endpoints: Vec<ReportTo, Global>
) -> &mut ContentSecurityPolicy
[src]

Defines the Content-Security-Policy report-to directive

MDN | report-to

pub fn sandbox<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy sandbox directive

MDN | sandbox

pub fn script_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy script-src directive

MDN | script-src

pub fn style_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy style-src directive

MDN | style-src

pub fn upgrade_insecure_requests(&mut self) -> &mut ContentSecurityPolicy[src]

Defines the Content-Security-Policy upgrade-insecure-requests directive

MDN | upgrade-insecure-requests

pub fn worker_src<T>(&mut self, source: T) -> &mut ContentSecurityPolicy where
    T: AsRef<str>, 
[src]

Defines the Content-Security-Policy worker-src directive

MDN | worker-src

pub fn report_only(&mut self) -> &mut ContentSecurityPolicy[src]

Change the header to Content-Security-Policy-Report-Only

pub fn apply(&mut self, headers: impl AsMut<Headers>)[src]

Sets the Content-Security-Policy (CSP) HTTP header to prevent cross-site injections

Trait Implementations

impl Clone for ContentSecurityPolicy[src]

impl Debug for ContentSecurityPolicy[src]

impl Default for ContentSecurityPolicy[src]

pub fn default() -> ContentSecurityPolicy[src]

Sets the Content-Security-Policy default to "script-src 'self'; object-src 'self'"

impl Eq for ContentSecurityPolicy[src]

impl PartialEq<ContentSecurityPolicy> for ContentSecurityPolicy[src]

impl StructuralEq for ContentSecurityPolicy[src]

impl StructuralPartialEq for ContentSecurityPolicy[src]

Auto Trait Implementations

Blanket Implementations

impl<T> Any for T where
    T: 'static + ?Sized
[src]

impl<T> Borrow<T> for T where
    T: ?Sized
[src]

impl<T> BorrowMut<T> for T where
    T: ?Sized
[src]

impl<T> From<T> for T[src]

impl<T, U> Into<U> for T where
    U: From<T>, 
[src]

impl<T> Same<T> for T

type Output = T

Should always be Self

impl<T> ToOwned for T where
    T: Clone
[src]

type Owned = T

The resulting type after obtaining ownership.

impl<T, U> TryFrom<U> for T where
    U: Into<T>, 
[src]

type Error = Infallible

The type returned in the event of a conversion error.

impl<T, U> TryInto<U> for T where
    U: TryFrom<T>, 
[src]

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

The type returned in the event of a conversion error.

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