/* This Source Code Form is subject to the terms of the Mozilla Public * License, v. 2.0. If a copy of the MPL was not distributed with this * file, You can obtain one at https://mozilla.org/MPL/2.0/. */ use content_security_policy::CspList; use malloc_size_of_derive::MallocSizeOf; use serde::{Deserialize, Serialize}; use crate::ReferrerPolicy; /// When a policy container is associated with a request, it has an additional state of "Client". As /// per the spec: /// /// `"client" is changed to a policy container during fetching. It provides a convenient way for /// standards to not have to set request’s policy container.` /// /// This can be achieved with an `Option` however this struct is used with the intent to reduce /// ambiguity when mapping our implementation to the spec. /// /// #[derive(Clone, Debug, Default, Deserialize, MallocSizeOf, Serialize)] pub enum RequestPolicyContainer { #[default] Client, PolicyContainer(PolicyContainer), } /// #[derive(Clone, Debug, Default, Deserialize, MallocSizeOf, Serialize)] pub struct PolicyContainer { #[ignore_malloc_size_of = "Defined in rust-content-security-policy"] /// pub csp_list: Option, /// referrer_policy: ReferrerPolicy, // https://html.spec.whatwg.org/multipage/#policy-container-embedder-policy // TODO: Embedder Policy } impl PolicyContainer { pub fn set_csp_list(&mut self, csp_list: Option) { self.csp_list = csp_list; } pub fn set_referrer_policy(&mut self, referrer_policy: ReferrerPolicy) { self.referrer_policy = referrer_policy; } pub fn get_referrer_policy(&self) -> ReferrerPolicy { // https://w3c.github.io/webappsec-referrer-policy/#referrer-policy-empty-string if self.referrer_policy == ReferrerPolicy::EmptyString { return ReferrerPolicy::default(); } self.referrer_policy } }