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

#if !defined(GPB_GRPC_PROTOCOL_ONLY) || !GPB_GRPC_PROTOCOL_ONLY
#import "keyapis/vc/v1/KeyapisVcCameraGroupV1.pbrpc.h"
#import "keyapis/vc/v1/KeyapisVcCameraGroupV1.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/GPBWrappers.pbobjc.h>
#else
#import "GPBWrappers.pbobjc.h"
#endif
#if defined(GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS) && GPB_USE_PROTOBUF_FRAMEWORK_IMPORTS
#import <Protobuf/GPBTimestamp.pbobjc.h>
#else
#import "GPBTimestamp.pbobjc.h"
#endif
#import "keyapis/vc/v1/KeyapisVcCameraV1.pbobjc.h"

@implementation KEYAPISVCV1CameraCollectionService

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

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

#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 GetCameraCollection(GetCameraCollectionRequest) returns (GetCameraCollectionResponse)

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

#pragma mark GetCameraCollectionList(GetCameraCollectionListRequest) returns (stream GetCameraCollectionListResponse)

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

#pragma mark GetCameraCollectionCount(GetCameraCollectionCountRequest) returns (GetCameraCollectionCountResponse)

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

#pragma mark SaveCameraCollection(SaveCameraCollectionRequest) returns (SaveCameraCollectionResponse)

/**
 * Метод создания и изменения коллекции камер.
 * При изменении коллекции массив external_camera_ids заменяется полностью.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)saveCameraCollectionWithRequest:(KEYAPISVCV1SaveCameraCollectionRequest *)request handler:(void(^)(KEYAPISVCV1SaveCameraCollectionResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToSaveCameraCollectionWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод создания и изменения коллекции камер.
 * При изменении коллекции массив external_camera_ids заменяется полностью.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToSaveCameraCollectionWithRequest:(KEYAPISVCV1SaveCameraCollectionRequest *)request handler:(void(^)(KEYAPISVCV1SaveCameraCollectionResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"SaveCameraCollection"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISVCV1SaveCameraCollectionResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод создания и изменения коллекции камер.
 * При изменении коллекции массив external_camera_ids заменяется полностью.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 */
- (GRPCUnaryProtoCall *)saveCameraCollectionWithMessage:(KEYAPISVCV1SaveCameraCollectionRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"SaveCameraCollection"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISVCV1SaveCameraCollectionResponse class]];
}

#pragma mark DeleteCameraCollection(DeleteCameraCollectionRequest) returns (DeleteCameraCollectionResponse)

/**
 * Метод удаления коллекции камер.
 * Проставляет в поле deleted_at текущую дату.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)deleteCameraCollectionWithRequest:(KEYAPISVCV1DeleteCameraCollectionRequest *)request handler:(void(^)(KEYAPISVCV1DeleteCameraCollectionResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToDeleteCameraCollectionWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод удаления коллекции камер.
 * Проставляет в поле deleted_at текущую дату.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToDeleteCameraCollectionWithRequest:(KEYAPISVCV1DeleteCameraCollectionRequest *)request handler:(void(^)(KEYAPISVCV1DeleteCameraCollectionResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"DeleteCameraCollection"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISVCV1DeleteCameraCollectionResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод удаления коллекции камер.
 * Проставляет в поле deleted_at текущую дату.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 */
- (GRPCUnaryProtoCall *)deleteCameraCollectionWithMessage:(KEYAPISVCV1DeleteCameraCollectionRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"DeleteCameraCollection"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISVCV1DeleteCameraCollectionResponse class]];
}

#pragma mark PostCameraCollectionRestore(PostCameraCollectionRestoreRequest) returns (PostCameraCollectionRestoreResponse)

/**
 * Метод восстановления удаленной коллекции камер.
 * Проставляет null в поле deleted_at.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postCameraCollectionRestoreWithRequest:(KEYAPISVCV1PostCameraCollectionRestoreRequest *)request handler:(void(^)(KEYAPISVCV1PostCameraCollectionRestoreResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostCameraCollectionRestoreWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод восстановления удаленной коллекции камер.
 * Проставляет null в поле deleted_at.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostCameraCollectionRestoreWithRequest:(KEYAPISVCV1PostCameraCollectionRestoreRequest *)request handler:(void(^)(KEYAPISVCV1PostCameraCollectionRestoreResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostCameraCollectionRestore"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISVCV1PostCameraCollectionRestoreResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод восстановления удаленной коллекции камер.
 * Проставляет null в поле deleted_at.
 * Для owner, employee сравнивается COMPANY_ID из токена и company_id коллекции, при несовпадении ошибка доступа.
 * Метод доступен для: admin, service, bti, owner, employee
 */
- (GRPCUnaryProtoCall *)postCameraCollectionRestoreWithMessage:(KEYAPISVCV1PostCameraCollectionRestoreRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostCameraCollectionRestore"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISVCV1PostCameraCollectionRestoreResponse class]];
}

@end
#endif
