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

#import <Foundation/Foundation.h>

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#import "keyapis/multiapp/v1/KeyapisMultiappPartnerV1.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 KEYAPISMULTIAPPV1DeletePartnerRequest;
@class KEYAPISMULTIAPPV1DeletePartnerResponse;
@class KEYAPISMULTIAPPV1GetPartnerAddressOrponRequest;
@class KEYAPISMULTIAPPV1GetPartnerAddressOrponResponse;
@class KEYAPISMULTIAPPV1GetPartnerCountRequest;
@class KEYAPISMULTIAPPV1GetPartnerCountResponse;
@class KEYAPISMULTIAPPV1GetPartnerListRequest;
@class KEYAPISMULTIAPPV1GetPartnerListResponse;
@class KEYAPISMULTIAPPV1GetPartnerRequest;
@class KEYAPISMULTIAPPV1GetPartnerResponse;
@class KEYAPISMULTIAPPV1GetPartnerTokenRequest;
@class KEYAPISMULTIAPPV1GetPartnerTokenResponse;
@class KEYAPISMULTIAPPV1PostPartnerPublicKeyRequest;
@class KEYAPISMULTIAPPV1PostPartnerPublicKeyResponse;
@class KEYAPISMULTIAPPV1PostPartnerRequest;
@class KEYAPISMULTIAPPV1PostPartnerResponse;

#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 "google/protobuf/Descriptor.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
  #import "keyapis/multiapp/v1/KeyapisMultiappAppV1.pbobjc.h"
#endif

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


NS_ASSUME_NONNULL_BEGIN

@protocol KEYAPISMULTIAPPV1PartnerService2 <NSObject>

#pragma mark PostPartner(PostPartnerRequest) returns (PostPartnerResponse)

/**
 * Метод сохранения партнера.
 * Поддерживает создание и обновление.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)postPartnerWithMessage:(KEYAPISMULTIAPPV1PostPartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetPartner(GetPartnerRequest) returns (GetPartnerResponse)

/**
 * Метод получения партнера.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerWithMessage:(KEYAPISMULTIAPPV1GetPartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetPartnerList(GetPartnerListRequest) returns (stream GetPartnerListResponse)

/**
 * Метод получения списка партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerListWithMessage:(KEYAPISMULTIAPPV1GetPartnerListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetPartnerCount(GetPartnerCountRequest) returns (GetPartnerCountResponse)

/**
 * Метод получения количества партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerCountWithMessage:(KEYAPISMULTIAPPV1GetPartnerCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetPartnerToken(GetPartnerTokenRequest) returns (GetPartnerTokenResponse)

/**
 * Метод получения токена.
 * Access токен возможно получить только для пользователей с типом master в статусе active, demo и new.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695865.
 * Не требует авторизации
 */
