mirror of
https://github.com/macintoshplus/mongo-php-driver.git
synced 2026-03-24 08:52:14 +01:00
* PHPC-2120: Bump libmongoc 1.22.1 and libmongocrypt 1.5.2 * Clean keyvault collection before CSFLE tests * Test invalid keyMaterial option for ClientEncryption::createDataKey() * ClientEncryption::createDataKey() "keyMaterial" option * ClientEncryption key management methods Use ClientEncryption::getKey in createDataKey tests * Require server 4.2+ for CSFLE integration tests * Accommodate PHP 7.2 error message in createDataKey error test
33 lines
1.0 KiB
PHP
33 lines
1.0 KiB
PHP
--TEST--
|
|
MongoDB\Driver\ClientEncryption::decrypt()
|
|
--SKIPIF--
|
|
<?php require __DIR__ . "/../utils/basic-skipif.inc"; ?>
|
|
<?php skip_if_not_libmongocrypt(); ?>
|
|
<?php skip_if_not_live(); ?>
|
|
<?php skip_if_server_version('<', '4.2'); ?>
|
|
<?php skip_if_not_server_storage_engine('wiredTiger'); ?>
|
|
<?php skip_if_not_clean(CSFLE_KEY_VAULT_DATABASE_NAME, CSFLE_KEY_VAULT_COLLECTION_NAME);
|
|
--FILE--
|
|
<?php
|
|
|
|
require_once __DIR__ . "/../utils/basic.inc";
|
|
|
|
$manager = create_test_manager();
|
|
|
|
$clientEncryption = $manager->createClientEncryption([
|
|
'keyVaultNamespace' => CSFLE_KEY_VAULT_NS,
|
|
'kmsProviders' => ['local' => ['key' => new MongoDB\BSON\Binary(CSFLE_LOCAL_KEY, 0)]],
|
|
]);
|
|
|
|
$keyId = $clientEncryption->createDataKey('local');
|
|
|
|
$encrypted = $clientEncryption->encrypt('top-secret', ['keyId' => $keyId, 'algorithm' => MongoDB\Driver\ClientEncryption::AEAD_AES_256_CBC_HMAC_SHA_512_DETERMINISTIC]);
|
|
var_dump($clientEncryption->decrypt($encrypted));
|
|
|
|
?>
|
|
===DONE===
|
|
<?php exit(0); ?>
|
|
--EXPECTF--
|
|
string(10) "top-secret"
|
|
===DONE===
|