pub struct VolumeValidator { /* private fields */ }Expand description
Volume security validator with whitelist support
Implementations§
Source§impl VolumeValidator
impl VolumeValidator
Sourcepub fn new(whitelist: Vec<PathBuf>) -> Self
pub fn new(whitelist: Vec<PathBuf>) -> Self
Create a new volume validator with whitelist
§Example
use clnrm_core::backend::volume::VolumeValidator;
use std::path::PathBuf;
let validator = VolumeValidator::new(vec![
PathBuf::from("/tmp"),
PathBuf::from("/var/data"),
]);Sourcepub fn validate(&self, mount: &VolumeMount) -> Result<()>
pub fn validate(&self, mount: &VolumeMount) -> Result<()>
Validate a volume mount against whitelist
§Errors
Returns error if host path is not under any whitelisted directory
Sourcepub fn validate_all(&self, mounts: &[VolumeMount]) -> Result<()>
pub fn validate_all(&self, mounts: &[VolumeMount]) -> Result<()>
Validate multiple mounts
Trait Implementations§
Source§impl Clone for VolumeValidator
impl Clone for VolumeValidator
Source§fn clone(&self) -> VolumeValidator
fn clone(&self) -> VolumeValidator
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for VolumeValidator
impl Debug for VolumeValidator
Auto Trait Implementations§
impl Freeze for VolumeValidator
impl RefUnwindSafe for VolumeValidator
impl Send for VolumeValidator
impl Sync for VolumeValidator
impl Unpin for VolumeValidator
impl UnwindSafe for VolumeValidator
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<T> FutureExt for T
impl<T> FutureExt for T
Source§fn with_context(self, otel_cx: Context) -> WithContext<Self>
fn with_context(self, otel_cx: Context) -> WithContext<Self>
Source§fn with_current_context(self) -> WithContext<Self>
fn with_current_context(self) -> WithContext<Self>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::RequestSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request