- (GRPCUnaryProtoCall *)getPartnerTokenWithMessage:(KEYAPISMULTIAPPV1GetPartnerTokenRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostPartnerPublicKey(PostPartnerPublicKeyRequest) returns (PostPartnerPublicKeyResponse)

/**
 * Метод обновления публичного ключа партнёра.
 * Поддерживает создание и обновление.
 * Метод доступен для: partner.
 * Требует передачи аутентификационного ключа в заголовке X-API-KEY.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525
 */
- (GRPCUnaryProtoCall *)postPartnerPublicKeyWithMessage:(KEYAPISMULTIAPPV1PostPartnerPublicKeyRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark DeletePartner(DeletePartnerRequest) returns (DeletePartnerResponse)

/**
 * Метод удаления партнёра.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=804302306.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)deletePartnerWithMessage:(KEYAPISMULTIAPPV1DeletePartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetPartnerAddressOrpon(GetPartnerAddressOrponRequest) returns (GetPartnerAddressOrponResponse)

/**
 * Метод получения адреса дома по ОРПОНу.
 * Адресная строка должны быть в формате "{Регион}, {Город}, {Улица}, {Дом}, {Строение}".
 * Партнер может получить адрес только по доступному ему ОРПОНу.
 * Доступные ОРПОНы для партнера может получить через привязанные app в поле app_tags и user_tags.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization
 */
- (GRPCUnaryProtoCall *)getPartnerAddressOrponWithMessage:(KEYAPISMULTIAPPV1GetPartnerAddressOrponRequest *)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 KEYAPISMULTIAPPV1PartnerService <NSObject>

#pragma mark PostPartner(PostPartnerRequest) returns (PostPartnerResponse)

/**
 * Метод сохранения партнера.
 * Поддерживает создание и обновление.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postPartnerWithRequest:(KEYAPISMULTIAPPV1PostPartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostPartnerResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод сохранения партнера.
 * Поддерживает создание и обновление.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostPartnerWithRequest:(KEYAPISMULTIAPPV1PostPartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostPartnerResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetPartner(GetPartnerRequest) returns (GetPartnerResponse)

/**
 * Метод получения партнера.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getPartnerWithRequest:(KEYAPISMULTIAPPV1GetPartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения партнера.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetPartnerWithRequest:(KEYAPISMULTIAPPV1GetPartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetPartnerList(GetPartnerListRequest) returns (stream GetPartnerListResponse)

/**
 * Метод получения списка партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getPartnerListWithRequest:(KEYAPISMULTIAPPV1GetPartnerListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISMULTIAPPV1GetPartnerListResponse *_Nullable response, NSError *_Nullable error))eventHandler;

/**
 * Метод получения списка партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetPartnerListWithRequest:(KEYAPISMULTIAPPV1GetPartnerListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISMULTIAPPV1GetPartnerListResponse *_Nullable response, NSError *_Nullable error))eventHandler;


#pragma mark GetPartnerCount(GetPartnerCountRequest) returns (GetPartnerCountResponse)

/**
 * Метод получения количества партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getPartnerCountWithRequest:(KEYAPISMULTIAPPV1GetPartnerCountRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerCountResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения количества партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetPartnerCountWithRequest:(KEYAPISMULTIAPPV1GetPartnerCountRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerCountResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetPartnerToken(GetPartnerTokenRequest) returns (GetPartnerTokenResponse)

/**
 * Метод получения токена.
 * Access токен возможно получить только для пользователей с типом master в статусе active, demo и new.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695865.
 * Не требует авторизации
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getPartnerTokenWithRequest:(KEYAPISMULTIAPPV1GetPartnerTokenRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerTokenResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения токена.
 * Access токен возможно получить только для пользователей с типом master в статусе active, demo и new.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695865.
 * Не требует авторизации
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetPartnerTokenWithRequest:(KEYAPISMULTIAPPV1GetPartnerTokenRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerTokenResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark PostPartnerPublicKey(PostPartnerPublicKeyRequest) returns (PostPartnerPublicKeyResponse)

/**
 * Метод обновления публичного ключа партнёра.
 * Поддерживает создание и обновление.
 * Метод доступен для: partner.
 * Требует передачи аутентификационного ключа в заголовке X-API-KEY.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postPartnerPublicKeyWithRequest:(KEYAPISMULTIAPPV1PostPartnerPublicKeyRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostPartnerPublicKeyResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод обновления публичного ключа партнёра.
 * Поддерживает создание и обновление.
 * Метод доступен для: partner.
 * Требует передачи аутентификационного ключа в заголовке X-API-KEY.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostPartnerPublicKeyWithRequest:(KEYAPISMULTIAPPV1PostPartnerPublicKeyRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostPartnerPublicKeyResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark DeletePartner(DeletePartnerRequest) returns (DeletePartnerResponse)

/**
 * Метод удаления партнёра.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=804302306.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)deletePartnerWithRequest:(KEYAPISMULTIAPPV1DeletePartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1DeletePartnerResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод удаления партнёра.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=804302306.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToDeletePartnerWithRequest:(KEYAPISMULTIAPPV1DeletePartnerRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1DeletePartnerResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark GetPartnerAddressOrpon(GetPartnerAddressOrponRequest) returns (GetPartnerAddressOrponResponse)

/**
 * Метод получения адреса дома по ОРПОНу.
 * Адресная строка должны быть в формате "{Регион}, {Город}, {Улица}, {Дом}, {Строение}".
 * Партнер может получить адрес только по доступному ему ОРПОНу.
 * Доступные ОРПОНы для партнера может получить через привязанные app в поле app_tags и user_tags.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getPartnerAddressOrponWithRequest:(KEYAPISMULTIAPPV1GetPartnerAddressOrponRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerAddressOrponResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения адреса дома по ОРПОНу.
 * Адресная строка должны быть в формате "{Регион}, {Город}, {Улица}, {Дом}, {Строение}".
 * Партнер может получить адрес только по доступному ему ОРПОНу.
 * Доступные ОРПОНы для партнера может получить через привязанные app в поле app_tags и user_tags.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetPartnerAddressOrponWithRequest:(KEYAPISMULTIAPPV1GetPartnerAddressOrponRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetPartnerAddressOrponResponse *_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 KEYAPISMULTIAPPV1PartnerService : GRPCProtoService<KEYAPISMULTIAPPV1PartnerService2, KEYAPISMULTIAPPV1PartnerService>
- (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

