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

namespace Keyapis\Invoice\V1;

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

/**
 * Запрос на подтверждение платежа
 *
 * Generated from protobuf message <code>keyapis.invoice.v1.PostInvoiceConfirmRequest</code>
 */
class PostInvoiceConfirmRequest extends \Google\Protobuf\Internal\Message
{
    /**
     * Идентификатор платежа в Ключе
     *
     * Generated from protobuf field <code>string src_pay_id = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $src_pay_id = '';
    /**
     * Идентификатор платежа во внешней системе
     *
     * Generated from protobuf field <code>string espp_pay_id = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $espp_pay_id = '';
    /**
     * Статус платежа из внешней системы
     *
     * Generated from protobuf field <code>int32 pay_status = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $pay_status = 0;
    /**
     * Тип запроса.
     * Должно иметь значение "confirmPayment"
     *
     * Generated from protobuf field <code>string req_type = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     */
    protected $req_type = '';
    /**
     * Сумма платежа в минимальных единицах валюты
     *
     * Generated from protobuf field <code>float amount = 5;</code>
     */
    protected $amount = 0.0;
    /**
     * Код валюты платежа
     *
     * Generated from protobuf field <code>string currency = 6;</code>
     */
    protected $currency = '';
    /**
     * Код способа оплаты
     *
     * Generated from protobuf field <code>string pay_method = 7;</code>
     */
    protected $pay_method = '';
    /**
     * Дата регистрации платежа.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp create_time_at = 8 [json_name = "createTime"];</code>
     */
    protected $create_time_at = null;
    /**
     * Комментарий или сообщение об ошибке
     *
     * Generated from protobuf field <code>string req_note = 9;</code>
     */
    protected $req_note = '';
    /**
     * Сообщение, отображаемое пользователю
     *
     * Generated from protobuf field <code>string req_user_msg = 10;</code>
     */
    protected $req_user_msg = '';
    /**
     * Время фактической оплаты. Время фактической оплаты на стороне Процессинга. Возвращается, если оплата состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp pay_time_at = 11 [json_name = "payTime"];</code>
     */
    protected $pay_time_at = null;
    /**
     * Время фактической отмены оплаты.
     * Время фактической отмены оплаты на стороне Процессинга.
     * Возвращается, если отмена оплаты состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp abandon_time_at = 12 [json_name = "abandonTime"];</code>
     */
    protected $abandon_time_at = null;
    /**
     * Структура с информацией о карте плательщика.
     * Передаётся только при успешном платеже и если указаны способы оплаты payMethod = StoredBankCard либо BankCard
     *
     * Generated from protobuf field <code>.keyapis.invoice.v1.PostInvoiceConfirmRequest.Card card = 13;</code>
     */
    protected $card = null;

    /**
     * Constructor.
     *
     * @param array $data {
     *     Optional. Data for populating the Message object.
     *
     *     @type string $src_pay_id
     *           Идентификатор платежа в Ключе
     *     @type string $espp_pay_id
     *           Идентификатор платежа во внешней системе
     *     @type int $pay_status
     *           Статус платежа из внешней системы
     *     @type string $req_type
     *           Тип запроса.
     *           Должно иметь значение "confirmPayment"
     *     @type float $amount
     *           Сумма платежа в минимальных единицах валюты
     *     @type string $currency
     *           Код валюты платежа
     *     @type string $pay_method
     *           Код способа оплаты
     *     @type \Google\Protobuf\Timestamp $create_time_at
     *           Дата регистрации платежа.
     *           # Тип: DateTime
     *     @type string $req_note
     *           Комментарий или сообщение об ошибке
     *     @type string $req_user_msg
     *           Сообщение, отображаемое пользователю
     *     @type \Google\Protobuf\Timestamp $pay_time_at
     *           Время фактической оплаты. Время фактической оплаты на стороне Процессинга. Возвращается, если оплата состоялась
     *     @type \Google\Protobuf\Timestamp $abandon_time_at
     *           Время фактической отмены оплаты.
     *           Время фактической отмены оплаты на стороне Процессинга.
     *           Возвращается, если отмена оплаты состоялась
     *     @type \Keyapis\Invoice\V1\PostInvoiceConfirmRequest\Card $card
     *           Структура с информацией о карте плательщика.
     *           Передаётся только при успешном платеже и если указаны способы оплаты payMethod = StoredBankCard либо BankCard
     * }
     */
    public function __construct($data = NULL) {
        \GPBMetadata\Keyapis\Invoice\V1\KeyapisInvoiceInvoiceV1::initOnce();
        parent::__construct($data);
    }

