Clase: Mongo::Crypt::ExplicitEncrypter Privado
- Hereda:
-
Objeto
- Objeto
- Mongo::Crypt::Cifrador explícito
- Ampliado por:
- Reenviable
- Definido en:
- lib/mongo/crypt/explicit_encrypter.rb
Overview
Esta clase forma parte de una API privada. Evita usar esta clase si es posible, ya que puede ser eliminada o modificada en el futuro.
Un ExplicitEncrypter es un objeto que realiza operaciones de cifrado explícitas y gestiona todas las opciones asociadas y variables de instancia.
Resumen del método de instancia colapsar
-
#add_key_alt_name(id, key_alt_name) ⇒ BSON::Document | nil
privado
Agrega un key_alt_name para la clave en la Colección de Bóvedas de Llaves con el ID proporcionado.
-
#crear_e_insertar_clave_de_datos(documento_de_clave_maestra, nombres_alt_de_clave, material_de_clave = nulo) ⇒ BSON::Binary
privado
Genera una clave de datos utilizada para el cifrado/descifrado y almacena esa clave en la colección KMS.
-
#decrypt(valor) ⇒ objeto
privado
Descifra un valor que ya ha sido cifrado.
-
#delete_key(id) ⇒ Operation::Result
privado
Remueve la clave con la ID indicada de la Colección de Bóvedas de Llaves.
-
#cifrar(valor, opciones) ⇒ BSON::Binary
privado
Cifra un valor utilizando la clave de cifrado y el algoritmo especificados.
-
#encrypt_expression(expresión, opciones) ⇒ BSON::Binary
privado
Encripta una expresión de coincidencia o una expresión de agregación para consultar un índice de rango.
-
#get_key(id) ⇒ BSON::Document | nil
privado
Encuentra una sola clave con el ID proporcionado.
-
#get_key_by_alt_name(key_alt_name) ⇒ BSON::Document | nil
privado
Devuelve una clave en la Colección de Bóvedas de Llaves con el key_alt_name (nombre alternativo de clave) proporcionado.
-
#get_keys ⇒ Collection::View
privado
Devuelve todas las Colección de Bóvedas de Llaves.
-
#inicializar(key_vault_client, key_vault_namespace, kms_providers, kms_tls_options, timeout_ms = nil) ⇒ ExplicitEncrypter
constructor
privado
Crea un nuevo objeto ExplicitEncrypter.
-
#remove_key_alt_name(id, key_alt_name) ⇒ BSON::Document | nil
privado
Remueve un key_alt_name de una clave en la Colección de Bóvedas de Llaves con el ID especificado.
-
#rewrap_many_data_key(filtro, opts = {}) ⇒ Crypt::RewrapManyDataKeyResult
privado
Descifra múltiples claves de datos y las vuelve a cifrar con una nueva clave maestra, o con su clave maestra actual si no se proporciona una nueva.
Detalles del constructor
#inicializar(cliente de key_vault, espacio de nombres de key_vault, proveedores de kms, opciones de kms_tls, tiempo de espera_ms = nulo) ⇒ ExplicitEncrypter
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Crea un nuevo objeto ExplicitEncrypter.
40 41 42 43 44 45 46 47 48 49 50 51 52 53 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 40 def inicializar(key_vault_client, key_vault_namespace, proveedores de kms, , timeout_ms = nulo) Cripta.validate_ffi! @crypt_handle = Manejar.Nuevo( proveedores de kms, , solo_cifrado_explícito: true ) @encryption_io = EncryptionIO.Nuevo( key_vault_client: key_vault_client, metadata_client: nulo, key_vault_namespace: key_vault_namespace ) @timeout_ms = timeout_ms end |
Detalles del método de instancia
#add_key_alt_name(id, key_alt_name) ⇒ BSON::Document | nil
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Agrega un key_alt_name para la clave en la Colección de Bóvedas de Llaves con el ID proporcionado.
203 204 205 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 203 def add_key_alt_name(ID, key_alt_name) @encryption_io.add_key_alt_name(ID, key_alt_name, tiempo_de_espera_ms: @timeout_ms) end |
#create_and_insert_data_key(master_key_document, key_alt_names, key_material = nil) ⇒ BSON::Binary
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Genera una clave de datos utilizada para el cifrado/descifrado y almacena esa clave en la colección KMS. La clave generada está cifrado con la clave maestra KMS.
70 71 72 73 74 75 76 77 78 79 80 81 82 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 70 def create_and_insert_data_key(master_key_document, clave_nombres_alternativos, material de clave = nulo) data_key_document = Cripta::Contexto de clave de datos.Nuevo( @crypt_handle, @encryption_io, master_key_document, clave_nombres_alternativos, material de clave ).run_state_machine(timeout_holder) @encryption_io.insert_data_key( data_key_document, tiempo_de_espera_ms: timeout_holder.¡tiempo de espera restante_ms! ).inserted_id end |
#descifrar(valor) ⇒ Objeto
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Descifra un valor que ya ha sido cifrado
188 189 190 191 192 193 194 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 188 def descifrar(Valor) Cripta::ExplicitDecryptionContext.Nuevo( @crypt_handle, @encryption_io, { v: Valor } ).run_state_machine(timeout_holder)['v'] end |
#delete_key(id) ⇒ Operación::Result
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Remueve la clave con la ID indicada de la Colección de Bóvedas de Llaves.
213 214 215 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 213 def delete_key(ID) @encryption_io.delete_key(ID, tiempo_de_espera_ms: @timeout_ms) end |
#encriptar(valor, opciones) ⇒ BSON::Binary
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Las opciones :key_id y :key_alt_name son mutuamente excluyentes. Solo se requiere uno para realizar el cifrado explícito.
Cifra un valor utilizando la clave de cifrado y el algoritmo especificados
Si el algoritmo de cifrado está configurado como "Indexado", se debe configurar el tipo de consulta.
only if encryption algorithm is set to "Indexed". The only allowed
value is "equality".
113 114 115 116 117 118 119 120 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 113 def cifrado(Valor, ) Cripta::ExplicitEncryptionContext.Nuevo( @crypt_handle, @encryption_io, { v: Valor }, ).run_state_machine(timeout_holder)['v'] end |
#encrypt_expression(expresión, opciones) ⇒ BSON::Binary
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
El algoritmo de rango es únicamente experimental. No es
Las opciones :key_id y :key_alt_name son mutuamente excluyentes. Solo se requiere uno para realizar el cifrado explícito.
Encripta una expresión de coincidencia o una expresión de agregación para consultar un índice de rango.
Solo está soportado cuando queryType es “rango” y el algoritmo es “rango”. @note: El algoritmo Rango es solo experimental. No está destinado
for public use. It is subject to breaking changes.
# @param [ Hash ] options destinado al uso publico.
173 174 175 176 177 178 179 180 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 173 def encrypt_expression(expresión, ) Cripta::Contexto de expresión de cifrado explícito.Nuevo( @crypt_handle, @encryption_io, { v: expresión }, ).run_state_machine(timeout_holder)['v'] end |
#get_key(id) ⇒ BSON::Document | nil
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Encuentra una sola clave con el ID proporcionado.
223 224 225 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 223 def obtener_clave(ID) @encryption_io.obtener_clave(ID, tiempo_de_espera_ms: @timeout_ms) end |
#get_key_by_alt_name(key_alt_name) ⇒ BSON::Document | nil
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Devuelve una clave en la Colección de Bóvedas de Llaves con el key_alt_name (nombre alternativo de clave) proporcionado.
233 234 235 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 233 def obtener_clave_por_nombre_alt(key_alt_name) @encryption_io.obtener_clave_por_nombre_alt(key_alt_name, tiempo_de_espera_ms: @timeout_ms) end |
#get_keys ⇒ colección::View
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Devuelve todas las Colección de Bóvedas de Llaves.
rubocop:disable Naming/AccessorMethodName El nombre de este método se define en la especificación FLE
242 243 244 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 242 def get_keys @encryption_io.get_keys(tiempo_de_espera_ms: @timeout_ms) end |
#remove_key_alt_name(id, key_alt_name) ⇒ BSON::Document | nil
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Remueve un key_alt_name de una clave en la Colección de Bóvedas de Llaves con el ID especificado.
254 255 256 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 254 def eliminar_tecla_alt_nombre(ID, key_alt_name) @encryption_io.eliminar_tecla_alt_nombre(ID, key_alt_name, tiempo_de_espera_ms: @timeout_ms) end |
#rewrap_many_data_key(filtro, opciones = {}) ⇒ Crypt::RewrapManyDataKeyResult
Este método forma parte de una API privada. Debe evitarlo si es posible, ya que podría eliminarse o modificarse en el futuro.
Descifra múltiples claves de datos y las (re)cifra con una nueva master_key,
or with their current master_key if a new one is not given.
269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 |
# Archivo 'lib/mongo/crypt/explicit_encrypter.rb', línea 269 def rewrap_many_data_key(filtro, opta = {}) (opta) master_key_document = llave maestra para proveedor(opta) rewrap_result = Cripta::RewrapManyDataKeyContext.Nuevo( @crypt_handle, @encryption_io, filtro, master_key_document ).run_state_machine(timeout_holder) return RewrapManyDataKeyResult.Nuevo(nulo) si rewrap_result.nil? updates = updates_from_data_key_documents(rewrap_result.obtener('v')) RewrapManyDataKeyResult.Nuevo( @encryption_io.update_data_keys(updates, tiempo_de_espera_ms: @timeout_ms) ) end |