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

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

#import "google/api/Annotations.pbobjc.h"
#import "google/api/FieldBehavior.pbobjc.h"
#import "keyapis/access_control/v1/KeyapisAccessControlAccessControlV1.pbobjc.h"

@implementation KEYAPISACCESSCONTROLV1EntranceService

#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:@"EntranceService"
                 callOptions:callOptions];
}

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

#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 PostEntrance(PostEntranceRequest) returns (PostEntranceResponse)

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

#pragma mark DeleteEntrance(DeleteEntranceRequest) returns (DeleteEntranceResponse)

/**
 * Метод удаления подъезда.
 * Реализуется как удаление квартир по указанному дому и номеру подъезда.
 * Для ролей employee, owner можно удалять только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)deleteEntranceWithRequest:(KEYAPISACCESSCONTROLV1DeleteEntranceRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1DeleteEntranceResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToDeleteEntranceWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления подъезда.
 * Реализуется как удаление квартир по указанному дому и номеру подъезда.
 * Для ролей employee, owner можно удалять только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToDeleteEntranceWithRequest:(KEYAPISACCESSCONTROLV1DeleteEntranceRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1DeleteEntranceResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"DeleteEntrance"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1DeleteEntranceResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления подъезда.
 * Реализуется как удаление квартир по указанному дому и номеру подъезда.
 * Для ролей employee, owner можно удалять только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 */
- (GRPCUnaryProtoCall *)deleteEntranceWithMessage:(KEYAPISACCESSCONTROLV1DeleteEntranceRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"DeleteEntrance"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1DeleteEntranceResponse class]];
}

#pragma mark GetEntranceList(GetEntranceListRequest) returns (stream GetEntranceListResponse)

/**
 * Метод получения списка подъездов.
 * При переданном company_ids учитывается тип связи компании и квартирограммы.
 * Если EntranceFilter.CompanyRelationType = DEVICE_SERVICE, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = MANAGEMENT, то проверяется связка в flatgramm_companies.
 * Если EntranceFilter.CompanyRelationType = DEFAULT, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = COMPANY_RELATION_TYPE_UNKNOWN, вернется ошибка валидации.
 * При не переданном company_ids поле EntranceFilter.CompanyRelationType вызовет ошибку валидации.
 * Для ролей employee, owner можно получать только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getEntranceListWithRequest:(KEYAPISACCESSCONTROLV1GetEntranceListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetEntranceListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  [[self RPCToGetEntranceListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения списка подъездов.
 * При переданном company_ids учитывается тип связи компании и квартирограммы.
 * Если EntranceFilter.CompanyRelationType = DEVICE_SERVICE, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = MANAGEMENT, то проверяется связка в flatgramm_companies.
 * Если EntranceFilter.CompanyRelationType = DEFAULT, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = COMPANY_RELATION_TYPE_UNKNOWN, вернется ошибка валидации.
 * При не переданном company_ids поле EntranceFilter.CompanyRelationType вызовет ошибку валидации.
 * Для ролей employee, owner можно получать только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetEntranceListWithRequest:(KEYAPISACCESSCONTROLV1GetEntranceListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetEntranceListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  return [self RPCToMethod:@"GetEntranceList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetEntranceListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения списка подъездов.
 * При переданном company_ids учитывается тип связи компании и квартирограммы.
 * Если EntranceFilter.CompanyRelationType = DEVICE_SERVICE, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = MANAGEMENT, то проверяется связка в flatgramm_companies.
 * Если EntranceFilter.CompanyRelationType = DEFAULT, то проверяется связка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE.
 * Если EntranceFilter.CompanyRelationType = COMPANY_RELATION_TYPE_UNKNOWN, вернется ошибка валидации.
 * При не переданном company_ids поле EntranceFilter.CompanyRelationType вызовет ошибку валидации.
 * Для ролей employee, owner можно получать только подъезды квартирограмм, привязанные к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 */
- (GRPCUnaryProtoCall *)getEntranceListWithMessage:(KEYAPISACCESSCONTROLV1GetEntranceListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetEntranceList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetEntranceListResponse class]];
}

#pragma mark PutEntranceDeviceAttach(PutEntranceDeviceAttachRequest) returns (PutEntranceDeviceAttachResponse)

/**
 * Метод создания связи подъезда и устройства.
 * Для ролей employee, owner можно сохранять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)putEntranceDeviceAttachWithRequest:(KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPutEntranceDeviceAttachWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод создания связи подъезда и устройства.
 * Для ролей employee, owner можно сохранять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPutEntranceDeviceAttachWithRequest:(KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PutEntranceDeviceAttach"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод создания связи подъезда и устройства.
 * Для ролей employee, owner можно сохранять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 */
- (GRPCUnaryProtoCall *)putEntranceDeviceAttachWithMessage:(KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PutEntranceDeviceAttach"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1PutEntranceDeviceAttachResponse class]];
}

#pragma mark PutEntranceDeviceDetach(PutEntranceDeviceDetachRequest) returns (PutEntranceDeviceDetachResponse)

/**
 * Метод удаления связи подъезда и устройства.
 * Для ролей employee, owner можно удалять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)putEntranceDeviceDetachWithRequest:(KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPutEntranceDeviceDetachWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления связи подъезда и устройства.
 * Для ролей employee, owner можно удалять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPutEntranceDeviceDetachWithRequest:(KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachRequest *)request handler:(void(^)(KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PutEntranceDeviceDetach"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления связи подъезда и устройства.
 * Для ролей employee, owner можно удалять только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * EntranceDevice.RelationType в данном методе не используется.
 * Метод доступен для: admin, service, owner, employee
 */
- (GRPCUnaryProtoCall *)putEntranceDeviceDetachWithMessage:(KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PutEntranceDeviceDetach"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1PutEntranceDeviceDetachResponse class]];
}

#pragma mark GetEntranceDeviceList(GetEntranceDeviceListRequest) returns (stream GetEntranceDeviceListResponse)

/**
 * Метод получения списка связок подъезд-устройство.
 * Для ролей employee, owner можно получать только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getEntranceDeviceListWithRequest:(KEYAPISACCESSCONTROLV1GetEntranceDeviceListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetEntranceDeviceListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  [[self RPCToGetEntranceDeviceListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения списка связок подъезд-устройство.
 * Для ролей employee, owner можно получать только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetEntranceDeviceListWithRequest:(KEYAPISACCESSCONTROLV1GetEntranceDeviceListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISACCESSCONTROLV1GetEntranceDeviceListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  return [self RPCToMethod:@"GetEntranceDeviceList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISACCESSCONTROLV1GetEntranceDeviceListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения списка связок подъезд-устройство.
 * Для ролей employee, owner можно получать только связи с подъездами квартирограмм, привязанным к домофонной компании пользователя (привязка компании с типом dc_company_flatgramm.type = DEVICE_SERVICE).
 * Метод доступен для: admin, service, owner, employee
 */
- (GRPCUnaryProtoCall *)getEntranceDeviceListWithMessage:(KEYAPISACCESSCONTROLV1GetEntranceDeviceListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetEntranceDeviceList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISACCESSCONTROLV1GetEntranceDeviceListResponse class]];
}

@end
#endif