    /**
     * Идентификатор платежа в Ключе
     *
     * Generated from protobuf field <code>string src_pay_id = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getSrcPayId()
    {
        return $this->src_pay_id;
    }

    /**
     * Идентификатор платежа в Ключе
     *
     * Generated from protobuf field <code>string src_pay_id = 1 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setSrcPayId($var)
    {
        GPBUtil::checkString($var, True);
        $this->src_pay_id = $var;

        return $this;
    }

    /**
     * Идентификатор платежа во внешней системе
     *
     * Generated from protobuf field <code>string espp_pay_id = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getEsppPayId()
    {
        return $this->espp_pay_id;
    }

    /**
     * Идентификатор платежа во внешней системе
     *
     * Generated from protobuf field <code>string espp_pay_id = 2 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setEsppPayId($var)
    {
        GPBUtil::checkString($var, True);
        $this->espp_pay_id = $var;

        return $this;
    }

    /**
     * Статус платежа из внешней системы
     *
     * Generated from protobuf field <code>int32 pay_status = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return int
     */
    public function getPayStatus()
    {
        return $this->pay_status;
    }

    /**
     * Статус платежа из внешней системы
     *
     * Generated from protobuf field <code>int32 pay_status = 3 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param int $var
     * @return $this
     */
    public function setPayStatus($var)
    {
        GPBUtil::checkInt32($var);
        $this->pay_status = $var;

        return $this;
    }

    /**
     * Тип запроса.
     * Должно иметь значение "confirmPayment"
     *
     * Generated from protobuf field <code>string req_type = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @return string
     */
    public function getReqType()
    {
        return $this->req_type;
    }

    /**
     * Тип запроса.
     * Должно иметь значение "confirmPayment"
     *
     * Generated from protobuf field <code>string req_type = 4 [(.google.api.field_behavior) = REQUIRED];</code>
     * @param string $var
     * @return $this
     */
    public function setReqType($var)
    {
        GPBUtil::checkString($var, True);
        $this->req_type = $var;

        return $this;
    }

    /**
     * Сумма платежа в минимальных единицах валюты
     *
     * Generated from protobuf field <code>float amount = 5;</code>
     * @return float
     */
    public function getAmount()
    {
        return $this->amount;
    }

    /**
     * Сумма платежа в минимальных единицах валюты
     *
     * Generated from protobuf field <code>float amount = 5;</code>
     * @param float $var
     * @return $this
     */
    public function setAmount($var)
    {
        GPBUtil::checkFloat($var);
        $this->amount = $var;

        return $this;
    }

    /**
     * Код валюты платежа
     *
     * Generated from protobuf field <code>string currency = 6;</code>
     * @return string
     */
    public function getCurrency()
    {
        return $this->currency;
    }

    /**
     * Код валюты платежа
     *
     * Generated from protobuf field <code>string currency = 6;</code>
     * @param string $var
     * @return $this
     */
    public function setCurrency($var)
    {
        GPBUtil::checkString($var, True);
        $this->currency = $var;

        return $this;
    }

    /**
     * Код способа оплаты
     *
     * Generated from protobuf field <code>string pay_method = 7;</code>
     * @return string
     */
    public function getPayMethod()
    {
        return $this->pay_method;
    }

    /**
     * Код способа оплаты
     *
     * Generated from protobuf field <code>string pay_method = 7;</code>
     * @param string $var
     * @return $this
     */
    public function setPayMethod($var)
    {
        GPBUtil::checkString($var, True);
        $this->pay_method = $var;

        return $this;
    }

    /**
     * Дата регистрации платежа.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp create_time_at = 8 [json_name = "createTime"];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getCreateTimeAt()
    {
        return $this->create_time_at;
    }

    public function hasCreateTimeAt()
    {
        return isset($this->create_time_at);
    }

    public function clearCreateTimeAt()
    {
        unset($this->create_time_at);
    }

    /**
     * Дата регистрации платежа.
     * # Тип: DateTime
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp create_time_at = 8 [json_name = "createTime"];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setCreateTimeAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->create_time_at = $var;

        return $this;
    }

    /**
     * Комментарий или сообщение об ошибке
     *
     * Generated from protobuf field <code>string req_note = 9;</code>
     * @return string
     */
    public function getReqNote()
    {
        return $this->req_note;
    }

