<?php
# Generated by the protocol buffer compiler.  DO NOT EDIT!
# source: keyapis/telemetry_alerting/v1/keyapis_telemetry_alerting_trigger_v1.proto

namespace Keyapis\TelemetryAlerting\V1\Trigger;

use Google\Protobuf\Internal\GPBType;
use Google\Protobuf\Internal\RepeatedField;
use Google\Protobuf\Internal\GPBUtil;

/**
 * Определение проблемы, сгенерированной по триггеру
 *
 * Generated from protobuf message <code>keyapis.telemetry_alerting.v1.Trigger.Alert</code>
 */
class Alert extends \Google\Protobuf\Internal\Message
{
    /**
     * Идентификатор
     *
     * Generated from protobuf field <code>int32 id = 1 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     */
    protected $id = 0;
    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * Заполняется при создании и изменении.
     * Является версией объекта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 2 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     */
    protected $changed_at = null;
    /**
     * Породивший триггер
     *
     * Generated from protobuf field <code>int32 trigger_id = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $trigger_id = 0;
    /**
     * ФИАС
     *
     * Generated from protobuf field <code>string fias_id = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $fias_id = '';
    /**
     * Время возникновения алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp raised_at = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $raised_at = null;
    /**
     * Признак погашенного алерта.
     * Проставляется сервисом при no_alarm_checks_count >= success_threshold
     *
     * Generated from protobuf field <code>bool is_disabled = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $is_disabled = false;
    /**
     * Количество проверок триггера для атрибутов данного алерта, при которых не выполнился критерий триггера.
     * Увеличивается у непогашенного алерта, если при очередной проверке нет срабатывания триггера с атрибутами данного алерта.
     * При увеличении проставляется changed_at
     *
     * Generated from protobuf field <code>int32 no_alarm_checks_count = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $no_alarm_checks_count = 0;
    /**
     * Типы метрик, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.MetricType trigger_metric_types = 8;</code>
     */
    private $trigger_metric_types;
    /**
     * Модели устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated string device_models = 9;</code>
     */
    private $device_models;
    /**
     * Типы устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.DeviceType trigger_device_types = 10;</code>
     */
    private $trigger_device_types;
    /**
     * Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *
     * Generated from protobuf field <code>.google.protobuf.Int32Value device_parent_id = 11;</code>
     */
    protected $device_parent_id = null;
    /**
     * Время погашения алерта.
     * Пустой или отсутствует у непогашенного активного алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp closed_at = 12;</code>
     */
    protected $closed_at = null;
    /**
     * Признак принудительного погашения алерта
     *
     * Generated from protobuf field <code>bool is_manually_closed = 13;</code>
     */
    protected $is_manually_closed = false;
    /**
     * Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue closing_reason = 14;</code>
     */
    protected $closing_reason = null;
    /**
     * Группировка метрик при вычислении критерия
     *
     * Generated from protobuf field <code>.keyapis.telemetry_alerting.v1.Trigger.MetricGroupingType trigger_metric_grouping_type = 15;</code>
     */
    protected $trigger_metric_grouping_type = 0;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type int $id
     *           Идентификатор
     *     @type \Google\Protobuf\Timestamp $changed_at
     *           Дата последнего изменения.
     *           Заполняется и обновляется сервером.
     *           Заполняется при создании и изменении.
     *           Является версией объекта
     *     @type int $trigger_id
     *           Породивший триггер
     *     @type string $fias_id
     *           ФИАС
     *     @type \Google\Protobuf\Timestamp $raised_at
     *           Время возникновения алерта
     *     @type bool $is_disabled
     *           Признак погашенного алерта.
     *           Проставляется сервисом при no_alarm_checks_count >= success_threshold
     *     @type int $no_alarm_checks_count
     *           Количество проверок триггера для атрибутов данного алерта, при которых не выполнился критерий триггера.
     *           Увеличивается у непогашенного алерта, если при очередной проверке нет срабатывания триггера с атрибутами данного алерта.
     *           При увеличении проставляется changed_at
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $trigger_metric_types
     *           Типы метрик, по которым были отфильтрованы метрики
     *     @type array<string>|\Google\Protobuf\Internal\RepeatedField $device_models
     *           Модели устройств, по которым были отфильтрованы метрики
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $trigger_device_types
     *           Типы устройств, по которым были отфильтрованы метрики
     *     @type \Google\Protobuf\Int32Value $device_parent_id
     *           Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *     @type \Google\Protobuf\Timestamp $closed_at
     *           Время погашения алерта.
     *           Пустой или отсутствует у непогашенного активного алерта
     *     @type bool $is_manually_closed
     *           Признак принудительного погашения алерта
     *     @type \Google\Protobuf\StringValue $closing_reason
     *           Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *     @type int $trigger_metric_grouping_type
     *           Группировка метрик при вычислении критерия
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\TelemetryAlerting\V1\KeyapisTelemetryAlertingTriggerV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Идентификатор
     *
     * Generated from protobuf field <code>int32 id = 1 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @return int
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Идентификатор
     *
     * Generated from protobuf field <code>int32 id = 1 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @param int $var
     * @return $this
     */
    public function setId($var)
    {
        GPBUtil::checkInt32($var);
        $this->id = $var;

        return $this;
    }

    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * Заполняется при создании и изменении.
     * Является версией объекта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 2 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getChangedAt()
    {
        return $this->changed_at;
    }

