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

namespace Keyapis\TelemetryMetric\V1;

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

/**
 * Фильтр измерений.
 * При передаче массива в параметр фильтра элементы массива работают в выборке через ИЛИ.
 * При передаче нескольких разных параметров фильтра они работают в выборке через И
 *
 * Generated from protobuf message <code>keyapis.telemetry_metric.v1.MeasurementFilter</code>
 */
class MeasurementFilter extends \Google\Protobuf\Internal\Message
{
    /**
     * По ФИАСам
     *
     * Generated from protobuf field <code>repeated string fias_ids = 1;</code>
     */
    private $fias_ids;
    /**
     * По идентификаторам
     *
     * Generated from protobuf field <code>repeated int32 device_ids = 2;</code>
     */
    private $device_ids;
    /**
     * По идентификаторам индикаторов
     *
     * Generated from protobuf field <code>repeated int32 indicator_ids = 3;</code>
     */
    private $indicator_ids;
    /**
     * От даты синхронизации включительно (>=)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp begin_synced_at = 4;</code>
     */
    protected $begin_synced_at = null;
    /**
     * До даты синхронизации (<)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp end_synced_at = 5;</code>
     */
    protected $end_synced_at = null;
    /**
     * По моделям устройств
     *
     * Generated from protobuf field <code>repeated string device_models = 6;</code>
     */
    private $device_models;
    /**
     * По типам устройств
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_metric.v1.Measurement.DeviceType device_types = 7;</code>
     */
    private $device_types;
    /**
     * По типам измерений
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_metric.v1.Measurement.MetricType metric_types = 8;</code>
     */
    private $metric_types;
    /**
     * Ограничение результатов только пограничными значениями для периода.
     * Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     * Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     * Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     * Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     *
     * Generated from protobuf field <code>.google.protobuf.BoolValue is_border_measurements_only = 9;</code>
     */
    protected $is_border_measurements_only = null;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type array<string>|\Google\Protobuf\Internal\RepeatedField $fias_ids
     *           По ФИАСам
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $device_ids
     *           По идентификаторам
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $indicator_ids
     *           По идентификаторам индикаторов
     *     @type \Google\Protobuf\Timestamp $begin_synced_at
     *           От даты синхронизации включительно (>=)
     *     @type \Google\Protobuf\Timestamp $end_synced_at
     *           До даты синхронизации (<)
     *     @type array<string>|\Google\Protobuf\Internal\RepeatedField $device_models
     *           По моделям устройств
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $device_types
     *           По типам устройств
     *     @type array<int>|\Google\Protobuf\Internal\RepeatedField $metric_types
     *           По типам измерений
     *     @type \Google\Protobuf\BoolValue $is_border_measurements_only
     *           Ограничение результатов только пограничными значениями для периода.
     *           Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     *           Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     *           Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     *           Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     *           Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     *           Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\TelemetryMetric\V1\KeyapisTelemetryMetricMeasurementV1::initOnce();
        parent::__construct($data);
    }

    /**
     * По ФИАСам
     *
     * Generated from protobuf field <code>repeated string fias_ids = 1;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getFiasIds()
    {
        return $this->fias_ids;
    }

    /**
     * По ФИАСам
     *
     * Generated from protobuf field <code>repeated string fias_ids = 1;</code>
     * @param array<string>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setFiasIds($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::STRING);
        $this->fias_ids = $arr;

        return $this;
    }

    /**
     * По идентификаторам
     *
     * Generated from protobuf field <code>repeated int32 device_ids = 2;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getDeviceIds()
    {
        return $this->device_ids;
    }

    /**
     * По идентификаторам
     *
     * Generated from protobuf field <code>repeated int32 device_ids = 2;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setDeviceIds($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::INT32);
        $this->device_ids = $arr;

        return $this;
    }

    /**
     * По идентификаторам индикаторов
     *
     * Generated from protobuf field <code>repeated int32 indicator_ids = 3;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getIndicatorIds()
    {
        return $this->indicator_ids;
    }

    /**
     * По идентификаторам индикаторов
     *
     * Generated from protobuf field <code>repeated int32 indicator_ids = 3;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setIndicatorIds($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::INT32);
        $this->indicator_ids = $arr;

        return $this;
    }

    /**
     * От даты синхронизации включительно (>=)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp begin_synced_at = 4;</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getBeginSyncedAt()
    {
        return $this->begin_synced_at;
    }

    public function hasBeginSyncedAt()
    {
        return isset($this->begin_synced_at);
    }

    public function clearBeginSyncedAt()
    {
        unset($this->begin_synced_at);
    }

    /**
     * От даты синхронизации включительно (>=)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp begin_synced_at = 4;</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setBeginSyncedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->begin_synced_at = $var;

        return $this;
    }

    /**
     * До даты синхронизации (<)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp end_synced_at = 5;</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getEndSyncedAt()
    {
        return $this->end_synced_at;
    }

    public function hasEndSyncedAt()
    {
        return isset($this->end_synced_at);
    }

    public function clearEndSyncedAt()
    {
        unset($this->end_synced_at);
    }

    /**
     * До даты синхронизации (<)
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp end_synced_at = 5;</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setEndSyncedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->end_synced_at = $var;

        return $this;
    }

    /**
     * По моделям устройств
     *
     * Generated from protobuf field <code>repeated string device_models = 6;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getDeviceModels()
    {
        return $this->device_models;
    }

    /**
     * По моделям устройств
     *
     * Generated from protobuf field <code>repeated string device_models = 6;</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_metric.v1.Measurement.DeviceType device_types = 7;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getDeviceTypes()
    {
        return $this->device_types;
    }

    /**
     * По типам устройств
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_metric.v1.Measurement.DeviceType device_types = 7;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setDeviceTypes($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::ENUM, \Keyapis\TelemetryMetric\V1\Measurement\DeviceType::class);
        $this->device_types = $arr;

        return $this;
    }

    /**
     * По типам измерений
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_metric.v1.Measurement.MetricType metric_types = 8;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getMetricTypes()
    {
        return $this->metric_types;
    }

    /**
     * По типам измерений
     *
     * Generated from protobuf field <code>repeated .keyapis.telemetry_metric.v1.Measurement.MetricType metric_types = 8;</code>
     * @param array<int>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setMetricTypes($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::ENUM, \Keyapis\TelemetryMetric\V1\Measurement\MetricType::class);
        $this->metric_types = $arr;

        return $this;
    }

    /**
     * Ограничение результатов только пограничными значениями для периода.
     * Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     * Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     * Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     * Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     *
     * Generated from protobuf field <code>.google.protobuf.BoolValue is_border_measurements_only = 9;</code>
     * @return \Google\Protobuf\BoolValue|null
     */
    public function getIsBorderMeasurementsOnly()
    {
        return $this->is_border_measurements_only;
    }

    public function hasIsBorderMeasurementsOnly()
    {
        return isset($this->is_border_measurements_only);
    }

    public function clearIsBorderMeasurementsOnly()
    {
        unset($this->is_border_measurements_only);
    }

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

     * Ограничение результатов только пограничными значениями для периода.
     * Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     * Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     * Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     * Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     *
     * Generated from protobuf field <code>.google.protobuf.BoolValue is_border_measurements_only = 9;</code>
     * @return bool|null
     */
    public function getIsBorderMeasurementsOnlyUnwrapped()
    {
        return $this->readWrapperValue("is_border_measurements_only");
    }

    /**
     * Ограничение результатов только пограничными значениями для периода.
     * Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     * Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     * Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     * Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     *
     * Generated from protobuf field <code>.google.protobuf.BoolValue is_border_measurements_only = 9;</code>
     * @param \Google\Protobuf\BoolValue $var
     * @return $this
     */
    public function setIsBorderMeasurementsOnly($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\BoolValue::class);
        $this->is_border_measurements_only = $var;

        return $this;
    }

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

     * Ограничение результатов только пограничными значениями для периода.
     * Если border_measurements_only=null возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если border_measurements_only=falsе возвращаем измерения по условиям фильтра, уникальные по (indicator_id, synced_at).
     * Если заданы border_measurements_only=true, begin_synced_at, end_synced_at возвращаем два измерения ближайшие к границам периода.
     * Если заданы border_measurements_only=true, и не задана end_synced_at возвращаем одно измерение ближайшее к begin_synced_at.
     * Если заданы border_measurements_only=true, и не задана begin_synced_at возвращаем одно измерение ближайшее к end_synced_at.
     * Если заданы border_measurements_only=true и не заданы begin_synced_at и end_synced_at возвращаем ошибку валидации параметров
     *
     * Generated from protobuf field <code>.google.protobuf.BoolValue is_border_measurements_only = 9;</code>
     * @param bool|null $var
     * @return $this
     */
    public function setIsBorderMeasurementsOnlyUnwrapped($var)
    {
        $this->writeWrapperValue("is_border_measurements_only", $var);
        return $this;}

}

