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

namespace Keyapis\Device\V1\GetDeviceConfigurationStatusesResponse;

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

/**
 * Статусы
 *
 * Generated from protobuf message <code>keyapis.device.v1.GetDeviceConfigurationStatusesResponse.Statuses</code>
 */
class Statuses extends \Google\Protobuf\Internal\Message
{
    /**
     * Статусы конфигурации устройства
     *
     * Generated from protobuf field <code>repeated .keyapis.device.v1.DeviceConfigurationStatus device_configuration_statuses = 1;</code>
     */
    private $device_configuration_statuses;
    /**
     * Статус камеры
     *
     * Generated from protobuf field <code>.keyapis.device.v1.CameraStatus camera_status = 2;</code>
     */
    protected $camera_status = null;
    /**
     * Статус синхронизации
     *
     * Generated from protobuf field <code>.keyapis.device.v1.SyncStatus sync_status = 3;</code>
     */
    protected $sync_status = null;
    /**
     * Статус устройства
     *
     * Generated from protobuf field <code>.keyapis.device.v1.Device.StatusType device_status_type = 4;</code>
     */
    protected $device_status_type = 0;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type array<\Keyapis\Device\V1\DeviceConfigurationStatus>|\Google\Protobuf\Internal\RepeatedField $device_configuration_statuses
     *           Статусы конфигурации устройства
     *     @type \Keyapis\Device\V1\CameraStatus $camera_status
     *           Статус камеры
     *     @type \Keyapis\Device\V1\SyncStatus $sync_status
     *           Статус синхронизации
     *     @type int $device_status_type
     *           Статус устройства
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\Device\V1\KeyapisDeviceDeviceV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Статусы конфигурации устройства
     *
     * Generated from protobuf field <code>repeated .keyapis.device.v1.DeviceConfigurationStatus device_configuration_statuses = 1;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getDeviceConfigurationStatuses()
    {
        return $this->device_configuration_statuses;
    }

    /**
     * Статусы конфигурации устройства
     *
     * Generated from protobuf field <code>repeated .keyapis.device.v1.DeviceConfigurationStatus device_configuration_statuses = 1;</code>
     * @param array<\Keyapis\Device\V1\DeviceConfigurationStatus>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setDeviceConfigurationStatuses($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::MESSAGE, \Keyapis\Device\V1\DeviceConfigurationStatus::class);
        $this->device_configuration_statuses = $arr;

        return $this;
    }

    /**
     * Статус камеры
     *
     * Generated from protobuf field <code>.keyapis.device.v1.CameraStatus camera_status = 2;</code>
     * @return \Keyapis\Device\V1\CameraStatus|null
     */
    public function getCameraStatus()
    {
        return $this->camera_status;
    }

    public function hasCameraStatus()
    {
        return isset($this->camera_status);
    }

    public function clearCameraStatus()
    {
        unset($this->camera_status);
    }

    /**
     * Статус камеры
     *
     * Generated from protobuf field <code>.keyapis.device.v1.CameraStatus camera_status = 2;</code>
     * @param \Keyapis\Device\V1\CameraStatus $var
     * @return $this
     */
    public function setCameraStatus($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Device\V1\CameraStatus::class);
        $this->camera_status = $var;

        return $this;
    }

    /**
     * Статус синхронизации
     *
     * Generated from protobuf field <code>.keyapis.device.v1.SyncStatus sync_status = 3;</code>
     * @return \Keyapis\Device\V1\SyncStatus|null
     */
    public function getSyncStatus()
    {
        return $this->sync_status;
    }

    public function hasSyncStatus()
    {
        return isset($this->sync_status);
    }

    public function clearSyncStatus()
    {
        unset($this->sync_status);
    }

    /**
     * Статус синхронизации
     *
     * Generated from protobuf field <code>.keyapis.device.v1.SyncStatus sync_status = 3;</code>
     * @param \Keyapis\Device\V1\SyncStatus $var
     * @return $this
     */
    public function setSyncStatus($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Device\V1\SyncStatus::class);
        $this->sync_status = $var;

        return $this;
    }

    /**
     * Статус устройства
     *
     * Generated from protobuf field <code>.keyapis.device.v1.Device.StatusType device_status_type = 4;</code>
     * @return int
     */
    public function getDeviceStatusType()
    {
        return $this->device_status_type;
    }

    /**
     * Статус устройства
     *
     * Generated from protobuf field <code>.keyapis.device.v1.Device.StatusType device_status_type = 4;</code>
     * @param int $var
     * @return $this
     */
    public function setDeviceStatusType($var)
    {
        GPBUtil::checkEnum($var, \Keyapis\Device\V1\Device\StatusType::class);
        $this->device_status_type = $var;

        return $this;
    }

}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(Statuses::class, \Keyapis\Device\V1\GetDeviceConfigurationStatusesResponse_Statuses::class);

