#[non_exhaustive]pub struct RumMetricCompute {
pub aggregation_type: RumMetricComputeAggregationType,
pub include_percentiles: Option<bool>,
pub path: Option<String>,
pub additional_properties: BTreeMap<String, Value>,
/* private fields */
}
Expand description
The compute rule to compute the rum-based metric.
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.aggregation_type: RumMetricComputeAggregationType
The type of aggregation to use.
include_percentiles: Option<bool>
Toggle to include or exclude percentile aggregations for distribution metrics.
Only present when aggregation_type
is distribution
.
path: Option<String>
The path to the value the rum-based metric will aggregate on.
Only present when aggregation_type
is distribution
.
additional_properties: BTreeMap<String, Value>
Implementations§
Source§impl RumMetricCompute
impl RumMetricCompute
Sourcepub fn new(
aggregation_type: RumMetricComputeAggregationType,
) -> RumMetricCompute
pub fn new( aggregation_type: RumMetricComputeAggregationType, ) -> RumMetricCompute
Examples found in repository?
examples/v2_rum-metrics_CreateRumMetric.rs (line 20)
17async fn main() {
18 let body = RumMetricCreateRequest::new(RumMetricCreateData::new(
19 RumMetricCreateAttributes::new(
20 RumMetricCompute::new(RumMetricComputeAggregationType::DISTRIBUTION)
21 .include_percentiles(true)
22 .path("@duration".to_string()),
23 RumMetricEventType::SESSION,
24 )
25 .filter(RumMetricFilter::new("@service:web-ui".to_string()))
26 .group_by(vec![
27 RumMetricGroupBy::new("@browser.name".to_string()).tag_name("browser_name".to_string())
28 ])
29 .uniqueness(RumMetricUniqueness::new(
30 RumMetricUniquenessWhen::WHEN_MATCH,
31 )),
32 "examplerummetric".to_string(),
33 RumMetricType::RUM_METRICS,
34 ));
35 let configuration = datadog::Configuration::new();
36 let api = RumMetricsAPI::with_config(configuration);
37 let resp = api.create_rum_metric(body).await;
38 if let Ok(value) = resp {
39 println!("{:#?}", value);
40 } else {
41 println!("{:#?}", resp.unwrap_err());
42 }
43}
Sourcepub fn include_percentiles(self, value: bool) -> Self
pub fn include_percentiles(self, value: bool) -> Self
Examples found in repository?
examples/v2_rum-metrics_CreateRumMetric.rs (line 21)
17async fn main() {
18 let body = RumMetricCreateRequest::new(RumMetricCreateData::new(
19 RumMetricCreateAttributes::new(
20 RumMetricCompute::new(RumMetricComputeAggregationType::DISTRIBUTION)
21 .include_percentiles(true)
22 .path("@duration".to_string()),
23 RumMetricEventType::SESSION,
24 )
25 .filter(RumMetricFilter::new("@service:web-ui".to_string()))
26 .group_by(vec![
27 RumMetricGroupBy::new("@browser.name".to_string()).tag_name("browser_name".to_string())
28 ])
29 .uniqueness(RumMetricUniqueness::new(
30 RumMetricUniquenessWhen::WHEN_MATCH,
31 )),
32 "examplerummetric".to_string(),
33 RumMetricType::RUM_METRICS,
34 ));
35 let configuration = datadog::Configuration::new();
36 let api = RumMetricsAPI::with_config(configuration);
37 let resp = api.create_rum_metric(body).await;
38 if let Ok(value) = resp {
39 println!("{:#?}", value);
40 } else {
41 println!("{:#?}", resp.unwrap_err());
42 }
43}
Sourcepub fn path(self, value: String) -> Self
pub fn path(self, value: String) -> Self
Examples found in repository?
examples/v2_rum-metrics_CreateRumMetric.rs (line 22)
17async fn main() {
18 let body = RumMetricCreateRequest::new(RumMetricCreateData::new(
19 RumMetricCreateAttributes::new(
20 RumMetricCompute::new(RumMetricComputeAggregationType::DISTRIBUTION)
21 .include_percentiles(true)
22 .path("@duration".to_string()),
23 RumMetricEventType::SESSION,
24 )
25 .filter(RumMetricFilter::new("@service:web-ui".to_string()))
26 .group_by(vec![
27 RumMetricGroupBy::new("@browser.name".to_string()).tag_name("browser_name".to_string())
28 ])
29 .uniqueness(RumMetricUniqueness::new(
30 RumMetricUniquenessWhen::WHEN_MATCH,
31 )),
32 "examplerummetric".to_string(),
33 RumMetricType::RUM_METRICS,
34 ));
35 let configuration = datadog::Configuration::new();
36 let api = RumMetricsAPI::with_config(configuration);
37 let resp = api.create_rum_metric(body).await;
38 if let Ok(value) = resp {
39 println!("{:#?}", value);
40 } else {
41 println!("{:#?}", resp.unwrap_err());
42 }
43}
pub fn additional_properties(self, value: BTreeMap<String, Value>) -> Self
Trait Implementations§
Source§impl Clone for RumMetricCompute
impl Clone for RumMetricCompute
Source§fn clone(&self) -> RumMetricCompute
fn clone(&self) -> RumMetricCompute
Returns a duplicate of the value. Read more
1.0.0 · 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 RumMetricCompute
impl Debug for RumMetricCompute
Source§impl<'de> Deserialize<'de> for RumMetricCompute
impl<'de> Deserialize<'de> for RumMetricCompute
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 PartialEq for RumMetricCompute
impl PartialEq for RumMetricCompute
Source§impl Serialize for RumMetricCompute
impl Serialize for RumMetricCompute
impl StructuralPartialEq for RumMetricCompute
Auto Trait Implementations§
impl Freeze for RumMetricCompute
impl RefUnwindSafe for RumMetricCompute
impl Send for RumMetricCompute
impl Sync for RumMetricCompute
impl Unpin for RumMetricCompute
impl UnwindSafe for RumMetricCompute
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