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

namespace Keyapis\Invoice\V1\PostInvoiceConfirmRequest;

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

/**
 * Структура с информацией о карте плательщика
 *
 * Generated from protobuf message <code>keyapis.invoice.v1.PostInvoiceConfirmRequest.Card</code>
 */
class Card extends \Google\Protobuf\Internal\Message
{
    /**
     * Идентификатор платежного средства во внешней системы.
     * Возвращается в случае успешной привязки БК к УЗ
     *
     * Generated from protobuf field <code>int32 espp_card_id = 1;</code>
     */
    protected $espp_card_id = 0;
    /**
     * Номер платежного средства.
     * Маскированный номер карты. Например: 123456******7890
     *
     * Generated from protobuf field <code>string card_num = 2;</code>
     */
    protected $card_num = '';
    /**
     * Тип банковской карты
     *
     * Generated from protobuf field <code>string card_kind = 3 [json_name = "cardType"];</code>
     */
    protected $card_kind = '';
    /**
     * Банк-эмитент.
     * Наименование банка-эмитента. Процессинг может вернуть значение "НЕ ЗАДАВАЛСЯ".
     * В этом случае рекомендуется не отображать эту информацию для пользователя
     *
     * Generated from protobuf field <code>string bank_name = 4;</code>
     */
    protected $bank_name = '';

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type int $espp_card_id
     *           Идентификатор платежного средства во внешней системы.
     *           Возвращается в случае успешной привязки БК к УЗ
     *     @type string $card_num
     *           Номер платежного средства.
     *           Маскированный номер карты. Например: 123456******7890
     *     @type string $card_kind
     *           Тип банковской карты
     *     @type string $bank_name
     *           Банк-эмитент.
     *           Наименование банка-эмитента. Процессинг может вернуть значение "НЕ ЗАДАВАЛСЯ".
     *           В этом случае рекомендуется не отображать эту информацию для пользователя
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\Invoice\V1\KeyapisInvoiceInvoiceV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Идентификатор платежного средства во внешней системы.
     * Возвращается в случае успешной привязки БК к УЗ
     *
     * Generated from protobuf field <code>int32 espp_card_id = 1;</code>
     * @return int
     */
    public function getEsppCardId()
    {
        return $this->espp_card_id;
    }

    /**
     * Идентификатор платежного средства во внешней системы.
     * Возвращается в случае успешной привязки БК к УЗ
     *
     * Generated from protobuf field <code>int32 espp_card_id = 1;</code>
     * @param int $var
     * @return $this
     */
    public function setEsppCardId($var)
    {
        GPBUtil::checkInt32($var);
        $this->espp_card_id = $var;

        return $this;
    }

    /**
     * Номер платежного средства.
     * Маскированный номер карты. Например: 123456******7890
     *
     * Generated from protobuf field <code>string card_num = 2;</code>
     * @return string
     */
    public function getCardNum()
    {
        return $this->card_num;
    }

    /**
     * Номер платежного средства.
     * Маскированный номер карты. Например: 123456******7890
     *
     * Generated from protobuf field <code>string card_num = 2;</code>
     * @param string $var
     * @return $this
     */
    public function setCardNum($var)
    {
        GPBUtil::checkString($var, True);
        $this->card_num = $var;

        return $this;
    }

    /**
     * Тип банковской карты
     *
     * Generated from protobuf field <code>string card_kind = 3 [json_name = "cardType"];</code>
     * @return string
     */
    public function getCardKind()
    {
        return $this->card_kind;
    }

    /**
     * Тип банковской карты
     *
     * Generated from protobuf field <code>string card_kind = 3 [json_name = "cardType"];</code>
     * @param string $var
     * @return $this
     */
    public function setCardKind($var)
    {
        GPBUtil::checkString($var, True);
        $this->card_kind = $var;

        return $this;
    }

    /**
     * Банк-эмитент.
     * Наименование банка-эмитента. Процессинг может вернуть значение "НЕ ЗАДАВАЛСЯ".
     * В этом случае рекомендуется не отображать эту информацию для пользователя
     *
     * Generated from protobuf field <code>string bank_name = 4;</code>
     * @return string
     */
    public function getBankName()
    {
        return $this->bank_name;
    }

    /**
     * Банк-эмитент.
     * Наименование банка-эмитента. Процессинг может вернуть значение "НЕ ЗАДАВАЛСЯ".
     * В этом случае рекомендуется не отображать эту информацию для пользователя
     *
     * Generated from protobuf field <code>string bank_name = 4;</code>
     * @param string $var
     * @return $this
     */
    public function setBankName($var)
    {
        GPBUtil::checkString($var, True);
        $this->bank_name = $var;

        return $this;
    }

}

// Adding a class alias for backwards compatibility with the previous class name.
class_alias(Card::class, \Keyapis\Invoice\V1\PostInvoiceConfirmRequest_Card::class);

