20 #include <bsoncxx/document/view_or_value.hpp>
21 #include <bsoncxx/stdx/optional.hpp>
22 #include <mongocxx/stdx.hpp>
24 #include <mongocxx/config/prelude.hpp>
27 inline namespace v_noabi {
28 class client_encryption;
99 const stdx::optional<bsoncxx::document::view_or_value>&
master_key()
const;
157 MONGOCXX_PRIVATE
void* convert()
const;
159 stdx::optional<bsoncxx::document::view_or_value> _master_key;
160 std::vector<std::string> _key_alt_names;
161 stdx::optional<key_material_type> _key_material;
170 #if defined(MONGOCXX_TEST_MACRO_GUARDS_FIX_MISSING_POSTLUDE)
171 #include <mongocxx/config/postlude.hpp>
Class supporting operations for MongoDB Client-Side Field Level Encryption.
Definition: client_encryption.hpp:38
Class representing options for data key generation for encryption.
Definition: data_key.hpp:35
std::vector< uint8_t > key_material_type
Sets the binary data for the key material.
Definition: data_key.hpp:142
const stdx::optional< key_material_type > & key_material()
Gets the keyMaterial as binary data.
const stdx::optional< bsoncxx::document::view_or_value > & master_key() const
Gets the master key.
data_key & master_key(bsoncxx::document::view_or_value master_key)
Sets a KMS-specific key used to encrypt the new data key.
const std::vector< std::string > & key_alt_names() const
Gets the alternate names for the data key.
data_key & key_alt_names(std::vector< std::string > key_alt_names)
Sets an optional list of string alternate names used to reference the key.
The top-level namespace for mongocxx library entities.
Definition: bulk_write.hpp:24