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

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import "keyapis/multiapp/v1/KeyapisMultiappPartnerV1.pbrpc.h"
#import "keyapis/multiapp/v1/KeyapisMultiappPartnerV1.pbobjc.h"
#import <ProtoRPC/ProtoRPCLegacy.h>
#import <RxLibrary/GRXWriter+Immediate.h>

#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"

@implementation KEYAPISMULTIAPPV1PartnerService

#pragma clang diagnostic push
#pragma clang diagnostic ignored "-Wobjc-designated-initializers"

// Designated initializer
- (instancetype)initWithHost:(NSString *)host callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [super initWithHost:host
                 packageName:@"keyapis.multiapp.v1"
                 serviceName:@"PartnerService"
                 callOptions:callOptions];
}

- (instancetype)initWithHost:(NSString *)host {
  return [super initWithHost:host
                 packageName:@"keyapis.multiapp.v1"
                 serviceName:@"PartnerService"];
}

#pragma clang diagnostic pop

// Override superclass initializer to disallow different package and service names.
- (instancetype)initWithHost:(NSString *)host
                 packageName:(NSString *)packageName
                 serviceName:(NSString *)serviceName {
  return [self initWithHost:host];
}

- (instancetype)initWithHost:(NSString *)host
                 packageName:(NSString *)packageName
                 serviceName:(NSString *)serviceName
                 callOptions:(GRPCCallOptions *)callOptions {
  return [self initWithHost:host callOptions:callOptions];
}

#pragma mark - Class Methods

+ (instancetype)serviceWithHost:(NSString *)host {
  return [[self alloc] initWithHost:host];
}

+ (instancetype)serviceWithHost:(NSString *)host callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [[self alloc] initWithHost:host callOptions:callOptions];
}

#pragma mark - Method Implementations

#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{
  [[self RPCToPostPartnerWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод сохранения партнера.
 * Поддерживает создание и обновление.
 * Сценарий использования метода: 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{
  return [self RPCToMethod:@"PostPartner"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1PostPartnerResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод сохранения партнера.
 * Поддерживает создание и обновление.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695525.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)postPartnerWithMessage:(KEYAPISMULTIAPPV1PostPartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostPartner"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1PostPartnerResponse class]];
}

#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{
  [[self RPCToGetPartnerWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения партнера.
 * Метод доступен для: 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{
  return [self RPCToMethod:@"GetPartner"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetPartnerResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения партнера.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerWithMessage:(KEYAPISMULTIAPPV1GetPartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetPartner"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetPartnerResponse class]];
}

#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{
  [[self RPCToGetPartnerListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения списка партнеров.
 * Метод доступен для: 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{
  return [self RPCToMethod:@"GetPartnerList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetPartnerListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения списка партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerListWithMessage:(KEYAPISMULTIAPPV1GetPartnerListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetPartnerList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetPartnerListResponse class]];
}

#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{
  [[self RPCToGetPartnerCountWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения количества партнеров.
 * Метод доступен для: 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{
  return [self RPCToMethod:@"GetPartnerCount"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetPartnerCountResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения количества партнеров.
 * Метод доступен для: admin, manager, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getPartnerCountWithMessage:(KEYAPISMULTIAPPV1GetPartnerCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetPartnerCount"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetPartnerCountResponse class]];
}

#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{
  [[self RPCToGetPartnerTokenWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения токена.
 * 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{
  return [self RPCToMethod:@"GetPartnerToken"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetPartnerTokenResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения токена.
 * 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 {
  return [self RPCToMethod:@"GetPartnerToken"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetPartnerTokenResponse class]];
}

#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{
  [[self RPCToPostPartnerPublicKeyWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод обновления публичного ключа партнёра.
 * Поддерживает создание и обновление.
 * Метод доступен для: 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{
  return [self RPCToMethod:@"PostPartnerPublicKey"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1PostPartnerPublicKeyResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод обновления публичного ключа партнёра.
 * Поддерживает создание и обновление.
 * Метод доступен для: 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 {
  return [self RPCToMethod:@"PostPartnerPublicKey"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1PostPartnerPublicKeyResponse class]];
}

#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{
  [[self RPCToDeletePartnerWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления партнёра.
 * Сценарий использования метода: 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{
  return [self RPCToMethod:@"DeletePartner"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1DeletePartnerResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления партнёра.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=804302306.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)deletePartnerWithMessage:(KEYAPISMULTIAPPV1DeletePartnerRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"DeletePartner"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1DeletePartnerResponse class]];
}

#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{
  [[self RPCToGetPartnerAddressOrponWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения адреса дома по ОРПОНу.
 * Адресная строка должны быть в формате "{Регион}, {Город}, {Улица}, {Дом}, {Строение}".
 * Партнер может получить адрес только по доступному ему ОРПОНу.
 * Доступные ОРПОНы для партнера может получить через привязанные 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{
  return [self RPCToMethod:@"GetPartnerAddressOrpon"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetPartnerAddressOrponResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения адреса дома по ОРПОНу.
 * Адресная строка должны быть в формате "{Регион}, {Город}, {Улица}, {Дом}, {Строение}".
 * Партнер может получить адрес только по доступному ему ОРПОНу.
 * Доступные ОРПОНы для партнера может получить через привязанные 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 {
  return [self RPCToMethod:@"GetPartnerAddressOrpon"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetPartnerAddressOrponResponse class]];
}

@end
#endif
