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

namespace Keyapis\AccessManagement\V1;

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

/**
 * Группа атрибутов пользователя
 *
 * Generated from protobuf message <code>keyapis.access_management.v1.Group</code>
 */
class Group extends \Google\Protobuf\Internal\Message
{
    /**
     * Идентификатор группы.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     */
    protected $id = '';
    /**
     * Наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $title = '';
    /**
     * Описание.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string description = 3;</code>
     */
    protected $description = '';
    /**
     * Массив атрибутов группы.
     * Эти атрибуты назначены пользователям, которые принадлежат группе.
     * # Диапазон: 0..100
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim claims = 4;</code>
     */
    private $claims;
    /**
     * Требования, означающие принадлежность пользователя к данной группе.
     * Пользователь принадлежит группе, если все атрибуты требований группы присутствуют у пользователя и имеют те же значения.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim requirements = 5;</code>
     */
    private $requirements;
    /**
     * Дата удаления группы из использования.
     * Группа не участвует в определении разрешений пользователя, если дата deleted_at непустая и уже в прошлом
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6;</code>
     */
    protected $deleted_at = null;
    /**
     * Теги группы.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated string tags = 7;</code>
     */
    private $tags;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type string $id
     *           Идентификатор группы.
     *           # Тип: Guid
     *     @type string $title
     *           Наименование.
     *           # Диапазон: 3..256
     *     @type string $description
     *           Описание.
     *           # Диапазон: 3..256
     *     @type array<\Keyapis\AccessManagement\V1\Claim>|\Google\Protobuf\Internal\RepeatedField $claims
     *           Массив атрибутов группы.
     *           Эти атрибуты назначены пользователям, которые принадлежат группе.
     *           # Диапазон: 0..100
     *     @type array<\Keyapis\AccessManagement\V1\Claim>|\Google\Protobuf\Internal\RepeatedField $requirements
     *           Требования, означающие принадлежность пользователя к данной группе.
     *           Пользователь принадлежит группе, если все атрибуты требований группы присутствуют у пользователя и имеют те же значения.
     *           # Диапазон: 0..10
     *     @type \Google\Protobuf\Timestamp $deleted_at
     *           Дата удаления группы из использования.
     *           Группа не участвует в определении разрешений пользователя, если дата deleted_at непустая и уже в прошлом
     *     @type array<string>|\Google\Protobuf\Internal\RepeatedField $tags
     *           Теги группы.
     *           # Диапазон: 0..10
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\AccessManagement\V1\KeyapisAccessManagementGroupV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Идентификатор группы.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     * @return string
     */
    public function getId()
    {
        return $this->id;
    }

    /**
     * Идентификатор группы.
     * # Тип: Guid
     *
     * Generated from protobuf field <code>string id = 1;</code>
     * @param string $var
     * @return $this
     */
    public function setId($var)
    {
        GPBUtil::checkString($var, True);
        $this->id = $var;

        return $this;
    }

    /**
     * Наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getTitle()
    {
        return $this->title;
    }

    /**
     * Наименование.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string title = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setTitle($var)
    {
        GPBUtil::checkString($var, True);
        $this->title = $var;

        return $this;
    }

    /**
     * Описание.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string description = 3;</code>
     * @return string
     */
    public function getDescription()
    {
        return $this->description;
    }

    /**
     * Описание.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string description = 3;</code>
     * @param string $var
     * @return $this
     */
    public function setDescription($var)
    {
        GPBUtil::checkString($var, True);
        $this->description = $var;

        return $this;
    }

    /**
     * Массив атрибутов группы.
     * Эти атрибуты назначены пользователям, которые принадлежат группе.
     * # Диапазон: 0..100
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim claims = 4;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getClaims()
    {
        return $this->claims;
    }

    /**
     * Массив атрибутов группы.
     * Эти атрибуты назначены пользователям, которые принадлежат группе.
     * # Диапазон: 0..100
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim claims = 4;</code>
     * @param array<\Keyapis\AccessManagement\V1\Claim>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setClaims($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::MESSAGE, \Keyapis\AccessManagement\V1\Claim::class);
        $this->claims = $arr;

        return $this;
    }

    /**
     * Требования, означающие принадлежность пользователя к данной группе.
     * Пользователь принадлежит группе, если все атрибуты требований группы присутствуют у пользователя и имеют те же значения.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim requirements = 5;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getRequirements()
    {
        return $this->requirements;
    }

    /**
     * Требования, означающие принадлежность пользователя к данной группе.
     * Пользователь принадлежит группе, если все атрибуты требований группы присутствуют у пользователя и имеют те же значения.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim requirements = 5;</code>
     * @param array<\Keyapis\AccessManagement\V1\Claim>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setRequirements($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::MESSAGE, \Keyapis\AccessManagement\V1\Claim::class);
        $this->requirements = $arr;

        return $this;
    }

    /**
     * Дата удаления группы из использования.
     * Группа не участвует в определении разрешений пользователя, если дата deleted_at непустая и уже в прошлом
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6;</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getDeletedAt()
    {
        return $this->deleted_at;
    }

    public function hasDeletedAt()
    {
        return isset($this->deleted_at);
    }

    public function clearDeletedAt()
    {
        unset($this->deleted_at);
    }

    /**
     * Дата удаления группы из использования.
     * Группа не участвует в определении разрешений пользователя, если дата deleted_at непустая и уже в прошлом
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp deleted_at = 6;</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setDeletedAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->deleted_at = $var;

        return $this;
    }

    /**
     * Теги группы.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated string tags = 7;</code>
     * @return \Google\Protobuf\Internal\RepeatedField
     */
    public function getTags()
    {
        return $this->tags;
    }

    /**
     * Теги группы.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated string tags = 7;</code>
     * @param array<string>|\Google\Protobuf\Internal\RepeatedField $var
     * @return $this
     */
    public function setTags($var)
    {
        $arr = GPBUtil::checkRepeatedField($var, \Google\Protobuf\Internal\GPBType::STRING);
        $this->tags = $arr;

        return $this;
    }

}

