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

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import "keyapis/iot_connect/v1/KeyapisIotConnectCallbackV1.pbrpc.h"
#import "keyapis/iot_connect/v1/KeyapisIotConnectCallbackV1.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"
#if defined(GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS) && GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
#import <Protobuf/GPBWrappers.pbobjc.h>
#else
#import "GPBWrappers.pbobjc.h"
#endif

@implementation KEYAPISIOTCONNECTV1IotConnectCallbackService

#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.iot_connect.v1"
                 serviceName:@"IotConnectCallbackService"
                 callOptions:callOptions];
}

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

#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 GetCallbackUser(GetCallbackUserRequest) returns (GetCallbackUserResponse)

/**
 * Метод получения пользователя для соединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getCallbackUserWithRequest:(KEYAPISIOTCONNECTV1GetCallbackUserRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1GetCallbackUserResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetCallbackUserWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения пользователя для соединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetCallbackUserWithRequest:(KEYAPISIOTCONNECTV1GetCallbackUserRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1GetCallbackUserResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetCallbackUser"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISIOTCONNECTV1GetCallbackUserResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения пользователя для соединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 */
- (GRPCUnaryProtoCall *)getCallbackUserWithMessage:(KEYAPISIOTCONNECTV1GetCallbackUserRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetCallbackUser"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISIOTCONNECTV1GetCallbackUserResponse class]];
}

#pragma mark PostCallbackUnlink(PostCallbackUnlinkRequest) returns (PostCallbackUnlinkResponse)

/**
 * Метод разъединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postCallbackUnlinkWithRequest:(KEYAPISIOTCONNECTV1PostCallbackUnlinkRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackUnlinkResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostCallbackUnlinkWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод разъединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostCallbackUnlinkWithRequest:(KEYAPISIOTCONNECTV1PostCallbackUnlinkRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackUnlinkResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostCallbackUnlink"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackUnlinkResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод разъединения аккаунтов.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 */
- (GRPCUnaryProtoCall *)postCallbackUnlinkWithMessage:(KEYAPISIOTCONNECTV1PostCallbackUnlinkRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostCallbackUnlink"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackUnlinkResponse class]];
}

#pragma mark GetCallbackDevices(GetCallbackDevicesRequest) returns (GetCallbackDevicesResponse)

/**
 * Метод получения устройств, доступных пользователю.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getCallbackDevicesWithRequest:(KEYAPISIOTCONNECTV1GetCallbackDevicesRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1GetCallbackDevicesResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetCallbackDevicesWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения устройств, доступных пользователю.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetCallbackDevicesWithRequest:(KEYAPISIOTCONNECTV1GetCallbackDevicesRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1GetCallbackDevicesResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetCallbackDevices"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISIOTCONNECTV1GetCallbackDevicesResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения устройств, доступных пользователю.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 */
- (GRPCUnaryProtoCall *)getCallbackDevicesWithMessage:(KEYAPISIOTCONNECTV1GetCallbackDevicesRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetCallbackDevices"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISIOTCONNECTV1GetCallbackDevicesResponse class]];
}

#pragma mark PostCallbackQuery(PostCallbackQueryRequest) returns (PostCallbackQueryResponse)

/**
 * Зачем.
 * Метод получения состояния устройства.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postCallbackQueryWithRequest:(KEYAPISIOTCONNECTV1PostCallbackQueryRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackQueryResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostCallbackQueryWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Зачем.
 * Метод получения состояния устройства.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostCallbackQueryWithRequest:(KEYAPISIOTCONNECTV1PostCallbackQueryRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackQueryResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostCallbackQuery"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackQueryResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Зачем.
 * Метод получения состояния устройства.
 * Идентификатор пользователя - это subject из токена.
 * Метод доступен для: TokenACF: Scope: sber_iot
 */
- (GRPCUnaryProtoCall *)postCallbackQueryWithMessage:(KEYAPISIOTCONNECTV1PostCallbackQueryRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostCallbackQuery"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackQueryResponse class]];
}

#pragma mark PostCallbackCommand(PostCallbackCommandRequest) returns (PostCallbackCommandResponse)

/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postCallbackCommandWithRequest:(KEYAPISIOTCONNECTV1PostCallbackCommandRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackCommandResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostCallbackCommandWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: sber_iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostCallbackCommandWithRequest:(KEYAPISIOTCONNECTV1PostCallbackCommandRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackCommandResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostCallbackCommand"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackCommandResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: sber_iot
 */
- (GRPCUnaryProtoCall *)postCallbackCommandWithMessage:(KEYAPISIOTCONNECTV1PostCallbackCommandRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostCallbackCommand"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISIOTCONNECTV1PostCallbackCommandResponse class]];
}

@end
#endif