    public function hasChangedAt()
    {
        return isset($this->changed_at);
    }

    public function clearChangedAt()
    {
        unset($this->changed_at);
    }

    /**
     * Дата последнего изменения.
     * Заполняется и обновляется сервером.
     * Заполняется при создании и изменении.
     * Является версией объекта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp changed_at = 2 [(.google.api.field_behavior) = OUTPUT_ONLY];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setChangedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->changed_at = $var;

        return $this;
    }

    /**
     * Породивший триггер
     *
     * Generated from protobuf field <code>int32 trigger_id = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getTriggerId()
    {
        return $this->trigger_id;
    }

    /**
     * Породивший триггер
     *
     * Generated from protobuf field <code>int32 trigger_id = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setTriggerId($var)
    {
        GPBUtil::checkInt32($var);
        $this->trigger_id = $var;

        return $this;
    }

    /**
     * ФИАС
     *
     * Generated from protobuf field <code>string fias_id = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getFiasId()
    {
        return $this->fias_id;
    }

    /**
     * ФИАС
     *
     * Generated from protobuf field <code>string fias_id = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setFiasId($var)
    {
        GPBUtil::checkString($var, True);
        $this->fias_id = $var;

        return $this;
    }

    /**
     * Время возникновения алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp raised_at = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getRaisedAt()
    {
        return $this->raised_at;
    }

    public function hasRaisedAt()
    {
        return isset($this->raised_at);
    }

    public function clearRaisedAt()
    {
        unset($this->raised_at);
    }

    /**
     * Время возникновения алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp raised_at = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setRaisedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->raised_at = $var;

        return $this;
    }

    /**
     * Признак погашенного алерта.
     * Проставляется сервисом при no_alarm_checks_count >= success_threshold
     *
     * Generated from protobuf field <code>bool is_disabled = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return bool
     */
    public function getIsDisabled()
    {
        return $this->is_disabled;
    }

    /**
     * Признак погашенного алерта.
     * Проставляется сервисом при no_alarm_checks_count >= success_threshold
     *
     * Generated from protobuf field <code>bool is_disabled = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param bool $var
     * @return $this
     */
    public function setIsDisabled($var)
    {
        GPBUtil::checkBool($var);
        $this->is_disabled = $var;

        return $this;
    }

    /**
     * Количество проверок триггера для атрибутов данного алерта, при которых не выполнился критерий триггера.
     * Увеличивается у непогашенного алерта, если при очередной проверке нет срабатывания триггера с атрибутами данного алерта.
     * При увеличении проставляется changed_at
     *
     * Generated from protobuf field <code>int32 no_alarm_checks_count = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getNoAlarmChecksCount()
    {
        return $this->no_alarm_checks_count;
    }

    /**
     * Количество проверок триггера для атрибутов данного алерта, при которых не выполнился критерий триггера.
     * Увеличивается у непогашенного алерта, если при очередной проверке нет срабатывания триггера с атрибутами данного алерта.
     * При увеличении проставляется changed_at
     *
     * Generated from protobuf field <code>int32 no_alarm_checks_count = 7 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setNoAlarmChecksCount($var)
    {
        GPBUtil::checkInt32($var);
        $this->no_alarm_checks_count = $var;

        return $this;
    }

    /**
     * Типы метрик, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.MetricType trigger_metric_types = 8;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getTriggerMetricTypes()
    {
        return $this->trigger_metric_types;
    }

    /**
     * Типы метрик, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.MetricType trigger_metric_types = 8;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setTriggerMetricTypes($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::ENUM, \Keyapis\TelemetryAlerting\V1\Trigger\MetricType::class);
        $this->trigger_metric_types = $arr;

        return $this;
    }

    /**
     * Модели устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated string device_models = 9;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getDeviceModels()
    {
        return $this->device_models;
    }

    /**
     * Модели устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated string device_models = 9;</code>
     * @param array<string>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setDeviceModels($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::STRING);
        $this->device_models = $arr;

        return $this;
    }

    /**
     * Типы устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.DeviceType trigger_device_types = 10;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getTriggerDeviceTypes()
    {
        return $this->trigger_device_types;
    }

    /**
     * Типы устройств, по которым были отфильтрованы метрики
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_alerting.v1.Trigger.DeviceType trigger_device_types = 10;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setTriggerDeviceTypes($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::ENUM, \Keyapis\TelemetryAlerting\V1\Trigger\DeviceType::class);
        $this->trigger_device_types = $arr;

        return $this;
    }

    /**
     * Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *
     * Generated from protobuf field <code>.google.protobuf.Int32Value device_parent_id = 11;</code>
     * @return \Google\Protobuf\Int32Value|null
     */
    public function getDeviceParentId()
    {
        return $this->device_parent_id;
    }

