cedar_policy

Enum SchemaError

Source
#[non_exhaustive]
pub enum SchemaError {
Show 25 variants JsonSerialization(JsonSerializationError), JsonDeserialization(JsonDeserializationError), ActionTransitiveClosure(ActionTransitiveClosureError), EntityTypeTransitiveClosure(EntityTypeTransitiveClosureError), UnsupportedFeature(UnsupportedFeatureError), UndeclaredEntityTypes(UndeclaredEntityTypesError), TypeNotDefined(TypeNotDefinedError), ActionNotDefined(ActionNotDefinedError), TypeShadowing(TypeShadowingError), ActionShadowing(ActionShadowingError), DuplicateEntityType(DuplicateEntityTypeError), DuplicateAction(DuplicateActionError), DuplicateCommonType(DuplicateCommonTypeError), CycleInActionHierarchy(CycleInActionHierarchyError), CycleInCommonTypeReferences(CycleInCommonTypeReferencesError), ActionEntityTypeDeclared(ActionEntityTypeDeclaredError), ContextOrShapeNotRecord(ContextOrShapeNotRecordError), ActionAttributesContainEmptySet(ActionAttributesContainEmptySetError), UnsupportedActionAttribute(UnsupportedActionAttributeError), ActionAttrEval(ActionAttrEvalError), ExprEscapeUsed(ExprEscapeUsedError), UnknownExtensionType(UnknownExtensionTypeError), ReservedName(ReservedNameError), CommonTypeInvariantViolation(CommonTypeInvariantViolationError), ActionInvariantViolation(ActionInvariantViolationError),
}
Expand description

Error when constructing a schema

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

JsonSerialization(JsonSerializationError)

Error thrown by the serde_json crate during serialization

§

JsonDeserialization(JsonDeserializationError)

This error is thrown when serde_json fails to deserialize the JSON

§

ActionTransitiveClosure(ActionTransitiveClosureError)

Errors occurring while computing or enforcing transitive closure on action hierarchy.

§

EntityTypeTransitiveClosure(EntityTypeTransitiveClosureError)

Errors occurring while computing or enforcing transitive closure on entity type hierarchy.

§

UnsupportedFeature(UnsupportedFeatureError)

Error generated when processing a schema file that uses unsupported features

§

UndeclaredEntityTypes(UndeclaredEntityTypesError)

Undeclared entity type(s) used in the memberOf field of an entity type, the appliesTo fields of an action, or an attribute type in a context or entity attribute record. Entity types in the error message are fully qualified, including any implicit or explicit namespaces.

§

TypeNotDefined(TypeNotDefinedError)

This error occurs when we cannot resolve a typename (because it refers to an entity type or common type that was not defined).

§

ActionNotDefined(ActionNotDefinedError)

This error occurs when we cannot resolve an action name used in the memberOf field of an action (because it refers to an action that was not defined).

§

TypeShadowing(TypeShadowingError)

Entity/common type shadowing error. Some shadowing relationships are not allowed for clarity reasons; see RFC 70.

§

ActionShadowing(ActionShadowingError)

Action shadowing error. Some shadowing relationships are not allowed for clarity reasons; see RFC 70.

§

DuplicateEntityType(DuplicateEntityTypeError)

Duplicate specifications for an entity type

§

DuplicateAction(DuplicateActionError)

Duplicate specifications for an action

§

DuplicateCommonType(DuplicateCommonTypeError)

Duplicate specification for a common type declaration

§

CycleInActionHierarchy(CycleInActionHierarchyError)

Cycle in the schema’s action hierarchy.

§

CycleInCommonTypeReferences(CycleInCommonTypeReferencesError)

Cycle in the schema’s common type declarations.

§

ActionEntityTypeDeclared(ActionEntityTypeDeclaredError)

The schema file included an entity type Action in the entity type list. The Action entity type is always implicitly declared, and it cannot currently have attributes or be in any groups, so there is no purposes in adding an explicit entry.

§

ContextOrShapeNotRecord(ContextOrShapeNotRecordError)

context or shape fields are not records

§

ActionAttributesContainEmptySet(ActionAttributesContainEmptySetError)

An action entity (transitively) has an attribute that is an empty set. The validator cannot assign a type to an empty set. This error variant should only be used when PermitAttributes is enabled.

§

UnsupportedActionAttribute(UnsupportedActionAttributeError)

An action entity (transitively) has an attribute of unsupported type (ExprEscape, EntityEscape or ExtnEscape). This error variant should only be used when PermitAttributes is enabled.

§

ActionAttrEval(ActionAttrEvalError)

Error when evaluating an action attribute

§

ExprEscapeUsed(ExprEscapeUsedError)

Error thrown when the schema contains the __expr escape. Support for this escape form has been dropped.

§

UnknownExtensionType(UnknownExtensionTypeError)

The schema used an extension type that the validator doesn’t know about.

§

ReservedName(ReservedNameError)

The schema used a reserved namespace or typename (as of this writing, just __cedar).

§

CommonTypeInvariantViolation(CommonTypeInvariantViolationError)

Could not find a definition for a common type, at a point in the code where internal invariants should guarantee that we would find one.

§

ActionInvariantViolation(ActionInvariantViolationError)

