<?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.GroupClaimFilter</code>
 */
class GroupClaimFilter extends \Google\Protobuf\Internal\Message
{
    /**
     * По идентификатору пользователя.
     * Соответствует subject, sub, client_id из JWT.
     * Для пользователя Ключа это user_id Ключа
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue user_id = 1;</code>
     */
    protected $user_id = null;
    /**
     * По назначенным атрибутам пользователя.
     * Фильтр ограничивает возвращаемые атрибуты данным списком.
     * Возвращаем атрибуты групп, у которых Claim.key=claims[n].key И (Claim.value=claims[n].value ИЛИ claims[n].value пустой).
     * При пустом GroupClaimFilter.claims не ограничиваем выдачу, отдаем все Claims, назначенные пользователю
     *
     * Generated from protobuf field <code>map<string, string> claims = 2;</code>
     */
    private $claims;
    /**
     * По условию принадлежности к группе.
     * Пользователь принадлежит группе, если user_data полностью удовлетворяет требованиям группы, то есть user_data содержит в себе Group.requirements целиком
     *
     * Generated from protobuf field <code>.keyapis.access_management.v1.GroupClaimFilter.UserData user_data = 3;</code>
     */
    protected $user_data = null;
    /**
     * Хешированное SHA256 значение ключа доступа ApiKey
     *
     * Generated from protobuf field <code>string api_key_hash = 4;</code>
     */
    protected $api_key_hash = '';

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type \Google\Protobuf\StringValue $user_id
     *           По идентификатору пользователя.
     *           Соответствует subject, sub, client_id из JWT.
     *           Для пользователя Ключа это user_id Ключа
     *     @type array|\Google\Protobuf\Internal\MapField $claims
     *           По назначенным атрибутам пользователя.
     *           Фильтр ограничивает возвращаемые атрибуты данным списком.
     *           Возвращаем атрибуты групп, у которых Claim.key=claims[n].key И (Claim.value=claims[n].value ИЛИ claims[n].value пустой).
     *           При пустом GroupClaimFilter.claims не ограничиваем выдачу, отдаем все Claims, назначенные пользователю
     *     @type \Keyapis\AccessManagement\V1\GroupClaimFilter\UserData $user_data
     *           По условию принадлежности к группе.
     *           Пользователь принадлежит группе, если user_data полностью удовлетворяет требованиям группы, то есть user_data содержит в себе Group.requirements целиком
     *     @type string $api_key_hash
     *           Хешированное SHA256 значение ключа доступа ApiKey
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\AccessManagement\V1\KeyapisAccessManagementGroupV1::initOnce();
        parent::__construct($data);
    }

    /**
     * По идентификатору пользователя.
     * Соответствует subject, sub, client_id из JWT.
     * Для пользователя Ключа это user_id Ключа
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue user_id = 1;</code>
     * @return \Google\Protobuf\StringValue|null
     */
    public function getUserId()
    {
        return $this->user_id;
    }

    public function hasUserId()
    {
        return isset($this->user_id);
    }

    public function clearUserId()
    {
        unset($this->user_id);
    }

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

     * По идентификатору пользователя.
     * Соответствует subject, sub, client_id из JWT.
     * Для пользователя Ключа это user_id Ключа
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue user_id = 1;</code>
     * @return string|null
     */
    public function getUserIdUnwrapped()
    {
        return $this->readWrapperValue("user_id");
    }

    /**
     * По идентификатору пользователя.
     * Соответствует subject, sub, client_id из JWT.
     * Для пользователя Ключа это user_id Ключа
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue user_id = 1;</code>
     * @param \Google\Protobuf\StringValue $var
     * @return $this
     */
    public function setUserId($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\StringValue::class);
        $this->user_id = $var;

        return $this;
    }

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

     * По идентификатору пользователя.
     * Соответствует subject, sub, client_id из JWT.
     * Для пользователя Ключа это user_id Ключа
     *
     * Generated from protobuf field <code>.google.protobuf.StringValue user_id = 1;</code>
     * @param string|null $var
     * @return $this
     */
    public function setUserIdUnwrapped($var)
    {
        $this->writeWrapperValue("user_id", $var);
        return $this;}

    /**
     * По назначенным атрибутам пользователя.
     * Фильтр ограничивает возвращаемые атрибуты данным списком.
     * Возвращаем атрибуты групп, у которых Claim.key=claims[n].key И (Claim.value=claims[n].value ИЛИ claims[n].value пустой).
     * При пустом GroupClaimFilter.claims не ограничиваем выдачу, отдаем все Claims, назначенные пользователю
     *
     * Generated from protobuf field <code>map<string, string> claims = 2;</code>
     * @return \Google\Protobuf\Internal\MapField
     */
    public function getClaims()
    {
        return $this->claims;
    }

    /**
     * По назначенным атрибутам пользователя.
     * Фильтр ограничивает возвращаемые атрибуты данным списком.
     * Возвращаем атрибуты групп, у которых Claim.key=claims[n].key И (Claim.value=claims[n].value ИЛИ claims[n].value пустой).
     * При пустом GroupClaimFilter.claims не ограничиваем выдачу, отдаем все Claims, назначенные пользователю
     *
     * Generated from protobuf field <code>map<string, string> claims = 2;</code>
     * @param array|\Google\Protobuf\Internal\MapField $var
     * @return $this
     */
    public function setClaims($var)
    {
        $arr = GPBUtil::checkMapField($var, \Google\Protobuf\Internal\GPBType::STRING, \Google\Protobuf\Internal\GPBType::STRING);
        $this->claims = $arr;

        return $this;
    }

    /**
     * По условию принадлежности к группе.
     * Пользователь принадлежит группе, если user_data полностью удовлетворяет требованиям группы, то есть user_data содержит в себе Group.requirements целиком
     *
     * Generated from protobuf field <code>.keyapis.access_management.v1.GroupClaimFilter.UserData user_data = 3;</code>
     * @return \Keyapis\AccessManagement\V1\GroupClaimFilter\UserData|null
     */
    public function getUserData()
    {
        return $this->user_data;
    }

    public function hasUserData()
    {
        return isset($this->user_data);
    }

    public function clearUserData()
    {
        unset($this->user_data);
    }

    /**
     * По условию принадлежности к группе.
     * Пользователь принадлежит группе, если user_data полностью удовлетворяет требованиям группы, то есть user_data содержит в себе Group.requirements целиком
     *
     * Generated from protobuf field <code>.keyapis.access_management.v1.GroupClaimFilter.UserData user_data = 3;</code>
     * @param \Keyapis\AccessManagement\V1\GroupClaimFilter\UserData $var
     * @return $this
     */
    public function setUserData($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\AccessManagement\V1\GroupClaimFilter\UserData::class);
        $this->user_data = $var;

        return $this;
    }

    /**
     * Хешированное SHA256 значение ключа доступа ApiKey
     *
     * Generated from protobuf field <code>string api_key_hash = 4;</code>
     * @return string
     */
    public function getApiKeyHash()
    {
        return $this->api_key_hash;
    }

    /**
     * Хешированное SHA256 значение ключа доступа ApiKey
     *
     * Generated from protobuf field <code>string api_key_hash = 4;</code>
     * @param string $var
     * @return $this
     */
    public function setApiKeyHash($var)
    {
        GPBUtil::checkString($var, True);
        $this->api_key_hash = $var;

        return $this;
    }

}

