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

#import <Foundation/Foundation.h>

#if !defined(GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO) || !GPB_GRPC_FORWARD_DECLARE_MESSAGE_PROTO
#import "keyapis/access_control/v1/KeyapisAccessControlAccessPointV1.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 KEYAPISACCESSCONTROLV1DeleteAccessPointRequest;
@class KEYAPISACCESSCONTROLV1DeleteAccessPointResponse;
@class KEYAPISACCESSCONTROLV1GetAccessPointCountRequest;
@class KEYAPISACCESSCONTROLV1GetAccessPointCountResponse;
@class KEYAPISACCESSCONTROLV1GetAccessPointListRequest;
@class KEYAPISACCESSCONTROLV1GetAccessPointListResponse;
@class KEYAPISACCESSCONTROLV1GetAccessPointRequest;
@class KEYAPISACCESSCONTROLV1GetAccessPointResponse;
@class KEYAPISACCESSCONTROLV1PostAccessPointOpenRequest;
@class KEYAPISACCESSCONTROLV1PostAccessPointOpenResponse;
@class KEYAPISACCESSCONTROLV1PostAccessPointRequest;
@class KEYAPISACCESSCONTROLV1PostAccessPointResponse;

#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"
  #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/access_control/v1/KeyapisAccessControlAccessControlV1.pbobjc.h"
#endif

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


NS_ASSUME_NONNULL_BEGIN

@protocol KEYAPISACCESSCONTROLV1AccessPointService2 <NSObject>

#pragma mark PostAccessPoint(PostAccessPointRequest) returns (PostAccessPointResponse)

/**
 * Метод сохранения точки доступа.
 * Поддерживает создание и обновление.
 * Метод доступен для: admin, service, bti
 */
- (GRPCUnaryProtoCall *)postAccessPointWithMessage:(KEYAPISACCESSCONTROLV1PostAccessPointRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetAccessPoint(GetAccessPointRequest) returns (GetAccessPointResponse)

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

#pragma mark GetAccessPointList(GetAccessPointListRequest) returns (stream GetAccessPointListResponse)

/**
 * Метод получения списка точек доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 */
- (GRPCUnaryProtoCall *)getAccessPointListWithMessage:(KEYAPISACCESSCONTROLV1GetAccessPointListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark GetAccessPointCount(GetAccessPointCountRequest) returns (GetAccessPointCountResponse)

/**
 * Метод получения количества точек доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 */
- (GRPCUnaryProtoCall *)getAccessPointCountWithMessage:(KEYAPISACCESSCONTROLV1GetAccessPointCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark DeleteAccessPoint(DeleteAccessPointRequest) returns (DeleteAccessPointResponse)

/**
 * Метод удаления точки доступа.
 * Метод доступен для: admin, service, bti
 */
- (GRPCUnaryProtoCall *)deleteAccessPointWithMessage:(KEYAPISACCESSCONTROLV1DeleteAccessPointRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions;

#pragma mark PostAccessPointOpen(PostAccessPointOpenRequest) returns (PostAccessPointOpenResponse)

/**
 * Метод открытия точки доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 */
- (GRPCUnaryProtoCall *)postAccessPointOpenWithMessage:(KEYAPISACCESSCONTROLV1PostAccessPointOpenRequest *)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 KEYAPISACCESSCONTROLV1AccessPointService <NSObject>

#pragma mark PostAccessPoint(PostAccessPointRequest) returns (PostAccessPointResponse)

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

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


#pragma mark GetAccessPoint(GetAccessPointRequest) returns (GetAccessPointResponse)

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

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


#pragma mark GetAccessPointList(GetAccessPointListRequest) returns (stream GetAccessPointListResponse)

/**
 * Метод получения списка точек доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getAccessPointListWithRequest:(KEYAPISACCESSCONTROLV1GetAccessPointListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetAccessPointListResponse *_Nullable response, NSError *_Nullable error))eventHandler;

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


#pragma mark GetAccessPointCount(GetAccessPointCountRequest) returns (GetAccessPointCountResponse)

/**
 * Метод получения количества точек доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getAccessPointCountWithRequest:(KEYAPISACCESSCONTROLV1GetAccessPointCountRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetAccessPointCountResponse *_Nullable response, NSError *_Nullable error))handler;

/**
 * Метод получения количества точек доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetAccessPointCountWithRequest:(KEYAPISACCESSCONTROLV1GetAccessPointCountRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetAccessPointCountResponse *_Nullable response, NSError *_Nullable error))handler;


#pragma mark DeleteAccessPoint(DeleteAccessPointRequest) returns (DeleteAccessPointResponse)

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

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


#pragma mark PostAccessPointOpen(PostAccessPointOpenRequest) returns (PostAccessPointOpenResponse)

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

/**
 * Метод открытия точки доступа.
 * Метод доступен для: admin, service, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostAccessPointOpenWithRequest:(KEYAPISACCESSCONTROLV1PostAccessPointOpenRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1PostAccessPointOpenResponse *_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 KEYAPISACCESSCONTROLV1AccessPointService : GRPCProtoService<KEYAPISACCESSCONTROLV1AccessPointService2, KEYAPISACCESSCONTROLV1AccessPointService>
- (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

