KeyVault.addKeyAlternateName(UUID, keyAltName)Agrega el
keyAltNameal arreglokeyAltNamesde la llave de cifrado de datos conUUID.keyAltNamedebe ser única entre todas las claves en el almacén de claves.getKeyVault()El método crea automáticamente un índice único en elkeyAltNamescampo con un filtro de índice parcial solo para los documentos dondekeyAltNamesexiste.Devuelve: Devuelve la versión anterior del documento de clave de cifrado de datos. Devuelve
nullsi ninguna clave de cifrado de datos tiene elUUID()especificado.
Compatibilidad
Este comando está disponible en implementaciones alojadas en los siguientes entornos:
MongoDB Atlas: El servicio totalmente gestionado para implementaciones de MongoDB en la nube
MongoDB Enterprise: La versión basada en suscripción y autogestionada de MongoDB
MongoDB Community: La versión de MongoDB con código fuente disponible, de uso gratuito y autogestionada.
Sintaxis
addKeyAlternateName() tiene la siguiente sintaxis:
keyVault = db.getMongo().getKeyVault() keyVault.addKeyAlternateName( UUID("<UUID string>"), "keyAlternateName" )
Comportamiento
Requiere configurar cifrado a nivel de campo del lado del cliente en la conexión a la base de datos.
Los métodos mongosh ClientEncryption requieren una conexión a la base de datos con la encriptación en uso activada. Si la conexión actual a la base de datos no se inició con la encriptación en uso activada, entonces:
Utilice el constructor
Mongo()demongoshpara establecer una conexión con las opciones de encriptación en uso requeridas. El métodoMongo()es compatible con los siguientes proveedores de Key Management Service (KMS) para la gestión de llaves maestras de cliente:or
Utilice las opciones de línea de comandos
mongoshpara establecer una conexión con las opciones requeridas. Las opciones de la línea de comandos solo admiten el proveedor Amazon Web Services KMS para la gestión de la llave maestra de cliente.
Ejemplo
El siguiente ejemplo está diseñado para la evaluación rápida del cifrado a nivel de campo del lado del cliente. Para obtener ejemplos específicos del uso de con cada campo KeyVault.addKeyAlternateName() compatible
Proveedor deKMS, consulte Administración de claves de cifrado.
Crear las opciones de cifrado a nivel de campo del lado del cliente
Cree las opciones de cifrado a nivel de campo del lado del cliente utilizando la cadena de clave local generada:
var autoEncryptionOpts = { "keyVaultNamespace" : "encryption.__dataKeys", "kmsProviders" : { "local" : { "key" : BinData(0, TEST_LOCAL_KEY) } } }
Crea tu cliente cifrado
Utilice el constructor con las opciones de cifrado de campo del lado del cliente configuradas para crear una conexión a la base de datos. Reemplace Mongo() el mongodb://myMongo.example.net URI por el URI de la cadena de conexión del clúster de destino.
encryptedClient = Mongo( "mongodb://myMongo.example.net:27017/?replSetName=myMongo", autoEncryptionOpts )
Recupere el KeyVault objeto y utilice el método para añadir un nuevo nombre de clave alternativo a la clave de cifrado de datos que KeyVault.addKeyAlternateName() coincida UUID con. El nombre de clave alternativo especificado debe ser único:
keyVault = encryptedClient.getKeyVault() keyVault.addKeyAlternateName(UUID("b4b41b33-5c97-412e-a02b-743498346079"),"Other-Data-Encryption-Key")
Si tiene éxito, devuelve la versión anterior del documento de clave de cifrado deaddKeyAlternateName() datos:
{ "_id" : UUID("b4b41b33-5c97-412e-a02b-743498346079"), "keyMaterial" : BinData(0,"PXRsLOAYxhzTS/mFQAI8486da7BwZgqA91UI7NKz/T/AjB0uJZxTvhvmQQsKbCJYsWVS/cp5Rqy/FUX2zZwxJOJmI3rosPhzV0OI5y1cuXhAlLWlj03CnTcOSRzE/YIrsCjMB0/NyiZ7MRWUYzLAEQnE30d947XCiiHIb8a0kt2SD0so8vZvSuP2n0Vtz4NYqnzF0CkhZSWFa2e2yA=="), "creationDate" : ISODate("2019-08-12T21:21:30.569Z"), "updateDate" : ISODate("2019-08-12T21:21:30.569Z"), "status" : 0, "version" : Long(0), "masterKey" : { "provider" : "local" }, "keyAltNames" : [ ] }
Para ver la versión actual del documento de clave de cifrado de datos, utiliza KeyVault.getKey() especificando el _id del documento devuelto o KeyVault.getKeyByAltName() especificando uno de los keyAltNames.