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

#import <Foundation/Foundation.h>

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#import "keyapis/iot_connect/v1/KeyapisIotConnectCallbackV1.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 KEYAPISIOTCONNECTV1GetCallbackDevicesRequest;
@class KEYAPISIOTCONNECTV1GetCallbackDevicesResponse;
@class KEYAPISIOTCONNECTV1GetCallbackUserRequest;
@class KEYAPISIOTCONNECTV1GetCallbackUserResponse;
@class KEYAPISIOTCONNECTV1PostCallbackCommandRequest;
@class KEYAPISIOTCONNECTV1PostCallbackCommandResponse;
@class KEYAPISIOTCONNECTV1PostCallbackStatusRequest;
@class KEYAPISIOTCONNECTV1PostCallbackStatusResponse;
@class KEYAPISIOTCONNECTV1PostCallbackUnlinkRequest;
@class KEYAPISIOTCONNECTV1PostCallbackUnlinkResponse;

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

#pragma mark GetCallbackUser(GetCallbackUserRequest) returns (GetCallbackUserResponse)

/**
 * Метод получения пользователя.
 * Метод доступен для: TokenACF: Scope: iot
 */
- (GRPCUnaryProtoCall *)getCallbackUserWithMessage:(KEYAPISIOTCONNECTV1GetCallbackUserRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetCallbackDevices(GetCallbackDevicesRequest) returns (GetCallbackDevicesResponse)

/**
 * Метод получения устройств, доступных пользователю.
 * Метод доступен для: TokenACF: Scope: iot
 */
- (GRPCUnaryProtoCall *)getCallbackDevicesWithMessage:(KEYAPISIOTCONNECTV1GetCallbackDevicesRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostCallbackStatus(PostCallbackStatusRequest) returns (PostCallbackStatusResponse)

/**
 * Метод получения внешним партнёром состояния устройства.
 * Метод доступен для: TokenACF: Scope: iot
 */
- (GRPCUnaryProtoCall *)postCallbackStatusWithMessage:(KEYAPISIOTCONNECTV1PostCallbackStatusRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostCallbackCommand(PostCallbackCommandRequest) returns (PostCallbackCommandResponse)

/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: iot
 */
- (GRPCUnaryProtoCall *)postCallbackCommandWithMessage:(KEYAPISIOTCONNECTV1PostCallbackCommandRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostCallbackUnlink(PostCallbackUnlinkRequest) returns (PostCallbackUnlinkResponse)

/**
 * Метод сообщения от внешнего IoT партнёра о разъединении аккаунтов.
 * Метод доступен для: TokenACF: Scope: iot
 */
- (GRPCUnaryProtoCall *)postCallbackUnlinkWithMessage:(KEYAPISIOTCONNECTV1PostCallbackUnlinkRequest *)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 KEYAPISIOTCONNECTV1IotConnectCallbackService <NSObject>

#pragma mark GetCallbackUser(GetCallbackUserRequest) returns (GetCallbackUserResponse)

/**
 * Метод получения пользователя.
 * Метод доступен для: TokenACF: Scope: 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;

/**
 * Метод получения пользователя.
 * Метод доступен для: TokenACF: Scope: 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;


#pragma mark GetCallbackDevices(GetCallbackDevicesRequest) returns (GetCallbackDevicesResponse)

/**
 * Метод получения устройств, доступных пользователю.
 * Метод доступен для: TokenACF: Scope: 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;

/**
 * Метод получения устройств, доступных пользователю.
 * Метод доступен для: TokenACF: Scope: 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;


#pragma mark PostCallbackStatus(PostCallbackStatusRequest) returns (PostCallbackStatusResponse)

/**
 * Метод получения внешним партнёром состояния устройства.
 * Метод доступен для: TokenACF: Scope: iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postCallbackStatusWithRequest:(KEYAPISIOTCONNECTV1PostCallbackStatusRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackStatusResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения внешним партнёром состояния устройства.
 * Метод доступен для: TokenACF: Scope: iot
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostCallbackStatusWithRequest:(KEYAPISIOTCONNECTV1PostCallbackStatusRequest *)request handler:(void(^)(KEYAPISIOTCONNECTV1PostCallbackStatusResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark PostCallbackCommand(PostCallbackCommandRequest) returns (PostCallbackCommandResponse)

/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: 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;

/**
 * Метод запроса внешнего IoT партнёра на изменение состояния устройства.
 * Поддерживается только открытие домофона.
 * Метод доступен для: TokenACF: Scope: 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;


#pragma mark PostCallbackUnlink(PostCallbackUnlinkRequest) returns (PostCallbackUnlinkResponse)

/**
 * Метод сообщения от внешнего IoT партнёра о разъединении аккаунтов.
 * Метод доступен для: TokenACF: Scope: 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;

/**
 * Метод сообщения от внешнего IoT партнёра о разъединении аккаунтов.
 * Метод доступен для: TokenACF: Scope: 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;


@end


#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
/**
 * Basic service implementation, over gRPC, that only does
 * marshalling and parsing.
 */
@interface KEYAPISIOTCONNECTV1IotConnectCallbackService : GRPCProtoService<KEYAPISIOTCONNECTV1IotConnectCallbackService2, KEYAPISIOTCONNECTV1IotConnectCallbackService>
- (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

