📂 File Browser

AgentAI/vendor/google/apiclient-services/src/Monitoring
🌙 Dark Mode
🎯 Quick Launch:

📁 Directories

📁 Resource/ 🔓 Open

📄 Files

🐘 Aggregation.php
▶ Open 📄 View Source
🐘 Alert.php
▶ Open 📄 View Source
🐘 AlertPolicy.php
▶ Open 📄 View Source
🐘 AlertStrategy.php
▶ Open 📄 View Source
🐘 AppEngine.php
▶ Open 📄 View Source
🐘 AvailabilityCriteria.php
▶ Open 📄 View Source
🐘 BasicAuthentication.php
▶ Open 📄 View Source
🐘 BasicService.php
▶ Open 📄 View Source
🐘 BasicSli.php
▶ Open 📄 View Source
🐘 BooleanTest.php
▶ Open 📄 View Source
🐘 BucketOptions.php
▶ Open 📄 View Source
🐘 CloudEndpoints.php
▶ Open 📄 View Source
🐘 CloudFunctionV2Target.php
▶ Open 📄 View Source
🐘 CloudRun.php
▶ Open 📄 View Source
🐘 ClusterIstio.php
▶ Open 📄 View Source
🐘 CollectdPayload.php
▶ Open 📄 View Source
🐘 CollectdPayloadError.php
▶ Open 📄 View Source
🐘 CollectdValue.php
▶ Open 📄 View Source
🐘 CollectdValueError.php
▶ Open 📄 View Source
🐘 Condition.php
▶ Open 📄 View Source
🐘 ContentMatcher.php
▶ Open 📄 View Source
🐘 CreateCollectdTimeSeriesRequest.php
▶ Open 📄 View Source
🐘 CreateCollectdTimeSeriesResponse.php
▶ Open 📄 View Source
🐘 CreateTimeSeriesRequest.php
▶ Open 📄 View Source
🐘 CreateTimeSeriesSummary.php
▶ Open 📄 View Source
🐘 Criteria.php
▶ Open 📄 View Source
🐘 Custom.php
▶ Open 📄 View Source
🐘 Daily.php
▶ Open 📄 View Source
🐘 Distribution.php
▶ Open 📄 View Source
🐘 DistributionCut.php
▶ Open 📄 View Source
🐘 Documentation.php
▶ Open 📄 View Source
🐘 DroppedLabels.php
▶ Open 📄 View Source
🐘 Error.php
▶ Open 📄 View Source
🐘 Exemplar.php
▶ Open 📄 View Source
🐘 Explicit.php
▶ Open 📄 View Source
🐘 Exponential.php
▶ Open 📄 View Source
🐘 Field.php
▶ Open 📄 View Source
🐘 ForecastOptions.php
▶ Open 📄 View Source
🐘 GetNotificationChannelVerificationCodeRequest.php
▶ Open 📄 View Source
🐘 GetNotificationChannelVerificationCodeResponse.php
▶ Open 📄 View Source
🐘 GkeNamespace.php
▶ Open 📄 View Source
🐘 GkeService.php
▶ Open 📄 View Source
🐘 GkeWorkload.php
▶ Open 📄 View Source
🐘 GoogleMonitoringV3Range.php
▶ Open 📄 View Source
🐘 Group.php
▶ Open 📄 View Source
🐘 Hourly.php
▶ Open 📄 View Source
🐘 HttpCheck.php
▶ Open 📄 View Source
🐘 InternalChecker.php
▶ Open 📄 View Source
🐘 IstioCanonicalService.php
▶ Open 📄 View Source
🐘 JsonPathMatcher.php
▶ Open 📄 View Source
🐘 LabelDescriptor.php
▶ Open 📄 View Source
🐘 LabelValue.php
▶ Open 📄 View Source
🐘 LatencyCriteria.php
▶ Open 📄 View Source
🐘 Linear.php
▶ Open 📄 View Source
🐘 Link.php
▶ Open 📄 View Source
🐘 ListAlertPoliciesResponse.php
▶ Open 📄 View Source
🐘 ListAlertsResponse.php
▶ Open 📄 View Source
🐘 ListGroupMembersResponse.php
▶ Open 📄 View Source
🐘 ListGroupsResponse.php
▶ Open 📄 View Source
🐘 ListMetricDescriptorsResponse.php
▶ Open 📄 View Source
🐘 ListMonitoredResourceDescriptorsResponse.php
▶ Open 📄 View Source
🐘 ListNotificationChannelDescriptorsResponse.php
▶ Open 📄 View Source
🐘 ListNotificationChannelsResponse.php
▶ Open 📄 View Source
🐘 ListServiceLevelObjectivesResponse.php
▶ Open 📄 View Source
🐘 ListServicesResponse.php
▶ Open 📄 View Source
🐘 ListSnoozesResponse.php
▶ Open 📄 View Source
🐘 ListTimeSeriesResponse.php
▶ Open 📄 View Source
🐘 ListUptimeCheckConfigsResponse.php
▶ Open 📄 View Source
🐘 ListUptimeCheckIpsResponse.php
▶ Open 📄 View Source
🐘 LogMatch.php
▶ Open 📄 View Source
🐘 LogMetadata.php
▶ Open 📄 View Source
🐘 MeshIstio.php
▶ Open 📄 View Source
🐘 Metric.php
▶ Open 📄 View Source
🐘 MetricAbsence.php
▶ Open 📄 View Source
🐘 MetricDescriptor.php
▶ Open 📄 View Source
🐘 MetricDescriptorMetadata.php
▶ Open 📄 View Source
🐘 MetricRange.php
▶ Open 📄 View Source
🐘 MetricThreshold.php
▶ Open 📄 View Source
🐘 Minutes.php
▶ Open 📄 View Source
🐘 MonitoredResource.php
▶ Open 📄 View Source
🐘 MonitoredResourceDescriptor.php
▶ Open 📄 View Source
🐘 MonitoredResourceMetadata.php
▶ Open 📄 View Source
🐘 MonitoringEmpty.php
▶ Open 📄 View Source
🐘 MonitoringQueryLanguageCondition.php
▶ Open 📄 View Source
🐘 MutationRecord.php
▶ Open 📄 View Source
🐘 NotificationChannel.php
▶ Open 📄 View Source
🐘 NotificationChannelDescriptor.php
▶ Open 📄 View Source
🐘 NotificationChannelStrategy.php
▶ Open 📄 View Source
🐘 NotificationRateLimit.php
▶ Open 📄 View Source
🐘 OperationMetadata.php
▶ Open 📄 View Source
🐘 Option.php
▶ Open 📄 View Source
🐘 PerformanceThreshold.php
▶ Open 📄 View Source
🐘 PingConfig.php
▶ Open 📄 View Source
🐘 Point.php
▶ Open 📄 View Source
🐘 PointData.php
▶ Open 📄 View Source
🐘 PolicySnapshot.php
▶ Open 📄 View Source
🐘 PrometheusQueryLanguageCondition.php
▶ Open 📄 View Source
🐘 QueryTimeSeriesRequest.php
▶ Open 📄 View Source
🐘 QueryTimeSeriesResponse.php
▶ Open 📄 View Source
🐘 Range.php
▶ Open 📄 View Source
🐘 RequestBasedSli.php
▶ Open 📄 View Source
🐘 ResourceGroup.php
▶ Open 📄 View Source
🐘 ResponseStatusCode.php
▶ Open 📄 View Source
🐘 RowCountTest.php
▶ Open 📄 View Source
🐘 SendNotificationChannelVerificationCodeRequest.php
▶ Open 📄 View Source
🐘 Service.php
▶ Open 📄 View Source
🐘 ServiceAgentAuthentication.php
▶ Open 📄 View Source
🐘 ServiceLevelIndicator.php
▶ Open 📄 View Source
🐘 ServiceLevelObjective.php
▶ Open 📄 View Source
🐘 Snooze.php
▶ Open 📄 View Source
🐘 SourceContext.php
▶ Open 📄 View Source
🐘 SpanContext.php
▶ Open 📄 View Source
🐘 SqlCondition.php
▶ Open 📄 View Source
🐘 Status.php
▶ Open 📄 View Source
🐘 SyntheticMonitorTarget.php
▶ Open 📄 View Source
🐘 TcpCheck.php
▶ Open 📄 View Source
🐘 Telemetry.php
▶ Open 📄 View Source
🐘 TimeInterval.php
▶ Open 📄 View Source
🐘 TimeOfDay.php
▶ Open 📄 View Source
🐘 TimeSeries.php
▶ Open 📄 View Source
🐘 TimeSeriesData.php
▶ Open 📄 View Source
🐘 TimeSeriesDescriptor.php
▶ Open 📄 View Source
🐘 TimeSeriesRatio.php
▶ Open 📄 View Source
🐘 Trigger.php
▶ Open 📄 View Source
🐘 Type.php
▶ Open 📄 View Source
🐘 TypedValue.php
▶ Open 📄 View Source
🐘 UptimeCheckConfig.php
▶ Open 📄 View Source
🐘 UptimeCheckIp.php
▶ Open 📄 View Source
🐘 ValueDescriptor.php
▶ Open 📄 View Source
🐘 VerifyNotificationChannelRequest.php
▶ Open 📄 View Source
🐘 WindowsBasedSli.php
▶ Open 📄 View Source

