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

namespace Keyapis\AccessControl\V1;

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

/**
 * Запрос на запуск массового оповещения через домофоны
 *
 * Generated from protobuf message <code>keyapis.access_control.v1.PostBroadcastAlertStartRequest</code>
 */
class PostBroadcastAlertStartRequest extends \Google\Protobuf\Internal\Message
{
    /**
     * Ссылка на звуковой файл для проигрывания.
     * Файл должен лежать на внутреннем хранилище.
     * # Диапазон: 2..100
     *
     * Generated from protobuf field <code>string sound_file_uri = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $sound_file_uri = '';
    /**
     * Массив ОРПОНов домов, на которых запускаем проигрывание.
     * # Диапазон: 1..100
     *
     * Generated from protobuf field <code>repeated int64 orpons = 2;</code>
     */
    private $orpons;
    /**
     * Длительность воспроизведения такта в секундах.
     * Такт включает в себя проигрывание файла на трубках или на динамике.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_play_duration = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $tact_play_duration = 0;
    /**
     * Количество последовательных повторов тактов перед сменой динамика на трубки или наоборот.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_repeat_count = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $tact_repeat_count = 0;
    /**
     * Количество дополнительных повторов тактов, т.е. умолчание=0 - это проигрывание одного такта.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 play_repeat_count = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $play_repeat_count = 0;
    /**
     * Тип проигрывания
     *
     * Generated from protobuf field <code>.keyapis.access_control.v1.PostBroadcastAlertStartRequest.PlayType play_type = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $play_type = 0;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type string $sound_file_uri
     *           Ссылка на звуковой файл для проигрывания.
     *           Файл должен лежать на внутреннем хранилище.
     *           # Диапазон: 2..100
     *     @type array<int>|array<string>|\Google\Protobuf\Internal\RepeatedField $orpons
     *           Массив ОРПОНов домов, на которых запускаем проигрывание.
     *           # Диапазон: 1..100
     *     @type int $tact_play_duration
     *           Длительность воспроизведения такта в секундах.
     *           Такт включает в себя проигрывание файла на трубках или на динамике.
     *           # Диапазон: 0..65536
     *     @type int $tact_repeat_count
     *           Количество последовательных повторов тактов перед сменой динамика на трубки или наоборот.
     *           # Диапазон: 0..65536
     *     @type int $play_repeat_count
     *           Количество дополнительных повторов тактов, т.е. умолчание=0 - это проигрывание одного такта.
     *           # Диапазон: 0..65536
     *     @type int $play_type
     *           Тип проигрывания
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\AccessControl\V1\KeyapisAccessControlBroadcastAlertV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Ссылка на звуковой файл для проигрывания.
     * Файл должен лежать на внутреннем хранилище.
     * # Диапазон: 2..100
     *
     * Generated from protobuf field <code>string sound_file_uri = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getSoundFileUri()
    {
        return $this->sound_file_uri;
    }

    /**
     * Ссылка на звуковой файл для проигрывания.
     * Файл должен лежать на внутреннем хранилище.
     * # Диапазон: 2..100
     *
     * Generated from protobuf field <code>string sound_file_uri = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setSoundFileUri($var)
    {
        GPBUtil::checkString($var, True);
        $this->sound_file_uri = $var;

        return $this;
    }

    /**
     * Массив ОРПОНов домов, на которых запускаем проигрывание.
     * # Диапазон: 1..100
     *
     * Generated from protobuf field <code>repeated int64 orpons = 2;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getOrpons()
    {
        return $this->orpons;
    }

    /**
     * Массив ОРПОНов домов, на которых запускаем проигрывание.
     * # Диапазон: 1..100
     *
     * Generated from protobuf field <code>repeated int64 orpons = 2;</code>
     * @param array<int>|array<string>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setOrpons($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::INT64);
        $this->orpons = $arr;

        return $this;
    }

    /**
     * Длительность воспроизведения такта в секундах.
     * Такт включает в себя проигрывание файла на трубках или на динамике.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_play_duration = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getTactPlayDuration()
    {
        return $this->tact_play_duration;
    }

    /**
     * Длительность воспроизведения такта в секундах.
     * Такт включает в себя проигрывание файла на трубках или на динамике.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_play_duration = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setTactPlayDuration($var)
    {
        GPBUtil::checkInt32($var);
        $this->tact_play_duration = $var;

        return $this;
    }

    /**
     * Количество последовательных повторов тактов перед сменой динамика на трубки или наоборот.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_repeat_count = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getTactRepeatCount()
    {
        return $this->tact_repeat_count;
    }

    /**
     * Количество последовательных повторов тактов перед сменой динамика на трубки или наоборот.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 tact_repeat_count = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setTactRepeatCount($var)
    {
        GPBUtil::checkInt32($var);
        $this->tact_repeat_count = $var;

        return $this;
    }

    /**
     * Количество дополнительных повторов тактов, т.е. умолчание=0 - это проигрывание одного такта.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 play_repeat_count = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getPlayRepeatCount()
    {
        return $this->play_repeat_count;
    }

    /**
     * Количество дополнительных повторов тактов, т.е. умолчание=0 - это проигрывание одного такта.
     * # Диапазон: 0..65536
     *
     * Generated from protobuf field <code>int32 play_repeat_count = 5 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setPlayRepeatCount($var)
    {
        GPBUtil::checkInt32($var);
        $this->play_repeat_count = $var;

        return $this;
    }

    /**
     * Тип проигрывания
     *
     * Generated from protobuf field <code>.keyapis.access_control.v1.PostBroadcastAlertStartRequest.PlayType play_type = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getPlayType()
    {
        return $this->play_type;
    }

    /**
     * Тип проигрывания
     *
     * Generated from protobuf field <code>.keyapis.access_control.v1.PostBroadcastAlertStartRequest.PlayType play_type = 6 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setPlayType($var)
    {
        GPBUtil::checkEnum($var, \Keyapis\AccessControl\V1\PostBroadcastAlertStartRequest\PlayType::class);
        $this->play_type = $var;

        return $this;
    }

}

