MongoDB C++ Driver
mongocxx-3.7.0
|
Class representing options for the object managing explicit client-side encryption. More...
#include <client_encryption.hpp>
Public Types | |
using | ns_pair = std::pair< std::string, std::string > |
Sets the namespace to use to access the key vault collection, which contains all data keys used for encryption and decryption. More... | |
Public Member Functions | |
client_encryption & | key_vault_client (mongocxx::client *client) |
When the key vault collection is on a separate MongoDB cluster, sets the optional client to use to route data key queries to that cluster. More... | |
const stdx::optional< mongocxx::client * > & | key_vault_client () const |
Gets the key vault client. More... | |
const stdx::optional< ns_pair > & | key_vault_namespace () const |
Gets the key vault namespace. More... | |
client_encryption & | kms_providers (bsoncxx::document::view_or_value kms_providers) |
Sets the KMS providers to use for client side encryption. More... | |
const stdx::optional< bsoncxx::document::view_or_value > & | kms_providers () const |
Gets the KMS providers. More... | |
client_encryption & | tls_opts (bsoncxx::document::view_or_value tls_opts) |
Sets the TLS options to use for client side encryption with a given KMS provider. More... | |
const stdx::optional< bsoncxx::document::view_or_value > & | tls_opts () const |
Gets the TLS options. More... | |
Friends | |
class | mongocxx::client_encryption |
Class representing options for the object managing explicit client-side encryption.
using mongocxx::options::client_encryption::ns_pair = std::pair<std::string, std::string> |
Sets the namespace to use to access the key vault collection, which contains all data keys used for encryption and decryption.
This option must be set:
client_encryption.key_vault_namespace({ "db", "coll" });
ns | A std::pair of strings representing the db and collection to use to access the key vault. |
const stdx::optional<mongocxx::client*>& mongocxx::options::client_encryption::key_vault_client | ( | ) | const |
Gets the key vault client.
client_encryption& mongocxx::options::client_encryption::key_vault_client | ( | mongocxx::client * | client | ) |
When the key vault collection is on a separate MongoDB cluster, sets the optional client to use to route data key queries to that cluster.
client | A client to use for routing queries to the key vault collection. |
const stdx::optional<ns_pair>& mongocxx::options::client_encryption::key_vault_namespace | ( | ) | const |
Gets the key vault namespace.
const stdx::optional<bsoncxx::document::view_or_value>& mongocxx::options::client_encryption::kms_providers | ( | ) | const |
Gets the KMS providers.
client_encryption& mongocxx::options::client_encryption::kms_providers | ( | bsoncxx::document::view_or_value | kms_providers | ) |
Sets the KMS providers to use for client side encryption.
Multiple KMS providers may be specified. Supported KMS providers are "aws", "azure", "gcp", "kmip", and "local". The kmsProviders map values differ by provider:
aws: { accessKeyId: String, secretAccessKey: String }
azure: { tenantId: String, clientId: String, clientSecret: String, identityPlatformEndpoint: Optional<String> // Defaults to login.microsoftonline.com }
gcp: { email: String, privateKey: byte[] or String, // May be passed as a base64 encoded string. endpoint: Optional<String> // Defaults to oauth2.googleapis.com }
kmip: { endpoint: String }
local: { key: byte[96] // The master key used to encrypt/decrypt data keys. }
kms_providers | A document containing the KMS providers. |
const stdx::optional<bsoncxx::document::view_or_value>& mongocxx::options::client_encryption::tls_opts | ( | ) | const |
Gets the TLS options.
client_encryption& mongocxx::options::client_encryption::tls_opts | ( | bsoncxx::document::view_or_value | tls_opts | ) |
Sets the TLS options to use for client side encryption with a given KMS provider.
Multiple KMS providers may be specified. Supported KMS providers are "aws", "azure", "gcp", and "kmip". The map value has the same form for all supported providers:
<KMS provider name>: { tlsCaFile: Optional<String> tlsCertificateKeyFile: Optional<String> tlsCertificateKeyFilePassword: Optional<String> }
tls_opts | A document containing the TLS options. |