#[derive(Default, Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[derive(Deserialize, Serialize)]
#[serde(default, deny_unknown_fields)]
pub struct ThreadCapabilitiesConfiguration
{
#[allow(missing_docs)]
pub bounding_set_to_retain: BoundingCapabilitySet,
#[allow(missing_docs)]
pub permitted_effective_and_inheritable_capability_sets: PermittedEffectiveAndInheritableCapabilitySets,
#[allow(missing_docs)]
pub ambient_capabilities: AmbientCapabilitySet,
}
impl ThreadCapabilitiesConfiguration
{
pub(crate) fn configure_just_capabilities(&self) -> Result<(), ThreadCapabilitiesConfigurationError>
{
use self::ThreadCapabilitiesConfigurationError::*;
self.bounding_set_to_retain.retain().map_err(|_ :()| CouldNotConfigureBoundingSet)?;
self.permitted_effective_and_inheritable_capability_sets.set(ThreadIdentifier::default()).map_err(CouldNotConfigurePermittedEffectiveAndInheritableSets)?;
self.ambient_capabilities.set_for_current_thread().map_err(CouldNotConfigureAmbient)
}
fn configure_if_wanted(&self) -> Result<(), ThreadCapabilitiesConfigurationError>
{
self.configure_just_capabilities()?;
Self::configure_secure_bits(true)
}
fn configure_if_unwanted() -> Result<(), ThreadCapabilitiesConfigurationError>
{
AmbientCapabilitySet::clear_current_thread_ambient_set();
Self::configure_secure_bits(false)
}
#[inline(always)]
fn configure_secure_bits(allow_keep_capabilities: bool) -> Result<(), ThreadCapabilitiesConfigurationError>
{
SecureBits::lock_secure_bits_so_capabilities_are_always_enforced(allow_keep_capabilities).map_err(ThreadCapabilitiesConfigurationError::CouldNotLockSecureBits)
}
}