MetricDefinitionRequest  
    Use this structure to define one extended metric or custom metric that RUM will send to CloudWatch or CloudWatch Evidently. For more information, see Custom metrics and extended metrics that you can send to CloudWatch and CloudWatch Evidently.
This structure is validated differently for extended metrics and custom metrics. For extended metrics that are sent to the AWS/RUM namespace, the following validations apply:
- The - Namespaceparameter must be omitted or set to- AWS/RUM.
- Only certain combinations of values for - Name,- ValueKey, and- EventPatternare valid. In addition to what is displayed in the following list, the- EventPatterncan also include information used by the- DimensionKeysfield.
- If - Nameis- PerformanceNavigationDuration, then- ValueKeymust be- event_details.durationand the- EventPatternmust include- {"event_type":["com.amazon.rum.performance_navigation_event"]}
- If - Nameis- PerformanceResourceDuration, then- ValueKeymust be- event_details.durationand the- EventPatternmust include- {"event_type":["com.amazon.rum.performance_resource_event"]}
- If - Nameis- NavigationSatisfiedTransaction, then- ValueKeymust be null and the- EventPatternmust include- { "event_type": ["com.amazon.rum.performance_navigation_event"], "event_details": { "duration": [{ "numeric": [">",2000] }] } }
- If - Nameis- NavigationToleratedTransaction, then- ValueKeymust be null and the- EventPatternmust include- { "event_type": ["com.amazon.rum.performance_navigation_event"], "event_details": { "duration": [{ "numeric": [">=",2000,"<"8000] }] } }
- If - Nameis- NavigationFrustratedTransaction, then- ValueKeymust be null and the- EventPatternmust include- { "event_type": ["com.amazon.rum.performance_navigation_event"], "event_details": { "duration": [{ "numeric": [">=",8000] }] } }
- If - Nameis- WebVitalsCumulativeLayoutShift, then- ValueKeymust be- event_details.valueand the- EventPatternmust include- {"event_type":["com.amazon.rum.cumulative_layout_shift_event"]}
- If - Nameis- WebVitalsFirstInputDelay, then- ValueKeymust be- event_details.valueand the- EventPatternmust include- {"event_type":["com.amazon.rum.first_input_delay_event"]}
- If - Nameis- WebVitalsLargestContentfulPaint, then- ValueKeymust be- event_details.valueand the- EventPatternmust include- {"event_type":["com.amazon.rum.largest_contentful_paint_event"]}
- If - Nameis- JsErrorCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type":["com.amazon.rum.js_error_event"]}
- If - Nameis- HttpErrorCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type":["com.amazon.rum.http_event"]}
- If - Nameis- SessionCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type":["com.amazon.rum.session_start_event"]}
- If - Nameis- PageViewCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type":["com.amazon.rum.page_view_event"]}
- If - Nameis- Http4xxCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type": ["com.amazon.rum.http_event"],"event_details":{"response":{"status":[{"numeric":[">=",400,"<",500]}]}}} }
- If - Nameis- Http5xxCount, then- ValueKeymust be null and the- EventPatternmust include- {"event_type": ["com.amazon.rum.http_event"],"event_details":{"response":{"status":[{"numeric":[">=",500,"<=",599]}]}}} }
For custom metrics, the following validation rules apply:
- The namespace can't be omitted and can't be - AWS/RUM. You can use the- AWS/RUMnamespace only for extended metrics.
- All dimensions listed in the - DimensionKeysfield must be present in the value of- EventPattern.
- The values that you specify for - ValueKey,- EventPattern, and- DimensionKeysmust be fields in RUM events, so all first-level keys in these fields must be one of the keys in the list later in this section.
- If you set a value for - EventPattern, it must be a JSON object.
- For every non-empty - event_details, there must be a non-empty- event_type.
- If - EventPatterncontains an- event_detailsfield, it must also contain an- event_type. For every built-in- event_typethat you use, you must use a value for- event_detailsthat corresponds to that- event_type. For information about event details that correspond to event types, see RUM event details.
- In - EventPattern, any JSON array must contain only one value.
Valid key values for first-level keys in the ValueKey, EventPattern, and DimensionKeys fields:
- account_id
- application_Id
- application_version
- application_name
- batch_id
- event_details
- event_id
- event_interaction
- event_timestamp
- event_type
- event_version
- log_stream
- metadata
- sessionId
- user_details
- userId
Types
Properties
Use this field only if you are sending the metric to CloudWatch.
The pattern that defines the metric, specified as a JSON object. RUM checks events that happen in a user's session against the pattern, and events that match the pattern are sent to the metric destination.