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

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import "keyapis/multiapp/v1/KeyapisMultiappNotificationTemplateV1.pbrpc.h"
#import "keyapis/multiapp/v1/KeyapisMultiappNotificationTemplateV1.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 KEYAPISMULTIAPPV1NotificationTemplateService

#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:@"NotificationTemplateService"
                 callOptions:callOptions];
}

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

#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 PostNotificationTemplate(PostNotificationTemplateRequest) returns (PostNotificationTemplateResponse)

/**
 * Метод сохранения шаблона уведомления.
 * Поддерживает создание и обновление.
 * Поддерживает mustache теги в переменных template_header и template_text.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=774989444.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1PostNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostNotificationTemplateWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод сохранения шаблона уведомления.
 * Поддерживает создание и обновление.
 * Поддерживает mustache теги в переменных template_header и template_text.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=774989444.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1PostNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PostNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostNotificationTemplate"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1PostNotificationTemplateResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод сохранения шаблона уведомления.
 * Поддерживает создание и обновление.
 * Поддерживает mustache теги в переменных template_header и template_text.
 * Сценарий использования метода: https://confluence.rt.ru/pages/viewpage.action?pageId=774989444.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)postNotificationTemplateWithMessage:(KEYAPISMULTIAPPV1PostNotificationTemplateRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostNotificationTemplate"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1PostNotificationTemplateResponse class]];
}

#pragma mark GetNotificationTemplate(GetNotificationTemplateRequest) returns (GetNotificationTemplateResponse)

/**
 * Метод получения шаблона уведомления.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Роли partner доступны только связанные с ней шаблоны
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetNotificationTemplateWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения шаблона уведомления.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Роли partner доступны только связанные с ней шаблоны
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetNotificationTemplate"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения шаблона уведомления.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Роли partner доступны только связанные с ней шаблоны
 */
- (GRPCUnaryProtoCall *)getNotificationTemplateWithMessage:(KEYAPISMULTIAPPV1GetNotificationTemplateRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetNotificationTemplate"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateResponse class]];
}

#pragma mark DeleteNotificationTemplate(DeleteNotificationTemplateRequest) returns (DeleteNotificationTemplateResponse)

/**
 * Метод удаления шаблона уведомления.
 * Устанавливает текущую дату и время в параметр deleted_at.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)deleteNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1DeleteNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1DeleteNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToDeleteNotificationTemplateWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления шаблона уведомления.
 * Устанавливает текущую дату и время в параметр deleted_at.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToDeleteNotificationTemplateWithRequest:(KEYAPISMULTIAPPV1DeleteNotificationTemplateRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1DeleteNotificationTemplateResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"DeleteNotificationTemplate"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1DeleteNotificationTemplateResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления шаблона уведомления.
 * Устанавливает текущую дату и время в параметр deleted_at.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)deleteNotificationTemplateWithMessage:(KEYAPISMULTIAPPV1DeleteNotificationTemplateRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"DeleteNotificationTemplate"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1DeleteNotificationTemplateResponse class]];
}

#pragma mark GetNotificationTemplateList(GetNotificationTemplateListRequest) returns (stream GetNotificationTemplateListResponse)

/**
 * Метод получения списка шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getNotificationTemplateListWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISMULTIAPPV1GetNotificationTemplateListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  [[self RPCToGetNotificationTemplateListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения списка шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetNotificationTemplateListWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISMULTIAPPV1GetNotificationTemplateListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  return [self RPCToMethod:@"GetNotificationTemplateList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения списка шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 */
- (GRPCUnaryProtoCall *)getNotificationTemplateListWithMessage:(KEYAPISMULTIAPPV1GetNotificationTemplateListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetNotificationTemplateList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateListResponse class]];
}

#pragma mark GetNotificationTemplateCount(GetNotificationTemplateCountRequest) returns (GetNotificationTemplateCountResponse)

/**
 * Метод получения количества шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getNotificationTemplateCountWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateCountRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetNotificationTemplateCountResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetNotificationTemplateCountWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения количества шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetNotificationTemplateCountWithRequest:(KEYAPISMULTIAPPV1GetNotificationTemplateCountRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1GetNotificationTemplateCountResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetNotificationTemplateCount"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateCountResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения количества шаблонов уведомлений.
 * Метод доступен для: admin, manager, service, partner.
 * Роль partner определяется по наличию заголовка X-API-KEY вместо Authorization.
 * Если метод вызван ролью partner в фильтре поле partner_ids принудительно замещается его идентификатором
 */
- (GRPCUnaryProtoCall *)getNotificationTemplateCountWithMessage:(KEYAPISMULTIAPPV1GetNotificationTemplateCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetNotificationTemplateCount"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1GetNotificationTemplateCountResponse class]];
}

#pragma mark PutNotificationTemplatePartnerAttach(PutNotificationTemplatePartnerAttachRequest) returns (PutNotificationTemplatePartnerAttachResponse)

/**
 * Метод создания связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)putNotificationTemplatePartnerAttachWithRequest:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPutNotificationTemplatePartnerAttachWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод создания связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPutNotificationTemplatePartnerAttachWithRequest:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PutNotificationTemplatePartnerAttach"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод создания связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)putNotificationTemplatePartnerAttachWithMessage:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PutNotificationTemplatePartnerAttach"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1PutNotificationTemplatePartnerAttachResponse class]];
}

#pragma mark PutNotificationTemplatePartnerDetach(PutNotificationTemplatePartnerDetachRequest) returns (PutNotificationTemplatePartnerDetachResponse)

/**
 * Метод удаления связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)putNotificationTemplatePartnerDetachWithRequest:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPutNotificationTemplatePartnerDetachWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPutNotificationTemplatePartnerDetachWithRequest:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachRequest *)request handler:(void(^)(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PutNotificationTemplatePartnerDetach"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления связи шаблона уведомления и партнера.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)putNotificationTemplatePartnerDetachWithMessage:(KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PutNotificationTemplatePartnerDetach"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISMULTIAPPV1PutNotificationTemplatePartnerDetachResponse class]];
}

@end
#endif
