mirror of
https://github.com/servo/servo.git
synced 2025-06-06 16:45:39 +00:00
* Remove the referrer policy from document and rely on its policy container Signed-off-by: Shane Handley <shanehandley@fastmail.com> * Make ReferrerPolicy non-optional, instead using a new enum value to represent the empty string case Signed-off-by: Shane Handley <shanehandley@fastmail.com> * Fix clippy issue Signed-off-by: Shane Handley <shanehandley@fastmail.com> * Fix usage of Option<ReferrerPolicy> in unit test Signed-off-by: Shane Handley <shanehandley@fastmail.com> --------- Signed-off-by: Shane Handley <shanehandley@fastmail.com>
57 lines
2.1 KiB
Rust
57 lines
2.1 KiB
Rust
/* 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.
|
||
///
|
||
/// <https://fetch.spec.whatwg.org/#concept-request-policy-container>
|
||
#[derive(Clone, Debug, Default, Deserialize, MallocSizeOf, Serialize)]
|
||
pub enum RequestPolicyContainer {
|
||
#[default]
|
||
Client,
|
||
PolicyContainer(PolicyContainer),
|
||
}
|
||
|
||
/// <https://html.spec.whatwg.org/multipage/#policy-containers>
|
||
#[derive(Clone, Debug, Default, Deserialize, MallocSizeOf, Serialize)]
|
||
pub struct PolicyContainer {
|
||
#[ignore_malloc_size_of = "Defined in rust-content-security-policy"]
|
||
/// <https://html.spec.whatwg.org/multipage/#policy-container-csp-list>
|
||
pub csp_list: Option<CspList>,
|
||
/// <https://html.spec.whatwg.org/multipage/#policy-container-referrer-policy>
|
||
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<CspList>) {
|
||
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
|
||
}
|
||
}
|