    /**
     * Комментарий или сообщение об ошибке
     *
     * Generated from protobuf field <code>string req_note = 9;</code>
     * @param string $var
     * @return $this
     */
    public function setReqNote($var)
    {
        GPBUtil::checkString($var, True);
        $this->req_note = $var;

        return $this;
    }

    /**
     * Сообщение, отображаемое пользователю
     *
     * Generated from protobuf field <code>string req_user_msg = 10;</code>
     * @return string
     */
    public function getReqUserMsg()
    {
        return $this->req_user_msg;
    }

    /**
     * Сообщение, отображаемое пользователю
     *
     * Generated from protobuf field <code>string req_user_msg = 10;</code>
     * @param string $var
     * @return $this
     */
    public function setReqUserMsg($var)
    {
        GPBUtil::checkString($var, True);
        $this->req_user_msg = $var;

        return $this;
    }

    /**
     * Время фактической оплаты. Время фактической оплаты на стороне Процессинга. Возвращается, если оплата состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp pay_time_at = 11 [json_name = "payTime"];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getPayTimeAt()
    {
        return $this->pay_time_at;
    }

    public function hasPayTimeAt()
    {
        return isset($this->pay_time_at);
    }

    public function clearPayTimeAt()
    {
        unset($this->pay_time_at);
    }

    /**
     * Время фактической оплаты. Время фактической оплаты на стороне Процессинга. Возвращается, если оплата состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp pay_time_at = 11 [json_name = "payTime"];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setPayTimeAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->pay_time_at = $var;

        return $this;
    }

    /**
     * Время фактической отмены оплаты.
     * Время фактической отмены оплаты на стороне Процессинга.
     * Возвращается, если отмена оплаты состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp abandon_time_at = 12 [json_name = "abandonTime"];</code>
     * @return \Google\Protobuf\Timestamp|null
     */
    public function getAbandonTimeAt()
    {
        return $this->abandon_time_at;
    }

    public function hasAbandonTimeAt()
    {
        return isset($this->abandon_time_at);
    }

    public function clearAbandonTimeAt()
    {
        unset($this->abandon_time_at);
    }

    /**
     * Время фактической отмены оплаты.
     * Время фактической отмены оплаты на стороне Процессинга.
     * Возвращается, если отмена оплаты состоялась
     *
     * Generated from protobuf field <code>.google.protobuf.Timestamp abandon_time_at = 12 [json_name = "abandonTime"];</code>
     * @param \Google\Protobuf\Timestamp $var
     * @return $this
     */
    public function setAbandonTimeAt($var)
    {
        GPBUtil::checkMessage($var, \Google\Protobuf\Timestamp::class);
        $this->abandon_time_at = $var;

        return $this;
    }

    /**
     * Структура с информацией о карте плательщика.
     * Передаётся только при успешном платеже и если указаны способы оплаты payMethod = StoredBankCard либо BankCard
     *
     * Generated from protobuf field <code>.keyapis.invoice.v1.PostInvoiceConfirmRequest.Card card = 13;</code>
     * @return \Keyapis\Invoice\V1\PostInvoiceConfirmRequest\Card|null
     */
    public function getCard()
    {
        return $this->card;
    }

    public function hasCard()
    {
        return isset($this->card);
    }

    public function clearCard()
    {
        unset($this->card);
    }

    /**
     * Структура с информацией о карте плательщика.
     * Передаётся только при успешном платеже и если указаны способы оплаты payMethod = StoredBankCard либо BankCard
     *
     * Generated from protobuf field <code>.keyapis.invoice.v1.PostInvoiceConfirmRequest.Card card = 13;</code>
     * @param \Keyapis\Invoice\V1\PostInvoiceConfirmRequest\Card $var
     * @return $this
     */
    public function setCard($var)
    {
        GPBUtil::checkMessage($var, \Keyapis\Invoice\V1\PostInvoiceConfirmRequest\Card::class);
        $this->card = $var;

        return $this;
    }

}

