<?php
// GENERATED CODE -- DO NOT EDIT!

// Original file comments:
//
// Сервис реализует функционал управления выставленными счётами
namespace Keyapis\Invoice\V1;

/**
 * Сервис invoices
 */
class InvoiceServiceClient extends \Grpc\BaseStub {

    /**
     * @param string $hostname hostname
     * @param array $opts channel options
     * @param \Grpc\Channel $channel (optional) re-use channel object
     */
    public function __construct($hostname, $opts, $channel = null) {
        parent::__construct($hostname, $opts, $channel);
    }

    /**
     * Метод создания платежа.
     * Создание платежа в своей и внешней платежной системе.
     * Метод доступен для: service
     * @param \Keyapis\Invoice\V1\CreateInvoiceRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function CreateInvoice(\Keyapis\Invoice\V1\CreateInvoiceRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.invoice.v1.InvoiceService/CreateInvoice',
        $argument,
        ['\Keyapis\Invoice\V1\CreateInvoiceResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения платежа.
     * Для master доступно получение платежа только с user_id из токена.
     * Метод доступен для: admin, service, master
     * @param \Keyapis\Invoice\V1\GetInvoiceRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function GetInvoice(\Keyapis\Invoice\V1\GetInvoiceRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.invoice.v1.InvoiceService/GetInvoice',
        $argument,
        ['\Keyapis\Invoice\V1\GetInvoiceResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод подтверждения платежа (вызывается со стороны внешней системы).
     * Не требует авторизации
     * @param \Keyapis\Invoice\V1\PostInvoiceConfirmRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function PostInvoiceConfirm(\Keyapis\Invoice\V1\PostInvoiceConfirmRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.invoice.v1.InvoiceService/PostInvoiceConfirm',
        $argument,
        ['\Keyapis\Invoice\V1\PostInvoiceConfirmResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения списка платежей.
     * Для master доступно получение только собственных платежей, если параметр filter.user_id передан и не совпадает с user_id из токена, возвращается ошибка доступа.
     * Метод доступен для: admin, service, master, ltp_first
     * @param \Keyapis\Invoice\V1\GetInvoiceListRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function GetInvoiceList(\Keyapis\Invoice\V1\GetInvoiceListRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.invoice.v1.InvoiceService/GetInvoiceList',
        $argument,
        ['\Keyapis\Invoice\V1\GetInvoiceListResponse', 'decode'],
        $metadata, $options);
    }

    /**
     * Метод получения количества платежей.
     * Для master в параметр filter.user_id подставляется user_id из токена.
     * Метод доступен для: admin, service, master, ltp_first
     * @param \Keyapis\Invoice\V1\GetInvoiceCountRequest $argument input argument
     * @param array $metadata metadata
     * @param array $options call options
     * @return \Grpc\UnaryCall
     */
    public function GetInvoiceCount(\Keyapis\Invoice\V1\GetInvoiceCountRequest $argument,
      $metadata = [], $options = []) {
        return $this->_simpleRequest('/keyapis.invoice.v1.InvoiceService/GetInvoiceCount',
        $argument,
        ['\Keyapis\Invoice\V1\GetInvoiceCountResponse', 'decode'],
        $metadata, $options);
    }

}