📄 Source: PrometheusQueryLanguageCondition.php

<?php
/*
 * Copyright 2014 Google Inc.
 *
 * 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
 *
 * http://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.
 */

namespace Google\Service\Monitoring;

class PrometheusQueryLanguageCondition extends \Google\Model
{
  /**
   * 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.
   *
   * @var string
   */
  public $alertRule;
  /**
   * Optional. Whether to disable metric existence validation for this
   * condition.This allows alerting policies to be defined on metrics that do
   * not yet exist, improving advanced customer workflows such as configuring
   * alerting policies using Terraform.Users with the
   * monitoring.alertPolicyViewer role are able to see the name of the non-
   * existent metric in the alerting policy condition.
   *
   * @var bool
   */
  public $disableMetricValidation;
  /**
   * 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.
   *
   * @var string
   */
  public $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.
   *
   * @var string
   */
  public $evaluationInterval;
  /**
   * 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#doc-vars). The
   * only available variable names are the names of the labels in the PromQL
   * result, including "__name__" and "value". "labels" may be empty.
   *
   * @var string[]
   */
  public $labels;
  /**
   * 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.
   *
   * @var string
   */
  public $query;
  /**
   * 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.
   *
   * @var string
   */
  public $ruleGroup;

  /**
   * 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.
   *
   * @param string $alertRule
   */
  public function setAlertRule($alertRule)
  {
    $this->alertRule = $alertRule;
  }
  /**
   * @return string
   */
  public function getAlertRule()
  {
    return $this->alertRule;
  }
  /**
   * Optional. Whether to disable metric existence validation for this
   * condition.This allows alerting policies to be defined on metrics that do
   * not yet exist, improving advanced customer workflows such as configuring
   * alerting policies using Terraform.Users with the
   * monitoring.alertPolicyViewer role are able to see the name of the non-
   * existent metric in the alerting policy condition.
   *
   * @param bool $disableMetricValidation
   */
  public function setDisableMetricValidation($disableMetricValidation)
  {
    $this->disableMetricValidation = $disableMetricValidation;
  }
  /**
   * @return bool
   */
  public function getDisableMetricValidation()
  {
    return $this->disableMetricValidation;
  }
  /**
   * 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.
   *
   * @param string $duration
   */
  public function setDuration($duration)
  {
    $this->duration = $duration;
  }
  /**
   * @return string
   */
  public function getDuration()
  {
    return $this->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.
   *
   * @param string $evaluationInterval
   */
  public function setEvaluationInterval($evaluationInterval)
  {
    $this->evaluationInterval = $evaluationInterval;
  }
  /**
   * @return string
   */
  public function getEvaluationInterval()
  {
    return $this->evaluationInterval;
  }
  /**
   * 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#doc-vars). The
   * only available variable names are the names of the labels in the PromQL
   * result, including "__name__" and "value". "labels" may be empty.
   *
   * @param string[] $labels
   */
  public function setLabels($labels)
  {
    $this->labels = $labels;
  }
  /**
   * @return string[]
   */
  public function getLabels()
  {
    return $this->labels;
  }
  /**
   * 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.
   *
   * @param string $query
   */
  public function setQuery($query)
  {
    $this->query = $query;
  }
  /**
   * @return string
   */
  public function getQuery()
  {
    return $this->query;
  }
  /**
   * 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.
   *
   * @param string $ruleGroup
   */
  public function setRuleGroup($ruleGroup)
  {
    $this->ruleGroup = $ruleGroup;
  }
  /**
   * @return string
   */
  public function getRuleGroup()
  {
    return $this->ruleGroup;
  }
}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(PrometheusQueryLanguageCondition::class, 'Google_Service_Monitoring_PrometheusQueryLanguageCondition');
← Back