1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
// Code generated by software.amazon.smithy.rust.codegen.smithy-rs. DO NOT EDIT.
/// <p>Defines the parameters and conditions used to evaluate and filter security findings.</p>
#[non_exhaustive]
#[derive(::std::clone::Clone, ::std::cmp::PartialEq, ::std::fmt::Debug)]
pub enum Criteria {
/// <p>The filtering conditions that align with OCSF standards.</p>
OcsfFindingCriteria(crate::types::OcsfFindingFilters),
/// The `Unknown` variant represents cases where new union variant was received. Consider upgrading the SDK to the latest available version.
/// An unknown enum variant
///
/// _Note: If you encounter this error, consider upgrading your SDK to the latest version._
/// The `Unknown` variant represents cases where the server sent a value that wasn't recognized
/// by the client. This can happen when the server adds new functionality, but the client has not been updated.
/// To investigate this, consider turning on debug logging to print the raw HTTP response.
#[non_exhaustive]
Unknown,
}
impl Criteria {
#[allow(irrefutable_let_patterns)]
/// Tries to convert the enum instance into [`OcsfFindingCriteria`](crate::types::Criteria::OcsfFindingCriteria), extracting the inner [`OcsfFindingFilters`](crate::types::OcsfFindingFilters).
/// Returns `Err(&Self)` if it can't be converted.
pub fn as_ocsf_finding_criteria(&self) -> ::std::result::Result<&crate::types::OcsfFindingFilters, &Self> {
if let Criteria::OcsfFindingCriteria(val) = &self {
::std::result::Result::Ok(val)
} else {
::std::result::Result::Err(self)
}
}
/// Returns true if this is a [`OcsfFindingCriteria`](crate::types::Criteria::OcsfFindingCriteria).
pub fn is_ocsf_finding_criteria(&self) -> bool {
self.as_ocsf_finding_criteria().is_ok()
}
/// Returns true if the enum instance is the `Unknown` variant.
pub fn is_unknown(&self) -> bool {
matches!(self, Self::Unknown)
}
}