pub struct ActivePermissionProfile {
pub id: String,
pub extends: Option<String>,
pub modifications: Vec<ActivePermissionProfileModification>,
}Expand description
Metadata for the named or implicit built-in permissions profile that
produced the active PermissionProfile.
The runtime must honor PermissionProfile; this sidecar exists so clients
can display stable profile identity without trying to reverse-engineer a
name from the compiled permissions.
Fields§
§id: StringProfile identifier from default_permissions or the implicit built-in
default, such as :workspace or a user-defined [permissions.<id>]
profile.
extends: Option<String>Optional parent profile identifier once permissions profiles support
inheritance. This is always None until that config feature exists.
modifications: Vec<ActivePermissionProfileModification>Bounded user-requested modifications applied on top of the named profile, if any.
Implementations§
Source§impl ActivePermissionProfile
impl ActivePermissionProfile
pub fn new(id: impl Into<String>) -> Self
pub fn with_modifications( self, modifications: Vec<ActivePermissionProfileModification>, ) -> Self
Trait Implementations§
Source§impl Clone for ActivePermissionProfile
impl Clone for ActivePermissionProfile
Source§fn clone(&self) -> ActivePermissionProfile
fn clone(&self) -> ActivePermissionProfile
Returns a duplicate of the value. Read more
1.0.0 (const: unstable) · 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 ActivePermissionProfile
impl Debug for ActivePermissionProfile
Source§impl<'de> Deserialize<'de> for ActivePermissionProfile
impl<'de> Deserialize<'de> for ActivePermissionProfile
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 JsonSchema for ActivePermissionProfile
impl JsonSchema for ActivePermissionProfile
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 ActivePermissionProfile
impl PartialEq for ActivePermissionProfile
Source§fn eq(&self, other: &ActivePermissionProfile) -> bool
fn eq(&self, other: &ActivePermissionProfile) -> bool
Tests for
self and other values to be equal, and is used by ==.Source§impl Serialize for ActivePermissionProfile
impl Serialize for ActivePermissionProfile
Source§impl TS for ActivePermissionProfile
impl TS for ActivePermissionProfile
Source§type WithoutGenerics = ActivePermissionProfile
type WithoutGenerics = ActivePermissionProfile
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 = ActivePermissionProfile
type OptionInnerType = ActivePermissionProfile
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 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 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 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 ActivePermissionProfile
impl StructuralPartialEq for ActivePermissionProfile
Auto Trait Implementations§
impl Freeze for ActivePermissionProfile
impl RefUnwindSafe for ActivePermissionProfile
impl Send for ActivePermissionProfile
impl Sync for ActivePermissionProfile
impl Unpin for ActivePermissionProfile
impl UnsafeUnpin for ActivePermissionProfile
impl UnwindSafe for ActivePermissionProfile
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