SafePath

Struct SafePath 

Source
pub struct SafePath { /* private fields */ }
Expand description

Data-only type for safe path handling. Centralized under crate::types for cross-layer reuse.

Implementations§

Source§

impl SafePath

Source

pub fn from_rooted(root: &Path, candidate: &Path) -> Result<Self>

Creates a new SafePath from a root and candidate path.

This function ensures that the candidate path is within the root path and does not contain any unsafe components like dotdot (..).

§Arguments
  • root - The root path that the candidate should be within
  • candidate - The path to check and make safe
§Returns
  • Result<Self> - A SafePath if the candidate is valid, or an error otherwise
§Errors

Returns an error if the root path is not absolute, if the candidate path escapes the root, or if the candidate path contains unsafe components like dotdot (..).

§Panics

Panics when root is not absolute. This mirrors historical semantics and preserves SPEC/BDD expectations for construction invariants in tests.

§Example
use switchyard::types::safepath::SafePath;
let td = tempfile::tempdir()?;
let root = td.path();
std::fs::create_dir_all(root.join("usr/bin"))?;
let sp = SafePath::from_rooted(root, &root.join("usr/bin/ls"))?;
assert!(sp.as_path().starts_with(root));
Source

pub fn as_path(&self) -> PathBuf

Returns the full path by joining the root and relative components.

§Returns
  • PathBuf - The complete path
Source

pub fn rel(&self) -> &Path

Returns a reference to the relative path component.

§Returns
  • &Path - Reference to the relative path

Trait Implementations§

Source§

impl Clone for SafePath

Source§

fn clone(&self) -> SafePath

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for SafePath

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for SafePath

Source§

fn eq(&self, other: &SafePath) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Eq for SafePath

Source§

impl StructuralPartialEq for SafePath

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

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

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.