pub struct FileSystemSandboxPolicy {
pub kind: FileSystemSandboxKind,
pub entries: Vec<FileSystemSandboxEntry>,
}Fields§
§kind: FileSystemSandboxKind§entries: Vec<FileSystemSandboxEntry>Implementations§
Source§impl FileSystemSandboxPolicy
impl FileSystemSandboxPolicy
pub fn unrestricted() -> Self
pub fn external_sandbox() -> Self
pub fn restricted(entries: Vec<FileSystemSandboxEntry>) -> Self
Sourcepub fn from_legacy_sandbox_policy(
sandbox_policy: &SandboxPolicy,
cwd: &Path,
) -> Self
pub fn from_legacy_sandbox_policy( sandbox_policy: &SandboxPolicy, cwd: &Path, ) -> Self
Converts a legacy sandbox policy into an equivalent filesystem policy for the provided cwd.
Legacy WorkspaceWrite policies may list readable roots that live
under an already-writable root. Those paths were redundant in the
legacy model and should not become read-only carveouts when projected
into split filesystem policy.
Sourcepub fn has_full_disk_read_access(&self) -> bool
pub fn has_full_disk_read_access(&self) -> bool
Returns true when filesystem reads are unrestricted.
Sourcepub fn has_full_disk_write_access(&self) -> bool
pub fn has_full_disk_write_access(&self) -> bool
Returns true when filesystem writes are unrestricted.
Sourcepub fn include_platform_defaults(&self) -> bool
pub fn include_platform_defaults(&self) -> bool
Returns true when platform-default readable roots should be included.
pub fn resolve_access_with_cwd( &self, path: &Path, cwd: &Path, ) -> FileSystemAccessMode
pub fn can_read_path_with_cwd(&self, path: &Path, cwd: &Path) -> bool
pub fn can_write_path_with_cwd(&self, path: &Path, cwd: &Path) -> bool
pub fn with_additional_readable_roots( self, cwd: &Path, additional_readable_roots: &[AbsolutePathBuf], ) -> Self
pub fn with_additional_writable_roots( self, cwd: &Path, additional_writable_roots: &[AbsolutePathBuf], ) -> Self
pub fn needs_direct_runtime_enforcement( &self, network_policy: NetworkSandboxPolicy, cwd: &Path, ) -> bool
Sourcepub fn get_readable_roots_with_cwd(&self, cwd: &Path) -> Vec<AbsolutePathBuf>
pub fn get_readable_roots_with_cwd(&self, cwd: &Path) -> Vec<AbsolutePathBuf>
Returns the explicit readable roots resolved against the provided cwd.
Sourcepub fn get_writable_roots_with_cwd(&self, cwd: &Path) -> Vec<WritableRoot>
pub fn get_writable_roots_with_cwd(&self, cwd: &Path) -> Vec<WritableRoot>
Returns the writable roots together with read-only carveouts resolved against the provided cwd.
Sourcepub fn get_unreadable_roots_with_cwd(&self, cwd: &Path) -> Vec<AbsolutePathBuf>
pub fn get_unreadable_roots_with_cwd(&self, cwd: &Path) -> Vec<AbsolutePathBuf>
Returns explicit unreadable roots resolved against the provided cwd.
pub fn to_legacy_sandbox_policy( &self, network_policy: NetworkSandboxPolicy, cwd: &Path, ) -> Result<SandboxPolicy>
Trait Implementations§
Source§impl Clone for FileSystemSandboxPolicy
impl Clone for FileSystemSandboxPolicy
Source§fn clone(&self) -> FileSystemSandboxPolicy
fn clone(&self) -> FileSystemSandboxPolicy
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 FileSystemSandboxPolicy
impl Debug for FileSystemSandboxPolicy
Source§impl Default for FileSystemSandboxPolicy
impl Default for FileSystemSandboxPolicy
Source§impl<'de> Deserialize<'de> for FileSystemSandboxPolicy
impl<'de> Deserialize<'de> for FileSystemSandboxPolicy
Source§fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>where
__D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl From<&SandboxPolicy> for FileSystemSandboxPolicy
impl From<&SandboxPolicy> for FileSystemSandboxPolicy
Source§fn from(value: &SandboxPolicy) -> Self
fn from(value: &SandboxPolicy) -> Self
Converts to this type from the input type.
Source§impl FromStr for FileSystemSandboxPolicy
impl FromStr for FileSystemSandboxPolicy
Source§impl JsonSchema for FileSystemSandboxPolicy
impl JsonSchema for FileSystemSandboxPolicy
Source§fn schema_name() -> String
fn schema_name() -> String
The name of the generated JSON Schema. Read more
Source§fn schema_id() -> Cow<'static, str>
fn schema_id() -> Cow<'static, str>
Returns a string that uniquely identifies the schema produced by this type. Read more
Source§fn json_schema(generator: &mut SchemaGenerator) -> Schema
fn json_schema(generator: &mut SchemaGenerator) -> Schema
Generates a JSON Schema for this type. Read more
Source§fn is_referenceable() -> bool
fn is_referenceable() -> bool
Whether JSON Schemas generated for this type should be re-used where possible using the
$ref keyword. Read moreSource§impl PartialEq for FileSystemSandboxPolicy
impl PartialEq for FileSystemSandboxPolicy
Source§impl Serialize for FileSystemSandboxPolicy
impl Serialize for FileSystemSandboxPolicy
Source§impl TS for FileSystemSandboxPolicy
impl TS for FileSystemSandboxPolicy
Source§type WithoutGenerics = FileSystemSandboxPolicy
type WithoutGenerics = FileSystemSandboxPolicy
If this type does not have generic parameters, then
WithoutGenerics should just be Self.
If the type does have generic parameters, then all generic parameters must be replaced with
a dummy type, e.g ts_rs::Dummy or ().
The only requirement for these dummy types is that EXPORT_TO must be None. Read moreSource§type OptionInnerType = FileSystemSandboxPolicy
type OptionInnerType = FileSystemSandboxPolicy
If the implementing type is
std::option::Option<T>, then this associated type is set to T.
All other implementations of TS should set this type to Self instead.Source§fn decl_concrete() -> String
fn decl_concrete() -> String
Declaration of this type using the supplied generic arguments.
The resulting TypeScript definition will not be generic. For that, see
TS::decl().
If this type is not generic, then this function is equivalent to TS::decl().Source§fn decl() -> String
fn decl() -> String
Declaration of this type, e.g.
type User = { user_id: number, ... }.
This function will panic if the type has no declaration. Read moreSource§fn inline() -> String
fn inline() -> String
Formats this types definition in TypeScript, e.g
{ user_id: number }.
This function will panic if the type cannot be inlined.Source§fn inline_flattened() -> String
fn inline_flattened() -> String
Flatten a type declaration.
This function will panic if the type cannot be flattened.
This function will panic if the type cannot be flattened.
Source§fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_generics(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all type parameters of this type.
Source§fn output_path() -> Option<PathBuf>
fn output_path() -> Option<PathBuf>
Returns the output path to where
The returned path does not include the base directory from
T should be exported.The returned path does not include the base directory from
TS_RS_EXPORT_DIR. Read moreSource§fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
fn visit_dependencies(v: &mut impl TypeVisitor)where
Self: 'static,
Iterates over all dependency of this type.
Source§fn docs() -> Option<String>
fn docs() -> Option<String>
JSDoc comment to describe this type in TypeScript - when
TS is derived, docs are
automatically read from your doc comments or #[doc = ".."] attributesSource§fn dependencies() -> Vec<Dependency>where
Self: 'static,
fn dependencies() -> Vec<Dependency>where
Self: 'static,
Resolves all dependencies of this type recursively.
Source§fn export() -> Result<(), ExportError>where
Self: 'static,
fn export() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem.
To export this type together with all of its dependencies, use
TS::export_all. Read moreSource§fn export_all() -> Result<(), ExportError>where
Self: 'static,
fn export_all() -> Result<(), ExportError>where
Self: 'static,
Manually export this type to the filesystem, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
fn export_all_to(out_dir: impl AsRef<Path>) -> Result<(), ExportError>where
Self: 'static,
Manually export this type into the given directory, together with all of its dependencies.
To export only this type, without its dependencies, use
To export only this type, without its dependencies, use
TS::export. Read moreSource§fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
fn export_to_string() -> Result<String, ExportError>where
Self: 'static,
impl Eq for FileSystemSandboxPolicy
impl StructuralPartialEq for FileSystemSandboxPolicy
Auto Trait Implementations§
impl Freeze for FileSystemSandboxPolicy
impl RefUnwindSafe for FileSystemSandboxPolicy
impl Send for FileSystemSandboxPolicy
impl Sync for FileSystemSandboxPolicy
impl Unpin for FileSystemSandboxPolicy
impl UnsafeUnpin for FileSystemSandboxPolicy
impl UnwindSafe for FileSystemSandboxPolicy
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