    public function hasDeviceParentId()
    {
        return isset($this->device_parent_id);
    }

    public function clearDeviceParentId()
    {
        unset($this->device_parent_id);
    }

    /**
     * Returns the unboxed value from <code>getDeviceParentId()</code>

     * Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *
     * Generated from protobuf field <code>.google.protobuf.Int32Value device_parent_id = 11;</code>
     * @return int|null
     */
    public function getDeviceParentIdUnwrapped()
    {
        return $this->readWrapperValue("device_parent_id");
    }

    /**
     * Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *
     * Generated from protobuf field <code>.google.protobuf.Int32Value device_parent_id = 11;</code>
     * @param \Google\Protobuf\Int32Value $var
     * @return $this
     */
    public function setDeviceParentId($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Int32Value::class);
        $this->device_parent_id = $var;

        return $this;
    }

    /**
     * Sets the field by wrapping a primitive type in a Google\Protobuf\Int32Value object.

     * Идентификаторы родительских устройств, по которому были сгруппированы метрики
     *
     * Generated from protobuf field <code>.google.protobuf.Int32Value device_parent_id = 11;</code>
     * @param int|null $var
     * @return $this
     */
    public function setDeviceParentIdUnwrapped($var)
    {
        $this->writeWrapperValue("device_parent_id", $var);
        return $this;}

    /**
     * Время погашения алерта.
     * Пустой или отсутствует у непогашенного активного алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp closed_at = 12;</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getClosedAt()
    {
        return $this->closed_at;
    }

    public function hasClosedAt()
    {
        return isset($this->closed_at);
    }

    public function clearClosedAt()
    {
        unset($this->closed_at);
    }

    /**
     * Время погашения алерта.
     * Пустой или отсутствует у непогашенного активного алерта
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp closed_at = 12;</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setClosedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->closed_at = $var;

        return $this;
    }

    /**
     * Признак принудительного погашения алерта
     *
     * Generated from protobuf field <code>bool is_manually_closed = 13;</code>
     * @return bool
     */
    public function getIsManuallyClosed()
    {
        return $this->is_manually_closed;
    }

    /**
     * Признак принудительного погашения алерта
     *
     * Generated from protobuf field <code>bool is_manually_closed = 13;</code>
     * @param bool $var
     * @return $this
     */
    public function setIsManuallyClosed($var)
    {
        GPBUtil::checkBool($var);
        $this->is_manually_closed = $var;

        return $this;
    }

    /**
     * Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue closing_reason = 14;</code>
     * @return \Google\Protobuf\StringValue|null
     */
    public function getClosingReason()
    {
        return $this->closing_reason;
    }

    public function hasClosingReason()
    {
        return isset($this->closing_reason);
    }

    public function clearClosingReason()
    {
        unset($this->closing_reason);
    }

    /**
     * Returns the unboxed value from <code>getClosingReason()</code>

     * Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue closing_reason = 14;</code>
     * @return string|null
     */
    public function getClosingReasonUnwrapped()
    {
        return $this->readWrapperValue("closing_reason");
    }

    /**
     * Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue closing_reason = 14;</code>
     * @param \Google\Protobuf\StringValue $var
     * @return $this
     */
    public function setClosingReason($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\StringValue::class);
        $this->closing_reason = $var;

        return $this;
    }

    /**
     * Sets the field by wrapping a primitive type in a Google\Protobuf\StringValue object.

     * Причина принудительного закрытия, заполняется в момент принудительного закрытия
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue closing_reason = 14;</code>
     * @param string|null $var
     * @return $this
     */
    public function setClosingReasonUnwrapped($var)
    {
        $this->writeWrapperValue("closing_reason", $var);
        return $this;}

    /**
     * Группировка метрик при вычислении критерия
     *
     * Generated from protobuf field <code>.keyapis.telemetry_alerting.v1.Trigger.MetricGroupingType trigger_metric_grouping_type = 15;</code>
     * @return int
     */
    public function getTriggerMetricGroupingType()
    {
        return $this->trigger_metric_grouping_type;
    }

    /**
     * Группировка метрик при вычислении критерия
     *
     * Generated from protobuf field <code>.keyapis.telemetry_alerting.v1.Trigger.MetricGroupingType trigger_metric_grouping_type = 15;</code>
     * @param int $var
     * @return $this
     */
    public function setTriggerMetricGroupingType($var)
    {
        GPBUtil::checkEnum($var, \Keyapis\TelemetryAlerting\V1\Trigger\MetricGroupingType::class);
        $this->trigger_metric_grouping_type = $var;

        return $this;
    }

}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(Alert::class, \Keyapis\TelemetryAlerting\V1\Trigger_Alert::class);

