Struct ServiceLevelObjective

Source
#[non_exhaustive]
pub struct ServiceLevelObjective {
Show 18 fields pub created_at: Option<i64>, pub creator: Option<Creator>, pub description: Option<Option<String>>, pub groups: Option<Vec<String>>, pub id: Option<String>, pub modified_at: Option<i64>, pub monitor_ids: Option<Vec<i64>>, pub monitor_tags: Option<Vec<String>>, pub name: String, pub query: Option<ServiceLevelObjectiveQuery>, pub sli_specification: Option<SLOSliSpec>, pub tags: Option<Vec<String>>, pub target_threshold: Option<f64>, pub thresholds: Vec<SLOThreshold>, pub timeframe: Option<SLOTimeframe>, pub type_: SLOType, pub warning_threshold: Option<f64>, pub additional_properties: BTreeMap<String, Value>, /* private fields */
}
Expand description

A service level objective object includes a service level indicator, thresholds for one or more timeframes, and metadata (name, description, tags, etc.).

Fields (Non-exhaustive)§

This struct is marked as non-exhaustive
Non-exhaustive structs could have additional fields added in future. Therefore, non-exhaustive structs cannot be constructed in external crates using the traditional Struct { .. } syntax; cannot be matched against without a wildcard ..; and struct update syntax will not work.
§created_at: Option<i64>

Creation timestamp (UNIX time in seconds)

Always included in service level objective responses.

§creator: Option<Creator>

Object describing the creator of the shared element.

§description: Option<Option<String>>

A user-defined description of the service level objective.

Always included in service level objective responses (but may be null). Optional in create/update requests.

§groups: Option<Vec<String>>

A list of (up to 100) monitor groups that narrow the scope of a monitor service level objective.

Included in service level objective responses if it is not empty. Optional in create/update requests for monitor service level objectives, but may only be used when then length of the monitor_ids field is one.

§id: Option<String>

A unique identifier for the service level objective object.

Always included in service level objective responses.

§modified_at: Option<i64>

Modification timestamp (UNIX time in seconds)

Always included in service level objective responses.

§monitor_ids: Option<Vec<i64>>

A list of monitor ids that defines the scope of a monitor service level objective. Required if type is monitor.

§monitor_tags: Option<Vec<String>>

The union of monitor tags for all monitors referenced by the monitor_ids field. Always included in service level objective responses for monitor-based service level objectives (but may be empty). Ignored in create/update requests. Does not affect which monitors are included in the service level objective (that is determined entirely by the monitor_ids field).

§name: String

The name of the service level objective object.

§query: Option<ServiceLevelObjectiveQuery>

A metric-based SLO. Required if type is metric. Note that Datadog only allows the sum by aggregator to be used because this will sum up all request counts instead of averaging them, or taking the max or min of all of those requests.

§sli_specification: Option<SLOSliSpec>

A generic SLI specification. This is currently used for time-slice SLOs only.

§tags: Option<Vec<String>>

A list of tags associated with this service level objective. Always included in service level objective responses (but may be empty). Optional in create/update requests.

§target_threshold: Option<f64>

The target threshold such that when the service level indicator is above this threshold over the given timeframe, the objective is being met.

§thresholds: Vec<SLOThreshold>

The thresholds (timeframes and associated targets) for this service level objective object.

§timeframe: Option<SLOTimeframe>

The SLO time window options. Note that “custom” is not a valid option for creating or updating SLOs. It is only used when querying SLO history over custom timeframes.

§type_: SLOType

The type of the service level objective.

§warning_threshold: Option<f64>

The optional warning threshold such that when the service level indicator is below this value for the given threshold, but above the target threshold, the objective appears in a “warning” state. This value must be greater than the target threshold.

§additional_properties: BTreeMap<String, Value>

Implementations§

Source§

impl ServiceLevelObjective

Source

pub fn new( name: String, thresholds: Vec<SLOThreshold>, type_: SLOType, ) -> ServiceLevelObjective

