// Code generated by gRPC proto compiler.  DO NOT EDIT!
// source: keyapis/invoice/v1/keyapis_invoice_invoice_v1.proto

#import <Foundation/Foundation.h>

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#import "keyapis/invoice/v1/KeyapisInvoiceInvoiceV1.pbobjc.h"
#endif

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import <ProtoRPC/ProtoService.h>
#import <ProtoRPC/ProtoRPCLegacy.h>
#import <RxLibrary/GRXWriteable.h>
#import <RxLibrary/GRXWriter.h>
#endif

@class KEYAPISINVOICEV1CreateInvoiceRequest;
@class KEYAPISINVOICEV1CreateInvoiceResponse;
@class KEYAPISINVOICEV1GetInvoiceCountRequest;
@class KEYAPISINVOICEV1GetInvoiceCountResponse;
@class KEYAPISINVOICEV1GetInvoiceListRequest;
@class KEYAPISINVOICEV1GetInvoiceListResponse;
@class KEYAPISINVOICEV1GetInvoiceRequest;
@class KEYAPISINVOICEV1GetInvoiceResponse;
@class KEYAPISINVOICEV1PostInvoiceConfirmRequest;
@class KEYAPISINVOICEV1PostInvoiceConfirmResponse;

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#if defined(GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS) && GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
  #import <Protobuf/GPBTimestamp.pbobjc.h>
#else
  #import "GPBTimestamp.pbobjc.h"
#endif
  #import "google/api/Annotations.pbobjc.h"
  #import "google/api/FieldBehavior.pbobjc.h"
  #import "keyapis/invoice/v1/KeyapisInvoicePaymethodV1.pbobjc.h"
#if defined(GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS) && GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
  #import <Protobuf/GPBWrappers.pbobjc.h>
#else
  #import "GPBWrappers.pbobjc.h"
#endif
#endif

@class GRPCUnaryProtoCall;
@class GRPCStreamingProtoCall;
@class GRPCCallOptions;
@protocol GRPCProtoResponseHandler;
@class GRPCProtoCall;


NS_ASSUME_NONNULL_BEGIN

@protocol KEYAPISINVOICEV1InvoiceService2 <NSObject>

#pragma mark CreateInvoice(CreateInvoiceRequest) returns (CreateInvoiceResponse)

/**
 * Метод создания платежа.
 * Создание платежа в своей и внешней платежной системе.
 * Метод доступен для: service
 */
