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

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import "keyapis/access_control/v1/KeyapisAccessControlBuildingV1.pbrpc.h"
#import "keyapis/access_control/v1/KeyapisAccessControlBuildingV1.pbobjc.h"
#import <ProtoRPC/ProtoRPCLegacy.h>
#import <RxLibrary/GRXWriter+Immediate.h>

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

@implementation KEYAPISACCESSCONTROLV1BuildingService

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

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

#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 GetBuilding(GetBuildingRequest) returns (GetBuildingResponse)

/**
 * Метод получения Дома.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, seller, external_seller, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getBuildingWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetBuildingWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения Дома.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, seller, external_seller, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetBuildingWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetBuilding"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения Дома.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, seller, external_seller, ltp_first, bti
 */
- (GRPCUnaryProtoCall *)getBuildingWithMessage:(KEYAPISACCESSCONTROLV1GetBuildingRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetBuilding"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingResponse class]];
}

#pragma mark GetBuildingList(GetBuildingListRequest) returns (stream GetBuildingListResponse)

/**
 * Метод получения списка домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * При запросе через ApiKey происходит дополнительная фильтрация домов на основе доступности домов для этого ApiKey (фильтрация происходит по доступным AccessPoint для этой группы).
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getBuildingListWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetBuildingListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  [[self RPCToGetBuildingListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения списка домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * При запросе через ApiKey происходит дополнительная фильтрация домов на основе доступности домов для этого ApiKey (фильтрация происходит по доступным AccessPoint для этой группы).
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti.
 * Метод доступен для: ApiKey
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetBuildingListWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetBuildingListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  return [self RPCToMethod:@"GetBuildingList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения списка домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * При запросе через ApiKey происходит дополнительная фильтрация домов на основе доступности домов для этого ApiKey (фильтрация происходит по доступным AccessPoint для этой группы).
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti.
 * Метод доступен для: ApiKey
 */
- (GRPCUnaryProtoCall *)getBuildingListWithMessage:(KEYAPISACCESSCONTROLV1GetBuildingListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetBuildingList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingListResponse class]];
}

#pragma mark GetBuildingCount(GetBuildingCountRequest) returns (GetBuildingCountResponse)

/**
 * Метод получения количества домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getBuildingCountWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingCountRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingCountResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetBuildingCountWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения количества домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetBuildingCountWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingCountRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingCountResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetBuildingCount"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingCountResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения количества домов.
 * Для пользователей типов owner, employee: в результат попадают только дома, которые привязаны к компании пользователя или дома квартирограамм привязанных к компании пользователя.
 * Метод доступен для: admin, service, owner, employee, ltp_first, bti
 */
- (GRPCUnaryProtoCall *)getBuildingCountWithMessage:(KEYAPISACCESSCONTROLV1GetBuildingCountRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetBuildingCount"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingCountResponse class]];
}

#pragma mark GetBuildingOrponSubscriptionMode(GetBuildingOrponSubscriptionModeRequest) returns (GetBuildingOrponSubscriptionModeResponse)

/**
 * Метод получения статуса режима работы с подписками у помещений дома.
 * Возвращает агрегированный статус по всем помещениям дома.
 * Метод доступен для: admin, service, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getBuildingOrponSubscriptionModeWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetBuildingOrponSubscriptionModeWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения статуса режима работы с подписками у помещений дома.
 * Возвращает агрегированный статус по всем помещениям дома.
 * Метод доступен для: admin, service, ltp_first, bti
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetBuildingOrponSubscriptionModeWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetBuildingOrponSubscriptionMode"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод получения статуса режима работы с подписками у помещений дома.
 * Возвращает агрегированный статус по всем помещениям дома.
 * Метод доступен для: admin, service, ltp_first, bti
 */
- (GRPCUnaryProtoCall *)getBuildingOrponSubscriptionModeWithMessage:(KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetBuildingOrponSubscriptionMode"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingOrponSubscriptionModeResponse class]];
}

#pragma mark GetBuildingOrponExists(GetBuildingOrponExistsRequest) returns (GetBuildingOrponExistsResponse)

/**
 * Метод проверки существования дома по ОРПОН.
 * Возвращает true если найден дом с указанным ОРПОН.
 * Метод доступен для: admin, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getBuildingOrponExistsWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingOrponExistsRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingOrponExistsResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToGetBuildingOrponExistsWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод проверки существования дома по ОРПОН.
 * Возвращает true если найден дом с указанным ОРПОН.
 * Метод доступен для: admin, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetBuildingOrponExistsWithRequest:(KEYAPISACCESSCONTROLV1GetBuildingOrponExistsRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1GetBuildingOrponExistsResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"GetBuildingOrponExists"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingOrponExistsResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод проверки существования дома по ОРПОН.
 * Возвращает true если найден дом с указанным ОРПОН.
 * Метод доступен для: admin, service
 */
- (GRPCUnaryProtoCall *)getBuildingOrponExistsWithMessage:(KEYAPISACCESSCONTROLV1GetBuildingOrponExistsRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetBuildingOrponExists"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetBuildingOrponExistsResponse class]];
}

@end
#endif