Examples found in repository?
examples/v1_service-level-objectives_UpdateSLO.rs (lines 15-19)
11async fn main() {
12    // there is a valid "slo" in the system
13    let slo_data_0_id = std::env::var("SLO_DATA_0_ID").unwrap();
14    let slo_data_0_name = std::env::var("SLO_DATA_0_NAME").unwrap();
15    let body = ServiceLevelObjective::new(
16        slo_data_0_name.clone(),
17        vec![SLOThreshold::new(97.0, SLOTimeframe::SEVEN_DAYS).warning(98.0 as f64)],
18        SLOType::METRIC,
19    )
20    .query(ServiceLevelObjectiveQuery::new(
21        "sum:httpservice.hits{!code:3xx}.as_count()".to_string(),
22        "sum:httpservice.hits{code:2xx}.as_count()".to_string(),
23    ))
24    .target_threshold(97.0 as f64)
25    .timeframe(SLOTimeframe::SEVEN_DAYS)
26    .warning_threshold(98.0 as f64);
27    let configuration = datadog::Configuration::new();
28    let api = ServiceLevelObjectivesAPI::with_config(configuration);
29    let resp = api.update_slo(slo_data_0_id.clone(), body).await;
30    if let Ok(value) = resp {
31        println!("{:#?}", value);
32    } else {
33        println!("{:#?}", resp.unwrap_err());
34    }
35}
Source

pub fn created_at(self, value: i64) -> Self

Source

pub fn creator(self, value: Creator) -> Self

Source

pub fn description(self, value: Option<String>) -> Self

Source

pub fn groups(self, value: Vec<String>) -> Self

Source

pub fn id(self, value: String) -> Self

Source

pub fn modified_at(self, value: i64) -> Self

Source

pub fn monitor_ids(self, value: Vec<i64>) -> Self

Source

pub fn monitor_tags(self, value: Vec<String>) -> Self

Source

pub fn query(self, value: ServiceLevelObjectiveQuery) -> Self

Examples found in repository?
examples/v1_service-level-objectives_UpdateSLO.rs (lines 20-23)
11async fn main() {
12    // there is a valid "slo" in the system
13    let slo_data_0_id = std::env::var("SLO_DATA_0_ID").unwrap();
14    let slo_data_0_name = std::env::var("SLO_DATA_0_NAME").unwrap();
15    let body = ServiceLevelObjective::new(
16        slo_data_0_name.clone(),
17        vec![SLOThreshold::new(97.0, SLOTimeframe::SEVEN_DAYS).warning(98.0 as f64)],
18        SLOType::METRIC,
19    )
20    .query(ServiceLevelObjectiveQuery::new(
21        "sum:httpservice.hits{!code:3xx}.as_count()".to_string(),
22        "sum:httpservice.hits{code:2xx}.as_count()".to_string(),
23    ))
24    .target_threshold(97.0 as f64)
25    .timeframe(SLOTimeframe::SEVEN_DAYS)
26    .warning_threshold(98.0 as f64);
27    let configuration = datadog::Configuration::new();
28    let api = ServiceLevelObjectivesAPI::with_config(configuration);
29    let resp = api.update_slo(slo_data_0_id.clone(), body).await;
30    if let Ok(value) = resp {
31        println!("{:#?}", value);
32    } else {
33        println!("{:#?}", resp.unwrap_err());
34    }
35}
Source

pub fn sli_specification(self, value: SLOSliSpec) -> Self

Source

pub fn tags(self, value: Vec<String>) -> Self

Source

pub fn target_threshold(self, value: f64) -> Self

Examples found in repository?
examples/v1_service-level-objectives_UpdateSLO.rs (line 24)
11async fn main() {
12    // there is a valid "slo" in the system
13    let slo_data_0_id = std::env::var("SLO_DATA_0_ID").unwrap();
14    let slo_data_0_name = std::env::var("SLO_DATA_0_NAME").unwrap();
15    let body = ServiceLevelObjective::new(
16        slo_data_0_name.clone(),
17        vec![SLOThreshold::new(97.0, SLOTimeframe::SEVEN_DAYS).warning(98.0 as f64)],
18        SLOType::METRIC,
19    )
20    .query(ServiceLevelObjectiveQuery::new(
21        "sum:httpservice.hits{!code:3xx}.as_count()".to_string(),
22        "sum:httpservice.hits{code:2xx}.as_count()".to_string(),
23    ))
24    .target_threshold(97.0 as f64)
25    .timeframe(SLOTimeframe::SEVEN_DAYS)
26    .warning_threshold(98.0 as f64);
27    let configuration = datadog::Configuration::new();
28    let api = ServiceLevelObjectivesAPI::with_config(configuration);
29    let resp = api.update_slo(slo_data_0_id.clone(), body).await;
30    if let Ok(value) = resp {
31        println!("{:#?}", value);
32    } else {
33        println!("{:#?}", resp.unwrap_err());
34    }
35}
Source

