PropertiesSchema

Struct PropertiesSchema 

Source
pub struct PropertiesSchema {
    pub properties: HashMap<String, Box<dyn Serializable>>,
    pub optional_properties: HashMap<String, Box<dyn Serializable>>,
    pub is_strict: Option<bool>,
    pub metadata: Option<MetadataSchema>,
    pub is_nullable: Option<bool>,
}
Expand description

Represents a schema for properties in an Arri schema.

This struct defines the properties, optional properties, and metadata associated with a schema. It also includes flags for strictness and nullability.

Fields§

§properties: HashMap<String, Box<dyn Serializable>>

A map of required properties, where the key is the property name and the value is a serializable object.

§optional_properties: HashMap<String, Box<dyn Serializable>>

A map of optional properties, where the key is the property name and the value is a serializable object.

§is_strict: Option<bool>

Indicates whether the schema is strict. If Some(true), the schema enforces strict validation.

§metadata: Option<MetadataSchema>

Metadata associated with the schema.

§is_nullable: Option<bool>

Indicates whether the schema allows null values. If Some(true), null values are permitted.

Implementations§

Source§

impl PropertiesSchema

Source

pub fn new() -> PropertiesSchema

Creates a new PropertiesSchema instance with default values.

Source

pub fn set_property( &mut self, key: impl ToString, value: Box<dyn Serializable>, ) -> &mut PropertiesSchema

Adds or updates a required property in the schema.

§Arguments
  • key - The name of the property.
  • value - A serializable object representing the property value.
§Returns

A mutable reference to the PropertiesSchema instance.

Source

pub fn set_optional_property( &mut self, key: impl ToString, value: Box<dyn Serializable>, ) -> &mut PropertiesSchema

Adds or updates an optional property in the schema.

§Arguments
  • key - The name of the property.
  • value - A serializable object representing the property value.
§Returns

A mutable reference to the PropertiesSchema instance.

Source

pub fn set_strict(&mut self, strict: bool) -> &mut PropertiesSchema

Sets the strictness flag for the schema.

§Arguments
  • strict - A boolean indicating whether the schema should enforce strict validation.
§Returns

A mutable reference to the PropertiesSchema instance.

Trait Implementations§

Source§

impl Debug for PropertiesSchema

Source§

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

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

impl Default for PropertiesSchema

Source§

fn default() -> PropertiesSchema

Returns the “default value” for a type. Read more
Source§

impl PartialEq for PropertiesSchema

Source§

fn eq(&self, other: &PropertiesSchema) -> 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 Serializable for PropertiesSchema

Source§

fn serialize(&self) -> Option<String>

Serializes the PropertiesSchema into a string representation.

§Returns

An Option<String> containing the serialized schema, or None if serialization fails.

Source§

fn set_metadata(&mut self, metadata: MetadataSchema)

Sets the metadata for the schema.

§Arguments
  • metadata - A MetadataSchema object to be merged with the existing metadata.
Source§

fn set_nullable(&mut self, is_nullable: bool)

Sets the nullability flag for the schema.

§Arguments
  • is_nullable - A boolean indicating whether null values are allowed.
Source§

fn set_rename(&mut self, new_name: &str)

Renames the object. Read more
Source§

impl Eq for PropertiesSchema

Source§

impl StructuralPartialEq for PropertiesSchema

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> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Converts Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Converts &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Converts &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
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, 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.