Could not find a definition for an action, at a point in the code where internal invariants should guarantee that we would find one.

Implementations§

Source§

impl SchemaError

Source

pub fn join_nonempty(errs: NonEmpty<SchemaError>) -> SchemaError

Given one or more SchemaError, collect them into a single SchemaError. Due to current structures, some errors may have to be dropped in some cases.

Trait Implementations§

Source§

impl Debug for SchemaError

Source§

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

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

impl Diagnostic for SchemaError

Source§

fn code(&self) -> Option<Box<dyn Display + '_>>

Unique diagnostic code that can be used to look up more information about this Diagnostic. Ideally also globally unique, and documented in the toplevel crate’s documentation for easy searching. Rust path format (foo::bar::baz) is recommended, but more classic codes like E0123 or enums will work just fine.
Source§

fn help(&self) -> Option<Box<dyn Display + '_>>

Additional help text related to this Diagnostic. Do you have any advice for the poor soul who’s just run into this issue?
Source§

fn severity(&self) -> Option<Severity>

Diagnostic severity. This may be used by ReportHandlers to change the display format of this diagnostic. Read more
Source§

fn labels(&self) -> Option<Box<dyn Iterator<Item = LabeledSpan> + '_>>

Labels to apply to this Diagnostic’s Diagnostic::source_code
Source§

fn source_code(&self) -> Option<&dyn SourceCode>

Source code to apply this Diagnostic’s Diagnostic::labels to.
Source§

fn related(&self) -> Option<Box<dyn Iterator<Item = &dyn Diagnostic> + '_>>

Additional related Diagnostics.
Source§

fn url(&self) -> Option<Box<dyn Display + '_>>

URL to visit for a more detailed explanation/help about this Diagnostic.
Source§

fn diagnostic_source(&self) -> Option<&dyn Diagnostic>

The cause of the error.
Source§

impl Display for SchemaError

Source§

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

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

impl Error for SchemaError

Source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
1.0.0 · Source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
1.0.0 · Source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
Source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
Source§

impl From<ActionAttrEvalError> for SchemaError

Source§

fn from(source: ActionAttrEvalError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionAttributesContainEmptySetError> for SchemaError

Source§

fn from(source: ActionAttributesContainEmptySetError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionEntityTypeDeclaredError> for SchemaError

Source§

fn from(source: ActionEntityTypeDeclaredError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionInvariantViolationError> for SchemaError

Source§

fn from(source: ActionInvariantViolationError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionNotDefinedError> for SchemaError

Source§

fn from(source: ActionNotDefinedError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionShadowingError> for SchemaError

Source§

fn from(source: ActionShadowingError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ActionTransitiveClosureError> for SchemaError

Source§

fn from(source: ActionTransitiveClosureError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<CommonTypeInvariantViolationError> for SchemaError

Source§

fn from(source: CommonTypeInvariantViolationError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ContextOrShapeNotRecordError> for SchemaError

Source§

fn from(source: ContextOrShapeNotRecordError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<CycleInActionHierarchyError> for SchemaError

Source§

fn from(source: CycleInActionHierarchyError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<CycleInCommonTypeReferencesError> for SchemaError

Source§

fn from(source: CycleInCommonTypeReferencesError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<DuplicateActionError> for SchemaError

Source§

fn from(source: DuplicateActionError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<DuplicateCommonTypeError> for SchemaError

Source§

fn from(source: DuplicateCommonTypeError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<DuplicateEntityTypeError> for SchemaError

Source§

fn from(source: DuplicateEntityTypeError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<EntityTypeTransitiveClosureError> for SchemaError

Source§

fn from(source: EntityTypeTransitiveClosureError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ExprEscapeUsedError> for SchemaError

Source§

fn from(source: ExprEscapeUsedError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<JsonDeserializationError> for SchemaError

Source§

fn from(source: JsonDeserializationError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<JsonSerializationError> for SchemaError

Source§

fn from(source: JsonSerializationError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<ReservedNameError> for SchemaError

Source§

fn from(source: ReservedNameError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<SchemaError> for CedarSchemaError

Source§

fn from(source: SchemaError) -> Self

Converts to this type from the input type.
Source§

impl From<TcError<EntityUID>> for SchemaError

Source§

fn from(e: TcError<EntityUID>) -> SchemaError

Converts to this type from the input type.
Source§

impl From<TypeNotDefinedError> for SchemaError

Source§

fn from(source: TypeNotDefinedError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<TypeShadowingError> for SchemaError

Source§

fn from(source: TypeShadowingError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<UndeclaredEntityTypesError> for SchemaError

Source§

fn from(source: UndeclaredEntityTypesError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<UnsupportedActionAttributeError> for SchemaError

Source§

fn from(source: UnsupportedActionAttributeError) -> SchemaError

Converts to this type from the input type.
Source§

impl From<UnsupportedFeatureError> for SchemaError

Source§

fn from(source: UnsupportedFeatureError) -> SchemaError

Converts to this type from the input type.

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> 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> IntoEither for T

Source§

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 more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

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 more
Source§

impl<T> ToSmolStr for T
where T: Display + ?Sized,

Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

default fn to_string(&self) -> String

Converts the given value to a String. 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.