- (GRPCUnaryProtoCall *)createInvoiceWithMessage:(KEYAPISINVOICEV1CreateInvoiceRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetInvoice(GetInvoiceRequest) returns (GetInvoiceResponse)

/**
 * Метод получения платежа.
 * Для master доступно получение платежа только с user_id из токена.
 * Метод доступен для: admin, service, master
 */
- (GRPCUnaryProtoCall *)getInvoiceWithMessage:(KEYAPISINVOICEV1GetInvoiceRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostInvoiceConfirm(PostInvoiceConfirmRequest) returns (PostInvoiceConfirmResponse)

/**
 * Метод подтверждения платежа (вызывается со стороны внешней системы).
 * Не требует авторизации
 */
- (GRPCUnaryProtoCall *)postInvoiceConfirmWithMessage:(KEYAPISINVOICEV1PostInvoiceConfirmRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetInvoiceList(GetInvoiceListRequest) returns (GetInvoiceListResponse)

/**
 * Метод получения списка платежей.
 * Для master доступно получение только собственных платежей, если параметр filter.user_id передан и не совпадает с user_id из токена, возвращается ошибка доступа.
 * Метод доступен для: admin, service, master, ltp_first
 */
- (GRPCUnaryProtoCall *)getInvoiceListWithMessage:(KEYAPISINVOICEV1GetInvoiceListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetInvoiceCount(GetInvoiceCountRequest) returns (GetInvoiceCountResponse)

/**
 * Метод получения количества платежей.
 * Для master в параметр filter.user_id подставляется user_id из токена.
 * Метод доступен для: admin, service, master, ltp_first
 */
- (GRPCUnaryProtoCall *)getInvoiceCountWithMessage:(KEYAPISINVOICEV1GetInvoiceCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

@end

/**
 * The methods in this protocol belong to a set of old APIs that have been deprecated. They do not
 * recognize call options provided in the initializer. Using the v2 protocol is recommended.
 */
@protocol KEYAPISINVOICEV1InvoiceService <NSObject>

#pragma mark CreateInvoice(CreateInvoiceRequest) returns (CreateInvoiceResponse)

/**
 * Метод создания платежа.
 * Создание платежа в своей и внешней платежной системе.
 * Метод доступен для: service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)createInvoiceWithRequest:(KEYAPISINVOICEV1CreateInvoiceRequest *)request handler:(void(^)(KEYAPISINVOICEV1CreateInvoiceResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод создания платежа.
 * Создание платежа в своей и внешней платежной системе.
 * Метод доступен для: service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToCreateInvoiceWithRequest:(KEYAPISINVOICEV1CreateInvoiceRequest *)request handler:(void(^)(KEYAPISINVOICEV1CreateInvoiceResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetInvoice(GetInvoiceRequest) returns (GetInvoiceResponse)

/**
 * Метод получения платежа.
 * Для master доступно получение платежа только с user_id из токена.
 * Метод доступен для: admin, service, master
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getInvoiceWithRequest:(KEYAPISINVOICEV1GetInvoiceRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения платежа.
 * Для master доступно получение платежа только с user_id из токена.
 * Метод доступен для: admin, service, master
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetInvoiceWithRequest:(KEYAPISINVOICEV1GetInvoiceRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark PostInvoiceConfirm(PostInvoiceConfirmRequest) returns (PostInvoiceConfirmResponse)

/**
 * Метод подтверждения платежа (вызывается со стороны внешней системы).
 * Не требует авторизации
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postInvoiceConfirmWithRequest:(KEYAPISINVOICEV1PostInvoiceConfirmRequest *)request handler:(void(^)(KEYAPISINVOICEV1PostInvoiceConfirmResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод подтверждения платежа (вызывается со стороны внешней системы).
 * Не требует авторизации
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostInvoiceConfirmWithRequest:(KEYAPISINVOICEV1PostInvoiceConfirmRequest *)request handler:(void(^)(KEYAPISINVOICEV1PostInvoiceConfirmResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetInvoiceList(GetInvoiceListRequest) returns (GetInvoiceListResponse)

/**
 * Метод получения списка платежей.
 * Для master доступно получение только собственных платежей, если параметр filter.user_id передан и не совпадает с user_id из токена, возвращается ошибка доступа.
 * Метод доступен для: admin, service, master, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getInvoiceListWithRequest:(KEYAPISINVOICEV1GetInvoiceListRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceListResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения списка платежей.
 * Для master доступно получение только собственных платежей, если параметр filter.user_id передан и не совпадает с user_id из токена, возвращается ошибка доступа.
 * Метод доступен для: admin, service, master, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetInvoiceListWithRequest:(KEYAPISINVOICEV1GetInvoiceListRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceListResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetInvoiceCount(GetInvoiceCountRequest) returns (GetInvoiceCountResponse)

/**
 * Метод получения количества платежей.
 * Для master в параметр filter.user_id подставляется user_id из токена.
 * Метод доступен для: admin, service, master, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getInvoiceCountWithRequest:(KEYAPISINVOICEV1GetInvoiceCountRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceCountResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения количества платежей.
 * Для master в параметр filter.user_id подставляется user_id из токена.
 * Метод доступен для: admin, service, master, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetInvoiceCountWithRequest:(KEYAPISINVOICEV1GetInvoiceCountRequest *)request handler:(void(^)(KEYAPISINVOICEV1GetInvoiceCountResponse *_Nullable response, NSError *_Nullable error))handler;


@end


#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
/**
 * Basic service implementation, over gRPC, that only does
 * marshalling and parsing.
 */
@interface KEYAPISINVOICEV1InvoiceService : GRPCProtoService<KEYAPISINVOICEV1InvoiceService2, KEYAPISINVOICEV1InvoiceService>
- (instancetype)initWithHost:(NSString *)host callOptions:(GRPCCallOptions *_Nullable)callOptions NS_DESIGNATED_INITIALIZER;
+ (instancetype)serviceWithHost:(NSString *)host callOptions:(GRPCCallOptions *_Nullable)callOptions;
// The following methods belong to a set of old APIs that have been deprecated.
- (instancetype)initWithHost:(NSString *)host;
+ (instancetype)serviceWithHost:(NSString *)host;
@end
#endif

NS_ASSUME_NONNULL_END