pub fn timeframe(self, value: SLOTimeframe) -> Self

Examples found in repository?
examples/v1_service-level-objectives_UpdateSLO.rs (line 25)
11async fn main() {
12    // there is a valid "slo" in the system
13    let slo_data_0_id = std::env::var("SLO_DATA_0_ID").unwrap();
14    let slo_data_0_name = std::env::var("SLO_DATA_0_NAME").unwrap();
15    let body = ServiceLevelObjective::new(
16        slo_data_0_name.clone(),
17        vec![SLOThreshold::new(97.0, SLOTimeframe::SEVEN_DAYS).warning(98.0 as f64)],
18        SLOType::METRIC,
19    )
20    .query(ServiceLevelObjectiveQuery::new(
21        "sum:httpservice.hits{!code:3xx}.as_count()".to_string(),
22        "sum:httpservice.hits{code:2xx}.as_count()".to_string(),
23    ))
24    .target_threshold(97.0 as f64)
25    .timeframe(SLOTimeframe::SEVEN_DAYS)
26    .warning_threshold(98.0 as f64);
27    let configuration = datadog::Configuration::new();
28    let api = ServiceLevelObjectivesAPI::with_config(configuration);
29    let resp = api.update_slo(slo_data_0_id.clone(), body).await;
30    if let Ok(value) = resp {
31        println!("{:#?}", value);
32    } else {
33        println!("{:#?}", resp.unwrap_err());
34    }
35}
Source

pub fn warning_threshold(self, value: f64) -> Self

Examples found in repository?
examples/v1_service-level-objectives_UpdateSLO.rs (line 26)
11async fn main() {
12    // there is a valid "slo" in the system
13    let slo_data_0_id = std::env::var("SLO_DATA_0_ID").unwrap();
14    let slo_data_0_name = std::env::var("SLO_DATA_0_NAME").unwrap();
15    let body = ServiceLevelObjective::new(
16        slo_data_0_name.clone(),
17        vec![SLOThreshold::new(97.0, SLOTimeframe::SEVEN_DAYS).warning(98.0 as f64)],
18        SLOType::METRIC,
19    )
20    .query(ServiceLevelObjectiveQuery::new(
21        "sum:httpservice.hits{!code:3xx}.as_count()".to_string(),
22        "sum:httpservice.hits{code:2xx}.as_count()".to_string(),
23    ))
24    .target_threshold(97.0 as f64)
25    .timeframe(SLOTimeframe::SEVEN_DAYS)
26    .warning_threshold(98.0 as f64);
27    let configuration = datadog::Configuration::new();
28    let api = ServiceLevelObjectivesAPI::with_config(configuration);
29    let resp = api.update_slo(slo_data_0_id.clone(), body).await;
30    if let Ok(value) = resp {
31        println!("{:#?}", value);
32    } else {
33        println!("{:#?}", resp.unwrap_err());
34    }
35}
Source

pub fn additional_properties(self, value: BTreeMap<String, Value>) -> Self

Trait Implementations§

Source§

impl Clone for ServiceLevelObjective

Source§

fn clone(&self) -> ServiceLevelObjective

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ServiceLevelObjective

Source§

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

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

impl<'de> Deserialize<'de> for ServiceLevelObjective

Source§

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 PartialEq for ServiceLevelObjective

Source§

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

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl StructuralPartialEq for ServiceLevelObjective

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> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. 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.
Source§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

Source§

fn vzip(self) -> V

Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

Source§

impl<T> ErasedDestructor for T
where T: 'static,