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

#import <Foundation/Foundation.h>

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#import "keyapis/device/v1/KeyapisDeviceTrunkConfig.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 KEYAPISDIALV1DeleteTrunkConfigRequest;
@class KEYAPISDIALV1DeleteTrunkConfigResponse;
@class KEYAPISDIALV1GetTrunkConfigCountRequest;
@class KEYAPISDIALV1GetTrunkConfigCountResponse;
@class KEYAPISDIALV1GetTrunkConfigListRequest;
@class KEYAPISDIALV1GetTrunkConfigListResponse;
@class KEYAPISDIALV1GetTrunkConfigRequest;
@class KEYAPISDIALV1GetTrunkConfigResponse;
@class KEYAPISDIALV1PostTrunkConfigRequest;
@class KEYAPISDIALV1PostTrunkConfigResponse;
@class KEYAPISDIALV1PostTrunkConfigRestoreRequest;
@class KEYAPISDIALV1PostTrunkConfigRestoreResponse;

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
  #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/GPBTimestamp.pbobjc.h>
#else
  #import "GPBTimestamp.pbobjc.h"
#endif
#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/device/v1/KeyapisDeviceDeviceV1.pbobjc.h"
#endif

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


NS_ASSUME_NONNULL_BEGIN

@protocol KEYAPISDIALV1TrunkConfigService2 <NSObject>

#pragma mark GetTrunkConfig(GetTrunkConfigRequest) returns (GetTrunkConfigResponse)

/**
 * Метод получения trunk-конфигурации.
 * Метод доступен для: admin, bti, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getTrunkConfigWithMessage:(KEYAPISDIALV1GetTrunkConfigRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetTrunkConfigList(GetTrunkConfigListRequest) returns (stream GetTrunkConfigListResponse)

/**
 * Метод получения списка trunk-конфигураций.
 * Метод доступен для: admin, bti, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getTrunkConfigListWithMessage:(KEYAPISDIALV1GetTrunkConfigListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetTrunkConfigCount(GetTrunkConfigCountRequest) returns (GetTrunkConfigCountResponse)

/**
 * Метод получения количества trunk-конфигураций.
 * Метод доступен для: admin, bti, service, ltp_first
 */
- (GRPCUnaryProtoCall *)getTrunkConfigCountWithMessage:(KEYAPISDIALV1GetTrunkConfigCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostTrunkConfig(PostTrunkConfigRequest) returns (PostTrunkConfigResponse)

/**
 * Метод создания trunk-конфигурации.
 * Поддерживает создание и обновление.
 * Метод доступен для: admin, bti, service, ltp_first
 */
- (GRPCUnaryProtoCall *)postTrunkConfigWithMessage:(KEYAPISDIALV1PostTrunkConfigRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark DeleteTrunkConfig(DeleteTrunkConfigRequest) returns (DeleteTrunkConfigResponse)

/**
 * Метод архивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 */
- (GRPCUnaryProtoCall *)deleteTrunkConfigWithMessage:(KEYAPISDIALV1DeleteTrunkConfigRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostTrunkConfigRestore(PostTrunkConfigRestoreRequest) returns (PostTrunkConfigRestoreResponse)

/**
 * Метод разархивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 */
- (GRPCUnaryProtoCall *)postTrunkConfigRestoreWithMessage:(KEYAPISDIALV1PostTrunkConfigRestoreRequest *)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 KEYAPISDIALV1TrunkConfigService <NSObject>

#pragma mark GetTrunkConfig(GetTrunkConfigRequest) returns (GetTrunkConfigResponse)

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

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


#pragma mark GetTrunkConfigList(GetTrunkConfigListRequest) returns (stream GetTrunkConfigListResponse)

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

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


#pragma mark GetTrunkConfigCount(GetTrunkConfigCountRequest) returns (GetTrunkConfigCountResponse)

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

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


#pragma mark PostTrunkConfig(PostTrunkConfigRequest) returns (PostTrunkConfigResponse)

/**
 * Метод создания trunk-конфигурации.
 * Поддерживает создание и обновление.
 * Метод доступен для: admin, bti, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postTrunkConfigWithRequest:(KEYAPISDIALV1PostTrunkConfigRequest *)request handler:(void(^)(KEYAPISDIALV1PostTrunkConfigResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод создания trunk-конфигурации.
 * Поддерживает создание и обновление.
 * Метод доступен для: admin, bti, service, ltp_first
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostTrunkConfigWithRequest:(KEYAPISDIALV1PostTrunkConfigRequest *)request handler:(void(^)(KEYAPISDIALV1PostTrunkConfigResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark DeleteTrunkConfig(DeleteTrunkConfigRequest) returns (DeleteTrunkConfigResponse)

/**
 * Метод архивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)deleteTrunkConfigWithRequest:(KEYAPISDIALV1DeleteTrunkConfigRequest *)request handler:(void(^)(KEYAPISDIALV1DeleteTrunkConfigResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод архивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToDeleteTrunkConfigWithRequest:(KEYAPISDIALV1DeleteTrunkConfigRequest *)request handler:(void(^)(KEYAPISDIALV1DeleteTrunkConfigResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark PostTrunkConfigRestore(PostTrunkConfigRestoreRequest) returns (PostTrunkConfigRestoreResponse)

/**
 * Метод разархивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postTrunkConfigRestoreWithRequest:(KEYAPISDIALV1PostTrunkConfigRestoreRequest *)request handler:(void(^)(KEYAPISDIALV1PostTrunkConfigRestoreResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод разархивации trunk-конфигурации.
 * Метод доступен для: admin, service, device_admin
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostTrunkConfigRestoreWithRequest:(KEYAPISDIALV1PostTrunkConfigRestoreRequest *)request handler:(void(^)(KEYAPISDIALV1PostTrunkConfigRestoreResponse *_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 KEYAPISDIALV1TrunkConfigService : GRPCProtoService<KEYAPISDIALV1TrunkConfigService2, KEYAPISDIALV1TrunkConfigService>
- (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

