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

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

#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/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

@implementation KEYAPISKMSV1KmsService

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

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

#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 PostKmsKeyGenerate(PostKmsKeyGenerateRequest) returns (PostKmsKeyGenerateResponse)

/**
 * Метод генерации пары ключей.
 * Генерирует публичный и приватный ключи.
 * Приватный ключ шифруется алгоритмом AES-GCM и сохранятеся в колонке kms.key_infos.encrypted_private_key.
 * Формат хранения приватного ключа - строковое представление JSON: состоит из переменных:
 * - Nonce: Number used once - представляет собой уникальный набор битов, используется один раз при шифровании блока данных в режиме GCM.
 * - EncryptedString: зашифрованный приватный ключ в формате DER.
 * - Tag: Message Authentication Code, используется для проверки целостности и подлинности данных после их расшифровки.
 * Публичный ключ сохранятеся в колонке kms.key_infos.public_key в формате DER и передаётся в сервис JWKS методом PostKey.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695357.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)postKmsKeyGenerateWithRequest:(KEYAPISKMSV1PostKmsKeyGenerateRequest *)request handler:(void(^)(KEYAPISKMSV1PostKmsKeyGenerateResponse *_Nullable response, NSError *_Nullable error))handler{
  [[self RPCToPostKmsKeyGenerateWithRequest:request handler:handler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод генерации пары ключей.
 * Генерирует публичный и приватный ключи.
 * Приватный ключ шифруется алгоритмом AES-GCM и сохранятеся в колонке kms.key_infos.encrypted_private_key.
 * Формат хранения приватного ключа - строковое представление JSON: состоит из переменных:
 * - Nonce: Number used once - представляет собой уникальный набор битов, используется один раз при шифровании блока данных в режиме GCM.
 * - EncryptedString: зашифрованный приватный ключ в формате DER.
 * - Tag: Message Authentication Code, используется для проверки целостности и подлинности данных после их расшифровки.
 * Публичный ключ сохранятеся в колонке kms.key_infos.public_key в формате DER и передаётся в сервис JWKS методом PostKey.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695357.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToPostKmsKeyGenerateWithRequest:(KEYAPISKMSV1PostKmsKeyGenerateRequest *)request handler:(void(^)(KEYAPISKMSV1PostKmsKeyGenerateResponse *_Nullable response, NSError *_Nullable error))handler{
  return [self RPCToMethod:@"PostKmsKeyGenerate"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISKMSV1PostKmsKeyGenerateResponse class]
        responsesWriteable:[GRXWriteable writeableWithSingleHandler:handler]];
}
/**
 * Метод генерации пары ключей.
 * Генерирует публичный и приватный ключи.
 * Приватный ключ шифруется алгоритмом AES-GCM и сохранятеся в колонке kms.key_infos.encrypted_private_key.
 * Формат хранения приватного ключа - строковое представление JSON: состоит из переменных:
 * - Nonce: Number used once - представляет собой уникальный набор битов, используется один раз при шифровании блока данных в режиме GCM.
 * - EncryptedString: зашифрованный приватный ключ в формате DER.
 * - Tag: Message Authentication Code, используется для проверки целостности и подлинности данных после их расшифровки.
 * Публичный ключ сохранятеся в колонке kms.key_infos.public_key в формате DER и передаётся в сервис JWKS методом PostKey.
 * Логика работы метода: https://confluence.rt.ru/pages/viewpage.action?pageId=664695357.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)postKmsKeyGenerateWithMessage:(KEYAPISKMSV1PostKmsKeyGenerateRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"PostKmsKeyGenerate"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISKMSV1PostKmsKeyGenerateResponse class]];
}

#pragma mark GetKmsKeyList(GetKmsKeyListRequest) returns (stream GetKmsKeyListResponse)

/**
 * Метод получения ключей.
 * Возвращает три последних ключа отсортированных по created_at DESC.
 * Используется в административном интерфейсе, для отображения даты выпуска последней пары ключей.
 * Сценарий использвания: https://confluence.rt.ru/pages/viewpage.action?pageId=682907591.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (void)getKmsKeyListWithRequest:(KEYAPISKMSV1GetKmsKeyListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISKMSV1GetKmsKeyListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  [[self RPCToGetKmsKeyListWithRequest:request eventHandler:eventHandler] start];
}
// Returns a not-yet-started RPC object.
/**
 * Метод получения ключей.
 * Возвращает три последних ключа отсортированных по created_at DESC.
 * Используется в административном интерфейсе, для отображения даты выпуска последней пары ключей.
 * Сценарий использвания: https://confluence.rt.ru/pages/viewpage.action?pageId=682907591.
 * Метод доступен для: admin, manager, service
 *
 * This method belongs to a set of APIs that have been deprecated. Using the v2 API is recommended.
 */
- (GRPCProtoCall *)RPCToGetKmsKeyListWithRequest:(KEYAPISKMSV1GetKmsKeyListRequest *)request eventHandler:(void(^)(BOOL done, KEYAPISKMSV1GetKmsKeyListResponse *_Nullable response, NSError *_Nullable error))eventHandler{
  return [self RPCToMethod:@"GetKmsKeyList"
            requestsWriter:[GRXWriter writerWithValue:request]
             responseClass:[KEYAPISKMSV1GetKmsKeyListResponse class]
        responsesWriteable:[GRXWriteable writeableWithEventHandler:eventHandler]];
}
/**
 * Метод получения ключей.
 * Возвращает три последних ключа отсортированных по created_at DESC.
 * Используется в административном интерфейсе, для отображения даты выпуска последней пары ключей.
 * Сценарий использвания: https://confluence.rt.ru/pages/viewpage.action?pageId=682907591.
 * Метод доступен для: admin, manager, service
 */
- (GRPCUnaryProtoCall *)getKmsKeyListWithMessage:(KEYAPISKMSV1GetKmsKeyListRequest *)message responseHandler:(id<GRPCProtoResponseHandler>)handler callOptions:(GRPCCallOptions *_Nullable)callOptions {
  return [self RPCToMethod:@"GetKmsKeyList"
                   message:message
           responseHandler:handler
               callOptions:callOptions
             responseClass:[KEYAPISKMSV1GetKmsKeyListResponse class]];
}

@end
#endif
