<?php
# Generated by the protocol buffer compiler.  DO NOT EDIT!
# source: keyapis/access_management/v1/keyapis_access_management_template_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.GroupTemplate</code>
 */
class GroupTemplate 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 group_title_suffix = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $group_title_suffix = '';
    /**
     * Описание шаблона группы.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string description = 4;</code>
     */
    protected $description = '';
    /**
     * Массив атрибутов группы.
     * Эти атрибуты назначены пользователям, которые принадлежат группе.
     * # Диапазон: 0..100
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim claims = 5;</code>
     */
    private $claims;
    /**
     * Требования, означающие принадлежность пользователя к данной группе.
     * Пользователь принадлежит группе, если все атрибуты требований группы присутствуют у пользователя и имеют те же значения.
     * # Диапазон: 0..10
     *
     * Generated from protobuf field <code>repeated .keyapis.access_management.v1.Claim requirements = 6;</code>
     */
    private $requirements;
    /**
     * Теги шаблона группы.
     * # Диапазон: 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 $group_title_suffix
     *           Суффикс наименования группы.
     *           # Диапазон: 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 array<string>|\Google\Protobuf\Internal\RepeatedField $tags
     *           Теги шаблона группы.
     *           # Диапазон: 0..10
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\AccessManagement\V1\KeyapisAccessManagementTemplateV1::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 group_title_suffix = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getGroupTitleSuffix()
    {
        return $this->group_title_suffix;
    }

    /**
     * Суффикс наименования группы.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string group_title_suffix = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setGroupTitleSuffix($var)
    {
        GPBUtil::checkString($var, True);
        $this->group_title_suffix = $var;

        return $this;
    }

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

    /**
     * Описание шаблона группы.
     * # Диапазон: 3..256
     *
     * Generated from protobuf field <code>string description = 4;</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 = 5;</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 = 5;</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 = 6;</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 = 6;</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;
    }

    /**
     * Теги шаблона группы.
     * # Диапазон: 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;
    }

}

