# frozen_string_literal: true

# Copyright 2020 Google LLC
#
# Licensed under the Apache License, Version 2.0 (the "License");
# you may not use this file except in compliance with the License.
# You may obtain a copy of the License at
#
#     https://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.

# Auto-generated by gapic-generator-ruby. DO NOT EDIT!


module Google
  module Cloud
    module Monitoring
      module V3
        # A description of the conditions under which some aspect of your system is
        # considered to be "unhealthy" and the ways to notify people or services about
        # this state. For an overview of alert policies, see
        # [Introduction to Alerting](https://cloud.google.com/monitoring/alerts/).
        # @!attribute [rw] name
        #   @return [::String]
        #     Required if the policy exists. The resource name for this policy. The
        #     format is:
        #
        #         projects/[PROJECT_ID_OR_NUMBER]/alertPolicies/[ALERT_POLICY_ID]
        #
        #     `[ALERT_POLICY_ID]` is assigned by Cloud Monitoring when the policy
        #     is created. When calling the
        #     {::Google::Cloud::Monitoring::V3::AlertPolicyService::Client#create_alert_policy alertPolicies.create}
        #     method, do not include the `name` field in the alerting policy passed as
        #     part of the request.
        # @!attribute [rw] display_name
        #   @return [::String]
        #     A short name or phrase used to identify the policy in dashboards,
        #     notifications, and incidents. To avoid confusion, don't use the same
        #     display name for multiple policies in the same project. The name is
        #     limited to 512 Unicode characters.
        #
        #     The convention for the display_name of a PrometheusQueryLanguageCondition
        #     is "\\{rule group name}/\\{alert name}", where the \\{rule group name} and
        #     \\{alert name} should be taken from the corresponding Prometheus
        #     configuration file. This convention is not enforced.
        #     In any case the display_name is not a unique key of the AlertPolicy.
        # @!attribute [rw] documentation
        #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Documentation]
        #     Documentation that is included with notifications and incidents related to
        #     this policy. Best practice is for the documentation to include information
        #     to help responders understand, mitigate, escalate, and correct the
        #     underlying problems detected by the alerting policy. Notification channels
        #     that have limited capacity might not show this documentation.
        # @!attribute [rw] user_labels
        #   @return [::Google::Protobuf::Map{::String => ::String}]
        #     User-supplied key/value data to be used for organizing and
        #     identifying the `AlertPolicy` objects.
        #
        #     The field can contain up to 64 entries. Each key and value is limited to
        #     63 Unicode characters or 128 bytes, whichever is smaller. Labels and
        #     values can contain only lowercase letters, numerals, underscores, and
        #     dashes. Keys must begin with a letter.
        #
        #     Note that Prometheus \\{alert name} is a
        #     [valid Prometheus label
        #     names](https://prometheus.io/docs/concepts/data_model/#metric-names-and-labels),
        #     whereas Prometheus \\{rule group} is an unrestricted UTF-8 string.
        #     This means that they cannot be stored as-is in user labels, because
        #     they may contain characters that are not allowed in user-label values.
        # @!attribute [rw] conditions
        #   @return [::Array<::Google::Cloud::Monitoring::V3::AlertPolicy::Condition>]
        #     A list of conditions for the policy. The conditions are combined by AND or
        #     OR according to the `combiner` field. If the combined conditions evaluate
        #     to true, then an incident is created. A policy can have from one to six
        #     conditions.
        #     If `condition_time_series_query_language` is present, it must be the only
        #     `condition`.
        #     If `condition_monitoring_query_language` is present, it must be the only
        #     `condition`.
        # @!attribute [rw] combiner
        #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::ConditionCombinerType]
        #     How to combine the results of multiple conditions to determine if an
        #     incident should be opened.
        #     If `condition_time_series_query_language` is present, this must be
        #     `COMBINE_UNSPECIFIED`.
        # @!attribute [rw] enabled
        #   @return [::Google::Protobuf::BoolValue]
        #     Whether or not the policy is enabled. On write, the default interpretation
        #     if unset is that the policy is enabled. On read, clients should not make
        #     any assumption about the state if it has not been populated. The
        #     field should always be populated on List and Get operations, unless
        #     a field projection has been specified that strips it out.
        # @!attribute [rw] validity
        #   @return [::Google::Rpc::Status]
        #     Read-only description of how the alert policy is invalid. This field is
        #     only set when the alert policy is invalid. An invalid alert policy will not
        #     generate incidents.
        # @!attribute [rw] notification_channels
        #   @return [::Array<::String>]
        #     Identifies the notification channels to which notifications should be sent
        #     when incidents are opened or closed or when new violations occur on
        #     an already opened incident. Each element of this array corresponds to
        #     the `name` field in each of the
        #     {::Google::Cloud::Monitoring::V3::NotificationChannel `NotificationChannel`}
        #     objects that are returned from the [`ListNotificationChannels`]
        #     [google.monitoring.v3.NotificationChannelService.ListNotificationChannels]
        #     method. The format of the entries in this field is:
        #
        #         projects/[PROJECT_ID_OR_NUMBER]/notificationChannels/[CHANNEL_ID]
        # @!attribute [rw] creation_record
        #   @return [::Google::Cloud::Monitoring::V3::MutationRecord]
        #     A read-only record of the creation of the alerting policy. If provided
        #     in a call to create or update, this field will be ignored.
        # @!attribute [rw] mutation_record
        #   @return [::Google::Cloud::Monitoring::V3::MutationRecord]
        #     A read-only record of the most recent change to the alerting policy. If
        #     provided in a call to create or update, this field will be ignored.
        # @!attribute [rw] alert_strategy
        #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::AlertStrategy]
        #     Control over how this alert policy's notification channels are notified.
        # @!attribute [rw] severity
        #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Severity]
        #     Optional. The severity of an alert policy indicates how important incidents
        #     generated by that policy are. The severity level will be displayed on the
        #     Incident detail page and in notifications.
        class AlertPolicy
          include ::Google::Protobuf::MessageExts
          extend ::Google::Protobuf::MessageExts::ClassMethods

          # A content string and a MIME type that describes the content string's
          # format.
          # @!attribute [rw] content
          #   @return [::String]
          #     The body of the documentation, interpreted according to `mime_type`.
          #     The content may not exceed 8,192 Unicode characters and may not exceed
          #     more than 10,240 bytes when encoded in UTF-8 format, whichever is
          #     smaller. This text can be [templatized by using
          #     variables](https://cloud.google.com/monitoring/alerts/doc-variables).
          # @!attribute [rw] mime_type
          #   @return [::String]
          #     The format of the `content` field. Presently, only the value
          #     `"text/markdown"` is supported. See
          #     [Markdown](https://en.wikipedia.org/wiki/Markdown) for more information.
          # @!attribute [rw] subject
          #   @return [::String]
          #     Optional. The subject line of the notification. The subject line may not
          #     exceed 10,240 bytes. In notifications generated by this policy, the
          #     contents of the subject line after variable expansion will be truncated
          #     to 255 bytes or shorter at the latest UTF-8 character boundary. The
          #     255-byte limit is recommended by [this
          #     thread](https://stackoverflow.com/questions/1592291/what-is-the-email-subject-length-limit).
          #     It is both the limit imposed by some third-party ticketing products and
          #     it is common to define textual fields in databases as VARCHAR(255).
          #
          #     The contents of the subject line can be [templatized by using
          #     variables](https://cloud.google.com/monitoring/alerts/doc-variables).
          #     If this field is missing or empty, a default subject line will be
          #     generated.
          class Documentation
            include ::Google::Protobuf::MessageExts
            extend ::Google::Protobuf::MessageExts::ClassMethods
          end

          # A condition is a true/false test that determines when an alerting policy
          # should open an incident. If a condition evaluates to true, it signifies
          # that something is wrong.
          # @!attribute [rw] name
          #   @return [::String]
          #     Required if the condition exists. The unique resource name for this
          #     condition. Its format is:
          #
          #         projects/[PROJECT_ID_OR_NUMBER]/alertPolicies/[POLICY_ID]/conditions/[CONDITION_ID]
          #
          #     `[CONDITION_ID]` is assigned by Cloud Monitoring when the
          #     condition is created as part of a new or updated alerting policy.
          #
          #     When calling the
          #     {::Google::Cloud::Monitoring::V3::AlertPolicyService::Client#create_alert_policy alertPolicies.create}
          #     method, do not include the `name` field in the conditions of the
          #     requested alerting policy. Cloud Monitoring creates the
          #     condition identifiers and includes them in the new policy.
          #
          #     When calling the
          #     {::Google::Cloud::Monitoring::V3::AlertPolicyService::Client#update_alert_policy alertPolicies.update}
          #     method to update a policy, including a condition `name` causes the
          #     existing condition to be updated. Conditions without names are added to
          #     the updated policy. Existing conditions are deleted if they are not
          #     updated.
          #
          #     Best practice is to preserve `[CONDITION_ID]` if you make only small
          #     changes, such as those to condition thresholds, durations, or trigger
          #     values.  Otherwise, treat the change as a new condition and let the
          #     existing condition be deleted.
          # @!attribute [rw] display_name
          #   @return [::String]
          #     A short name or phrase used to identify the condition in dashboards,
          #     notifications, and incidents. To avoid confusion, don't use the same
          #     display name for multiple conditions in the same policy.
          # @!attribute [rw] condition_threshold
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::MetricThreshold]
          #     A condition that compares a time series against a threshold.
          # @!attribute [rw] condition_absent
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::MetricAbsence]
          #     A condition that checks that a time series continues to
          #     receive new data points.
          # @!attribute [rw] condition_matched_log
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::LogMatch]
          #     A condition that checks for log messages matching given constraints. If
          #     set, no other conditions can be present.
          # @!attribute [rw] condition_monitoring_query_language
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::MonitoringQueryLanguageCondition]
          #     A condition that uses the Monitoring Query Language to define
          #     alerts.
          # @!attribute [rw] condition_prometheus_query_language
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::PrometheusQueryLanguageCondition]
          #     A condition that uses the Prometheus query language to define alerts.
          class Condition
            include ::Google::Protobuf::MessageExts
            extend ::Google::Protobuf::MessageExts::ClassMethods

            # Specifies how many time series must fail a predicate to trigger a
            # condition. If not specified, then a `{count: 1}` trigger is used.
            # @!attribute [rw] count
            #   @return [::Integer]
            #     The absolute number of time series that must fail
            #     the predicate for the condition to be triggered.
            # @!attribute [rw] percent
            #   @return [::Float]
            #     The percentage of time series that must fail the
            #     predicate for the condition to be triggered.
            class Trigger
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods
            end

            # A condition type that compares a collection of time series
            # against a threshold.
            # @!attribute [rw] filter
            #   @return [::String]
            #     Required. A
            #     [filter](https://cloud.google.com/monitoring/api/v3/filters) that
            #     identifies which time series should be compared with the threshold.
            #
            #     The filter is similar to the one that is specified in the
            #     [`ListTimeSeries`
            #     request](https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list)
            #     (that call is useful to verify the time series that will be retrieved /
            #     processed). The filter must specify the metric type and the resource
            #     type. Optionally, it can specify resource labels and metric labels.
            #     This field must not exceed 2048 Unicode characters in length.
            # @!attribute [rw] aggregations
            #   @return [::Array<::Google::Cloud::Monitoring::V3::Aggregation>]
            #     Specifies the alignment of data points in individual time series as
            #     well as how to combine the retrieved time series together (such as
            #     when aggregating multiple streams on each resource to a single
            #     stream for each resource or when aggregating streams across all
            #     members of a group of resources). Multiple aggregations
            #     are applied in the order specified.
            #
            #     This field is similar to the one in the [`ListTimeSeries`
            #     request](https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list).
            #     It is advisable to use the `ListTimeSeries` method when debugging this
            #     field.
            # @!attribute [rw] denominator_filter
            #   @return [::String]
            #     A [filter](https://cloud.google.com/monitoring/api/v3/filters) that
            #     identifies a time series that should be used as the denominator of a
            #     ratio that will be compared with the threshold. If a
            #     `denominator_filter` is specified, the time series specified by the
            #     `filter` field will be used as the numerator.
            #
            #     The filter must specify the metric type and optionally may contain
            #     restrictions on resource type, resource labels, and metric labels.
            #     This field may not exceed 2048 Unicode characters in length.
            # @!attribute [rw] denominator_aggregations
            #   @return [::Array<::Google::Cloud::Monitoring::V3::Aggregation>]
            #     Specifies the alignment of data points in individual time series
            #     selected by `denominatorFilter` as
            #     well as how to combine the retrieved time series together (such as
            #     when aggregating multiple streams on each resource to a single
            #     stream for each resource or when aggregating streams across all
            #     members of a group of resources).
            #
            #     When computing ratios, the `aggregations` and
            #     `denominator_aggregations` fields must use the same alignment period
            #     and produce time series that have the same periodicity and labels.
            # @!attribute [rw] forecast_options
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::MetricThreshold::ForecastOptions]
            #     When this field is present, the `MetricThreshold` condition forecasts
            #     whether the time series is predicted to violate the threshold within
            #     the `forecast_horizon`. When this field is not set, the
            #     `MetricThreshold` tests the current value of the timeseries against the
            #     threshold.
            # @!attribute [rw] comparison
            #   @return [::Google::Cloud::Monitoring::V3::ComparisonType]
            #     The comparison to apply between the time series (indicated by `filter`
            #     and `aggregation`) and the threshold (indicated by `threshold_value`).
            #     The comparison is applied on each time series, with the time series
            #     on the left-hand side and the threshold on the right-hand side.
            #
            #     Only `COMPARISON_LT` and `COMPARISON_GT` are supported currently.
            # @!attribute [rw] threshold_value
            #   @return [::Float]
            #     A value against which to compare the time series.
            # @!attribute [rw] duration
            #   @return [::Google::Protobuf::Duration]
            #     The amount of time that a time series must violate the
            #     threshold to be considered failing. Currently, only values
            #     that are a multiple of a minute--e.g., 0, 60, 120, or 300
            #     seconds--are supported. If an invalid value is given, an
            #     error will be returned. When choosing a duration, it is useful to
            #     keep in mind the frequency of the underlying time series data
            #     (which may also be affected by any alignments specified in the
            #     `aggregations` field); a good duration is long enough so that a single
            #     outlier does not generate spurious alerts, but short enough that
            #     unhealthy states are detected and alerted on quickly.
            # @!attribute [rw] trigger
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::Trigger]
            #     The number/percent of time series for which the comparison must hold
            #     in order for the condition to trigger. If unspecified, then the
            #     condition will trigger if the comparison is true for any of the
            #     time series that have been identified by `filter` and `aggregations`,
            #     or by the ratio, if `denominator_filter` and `denominator_aggregations`
            #     are specified.
            # @!attribute [rw] evaluation_missing_data
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::EvaluationMissingData]
            #     A condition control that determines how metric-threshold conditions
            #     are evaluated when data stops arriving.
            class MetricThreshold
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods

              # Options used when forecasting the time series and testing
              # the predicted value against the threshold.
              # @!attribute [rw] forecast_horizon
              #   @return [::Google::Protobuf::Duration]
              #     Required. The length of time into the future to forecast whether a
              #     time series will violate the threshold. If the predicted value is
              #     found to violate the threshold, and the violation is observed in all
              #     forecasts made for the configured `duration`, then the time series is
              #     considered to be failing.
              #     The forecast horizon can range from 1 hour to 60 hours.
              class ForecastOptions
                include ::Google::Protobuf::MessageExts
                extend ::Google::Protobuf::MessageExts::ClassMethods
              end
            end

            # A condition type that checks that monitored resources
            # are reporting data. The configuration defines a metric and
            # a set of monitored resources. The predicate is considered in violation
            # when a time series for the specified metric of a monitored
            # resource does not include any data in the specified `duration`.
            # @!attribute [rw] filter
            #   @return [::String]
            #     Required. A
            #     [filter](https://cloud.google.com/monitoring/api/v3/filters) that
            #     identifies which time series should be compared with the threshold.
            #
            #     The filter is similar to the one that is specified in the
            #     [`ListTimeSeries`
            #     request](https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list)
            #     (that call is useful to verify the time series that will be retrieved /
            #     processed). The filter must specify the metric type and the resource
            #     type. Optionally, it can specify resource labels and metric labels.
            #     This field must not exceed 2048 Unicode characters in length.
            # @!attribute [rw] aggregations
            #   @return [::Array<::Google::Cloud::Monitoring::V3::Aggregation>]
            #     Specifies the alignment of data points in individual time series as
            #     well as how to combine the retrieved time series together (such as
            #     when aggregating multiple streams on each resource to a single
            #     stream for each resource or when aggregating streams across all
            #     members of a group of resources). Multiple aggregations
            #     are applied in the order specified.
            #
            #     This field is similar to the one in the [`ListTimeSeries`
            #     request](https://cloud.google.com/monitoring/api/ref_v3/rest/v3/projects.timeSeries/list).
            #     It is advisable to use the `ListTimeSeries` method when debugging this
            #     field.
            # @!attribute [rw] duration
            #   @return [::Google::Protobuf::Duration]
            #     The amount of time that a time series must fail to report new
            #     data to be considered failing. The minimum value of this field
            #     is 120 seconds. Larger values that are a multiple of a
            #     minute--for example, 240 or 300 seconds--are supported.
            #     If an invalid value is given, an
            #     error will be returned. The `Duration.nanos` field is
            #     ignored.
            # @!attribute [rw] trigger
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::Trigger]
            #     The number/percent of time series for which the comparison must hold
            #     in order for the condition to trigger. If unspecified, then the
            #     condition will trigger if the comparison is true for any of the
            #     time series that have been identified by `filter` and `aggregations`.
            class MetricAbsence
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods
            end

            # A condition type that checks whether a log message in the [scoping
            # project](https://cloud.google.com/monitoring/api/v3#project_name)
            # satisfies the given filter. Logs from other projects in the metrics
            # scope are not evaluated.
            # @!attribute [rw] filter
            #   @return [::String]
            #     Required. A logs-based filter. See [Advanced Logs
            #     Queries](https://cloud.google.com/logging/docs/view/advanced-queries)
            #     for how this filter should be constructed.
            # @!attribute [rw] label_extractors
            #   @return [::Google::Protobuf::Map{::String => ::String}]
            #     Optional. A map from a label key to an extractor expression, which is
            #     used to extract the value for this label key. Each entry in this map is
            #     a specification for how data should be extracted from log entries that
            #     match `filter`. Each combination of extracted values is treated as a
            #     separate rule for the purposes of triggering notifications. Label keys
            #     and corresponding values can be used in notifications generated by this
            #     condition.
            #
            #     Please see [the documentation on logs-based metric
            #     `valueExtractor`s](https://cloud.google.com/logging/docs/reference/v2/rest/v2/projects.metrics#LogMetric.FIELDS.value_extractor)
            #     for syntax and examples.
            class LogMatch
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods

              # @!attribute [rw] key
              #   @return [::String]
              # @!attribute [rw] value
              #   @return [::String]
              class LabelExtractorsEntry
                include ::Google::Protobuf::MessageExts
                extend ::Google::Protobuf::MessageExts::ClassMethods
              end
            end

            # A condition type that allows alert policies to be defined using
            # [Monitoring Query Language](https://cloud.google.com/monitoring/mql).
            # @!attribute [rw] query
            #   @return [::String]
            #     [Monitoring Query Language](https://cloud.google.com/monitoring/mql)
            #     query that outputs a boolean stream.
            # @!attribute [rw] duration
            #   @return [::Google::Protobuf::Duration]
            #     The amount of time that a time series must violate the
            #     threshold to be considered failing. Currently, only values
            #     that are a multiple of a minute--e.g., 0, 60, 120, or 300
            #     seconds--are supported. If an invalid value is given, an
            #     error will be returned. When choosing a duration, it is useful to
            #     keep in mind the frequency of the underlying time series data
            #     (which may also be affected by any alignments specified in the
            #     `aggregations` field); a good duration is long enough so that a single
            #     outlier does not generate spurious alerts, but short enough that
            #     unhealthy states are detected and alerted on quickly.
            # @!attribute [rw] trigger
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::Trigger]
            #     The number/percent of time series for which the comparison must hold
            #     in order for the condition to trigger. If unspecified, then the
            #     condition will trigger if the comparison is true for any of the
            #     time series that have been identified by `filter` and `aggregations`,
            #     or by the ratio, if `denominator_filter` and `denominator_aggregations`
            #     are specified.
            # @!attribute [rw] evaluation_missing_data
            #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::Condition::EvaluationMissingData]
            #     A condition control that determines how metric-threshold conditions
            #     are evaluated when data stops arriving.
            class MonitoringQueryLanguageCondition
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods
            end

            # A condition type that allows alert policies to be defined using
            # [Prometheus Query Language
            # (PromQL)](https://prometheus.io/docs/prometheus/latest/querying/basics/).
            #
            # The PrometheusQueryLanguageCondition message contains information
            # from a Prometheus alerting rule and its associated rule group.
            #
            # A Prometheus alerting rule is described
            # [here](https://prometheus.io/docs/prometheus/latest/configuration/alerting_rules/).
            # The semantics of a Prometheus alerting rule is described
            # [here](https://prometheus.io/docs/prometheus/latest/configuration/recording_rules/#rule).
            #
            # A Prometheus rule group is described
            # [here](https://prometheus.io/docs/prometheus/latest/configuration/recording_rules/).
            # The semantics of a Prometheus rule group is described
            # [here](https://prometheus.io/docs/prometheus/latest/configuration/recording_rules/#rule_group).
            #
            # Because Cloud Alerting has no representation of a Prometheus rule
            # group resource, we must embed the information of the parent rule
            # group inside each of the conditions that refer to it. We must also
            # update the contents of all Prometheus alerts in case the information
            # of their rule group changes.
            #
            # The PrometheusQueryLanguageCondition protocol buffer combines the
            # information of the corresponding rule group and alerting rule.
            # The structure of the PrometheusQueryLanguageCondition protocol buffer
            # does NOT mimic the structure of the Prometheus rule group and alerting
            # rule YAML declarations. The PrometheusQueryLanguageCondition protocol
            # buffer may change in the future to support future rule group and/or
            # alerting rule features. There are no new such features at the present
            # time (2023-06-26).
            # @!attribute [rw] query
            #   @return [::String]
            #     Required. The PromQL expression to evaluate. Every evaluation cycle
            #     this expression is evaluated at the current time, and all resultant
            #     time series become pending/firing alerts. This field must not be empty.
            # @!attribute [rw] duration
            #   @return [::Google::Protobuf::Duration]
            #     Optional. Alerts are considered firing once their PromQL expression was
            #     evaluated to be "true" for this long.
            #     Alerts whose PromQL expression was not evaluated to be "true" for
            #     long enough are considered pending.
            #     Must be a non-negative duration or missing.
            #     This field is optional. Its default value is zero.
            # @!attribute [rw] evaluation_interval
            #   @return [::Google::Protobuf::Duration]
            #     Optional. How often this rule should be evaluated.
            #     Must be a positive multiple of 30 seconds or missing.
            #     This field is optional. Its default value is 30 seconds.
            #     If this PrometheusQueryLanguageCondition was generated from a
            #     Prometheus alerting rule, then this value should be taken from the
            #     enclosing rule group.
            # @!attribute [rw] labels
            #   @return [::Google::Protobuf::Map{::String => ::String}]
            #     Optional. Labels to add to or overwrite in the PromQL query result.
            #     Label names [must be
            #     valid](https://prometheus.io/docs/concepts/data_model/#metric-names-and-labels).
            #     Label values can be [templatized by using
            #     variables](https://cloud.google.com/monitoring/alerts/doc-variables).
            #     The only available variable names are the names of the labels in the
            #     PromQL result, including "__name__" and "value". "labels" may be empty.
            # @!attribute [rw] rule_group
            #   @return [::String]
            #     Optional. The rule group name of this alert in the corresponding
            #     Prometheus configuration file.
            #
            #     Some external tools may require this field to be populated correctly
            #     in order to refer to the original Prometheus configuration file.
            #     The rule group name and the alert name are necessary to update the
            #     relevant AlertPolicies in case the definition of the rule group changes
            #     in the future.
            #
            #     This field is optional. If this field is not empty, then it must
            #     contain a valid UTF-8 string.
            #     This field may not exceed 2048 Unicode characters in length.
            # @!attribute [rw] alert_rule
            #   @return [::String]
            #     Optional. The alerting rule name of this alert in the corresponding
            #     Prometheus configuration file.
            #
            #     Some external tools may require this field to be populated correctly
            #     in order to refer to the original Prometheus configuration file.
            #     The rule group name and the alert name are necessary to update the
            #     relevant AlertPolicies in case the definition of the rule group changes
            #     in the future.
            #
            #     This field is optional. If this field is not empty, then it must be a
            #     [valid Prometheus label
            #     name](https://prometheus.io/docs/concepts/data_model/#metric-names-and-labels).
            #     This field may not exceed 2048 Unicode characters in length.
            class PrometheusQueryLanguageCondition
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods

              # @!attribute [rw] key
              #   @return [::String]
              # @!attribute [rw] value
              #   @return [::String]
              class LabelsEntry
                include ::Google::Protobuf::MessageExts
                extend ::Google::Protobuf::MessageExts::ClassMethods
              end
            end

            # A condition control that determines how metric-threshold conditions
            # are evaluated when data stops arriving.
            # This control doesn't affect metric-absence policies.
            module EvaluationMissingData
              # An unspecified evaluation missing data option.  Equivalent to
              # EVALUATION_MISSING_DATA_NO_OP.
              EVALUATION_MISSING_DATA_UNSPECIFIED = 0

              # If there is no data to evaluate the condition, then evaluate the
              # condition as false.
              EVALUATION_MISSING_DATA_INACTIVE = 1

              # If there is no data to evaluate the condition, then evaluate the
              # condition as true.
              EVALUATION_MISSING_DATA_ACTIVE = 2

              # Do not evaluate the condition to any value if there is no data.
              EVALUATION_MISSING_DATA_NO_OP = 3
            end
          end

          # Control over how the notification channels in `notification_channels`
          # are notified when this alert fires.
          # @!attribute [rw] notification_rate_limit
          #   @return [::Google::Cloud::Monitoring::V3::AlertPolicy::AlertStrategy::NotificationRateLimit]
          #     Required for alert policies with a `LogMatch` condition.
          #
          #     This limit is not implemented for alert policies that are not log-based.
          # @!attribute [rw] auto_close
          #   @return [::Google::Protobuf::Duration]
          #     If an alert policy that was active has no data for this long, any open
          #     incidents will close
          # @!attribute [rw] notification_channel_strategy
          #   @return [::Array<::Google::Cloud::Monitoring::V3::AlertPolicy::AlertStrategy::NotificationChannelStrategy>]
          #     Control how notifications will be sent out, on a per-channel basis.
          class AlertStrategy
            include ::Google::Protobuf::MessageExts
            extend ::Google::Protobuf::MessageExts::ClassMethods

            # Control over the rate of notifications sent to this alert policy's
            # notification channels.
            # @!attribute [rw] period
            #   @return [::Google::Protobuf::Duration]
            #     Not more than one notification per `period`.
            class NotificationRateLimit
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods
            end

            # Control over how the notification channels in `notification_channels`
            # are notified when this alert fires, on a per-channel basis.
            # @!attribute [rw] notification_channel_names
            #   @return [::Array<::String>]
            #     The full REST resource name for the notification channels that these
            #     settings apply to. Each of these correspond to the name field in one
            #     of the NotificationChannel objects referenced in the
            #     notification_channels field of this AlertPolicy.
            #     The format is:
            #
            #         projects/[PROJECT_ID_OR_NUMBER]/notificationChannels/[CHANNEL_ID]
            # @!attribute [rw] renotify_interval
            #   @return [::Google::Protobuf::Duration]
            #     The frequency at which to send reminder notifications for open
            #     incidents.
            class NotificationChannelStrategy
              include ::Google::Protobuf::MessageExts
              extend ::Google::Protobuf::MessageExts::ClassMethods
            end
          end

          # @!attribute [rw] key
          #   @return [::String]
          # @!attribute [rw] value
          #   @return [::String]
          class UserLabelsEntry
            include ::Google::Protobuf::MessageExts
            extend ::Google::Protobuf::MessageExts::ClassMethods
          end

          # Operators for combining conditions.
          module ConditionCombinerType
            # An unspecified combiner.
            COMBINE_UNSPECIFIED = 0

            # Combine conditions using the logical `AND` operator. An
            # incident is created only if all the conditions are met
            # simultaneously. This combiner is satisfied if all conditions are
            # met, even if they are met on completely different resources.
            AND = 1

            # Combine conditions using the logical `OR` operator. An incident
            # is created if any of the listed conditions is met.
            OR = 2

            # Combine conditions using logical `AND` operator, but unlike the regular
            # `AND` option, an incident is created only if all conditions are met
            # simultaneously on at least one resource.
            AND_WITH_MATCHING_RESOURCE = 3
          end

          # An enumeration of possible severity level for an Alert Policy.
          module Severity
            # No severity is specified. This is the default value.
            SEVERITY_UNSPECIFIED = 0

            # This is the highest severity level. Use this if the problem could
            # cause significant damage or downtime.
            CRITICAL = 1

            # This is the medium severity level. Use this if the problem could
            # cause minor damage or downtime.
            ERROR = 2

            # This is the lowest severity level. Use this if the problem is not causing
            # any damage or downtime, but could potentially lead to a problem in the
            # future.
            WARNING = 3
          end
        end
      end
    end
  end
end