libmongocrypt-helper 1.7.4.0.1002 → 1.8.0.0.1001

Sign up to get free protection for your applications and to get access to all the features.
Files changed (396) hide show
  1. checksums.yaml +4 -4
  2. checksums.yaml.gz.sig +0 -0
  3. data/ext/libmongocrypt/libmongocrypt/CHANGELOG.md +9 -7
  4. data/ext/libmongocrypt/libmongocrypt/CMakeLists.txt +17 -23
  5. data/ext/libmongocrypt/libmongocrypt/Earthfile +374 -0
  6. data/ext/libmongocrypt/libmongocrypt/README.md +7 -7
  7. data/ext/libmongocrypt/libmongocrypt/VERSION_CURRENT +1 -1
  8. data/ext/libmongocrypt/libmongocrypt/bindings/cs/MongoDB.Libmongocrypt/CryptClient.cs +25 -6
  9. data/ext/libmongocrypt/libmongocrypt/bindings/cs/MongoDB.Libmongocrypt/Library.cs +25 -3
  10. data/ext/libmongocrypt/libmongocrypt/bindings/cs/MongoDB.Libmongocrypt.Example/MongoDB.Libmongocrypt.Example.csproj +1 -1
  11. data/ext/libmongocrypt/libmongocrypt/bindings/cs/MongoDB.Libmongocrypt.Test/BasicTests.cs +1 -1
  12. data/ext/libmongocrypt/libmongocrypt/bindings/cs/Scripts/build.cake +3 -2
  13. data/ext/libmongocrypt/libmongocrypt/bindings/cs/cs.sln +79 -0
  14. data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/build.gradle.kts +2 -2
  15. data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/java/com/mongodb/crypt/capi/MongoCryptTest.java +6 -4
  16. data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/fle2-find-range-explicit-v2/int32/encrypted-payload.json +26 -0
  17. data/ext/libmongocrypt/libmongocrypt/bindings/node/CHANGELOG.md +24 -0
  18. data/ext/libmongocrypt/libmongocrypt/bindings/node/README.md +134 -5
  19. data/ext/libmongocrypt/libmongocrypt/bindings/node/etc/build-static.sh +3 -6
  20. data/ext/libmongocrypt/libmongocrypt/bindings/node/index.d.ts +203 -77
  21. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/autoEncrypter.js +1 -1
  22. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/clientEncryption.js +165 -43
  23. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/common.js +12 -14
  24. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/errors.js +75 -0
  25. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/index.js +34 -3
  26. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/providers/aws.js +26 -0
  27. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/providers/azure.js +178 -0
  28. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/providers/gcp.js +24 -0
  29. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/providers/index.js +54 -0
  30. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/providers/utils.js +39 -0
  31. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/stateMachine.js +9 -4
  32. data/ext/libmongocrypt/libmongocrypt/bindings/node/package-lock.json +4440 -5189
  33. data/ext/libmongocrypt/libmongocrypt/bindings/node/package.json +27 -8
  34. data/ext/libmongocrypt/libmongocrypt/bindings/node/src/mongocrypt.cc +65 -38
  35. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/autoEncrypter.test.js +4 -7
  36. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/clientEncryption.test.js +434 -42
  37. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/common.test.js +94 -0
  38. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/cryptoCallbacks.test.js +1 -45
  39. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/index.test.js +45 -0
  40. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/mongocryptdManager.test.js +1 -1
  41. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/providers/credentialsProvider.test.js +551 -0
  42. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/release.test.js +10 -3
  43. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/requirements.helper.js +23 -1
  44. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/stateMachine.test.js +1 -1
  45. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/tools/chai-addons.js +8 -0
  46. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/types/index.test-d.ts +63 -0
  47. data/ext/libmongocrypt/libmongocrypt/bindings/python/CHANGELOG.rst +26 -0
  48. data/ext/libmongocrypt/libmongocrypt/bindings/python/README.rst +2 -2
  49. data/ext/libmongocrypt/libmongocrypt/bindings/python/build-manylinux-wheel.sh +1 -1
  50. data/ext/libmongocrypt/libmongocrypt/bindings/python/pymongocrypt/binding.py +128 -238
  51. data/ext/libmongocrypt/libmongocrypt/bindings/python/pymongocrypt/compat.py +0 -27
  52. data/ext/libmongocrypt/libmongocrypt/bindings/python/pymongocrypt/explicit_encrypter.py +1 -1
  53. data/ext/libmongocrypt/libmongocrypt/bindings/python/pymongocrypt/mongocrypt.py +5 -21
  54. data/ext/libmongocrypt/libmongocrypt/bindings/python/pymongocrypt/version.py +2 -2
  55. data/ext/libmongocrypt/libmongocrypt/bindings/python/release.sh +5 -5
  56. data/ext/libmongocrypt/libmongocrypt/bindings/python/setup.py +14 -9
  57. data/ext/libmongocrypt/libmongocrypt/bindings/python/test/__init__.py +1 -10
  58. data/ext/libmongocrypt/libmongocrypt/bindings/python/test/data/fle2-find-range-explicit-v2/int32/encrypted-payload.json +26 -0
  59. data/ext/libmongocrypt/libmongocrypt/bindings/python/test/test_mongocrypt.py +5 -5
  60. data/ext/libmongocrypt/libmongocrypt/bindings/python/test-requirements.txt +4 -12
  61. data/ext/libmongocrypt/libmongocrypt/cmake/ImportBSON.cmake +8 -6
  62. data/ext/libmongocrypt/libmongocrypt/cmake/IntelDFP.cmake +2 -1
  63. data/ext/libmongocrypt/libmongocrypt/cmake/Platform.cmake +50 -0
  64. data/ext/libmongocrypt/libmongocrypt/cmake/mongocrypt-config.cmake +21 -0
  65. data/ext/libmongocrypt/libmongocrypt/debian/gbp.conf +2 -2
  66. data/ext/libmongocrypt/libmongocrypt/etc/c6-vault.repo +39 -0
  67. data/ext/libmongocrypt/libmongocrypt/etc/fle2_aead_generate_tests.py +15 -24
  68. data/ext/libmongocrypt/libmongocrypt/etc/fle2_crypto.py +66 -54
  69. data/ext/libmongocrypt/libmongocrypt/etc/fle2_generate_tests.py +14 -23
  70. data/ext/libmongocrypt/libmongocrypt/etc/fle2v2_aead_generate_tests.py +32 -0
  71. data/ext/libmongocrypt/libmongocrypt/etc/format-all.sh +12 -0
  72. data/ext/libmongocrypt/libmongocrypt/etc/format.sh +16 -0
  73. data/ext/libmongocrypt/libmongocrypt/etc/install-package.sh +48 -0
  74. data/ext/libmongocrypt/libmongocrypt/etc/mongo-inteldfp-libmongocrypt-pr-625.patch +13 -0
  75. data/ext/libmongocrypt/libmongocrypt/src/crypto/cng.c +381 -436
  76. data/ext/libmongocrypt/libmongocrypt/src/crypto/commoncrypto.c +162 -227
  77. data/ext/libmongocrypt/libmongocrypt/src/crypto/libcrypto.c +180 -248
  78. data/ext/libmongocrypt/libmongocrypt/src/crypto/none.c +33 -55
  79. data/ext/libmongocrypt/libmongocrypt/src/csfle-markup.cpp +175 -205
  80. data/ext/libmongocrypt/libmongocrypt/src/mc-array-private.h +10 -21
  81. data/ext/libmongocrypt/libmongocrypt/src/mc-array.c +44 -56
  82. data/ext/libmongocrypt/libmongocrypt/src/mc-check-conversions-private.h +4 -8
  83. data/ext/libmongocrypt/libmongocrypt/src/mc-dec128.h +351 -463
  84. data/ext/libmongocrypt/libmongocrypt/src/mc-dec128.test.cpp +59 -66
  85. data/ext/libmongocrypt/libmongocrypt/src/mc-efc-private.h +7 -11
  86. data/ext/libmongocrypt/libmongocrypt/src/mc-efc.c +80 -92
  87. data/ext/libmongocrypt/libmongocrypt/src/mc-fle-blob-subtype-private.h +18 -10
  88. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-encryption-placeholder-private.h +59 -70
  89. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-encryption-placeholder.c +384 -439
  90. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-equality-payload-private-v2.h +41 -0
  91. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-equality-payload-private.h +11 -18
  92. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-equality-payload-v2.c +135 -0
  93. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-equality-payload.c +109 -126
  94. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-range-payload-private-v2.h +88 -0
  95. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-range-payload-private.h +24 -27
  96. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-range-payload-v2.c +137 -0
  97. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-find-range-payload.c +106 -125
  98. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-insert-update-payload-private-v2.h +117 -0
  99. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-insert-update-payload-private.h +28 -36
  100. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-insert-update-payload-v2.c +294 -0
  101. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-insert-update-payload.c +237 -278
  102. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-iev-private-v2.h +133 -0
  103. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-iev-private.h +67 -56
  104. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-iev-v2.c +437 -0
  105. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-iev.c +476 -325
  106. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev-common-private.h +69 -0
  107. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev-common.c +182 -0
  108. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev-private.h +23 -31
  109. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev-v2-private.h +85 -0
  110. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev-v2.c +142 -0
  111. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-payload-uev.c +104 -231
  112. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-range-operator-private.h +8 -7
  113. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-rfds-private.h +55 -56
  114. data/ext/libmongocrypt/libmongocrypt/src/mc-fle2-rfds.c +517 -580
  115. data/ext/libmongocrypt/libmongocrypt/src/mc-optional-private.h +36 -66
  116. data/ext/libmongocrypt/libmongocrypt/src/mc-range-edge-generation-private.h +57 -76
  117. data/ext/libmongocrypt/libmongocrypt/src/mc-range-edge-generation.c +158 -189
  118. data/ext/libmongocrypt/libmongocrypt/src/mc-range-encoding-private.h +36 -42
  119. data/ext/libmongocrypt/libmongocrypt/src/mc-range-encoding.c +515 -558
  120. data/ext/libmongocrypt/libmongocrypt/src/mc-range-mincover-generator.template.h +155 -191
  121. data/ext/libmongocrypt/libmongocrypt/src/mc-range-mincover-private.h +43 -53
  122. data/ext/libmongocrypt/libmongocrypt/src/mc-range-mincover.c +170 -240
  123. data/ext/libmongocrypt/libmongocrypt/src/mc-rangeopts-private.h +29 -34
  124. data/ext/libmongocrypt/libmongocrypt/src/mc-rangeopts.c +289 -338
  125. data/ext/libmongocrypt/libmongocrypt/src/mc-reader-private.h +36 -71
  126. data/ext/libmongocrypt/libmongocrypt/src/mc-reader.c +111 -164
  127. data/ext/libmongocrypt/libmongocrypt/src/mc-tokens-private.h +55 -49
  128. data/ext/libmongocrypt/libmongocrypt/src/mc-tokens.c +109 -125
  129. data/ext/libmongocrypt/libmongocrypt/src/mc-writer-private.h +66 -0
  130. data/ext/libmongocrypt/libmongocrypt/src/mc-writer.c +141 -0
  131. data/ext/libmongocrypt/libmongocrypt/src/mlib/check.hpp +37 -55
  132. data/ext/libmongocrypt/libmongocrypt/src/mlib/endian.h +11 -11
  133. data/ext/libmongocrypt/libmongocrypt/src/mlib/error.h +27 -32
  134. data/ext/libmongocrypt/libmongocrypt/src/mlib/int128.h +444 -499
  135. data/ext/libmongocrypt/libmongocrypt/src/mlib/int128.test.cpp +251 -334
  136. data/ext/libmongocrypt/libmongocrypt/src/mlib/macros.h +4 -5
  137. data/ext/libmongocrypt/libmongocrypt/src/mlib/path.h +196 -231
  138. data/ext/libmongocrypt/libmongocrypt/src/mlib/path.test.c +56 -79
  139. data/ext/libmongocrypt/libmongocrypt/src/mlib/str.h +411 -530
  140. data/ext/libmongocrypt/libmongocrypt/src/mlib/str.test.c +116 -131
  141. data/ext/libmongocrypt/libmongocrypt/src/mlib/thread.h +17 -26
  142. data/ext/libmongocrypt/libmongocrypt/src/mlib/user-check.h +2 -2
  143. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-binary-private.h +3 -6
  144. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-binary.c +31 -48
  145. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-buffer-private.h +55 -131
  146. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-buffer.c +444 -565
  147. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-collinfo-private.h +1 -2
  148. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-collinfo.c +28 -45
  149. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-key-private.h +11 -17
  150. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-key.c +103 -132
  151. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-oauth-private.h +8 -14
  152. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-oauth.c +78 -90
  153. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache-private.h +26 -45
  154. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-cache.c +220 -273
  155. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ciphertext-private.h +13 -25
  156. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ciphertext.c +147 -166
  157. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-compat.h +2 -2
  158. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-crypto-private.h +110 -204
  159. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-crypto.c +1137 -1565
  160. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx-datakey.c +425 -472
  161. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx-decrypt.c +817 -694
  162. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx-encrypt.c +2394 -2697
  163. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx-private.h +166 -186
  164. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx-rewrap-many-datakey.c +308 -351
  165. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-ctx.c +921 -1138
  166. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-dll-private.h +16 -24
  167. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-endian-private.h +44 -58
  168. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-endpoint-private.h +21 -25
  169. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-endpoint.c +167 -181
  170. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-kek-private.h +37 -43
  171. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-kek.c +215 -253
  172. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-key-broker-private.h +73 -108
  173. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-key-broker.c +889 -1034
  174. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-key-private.h +27 -44
  175. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-key.c +349 -402
  176. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-kms-ctx-private.h +92 -120
  177. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-kms-ctx.c +1397 -1612
  178. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-log-private.h +35 -67
  179. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-log.c +49 -83
  180. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-marking-private.h +30 -36
  181. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-marking.c +1821 -1470
  182. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-mutex-private.h +7 -12
  183. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-opts-private.h +80 -108
  184. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-opts.c +354 -424
  185. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-private.h +101 -117
  186. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-status-private.h +3 -8
  187. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-status.c +92 -119
  188. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-traverse-util-private.h +19 -29
  189. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-traverse-util.c +136 -176
  190. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-util-private.h +11 -21
  191. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt-util.c +96 -135
  192. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt.c +1092 -1320
  193. data/ext/libmongocrypt/libmongocrypt/src/mongocrypt.h +130 -295
  194. data/ext/libmongocrypt/libmongocrypt/src/os_posix/os_dll.c +66 -78
  195. data/ext/libmongocrypt/libmongocrypt/src/os_posix/os_mutex.c +20 -28
  196. data/ext/libmongocrypt/libmongocrypt/src/os_win/os_dll.c +60 -73
  197. data/ext/libmongocrypt/libmongocrypt/src/os_win/os_mutex.c +8 -16
  198. data/ext/libmongocrypt/libmongocrypt/test/crypt_shared-stub.cpp +57 -87
  199. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-delete/empty/encrypted-payload-v2.json +60 -0
  200. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-delete/success/encrypted-payload-v2.json +67 -0
  201. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explain/with-csfle/encrypted-payload.json +2 -2
  202. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explicit/find-indexed-contentionFactor1-v2.json +8 -0
  203. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explicit/find-indexed-v2.json +8 -0
  204. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explicit/insert-indexed-contentionFactor1-v2.json +8 -0
  205. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explicit/insert-indexed-same-user-and-index-key-v2.json +8 -0
  206. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-explicit/insert-indexed-v2.json +8 -0
  207. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-equality-v2/cmd.json +6 -0
  208. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-equality-v2/encrypted-field-map.json +22 -0
  209. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-equality-v2/encrypted-payload.json +40 -0
  210. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-equality-v2/mongocryptd-reply.json +19 -0
  211. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/date-v2/cmd.json +10 -0
  212. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/date-v2/encrypted-field-map.json +27 -0
  213. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/date-v2/encrypted-payload.json +41 -0
  214. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/date-v2/mongocryptd-reply.json +49 -0
  215. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-precision-v2/cmd.json +6 -0
  216. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-precision-v2/encrypted-field-map.json +30 -0
  217. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-precision-v2/encrypted-payload.json +50 -0
  218. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-precision-v2/mongocryptd-reply.json +58 -0
  219. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-v2/cmd.json +6 -0
  220. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-v2/encrypted-field-map.json +27 -0
  221. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-v2/encrypted-payload.json +41 -0
  222. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/decimal128-v2/mongocryptd-reply.json +49 -0
  223. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-precision-v2/cmd.json +8 -0
  224. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-precision-v2/encrypted-field-map.json +30 -0
  225. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-precision-v2/encrypted-payload.json +44 -0
  226. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-precision-v2/mongocryptd-reply.json +52 -0
  227. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-v2/cmd.json +8 -0
  228. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-v2/encrypted-field-map.json +27 -0
  229. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-v2/encrypted-payload.json +41 -0
  230. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/double-v2/mongocryptd-reply.json +49 -0
  231. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int32-v2/cmd.json +8 -0
  232. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int32-v2/encrypted-field-map.json +27 -0
  233. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int32-v2/encrypted-payload.json +41 -0
  234. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int32-v2/mongocryptd-reply.json +49 -0
  235. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int64-v2/cmd.json +8 -0
  236. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int64-v2/encrypted-field-map.json +27 -0
  237. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int64-v2/encrypted-payload.json +41 -0
  238. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range/int64-v2/mongocryptd-reply.json +49 -0
  239. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/double/encrypted-payload-v2.json +26 -0
  240. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/double-precision/encrypted-payload-v2.json +26 -0
  241. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32/encrypted-payload-v2.json +26 -0
  242. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32-nominmax/encrypted-payload-v2.json +26 -0
  243. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32-openinterval/encrypted-payload-v2.json +16 -0
  244. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert/cmd.json +1 -1
  245. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/date/RNG_DATA.h +65 -65
  246. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/date-v2/cmd.json +13 -0
  247. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/date-v2/encrypted-field-map.json +27 -0
  248. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/date-v2/encrypted-payload.json +44 -0
  249. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/date-v2/mongocryptd-reply.json +52 -0
  250. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128/RNG_DATA.h +132 -132
  251. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-precision/RNG_DATA.h +71 -71
  252. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-precision-v2/cmd.json +9 -0
  253. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-precision-v2/encrypted-field-map.json +30 -0
  254. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-precision-v2/encrypted-payload.json +53 -0
  255. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-precision-v2/mongocryptd-reply.json +61 -0
  256. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-v2/cmd.json +9 -0
  257. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-v2/encrypted-field-map.json +27 -0
  258. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-v2/encrypted-payload.json +44 -0
  259. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/decimal128-v2/mongocryptd-reply.json +52 -0
  260. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double/RNG_DATA.h +68 -68
  261. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-precision/RNG_DATA.h +19 -19
  262. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-precision-v2/cmd.json +11 -0
  263. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-precision-v2/encrypted-field-map.json +30 -0
  264. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-precision-v2/encrypted-payload.json +47 -0
  265. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-precision-v2/mongocryptd-reply.json +55 -0
  266. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-v2/cmd.json +11 -0
  267. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-v2/encrypted-field-map.json +27 -0
  268. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-v2/encrypted-payload.json +44 -0
  269. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/double-v2/mongocryptd-reply.json +52 -0
  270. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int32/RNG_DATA.h +25 -25
  271. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int32-v2/cmd.json +11 -0
  272. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int32-v2/encrypted-field-map.json +27 -0
  273. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int32-v2/encrypted-payload.json +44 -0
  274. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int32-v2/mongocryptd-reply.json +52 -0
  275. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int64/RNG_DATA.h +65 -65
  276. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int64-v2/cmd.json +11 -0
  277. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int64-v2/encrypted-field-map.json +27 -0
  278. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int64-v2/encrypted-payload.json +44 -0
  279. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range/int64-v2/mongocryptd-reply.json +52 -0
  280. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/double/RNG_DATA.h +68 -68
  281. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/double/encrypted-payload-v2.json +8 -0
  282. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/double-precision/RNG_DATA.h +19 -19
  283. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/double-precision/encrypted-payload-v2.json +8 -0
  284. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32/RNG_DATA.h +25 -25
  285. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32/encrypted-payload-v2.json +8 -0
  286. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32-nominmax/encrypted-payload-v2.json +8 -0
  287. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/sparsity-2/RNG_DATA.h +15 -15
  288. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/sparsity-2/encrypted-payload-v2.json +8 -0
  289. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-unindexed-v2/cmd.json +9 -0
  290. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-unindexed-v2/encrypted-field-map.json +18 -0
  291. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-unindexed-v2/encrypted-payload.json +14 -0
  292. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-unindexed-v2/mongocryptd-reply.json +41 -0
  293. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-v2/cmd.json +9 -0
  294. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-v2/encrypted-field-map.json +22 -0
  295. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-v2/encrypted-payload.json +39 -0
  296. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-v2/mongocryptd-reply.json +49 -0
  297. data/ext/libmongocrypt/libmongocrypt/test/data/iev-v2/FLECrudTest-insertOneRangeV2.json +10 -0
  298. data/ext/libmongocrypt/libmongocrypt/test/data/iev-v2/FLECrudTest-insertOneV2.json +10 -0
  299. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/README.md +17 -0
  300. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/aes-ctr.json +29 -0
  301. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2-fixed.json +10 -0
  302. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2-generated.json +38 -0
  303. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2aead-decrypt.json +35 -0
  304. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2aead-fixed.json +29 -0
  305. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2aead-generated.json +122 -0
  306. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2v2-aead-fixed.json +29 -0
  307. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/fle2v2-aead-generated.json +122 -0
  308. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/mcgrew.json +12 -0
  309. data/ext/libmongocrypt/libmongocrypt/test/data/roundtrip/nist.json +20 -0
  310. data/ext/libmongocrypt/libmongocrypt/test/data/tokens/README.md +27 -0
  311. data/ext/libmongocrypt/libmongocrypt/test/data/tokens/mc.json +21 -0
  312. data/ext/libmongocrypt/libmongocrypt/test/data/tokens/server.json +21 -0
  313. data/ext/libmongocrypt/libmongocrypt/test/example-no-bson.c +4 -4
  314. data/ext/libmongocrypt/libmongocrypt/test/example-state-machine.c +278 -323
  315. data/ext/libmongocrypt/libmongocrypt/test/fuzz_kms.c +8 -7
  316. data/ext/libmongocrypt/libmongocrypt/test/test-dll.cpp +6 -7
  317. data/ext/libmongocrypt/libmongocrypt/test/test-gcp-auth.c +221 -283
  318. data/ext/libmongocrypt/libmongocrypt/test/test-mc-efc.c +58 -73
  319. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-find-equality-payload-v2.c +78 -0
  320. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-find-range-payload-v2.c +89 -0
  321. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-iev-v2.c +248 -0
  322. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-iev.c +467 -414
  323. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-iup-v2.c +172 -0
  324. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-iup.c +141 -159
  325. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-uev-v2.c +338 -0
  326. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-payload-uev.c +238 -176
  327. data/ext/libmongocrypt/libmongocrypt/test/test-mc-fle2-rfds.c +373 -474
  328. data/ext/libmongocrypt/libmongocrypt/test/test-mc-range-edge-generation.c +346 -388
  329. data/ext/libmongocrypt/libmongocrypt/test/test-mc-range-encoding.c +708 -825
  330. data/ext/libmongocrypt/libmongocrypt/test/test-mc-range-mincover.c +417 -481
  331. data/ext/libmongocrypt/libmongocrypt/test/test-mc-rangeopts.c +110 -144
  332. data/ext/libmongocrypt/libmongocrypt/test/test-mc-reader.c +124 -207
  333. data/ext/libmongocrypt/libmongocrypt/test/test-mc-tokens.c +223 -213
  334. data/ext/libmongocrypt/libmongocrypt/test/test-mc-writer.c +176 -0
  335. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-assert-match-bson.c +634 -807
  336. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-assert-match-bson.h +1 -2
  337. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-assert.h +168 -189
  338. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-buffer.c +187 -211
  339. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-cache-oauth.c +34 -36
  340. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-cache.c +210 -233
  341. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-ciphertext.c +185 -220
  342. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-compact.c +331 -445
  343. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-crypto-hooks.c +670 -814
  344. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-crypto-std-hooks.c +102 -135
  345. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-crypto-std-hooks.h +54 -71
  346. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-crypto.c +394 -846
  347. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-csfle-lib.c +159 -183
  348. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-ctx-decrypt.c +867 -1045
  349. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-ctx-encrypt.c +4349 -4713
  350. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-ctx-rewrap-many-datakey.c +750 -964
  351. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-ctx-setopt.c +991 -1178
  352. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-datakey.c +342 -419
  353. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-dll.c +23 -30
  354. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-endpoint.c +98 -111
  355. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-kek.c +49 -52
  356. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-key-broker.c +770 -920
  357. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-key-cache.c +354 -407
  358. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-key.c +197 -245
  359. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-kms-ctx.c +286 -370
  360. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-kms-responses.c +147 -166
  361. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-local-kms.c +50 -61
  362. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-log.c +85 -100
  363. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-marking.c +656 -692
  364. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-status.c +46 -58
  365. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-traverse-util.c +377 -451
  366. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-util.c +48 -67
  367. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt-util.h +4 -10
  368. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt.c +827 -918
  369. data/ext/libmongocrypt/libmongocrypt/test/test-mongocrypt.h +111 -172
  370. data/ext/libmongocrypt/libmongocrypt/test/util/csfle.c +508 -559
  371. data/ext/libmongocrypt/libmongocrypt/test/util/util.c +735 -881
  372. data/ext/libmongocrypt/libmongocrypt/test/util/util.h +33 -55
  373. data/lib/libmongocrypt_helper/version.rb +2 -2
  374. data.tar.gz.sig +0 -0
  375. metadata +154 -26
  376. metadata.gz.sig +0 -0
  377. data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/fle2-find-range-explicit/int32/encrypted-payload.json +0 -26
  378. data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/fle2-find-range-explicit/int32/key-document.json +0 -0
  379. data/ext/libmongocrypt/libmongocrypt/bindings/node/lib/credentialsProvider.js +0 -33
  380. data/ext/libmongocrypt/libmongocrypt/bindings/node/test/credentialsProvider.test.js +0 -163
  381. data/ext/libmongocrypt/libmongocrypt/bindings/python/test/data/fle2-find-range-explicit/int32/encrypted-payload.json +0 -26
  382. data/ext/libmongocrypt/libmongocrypt/test/data/aes-ctr.cstructs +0 -359
  383. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-aead.cstructs +0 -109
  384. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32-nominmax/encrypted-payload.json +0 -26
  385. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32-nominmax/rangeopts.json +0 -5
  386. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-find-range-explicit/int32-nominmax/value-to-encrypt.json +0 -20
  387. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32-nominmax/RNG_DATA.h +0 -70
  388. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32-nominmax/encrypted-payload.json +0 -8
  389. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32-nominmax/rangeopts.json +0 -5
  390. data/ext/libmongocrypt/libmongocrypt/test/data/fle2-insert-range-explicit/int32-nominmax/value-to-encrypt.json +0 -5
  391. data/ext/libmongocrypt/libmongocrypt/test/data/fle2.cstructs +0 -33
  392. /data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/{fle2-find-range-explicit → fle2-find-range-explicit-v2}/int32/key-filter.json +0 -0
  393. /data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/{fle2-find-range-explicit → fle2-find-range-explicit-v2}/int32/rangeopts.json +0 -0
  394. /data/ext/libmongocrypt/libmongocrypt/bindings/java/mongocrypt/src/test/resources/{fle2-find-range-explicit → fle2-find-range-explicit-v2}/int32/value-to-encrypt.json +0 -0
  395. /data/ext/libmongocrypt/libmongocrypt/bindings/python/test/data/{fle2-find-range-explicit → fle2-find-range-explicit-v2}/int32/rangeopts.json +0 -0
  396. /data/ext/libmongocrypt/libmongocrypt/bindings/python/test/data/{fle2-find-range-explicit → fle2-find-range-explicit-v2}/int32/value-to-encrypt.json +0 -0
@@ -14,133 +14,113 @@
14
14
  * limitations under the License.
15
15
  */
16
16
 
17
- #include "mongocrypt.h"
18
17
  #include "mongocrypt-key-broker-private.h"
19
18
  #include "mongocrypt-key-private.h"
19
+ #include "mongocrypt.h"
20
20
  #include "test-mongocrypt.h"
21
21
 
22
22
  /* Given a string, populate a bson_value_t for that string */
23
- static void
24
- _bson_value_from_string (char *string, bson_value_t *value)
25
- {
26
- bson_t *bson;
27
- bson_iter_t iter;
23
+ static void _bson_value_from_string(char *string, bson_value_t *value) {
24
+ bson_t *bson;
25
+ bson_iter_t iter;
28
26
 
29
- bson = BCON_NEW ("key", string);
30
- BSON_ASSERT (bson_iter_init_find (&iter, bson, "key"));
31
- bson_value_copy (bson_iter_value (&iter), value);
27
+ bson = BCON_NEW("key", string);
28
+ BSON_ASSERT(bson_iter_init_find(&iter, bson, "key"));
29
+ bson_value_copy(bson_iter_value(&iter), value);
32
30
 
33
- bson_destroy (bson);
31
+ bson_destroy(bson);
34
32
  }
35
33
 
36
- static void
37
- _key_broker_add_name (_mongocrypt_key_broker_t *kb, char *string)
38
- {
39
- bson_value_t key_name;
34
+ static void _key_broker_add_name(_mongocrypt_key_broker_t *kb, char *string) {
35
+ bson_value_t key_name;
40
36
 
41
- _bson_value_from_string (string, &key_name);
42
- ASSERT_OK (_mongocrypt_key_broker_request_name (kb, (void *) &key_name), kb);
43
- bson_value_destroy (&key_name);
37
+ _bson_value_from_string(string, &key_name);
38
+ ASSERT_OK(_mongocrypt_key_broker_request_name(kb, (void *)&key_name), kb);
39
+ bson_value_destroy(&key_name);
44
40
  }
45
41
 
46
42
  /* Create an example 16 byte UUID. Use first_byte to distinguish. */
47
- static void
48
- _gen_uuid (uint8_t first_byte, _mongocrypt_buffer_t *out)
49
- {
50
- _mongocrypt_tester_fill_buffer (out, 16);
51
- out->subtype = BSON_SUBTYPE_UUID;
52
- out->data[0] = first_byte;
43
+ static void _gen_uuid(uint8_t first_byte, _mongocrypt_buffer_t *out) {
44
+ _mongocrypt_tester_fill_buffer(out, 16);
45
+ out->subtype = BSON_SUBTYPE_UUID;
46
+ out->data[0] = first_byte;
53
47
  }
54
48
 
55
-
56
49
  /* Create an example 16 byte UUID and a corresponding key document with the same
57
50
  * _id as the UUID. */
58
- static void
59
- _gen_uuid_and_key_and_altname (_mongocrypt_tester_t *tester,
60
- char *altname,
61
- uint8_t first_byte,
62
- _mongocrypt_buffer_t *id,
63
- _mongocrypt_buffer_t *doc)
64
- {
65
- bson_t as_bson, copied;
66
-
67
- _gen_uuid (first_byte, id);
68
- BSON_ASSERT (_mongocrypt_binary_to_bson (
69
- TEST_FILE ("./test/example/key-document.json"), &as_bson));
70
- bson_init (&copied);
71
- bson_copy_to_excluding_noinit (
72
- &as_bson, &copied, "_id", "keyAltNames", NULL);
73
- BSON_ASSERT (_mongocrypt_buffer_append (id, &copied, "_id", 3));
74
- if (altname) {
75
- bson_t child;
76
- bson_append_array_begin (&copied, "keyAltNames", -1, &child);
77
- bson_append_utf8 (&child, "0", -1, altname, -1);
78
- bson_append_array_end (&copied, &child);
79
- }
80
- _mongocrypt_buffer_steal_from_bson (doc, &copied);
51
+ static void _gen_uuid_and_key_and_altname(_mongocrypt_tester_t *tester,
52
+ char *altname,
53
+ uint8_t first_byte,
54
+ _mongocrypt_buffer_t *id,
55
+ _mongocrypt_buffer_t *doc) {
56
+ bson_t as_bson, copied;
57
+
58
+ _gen_uuid(first_byte, id);
59
+ BSON_ASSERT(_mongocrypt_binary_to_bson(TEST_FILE("./test/example/key-document.json"), &as_bson));
60
+ bson_init(&copied);
61
+ bson_copy_to_excluding_noinit(&as_bson, &copied, "_id", "keyAltNames", NULL);
62
+ BSON_ASSERT(_mongocrypt_buffer_append(id, &copied, "_id", 3));
63
+ if (altname) {
64
+ bson_t child;
65
+ bson_append_array_begin(&copied, "keyAltNames", -1, &child);
66
+ bson_append_utf8(&child, "0", -1, altname, -1);
67
+ bson_append_array_end(&copied, &child);
68
+ }
69
+ _mongocrypt_buffer_steal_from_bson(doc, &copied);
81
70
  }
82
71
 
83
- static void
84
- _gen_uuid_and_key (_mongocrypt_tester_t *tester,
85
- uint8_t first_byte,
86
- _mongocrypt_buffer_t *id,
87
- _mongocrypt_buffer_t *doc)
88
- {
89
- _gen_uuid_and_key_and_altname (tester, NULL, first_byte, id, doc);
72
+ static void _gen_uuid_and_key(_mongocrypt_tester_t *tester,
73
+ uint8_t first_byte,
74
+ _mongocrypt_buffer_t *id,
75
+ _mongocrypt_buffer_t *doc) {
76
+ _gen_uuid_and_key_and_altname(tester, NULL, first_byte, id, doc);
90
77
  }
91
78
 
92
-
93
- static uint32_t
94
- _key_broker_num_satisfied (_mongocrypt_key_broker_t *kb)
95
- {
96
- key_request_t *req;
97
- uint32_t count;
98
-
99
- count = 0;
100
- for (req = kb->key_requests; NULL != req; req = req->next) {
101
- if (req->satisfied) {
102
- count++;
103
- }
104
- }
105
- return count;
79
+ static uint32_t _key_broker_num_satisfied(_mongocrypt_key_broker_t *kb) {
80
+ key_request_t *req;
81
+ uint32_t count;
82
+
83
+ count = 0;
84
+ for (req = kb->key_requests; NULL != req; req = req->next) {
85
+ if (req->satisfied) {
86
+ count++;
87
+ }
88
+ }
89
+ return count;
106
90
  }
107
91
 
108
- static void
109
- _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
110
- {
111
- mongocrypt_t *crypt;
112
- mongocrypt_status_t *status;
113
- _mongocrypt_buffer_t key_id1, key_id2;
114
- mongocrypt_binary_t *filter;
115
- _mongocrypt_key_broker_t key_broker;
116
- bson_t as_bson;
117
- bson_t *expected;
118
-
119
- status = mongocrypt_status_new ();
120
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
121
- _gen_uuid (1, &key_id1);
122
- _gen_uuid (2, &key_id2);
123
-
124
- /* Multiple different key ids. */
125
- _mongocrypt_key_broker_init (&key_broker, crypt);
126
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
127
- &key_broker);
128
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id2),
129
- &key_broker);
130
- filter = mongocrypt_binary_new ();
131
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
132
- ASSERT_OK (_mongocrypt_key_broker_filter (&key_broker, filter), &key_broker);
133
- BSON_ASSERT (_mongocrypt_binary_to_bson (filter, &as_bson));
134
-
135
- expected = BCON_NEW ("$or",
92
+ static void _test_key_broker_get_key_filter(_mongocrypt_tester_t *tester) {
93
+ mongocrypt_t *crypt;
94
+ mongocrypt_status_t *status;
95
+ _mongocrypt_buffer_t key_id1, key_id2;
96
+ mongocrypt_binary_t *filter;
97
+ _mongocrypt_key_broker_t key_broker;
98
+ bson_t as_bson;
99
+ bson_t *expected;
100
+
101
+ status = mongocrypt_status_new();
102
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
103
+ _gen_uuid(1, &key_id1);
104
+ _gen_uuid(2, &key_id2);
105
+
106
+ /* Multiple different key ids. */
107
+ _mongocrypt_key_broker_init(&key_broker, crypt);
108
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
109
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id2), &key_broker);
110
+ filter = mongocrypt_binary_new();
111
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
112
+ ASSERT_OK(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker);
113
+ BSON_ASSERT(_mongocrypt_binary_to_bson(filter, &as_bson));
114
+
115
+ expected = BCON_NEW("$or",
136
116
  "[",
137
117
  "{",
138
118
  "_id",
139
119
  "{",
140
120
  "$in",
141
121
  "[",
142
- BCON_BIN (BSON_SUBTYPE_UUID, key_id2.data, key_id2.len),
143
- BCON_BIN (BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
122
+ BCON_BIN(BSON_SUBTYPE_UUID, key_id2.data, key_id2.len),
123
+ BCON_BIN(BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
144
124
  "]",
145
125
  "}",
146
126
  "}",
@@ -154,30 +134,28 @@ _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
154
134
  "}",
155
135
  "]");
156
136
 
157
- BSON_ASSERT (0 == bson_compare (expected, &as_bson));
158
- bson_destroy (expected);
159
- _mongocrypt_key_broker_cleanup (&key_broker);
160
- mongocrypt_binary_destroy (filter);
161
-
162
- /* Duplicate key ids. */
163
- _mongocrypt_key_broker_init (&key_broker, crypt);
164
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
165
- &key_broker);
166
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
167
- &key_broker);
168
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
169
- filter = mongocrypt_binary_new ();
170
- ASSERT_OK (_mongocrypt_key_broker_filter (&key_broker, filter), &key_broker);
171
- BSON_ASSERT (_mongocrypt_binary_to_bson (filter, &as_bson));
172
-
173
- expected = BCON_NEW ("$or",
137
+ BSON_ASSERT(0 == bson_compare(expected, &as_bson));
138
+ bson_destroy(expected);
139
+ _mongocrypt_key_broker_cleanup(&key_broker);
140
+ mongocrypt_binary_destroy(filter);
141
+
142
+ /* Duplicate key ids. */
143
+ _mongocrypt_key_broker_init(&key_broker, crypt);
144
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
145
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
146
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
147
+ filter = mongocrypt_binary_new();
148
+ ASSERT_OK(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker);
149
+ BSON_ASSERT(_mongocrypt_binary_to_bson(filter, &as_bson));
150
+
151
+ expected = BCON_NEW("$or",
174
152
  "[",
175
153
  "{",
176
154
  "_id",
177
155
  "{",
178
156
  "$in",
179
157
  "[",
180
- BCON_BIN (BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
158
+ BCON_BIN(BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
181
159
  "]",
182
160
  "}",
183
161
  "}",
@@ -191,38 +169,35 @@ _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
191
169
  "}",
192
170
  "]");
193
171
 
194
- BSON_ASSERT (0 == bson_compare (expected, &as_bson));
195
- bson_destroy (expected);
196
- _mongocrypt_key_broker_cleanup (&key_broker);
197
- mongocrypt_binary_destroy (filter);
198
-
199
- /* No key requests made. */
200
- _mongocrypt_key_broker_init (&key_broker, crypt);
201
- filter = mongocrypt_binary_new ();
202
- ASSERT_FAILS (_mongocrypt_key_broker_filter (&key_broker, filter),
203
- &key_broker,
204
- "in wrong state");
205
- mongocrypt_binary_destroy (filter);
206
- _mongocrypt_key_broker_cleanup (&key_broker);
207
-
208
- /* Both key ids and keyAltName */
209
- _mongocrypt_key_broker_init (&key_broker, crypt);
210
- _key_broker_add_name (&key_broker, "Miriam");
211
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
212
- &key_broker);
213
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
214
- filter = mongocrypt_binary_new ();
215
- ASSERT_OK (_mongocrypt_key_broker_filter (&key_broker, filter), &key_broker);
216
- BSON_ASSERT (_mongocrypt_binary_to_bson (filter, &as_bson));
217
-
218
- expected = BCON_NEW ("$or",
172
+ BSON_ASSERT(0 == bson_compare(expected, &as_bson));
173
+ bson_destroy(expected);
174
+ _mongocrypt_key_broker_cleanup(&key_broker);
175
+ mongocrypt_binary_destroy(filter);
176
+
177
+ /* No key requests made. */
178
+ _mongocrypt_key_broker_init(&key_broker, crypt);
179
+ filter = mongocrypt_binary_new();
180
+ ASSERT_FAILS(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker, "in wrong state");
181
+ mongocrypt_binary_destroy(filter);
182
+ _mongocrypt_key_broker_cleanup(&key_broker);
183
+
184
+ /* Both key ids and keyAltName */
185
+ _mongocrypt_key_broker_init(&key_broker, crypt);
186
+ _key_broker_add_name(&key_broker, "Miriam");
187
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
188
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
189
+ filter = mongocrypt_binary_new();
190
+ ASSERT_OK(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker);
191
+ BSON_ASSERT(_mongocrypt_binary_to_bson(filter, &as_bson));
192
+
193
+ expected = BCON_NEW("$or",
219
194
  "[",
220
195
  "{",
221
196
  "_id",
222
197
  "{",
223
198
  "$in",
224
199
  "[",
225
- BCON_BIN (BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
200
+ BCON_BIN(BSON_SUBTYPE_UUID, key_id1.data, key_id1.len),
226
201
  "]",
227
202
  "}",
228
203
  "}",
@@ -231,27 +206,27 @@ _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
231
206
  "{",
232
207
  "$in",
233
208
  "[",
234
- BCON_UTF8 ("Miriam"),
209
+ BCON_UTF8("Miriam"),
235
210
  "]",
236
211
  "}",
237
212
  "}",
238
213
  "]");
239
214
 
240
- BSON_ASSERT (0 == bson_compare (expected, &as_bson));
241
- bson_destroy (expected);
242
- _mongocrypt_key_broker_cleanup (&key_broker);
243
- mongocrypt_binary_destroy (filter);
244
-
245
- /* Keys with only keyAltName */
246
- _mongocrypt_key_broker_init (&key_broker, crypt);
247
- _key_broker_add_name (&key_broker, "Sharlene");
248
- _key_broker_add_name (&key_broker, "Emily");
249
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
250
- filter = mongocrypt_binary_new ();
251
- ASSERT_OK (_mongocrypt_key_broker_filter (&key_broker, filter), &key_broker);
252
- BSON_ASSERT (_mongocrypt_binary_to_bson (filter, &as_bson));
253
-
254
- expected = BCON_NEW ("$or",
215
+ BSON_ASSERT(0 == bson_compare(expected, &as_bson));
216
+ bson_destroy(expected);
217
+ _mongocrypt_key_broker_cleanup(&key_broker);
218
+ mongocrypt_binary_destroy(filter);
219
+
220
+ /* Keys with only keyAltName */
221
+ _mongocrypt_key_broker_init(&key_broker, crypt);
222
+ _key_broker_add_name(&key_broker, "Sharlene");
223
+ _key_broker_add_name(&key_broker, "Emily");
224
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
225
+ filter = mongocrypt_binary_new();
226
+ ASSERT_OK(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker);
227
+ BSON_ASSERT(_mongocrypt_binary_to_bson(filter, &as_bson));
228
+
229
+ expected = BCON_NEW("$or",
255
230
  "[",
256
231
  "{",
257
232
  "_id",
@@ -266,29 +241,29 @@ _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
266
241
  "{",
267
242
  "$in",
268
243
  "[",
269
- BCON_UTF8 ("Emily"),
270
- BCON_UTF8 ("Sharlene"),
244
+ BCON_UTF8("Emily"),
245
+ BCON_UTF8("Sharlene"),
271
246
  "]",
272
247
  "}",
273
248
  "}",
274
249
  "]");
275
250
 
276
- BSON_ASSERT (0 == bson_compare (expected, &as_bson));
277
- bson_destroy (expected);
278
- _mongocrypt_key_broker_cleanup (&key_broker);
279
- mongocrypt_binary_destroy (filter);
280
-
281
- /* Duplicate alt names */
282
- _mongocrypt_key_broker_init (&key_broker, crypt);
283
- _key_broker_add_name (&key_broker, "Jackie");
284
- _key_broker_add_name (&key_broker, "Jackie");
285
- _key_broker_add_name (&key_broker, "Jackie");
286
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
287
- filter = mongocrypt_binary_new ();
288
- ASSERT_OK (_mongocrypt_key_broker_filter (&key_broker, filter), &key_broker);
289
- BSON_ASSERT (_mongocrypt_binary_to_bson (filter, &as_bson));
290
-
291
- expected = BCON_NEW ("$or",
251
+ BSON_ASSERT(0 == bson_compare(expected, &as_bson));
252
+ bson_destroy(expected);
253
+ _mongocrypt_key_broker_cleanup(&key_broker);
254
+ mongocrypt_binary_destroy(filter);
255
+
256
+ /* Duplicate alt names */
257
+ _mongocrypt_key_broker_init(&key_broker, crypt);
258
+ _key_broker_add_name(&key_broker, "Jackie");
259
+ _key_broker_add_name(&key_broker, "Jackie");
260
+ _key_broker_add_name(&key_broker, "Jackie");
261
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
262
+ filter = mongocrypt_binary_new();
263
+ ASSERT_OK(_mongocrypt_key_broker_filter(&key_broker, filter), &key_broker);
264
+ BSON_ASSERT(_mongocrypt_binary_to_bson(filter, &as_bson));
265
+
266
+ expected = BCON_NEW("$or",
292
267
  "[",
293
268
  "{",
294
269
  "_id",
@@ -303,347 +278,285 @@ _test_key_broker_get_key_filter (_mongocrypt_tester_t *tester)
303
278
  "{",
304
279
  "$in",
305
280
  "[",
306
- BCON_UTF8 ("Jackie"),
281
+ BCON_UTF8("Jackie"),
307
282
  "]",
308
283
  "}",
309
284
  "}",
310
285
  "]");
311
286
 
312
- BSON_ASSERT (0 == bson_compare (expected, &as_bson));
313
- bson_destroy (expected);
314
- _mongocrypt_key_broker_cleanup (&key_broker);
315
- mongocrypt_binary_destroy (filter);
287
+ BSON_ASSERT(0 == bson_compare(expected, &as_bson));
288
+ bson_destroy(expected);
289
+ _mongocrypt_key_broker_cleanup(&key_broker);
290
+ mongocrypt_binary_destroy(filter);
316
291
 
317
- _mongocrypt_buffer_cleanup (&key_id1);
318
- _mongocrypt_buffer_cleanup (&key_id2);
319
- mongocrypt_status_destroy (status);
320
- mongocrypt_destroy (crypt);
292
+ _mongocrypt_buffer_cleanup(&key_id1);
293
+ _mongocrypt_buffer_cleanup(&key_id2);
294
+ mongocrypt_status_destroy(status);
295
+ mongocrypt_destroy(crypt);
321
296
  }
322
297
 
323
-
324
- static void
325
- _test_key_broker_add_key (_mongocrypt_tester_t *tester)
326
- {
327
- mongocrypt_t *crypt;
328
- mongocrypt_status_t *status;
329
- _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2, malformed_buf,
330
- key_buf_x, key_buf_y, key_doc_names;
331
- _mongocrypt_buffer_t *id_x;
332
- _mongocrypt_key_doc_t *key_x;
333
- bson_t key_bson_x;
334
- bson_t *malformed;
335
- _mongocrypt_opts_kms_providers_t *kms_providers;
336
- _mongocrypt_key_broker_t key_broker;
337
-
338
- status = mongocrypt_status_new ();
339
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
340
- kms_providers = &crypt->opts.kms_providers;
341
- _gen_uuid_and_key (tester, 1, &key_id1, &key_doc1);
342
- _gen_uuid_and_key (tester, 2, &key_id2, &key_doc2);
343
-
344
- /* Valid key documents. */
345
- _mongocrypt_key_broker_init (&key_broker, crypt);
346
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
347
- &key_broker);
348
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id2),
349
- &key_broker);
350
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
351
- ASSERT_OK (
352
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc2),
353
- &key_broker);
354
- ASSERT_OK (
355
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc1),
356
- &key_broker);
357
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&key_broker), &key_broker);
358
- _mongocrypt_key_broker_cleanup (&key_broker);
359
-
360
- /* Valid document with a key name. */
361
- _mongocrypt_key_broker_init (&key_broker, crypt);
362
- _key_broker_add_name (&key_broker, "Kasey");
363
- _mongocrypt_buffer_from_binary (
364
- &key_doc_names,
365
- TEST_FILE ("./test/data/key-document-with-alt-name.json"));
366
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
367
- ASSERT_OK (_mongocrypt_key_broker_add_doc (
368
- &key_broker, kms_providers, &key_doc_names),
369
- &key_broker);
370
- _mongocrypt_key_broker_cleanup (&key_broker);
371
-
372
- /* Malformed key document. */
373
- malformed = BCON_NEW ("abc", BCON_INT32 (123));
374
- _mongocrypt_key_broker_init (&key_broker, crypt);
375
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
376
- &key_broker);
377
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
378
- _mongocrypt_buffer_from_bson (&malformed_buf, malformed);
379
- ASSERT_FAILS (_mongocrypt_key_broker_add_doc (
380
- &key_broker, kms_providers, &malformed_buf),
298
+ static void _test_key_broker_add_key(_mongocrypt_tester_t *tester) {
299
+ mongocrypt_t *crypt;
300
+ mongocrypt_status_t *status;
301
+ _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2, malformed_buf, key_buf_x, key_buf_y, key_doc_names;
302
+ _mongocrypt_buffer_t *id_x;
303
+ _mongocrypt_key_doc_t *key_x;
304
+ bson_t key_bson_x;
305
+ bson_t *malformed;
306
+ _mongocrypt_opts_kms_providers_t *kms_providers;
307
+ _mongocrypt_key_broker_t key_broker;
308
+
309
+ status = mongocrypt_status_new();
310
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
311
+ kms_providers = &crypt->opts.kms_providers;
312
+ _gen_uuid_and_key(tester, 1, &key_id1, &key_doc1);
313
+ _gen_uuid_and_key(tester, 2, &key_id2, &key_doc2);
314
+
315
+ /* Valid key documents. */
316
+ _mongocrypt_key_broker_init(&key_broker, crypt);
317
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
318
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id2), &key_broker);
319
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
320
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc2), &key_broker);
321
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc1), &key_broker);
322
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&key_broker), &key_broker);
323
+ _mongocrypt_key_broker_cleanup(&key_broker);
324
+
325
+ /* Valid document with a key name. */
326
+ _mongocrypt_key_broker_init(&key_broker, crypt);
327
+ _key_broker_add_name(&key_broker, "Kasey");
328
+ _mongocrypt_buffer_from_binary(&key_doc_names, TEST_FILE("./test/data/key-document-with-alt-name.json"));
329
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
330
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc_names), &key_broker);
331
+ _mongocrypt_key_broker_cleanup(&key_broker);
332
+
333
+ /* Malformed key document. */
334
+ malformed = BCON_NEW("abc", BCON_INT32(123));
335
+ _mongocrypt_key_broker_init(&key_broker, crypt);
336
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
337
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
338
+ _mongocrypt_buffer_from_bson(&malformed_buf, malformed);
339
+ ASSERT_FAILS(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &malformed_buf),
381
340
  &key_broker,
382
341
  "unrecognized field");
383
- _mongocrypt_key_broker_cleanup (&key_broker);
384
- bson_destroy (malformed);
385
-
386
- /* NULL key document. */
387
- _mongocrypt_key_broker_init (&key_broker, crypt);
388
- BSON_ASSERT (_mongocrypt_key_broker_request_id (&key_broker, &key_id1));
389
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
390
- ASSERT_FAILS (
391
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, NULL),
392
- &key_broker,
393
- "invalid key");
394
- _mongocrypt_key_broker_cleanup (&key_broker);
395
-
396
- /* Unmatched key document. */
397
- _mongocrypt_key_broker_init (&key_broker, crypt);
398
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
399
- &key_broker);
400
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
401
- ASSERT_FAILS (
402
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc2),
403
- &key_broker,
404
- "unexpected key returned");
405
- _mongocrypt_key_broker_cleanup (&key_broker);
406
-
407
- /* Two key documents with the same keyAltName and
408
- different key ids. In order to test this, we need
409
- to add a name X and an id Y to the broker, then
410
- add a document with name X and id Z (succeeds) and
411
- afterwards add a doc with name X and id Y (fails). */
412
- key_x = _mongocrypt_key_new ();
413
- _mongocrypt_key_broker_init (&key_broker, crypt);
414
-
415
- _mongocrypt_buffer_from_binary (
416
- &key_buf_x, TEST_FILE ("./test/data/key-document-with-alt-name.json"));
417
- _mongocrypt_buffer_from_binary (
418
- &key_buf_y,
419
- TEST_FILE ("./test/data/key-document-with-alt-name-duplicate-id.json"));
420
-
421
- BSON_ASSERT (_mongocrypt_buffer_to_bson (&key_buf_x, &key_bson_x));
422
- ASSERT_OR_PRINT (_mongocrypt_key_parse_owned (&key_bson_x, key_x, status),
423
- status);
424
- id_x = &key_x->id;
425
-
426
- /* Configure the key broker so it contains:
427
- - { id : X }
428
- - { name : "Sharlene" } */
429
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, id_x),
430
- &key_broker);
431
- _key_broker_add_name (&key_broker, "Sharlene");
432
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
433
-
434
- /* Add { id : Y, name : "Sharlene" }, should pass. */
435
- ASSERT_OK (
436
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_buf_y),
437
- &key_broker);
438
-
439
- /* Add { id : X, name : "Sharlene" }, should fail, it shares an alt name. */
440
- ASSERT_FAILS (
441
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_buf_x),
442
- &key_broker,
443
- "duplicate keyAltNames");
444
-
445
- _mongocrypt_key_broker_cleanup (&key_broker);
446
-
447
- /* Calling done before supplying all keys. */
448
- _mongocrypt_key_broker_init (&key_broker, crypt);
449
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
450
- &key_broker);
451
- _mongocrypt_key_broker_cleanup (&key_broker);
452
-
453
- bson_destroy (&key_bson_x);
454
- _mongocrypt_key_destroy (key_x);
455
- _mongocrypt_buffer_cleanup (&key_doc_names);
456
- _mongocrypt_buffer_cleanup (&key_id1);
457
- _mongocrypt_buffer_cleanup (&key_id2);
458
- _mongocrypt_buffer_cleanup (&key_doc1);
459
- _mongocrypt_buffer_cleanup (&key_doc2);
460
- _mongocrypt_buffer_cleanup (&key_buf_x);
461
- _mongocrypt_buffer_cleanup (&key_buf_y);
462
- mongocrypt_status_destroy (status);
463
- mongocrypt_destroy (crypt);
342
+ _mongocrypt_key_broker_cleanup(&key_broker);
343
+ bson_destroy(malformed);
344
+
345
+ /* NULL key document. */
346
+ _mongocrypt_key_broker_init(&key_broker, crypt);
347
+ BSON_ASSERT(_mongocrypt_key_broker_request_id(&key_broker, &key_id1));
348
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
349
+ ASSERT_FAILS(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, NULL), &key_broker, "invalid key");
350
+ _mongocrypt_key_broker_cleanup(&key_broker);
351
+
352
+ /* Unmatched key document. */
353
+ _mongocrypt_key_broker_init(&key_broker, crypt);
354
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
355
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
356
+ ASSERT_FAILS(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc2),
357
+ &key_broker,
358
+ "unexpected key returned");
359
+ _mongocrypt_key_broker_cleanup(&key_broker);
360
+
361
+ /* Two key documents with the same keyAltName and
362
+ different key ids. In order to test this, we need
363
+ to add a name X and an id Y to the broker, then
364
+ add a document with name X and id Z (succeeds) and
365
+ afterwards add a doc with name X and id Y (fails). */
366
+ key_x = _mongocrypt_key_new();
367
+ _mongocrypt_key_broker_init(&key_broker, crypt);
368
+
369
+ _mongocrypt_buffer_from_binary(&key_buf_x, TEST_FILE("./test/data/key-document-with-alt-name.json"));
370
+ _mongocrypt_buffer_from_binary(&key_buf_y, TEST_FILE("./test/data/key-document-with-alt-name-duplicate-id.json"));
371
+
372
+ BSON_ASSERT(_mongocrypt_buffer_to_bson(&key_buf_x, &key_bson_x));
373
+ ASSERT_OR_PRINT(_mongocrypt_key_parse_owned(&key_bson_x, key_x, status), status);
374
+ id_x = &key_x->id;
375
+
376
+ /* Configure the key broker so it contains:
377
+ - { id : X }
378
+ - { name : "Sharlene" } */
379
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, id_x), &key_broker);
380
+ _key_broker_add_name(&key_broker, "Sharlene");
381
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
382
+
383
+ /* Add { id : Y, name : "Sharlene" }, should pass. */
384
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_buf_y), &key_broker);
385
+
386
+ /* Add { id : X, name : "Sharlene" }, should fail, it shares an alt name. */
387
+ ASSERT_FAILS(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_buf_x),
388
+ &key_broker,
389
+ "duplicate keyAltNames");
390
+
391
+ _mongocrypt_key_broker_cleanup(&key_broker);
392
+
393
+ /* Calling done before supplying all keys. */
394
+ _mongocrypt_key_broker_init(&key_broker, crypt);
395
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
396
+ _mongocrypt_key_broker_cleanup(&key_broker);
397
+
398
+ bson_destroy(&key_bson_x);
399
+ _mongocrypt_key_destroy(key_x);
400
+ _mongocrypt_buffer_cleanup(&key_doc_names);
401
+ _mongocrypt_buffer_cleanup(&key_id1);
402
+ _mongocrypt_buffer_cleanup(&key_id2);
403
+ _mongocrypt_buffer_cleanup(&key_doc1);
404
+ _mongocrypt_buffer_cleanup(&key_doc2);
405
+ _mongocrypt_buffer_cleanup(&key_buf_x);
406
+ _mongocrypt_buffer_cleanup(&key_buf_y);
407
+ mongocrypt_status_destroy(status);
408
+ mongocrypt_destroy(crypt);
464
409
  }
465
410
 
466
- static void
467
- _test_key_broker_add_decrypted_key (_mongocrypt_tester_t *tester)
468
- {
469
- mongocrypt_t *crypt;
470
- mongocrypt_status_t *status;
471
- _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2, key_doc_names,
472
- key_id_names;
473
- _mongocrypt_key_broker_t key_broker;
474
- mongocrypt_kms_ctx_t *kms;
475
- _mongocrypt_opts_kms_providers_t *kms_providers;
476
- bson_iter_t iter;
477
- bson_t key_doc_names_bson;
478
-
479
- status = mongocrypt_status_new ();
480
- _gen_uuid_and_key (tester, 1, &key_id1, &key_doc1);
481
- _gen_uuid_and_key (tester, 2, &key_id2, &key_doc2);
482
-
483
- /* Success. With key ids. */
484
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
485
- kms_providers = &crypt->opts.kms_providers;
486
- _mongocrypt_key_broker_init (&key_broker, crypt);
487
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id1),
488
- &key_broker);
489
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id2),
490
- &key_broker);
491
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
492
- ASSERT_OK (
493
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc2),
494
- &key_broker);
495
- ASSERT_OK (
496
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc1),
497
- &key_broker);
498
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&key_broker), &key_broker);
499
- kms = _mongocrypt_key_broker_next_kms (&key_broker);
500
- BSON_ASSERT (kms);
501
- _mongocrypt_tester_satisfy_kms (tester, kms);
502
- kms = _mongocrypt_key_broker_next_kms (&key_broker);
503
- BSON_ASSERT (kms);
504
- _mongocrypt_tester_satisfy_kms (tester, kms);
505
- BSON_ASSERT (!_mongocrypt_key_broker_next_kms (&key_broker));
506
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&key_broker, kms_providers),
507
- &key_broker);
508
- _mongocrypt_key_broker_cleanup (&key_broker);
509
- mongocrypt_destroy (crypt); /* destroy crypt to reset cache. */
510
-
511
- /* Success. With key alt names. */
512
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
513
- kms_providers = &crypt->opts.kms_providers;
514
- _mongocrypt_key_broker_init (&key_broker, crypt);
515
- _key_broker_add_name (&key_broker, "Sharlene");
516
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
517
-
518
- _mongocrypt_buffer_from_binary (
519
- &key_doc_names,
520
- TEST_FILE ("./test/data/key-document-with-alt-name.json"));
521
- ASSERT_OK (_mongocrypt_key_broker_add_doc (
522
- &key_broker, kms_providers, &key_doc_names),
523
- &key_broker);
524
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&key_broker), &key_broker);
525
- kms = _mongocrypt_key_broker_next_kms (&key_broker);
526
- BSON_ASSERT (kms);
527
-
528
- _mongocrypt_tester_satisfy_kms (tester, kms);
529
- BSON_ASSERT (!_mongocrypt_key_broker_next_kms (&key_broker));
530
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&key_broker, kms_providers),
531
- &key_broker);
532
- _mongocrypt_key_broker_cleanup (&key_broker);
533
- mongocrypt_destroy (crypt); /* destroy crypt to reset cache. */
534
-
535
- /* With both key ids and key alt names, some referring to the same key */
536
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
537
- kms_providers = &crypt->opts.kms_providers;
538
- _mongocrypt_key_broker_init (&key_broker, crypt);
539
- BSON_ASSERT (
540
- _mongocrypt_buffer_to_bson (&key_doc_names, &key_doc_names_bson));
541
- BSON_ASSERT (bson_iter_init_find (&iter, &key_doc_names_bson, "_id"));
542
- BSON_ASSERT (_mongocrypt_buffer_from_binary_iter (&key_id_names, &iter));
543
- BSON_ASSERT (key_id_names.subtype == BSON_SUBTYPE_UUID);
544
- ASSERT_OK (_mongocrypt_key_broker_request_id (&key_broker, &key_id_names),
545
- &key_broker);
546
- _key_broker_add_name (&key_broker, "Sharlene");
547
- _key_broker_add_name (&key_broker, "Kasey");
548
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
549
- ASSERT_OK (_mongocrypt_key_broker_add_doc (
550
- &key_broker, kms_providers, &key_doc_names),
551
- &key_broker);
552
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&key_broker), &key_broker);
553
- kms = _mongocrypt_key_broker_next_kms (&key_broker);
554
- BSON_ASSERT (kms);
555
- _mongocrypt_tester_satisfy_kms (tester, kms);
556
- BSON_ASSERT (!_mongocrypt_key_broker_next_kms (&key_broker));
557
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&key_broker, kms_providers),
558
- &key_broker);
559
- _mongocrypt_key_broker_cleanup (&key_broker);
560
-
561
- bson_destroy (&key_doc_names_bson);
562
- _mongocrypt_buffer_cleanup (&key_id_names);
563
- _mongocrypt_buffer_cleanup (&key_id1);
564
- _mongocrypt_buffer_cleanup (&key_id2);
565
- _mongocrypt_buffer_cleanup (&key_doc1);
566
- _mongocrypt_buffer_cleanup (&key_doc2);
567
- mongocrypt_status_destroy (status);
568
- mongocrypt_destroy (crypt);
411
+ static void _test_key_broker_add_decrypted_key(_mongocrypt_tester_t *tester) {
412
+ mongocrypt_t *crypt;
413
+ mongocrypt_status_t *status;
414
+ _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2, key_doc_names, key_id_names;
415
+ _mongocrypt_key_broker_t key_broker;
416
+ mongocrypt_kms_ctx_t *kms;
417
+ _mongocrypt_opts_kms_providers_t *kms_providers;
418
+ bson_iter_t iter;
419
+ bson_t key_doc_names_bson;
420
+
421
+ status = mongocrypt_status_new();
422
+ _gen_uuid_and_key(tester, 1, &key_id1, &key_doc1);
423
+ _gen_uuid_and_key(tester, 2, &key_id2, &key_doc2);
424
+
425
+ /* Success. With key ids. */
426
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
427
+ kms_providers = &crypt->opts.kms_providers;
428
+ _mongocrypt_key_broker_init(&key_broker, crypt);
429
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id1), &key_broker);
430
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id2), &key_broker);
431
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
432
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc2), &key_broker);
433
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc1), &key_broker);
434
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&key_broker), &key_broker);
435
+ kms = _mongocrypt_key_broker_next_kms(&key_broker);
436
+ BSON_ASSERT(kms);
437
+ _mongocrypt_tester_satisfy_kms(tester, kms);
438
+ kms = _mongocrypt_key_broker_next_kms(&key_broker);
439
+ BSON_ASSERT(kms);
440
+ _mongocrypt_tester_satisfy_kms(tester, kms);
441
+ BSON_ASSERT(!_mongocrypt_key_broker_next_kms(&key_broker));
442
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&key_broker, kms_providers), &key_broker);
443
+ _mongocrypt_key_broker_cleanup(&key_broker);
444
+ mongocrypt_destroy(crypt); /* destroy crypt to reset cache. */
445
+
446
+ /* Success. With key alt names. */
447
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
448
+ kms_providers = &crypt->opts.kms_providers;
449
+ _mongocrypt_key_broker_init(&key_broker, crypt);
450
+ _key_broker_add_name(&key_broker, "Sharlene");
451
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
452
+
453
+ _mongocrypt_buffer_from_binary(&key_doc_names, TEST_FILE("./test/data/key-document-with-alt-name.json"));
454
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc_names), &key_broker);
455
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&key_broker), &key_broker);
456
+ kms = _mongocrypt_key_broker_next_kms(&key_broker);
457
+ BSON_ASSERT(kms);
458
+
459
+ _mongocrypt_tester_satisfy_kms(tester, kms);
460
+ BSON_ASSERT(!_mongocrypt_key_broker_next_kms(&key_broker));
461
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&key_broker, kms_providers), &key_broker);
462
+ _mongocrypt_key_broker_cleanup(&key_broker);
463
+ mongocrypt_destroy(crypt); /* destroy crypt to reset cache. */
464
+
465
+ /* With both key ids and key alt names, some referring to the same key */
466
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
467
+ kms_providers = &crypt->opts.kms_providers;
468
+ _mongocrypt_key_broker_init(&key_broker, crypt);
469
+ BSON_ASSERT(_mongocrypt_buffer_to_bson(&key_doc_names, &key_doc_names_bson));
470
+ BSON_ASSERT(bson_iter_init_find(&iter, &key_doc_names_bson, "_id"));
471
+ BSON_ASSERT(_mongocrypt_buffer_from_binary_iter(&key_id_names, &iter));
472
+ BSON_ASSERT(key_id_names.subtype == BSON_SUBTYPE_UUID);
473
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&key_broker, &key_id_names), &key_broker);
474
+ _key_broker_add_name(&key_broker, "Sharlene");
475
+ _key_broker_add_name(&key_broker, "Kasey");
476
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
477
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc_names), &key_broker);
478
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&key_broker), &key_broker);
479
+ kms = _mongocrypt_key_broker_next_kms(&key_broker);
480
+ BSON_ASSERT(kms);
481
+ _mongocrypt_tester_satisfy_kms(tester, kms);
482
+ BSON_ASSERT(!_mongocrypt_key_broker_next_kms(&key_broker));
483
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&key_broker, kms_providers), &key_broker);
484
+ _mongocrypt_key_broker_cleanup(&key_broker);
485
+
486
+ bson_destroy(&key_doc_names_bson);
487
+ _mongocrypt_buffer_cleanup(&key_id_names);
488
+ _mongocrypt_buffer_cleanup(&key_id1);
489
+ _mongocrypt_buffer_cleanup(&key_id2);
490
+ _mongocrypt_buffer_cleanup(&key_doc1);
491
+ _mongocrypt_buffer_cleanup(&key_doc2);
492
+ mongocrypt_status_destroy(status);
493
+ mongocrypt_destroy(crypt);
569
494
  }
570
495
 
571
-
572
- static void
573
- _test_key_broker_wrong_subtype (_mongocrypt_tester_t *tester)
574
- {
575
- mongocrypt_t *crypt;
576
- mongocrypt_status_t *status;
577
- _mongocrypt_buffer_t key_id, key_doc;
578
- _mongocrypt_key_broker_t key_broker;
579
-
580
- status = mongocrypt_status_new ();
581
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
582
- _gen_uuid_and_key (tester, 1, &key_id, &key_doc);
583
-
584
- /* Valid key documents. */
585
- _mongocrypt_key_broker_init (&key_broker, crypt);
586
- key_id.subtype = 0;
587
- ASSERT_FAILS (_mongocrypt_key_broker_request_id (&key_broker, &key_id),
588
- &key_broker,
589
- "expected UUID");
590
-
591
- _mongocrypt_buffer_cleanup (&key_id);
592
- _mongocrypt_buffer_cleanup (&key_doc);
593
- _mongocrypt_key_broker_cleanup (&key_broker);
594
- mongocrypt_status_destroy (status);
595
- mongocrypt_destroy (crypt);
496
+ static void _test_key_broker_wrong_subtype(_mongocrypt_tester_t *tester) {
497
+ mongocrypt_t *crypt;
498
+ mongocrypt_status_t *status;
499
+ _mongocrypt_buffer_t key_id, key_doc;
500
+ _mongocrypt_key_broker_t key_broker;
501
+
502
+ status = mongocrypt_status_new();
503
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
504
+ _gen_uuid_and_key(tester, 1, &key_id, &key_doc);
505
+
506
+ /* Valid key documents. */
507
+ _mongocrypt_key_broker_init(&key_broker, crypt);
508
+ key_id.subtype = 0;
509
+ ASSERT_FAILS(_mongocrypt_key_broker_request_id(&key_broker, &key_id), &key_broker, "expected UUID");
510
+
511
+ _mongocrypt_buffer_cleanup(&key_id);
512
+ _mongocrypt_buffer_cleanup(&key_doc);
513
+ _mongocrypt_key_broker_cleanup(&key_broker);
514
+ mongocrypt_status_destroy(status);
515
+ mongocrypt_destroy(crypt);
596
516
  }
597
517
 
598
-
599
- static void
600
- _test_key_broker_multi_match (_mongocrypt_tester_t *tester)
601
- {
602
- mongocrypt_t *crypt;
603
- mongocrypt_status_t *status;
604
- _mongocrypt_opts_kms_providers_t *kms_providers;
605
- _mongocrypt_key_broker_t key_broker;
606
- status = mongocrypt_status_new ();
607
- _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2;
608
-
609
- _gen_uuid_and_key_and_altname (tester, "alt1", 1, &key_id1, &key_doc1);
610
- _gen_uuid_and_key_and_altname (tester, "alt2", 2, &key_id2, &key_doc2);
611
-
612
-
613
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
614
- kms_providers = &crypt->opts.kms_providers;
615
- _mongocrypt_key_broker_init (&key_broker, crypt);
616
-
617
- /* Add two ids and two alt names */
618
- BSON_ASSERT (_mongocrypt_key_broker_request_id (&key_broker, &key_id1));
619
- _key_broker_add_name (&key_broker, "alt1");
620
- BSON_ASSERT (_mongocrypt_key_broker_request_id (&key_broker, &key_id2));
621
- _key_broker_add_name (&key_broker, "alt2");
622
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&key_broker), &key_broker);
623
-
624
- /* Should be zero satisfied */
625
- BSON_ASSERT (0 == _key_broker_num_satisfied (&key_broker));
626
-
627
- /* Add one doc, should satisfy two requests. */
628
- BSON_ASSERT (
629
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc1));
630
- BSON_ASSERT (2 == _key_broker_num_satisfied (&key_broker));
631
-
632
- /* Add other doc, should satisfy all. */
633
- BSON_ASSERT (
634
- _mongocrypt_key_broker_add_doc (&key_broker, kms_providers, &key_doc2));
635
- BSON_ASSERT (4 == _key_broker_num_satisfied (&key_broker));
636
-
637
- _mongocrypt_buffer_cleanup (&key_id1);
638
- _mongocrypt_buffer_cleanup (&key_doc1);
639
- _mongocrypt_buffer_cleanup (&key_id2);
640
- _mongocrypt_buffer_cleanup (&key_doc2);
641
- _mongocrypt_key_broker_cleanup (&key_broker);
642
- mongocrypt_destroy (crypt);
643
- mongocrypt_status_destroy (status);
518
+ static void _test_key_broker_multi_match(_mongocrypt_tester_t *tester) {
519
+ mongocrypt_t *crypt;
520
+ mongocrypt_status_t *status;
521
+ _mongocrypt_opts_kms_providers_t *kms_providers;
522
+ _mongocrypt_key_broker_t key_broker;
523
+ status = mongocrypt_status_new();
524
+ _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2;
525
+
526
+ _gen_uuid_and_key_and_altname(tester, "alt1", 1, &key_id1, &key_doc1);
527
+ _gen_uuid_and_key_and_altname(tester, "alt2", 2, &key_id2, &key_doc2);
528
+
529
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
530
+ kms_providers = &crypt->opts.kms_providers;
531
+ _mongocrypt_key_broker_init(&key_broker, crypt);
532
+
533
+ /* Add two ids and two alt names */
534
+ BSON_ASSERT(_mongocrypt_key_broker_request_id(&key_broker, &key_id1));
535
+ _key_broker_add_name(&key_broker, "alt1");
536
+ BSON_ASSERT(_mongocrypt_key_broker_request_id(&key_broker, &key_id2));
537
+ _key_broker_add_name(&key_broker, "alt2");
538
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&key_broker), &key_broker);
539
+
540
+ /* Should be zero satisfied */
541
+ BSON_ASSERT(0 == _key_broker_num_satisfied(&key_broker));
542
+
543
+ /* Add one doc, should satisfy two requests. */
544
+ BSON_ASSERT(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc1));
545
+ BSON_ASSERT(2 == _key_broker_num_satisfied(&key_broker));
546
+
547
+ /* Add other doc, should satisfy all. */
548
+ BSON_ASSERT(_mongocrypt_key_broker_add_doc(&key_broker, kms_providers, &key_doc2));
549
+ BSON_ASSERT(4 == _key_broker_num_satisfied(&key_broker));
550
+
551
+ _mongocrypt_buffer_cleanup(&key_id1);
552
+ _mongocrypt_buffer_cleanup(&key_doc1);
553
+ _mongocrypt_buffer_cleanup(&key_id2);
554
+ _mongocrypt_buffer_cleanup(&key_doc2);
555
+ _mongocrypt_key_broker_cleanup(&key_broker);
556
+ mongocrypt_destroy(crypt);
557
+ mongocrypt_status_destroy(status);
644
558
  }
645
559
 
646
-
647
560
  /*
648
561
  <RequestMessage tag="0x420078" type="Structure">
649
562
  <RequestHeader tag="0x420077" type="Structure">
@@ -663,18 +576,14 @@ value="ywxrSj5TLjswd1G4oGFJ6hwWgtTsQip0"/>
663
576
  </RequestMessage>
664
577
  */
665
578
  static const uint8_t EXPECTED_GET_REQUEST[] = {
666
- 0x42, 0x00, 0x78, 0x01, 0x00, 0x00, 0x00, 0x88, 0x42, 0x00, 0x77, 0x01,
667
- 0x00, 0x00, 0x00, 0x38, 0x42, 0x00, 0x69, 0x01, 0x00, 0x00, 0x00, 0x20,
668
- 0x42, 0x00, 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01,
669
- 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04,
670
- 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x0d, 0x02,
671
- 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
672
- 0x42, 0x00, 0x0f, 0x01, 0x00, 0x00, 0x00, 0x40, 0x42, 0x00, 0x5c, 0x05,
673
- 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, 0x00,
674
- 0x42, 0x00, 0x79, 0x01, 0x00, 0x00, 0x00, 0x28, 0x42, 0x00, 0x94, 0x07,
675
- 0x00, 0x00, 0x00, 0x20, 0x79, 0x77, 0x78, 0x72, 0x53, 0x6a, 0x35, 0x54,
676
- 0x4c, 0x6a, 0x73, 0x77, 0x64, 0x31, 0x47, 0x34, 0x6f, 0x47, 0x46, 0x4a,
677
- 0x36, 0x68, 0x77, 0x57, 0x67, 0x74, 0x54, 0x73, 0x51, 0x69, 0x70, 0x30};
579
+ 0x42, 0x00, 0x78, 0x01, 0x00, 0x00, 0x00, 0x88, 0x42, 0x00, 0x77, 0x01, 0x00, 0x00, 0x00, 0x38, 0x42, 0x00,
580
+ 0x69, 0x01, 0x00, 0x00, 0x00, 0x20, 0x42, 0x00, 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01,
581
+ 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00,
582
+ 0x00, 0x00, 0x42, 0x00, 0x0d, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
583
+ 0x42, 0x00, 0x0f, 0x01, 0x00, 0x00, 0x00, 0x40, 0x42, 0x00, 0x5c, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00,
584
+ 0x00, 0x0a, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x79, 0x01, 0x00, 0x00, 0x00, 0x28, 0x42, 0x00, 0x94, 0x07,
585
+ 0x00, 0x00, 0x00, 0x20, 0x79, 0x77, 0x78, 0x72, 0x53, 0x6a, 0x35, 0x54, 0x4c, 0x6a, 0x73, 0x77, 0x64, 0x31,
586
+ 0x47, 0x34, 0x6f, 0x47, 0x46, 0x4a, 0x36, 0x68, 0x77, 0x57, 0x67, 0x74, 0x54, 0x73, 0x51, 0x69, 0x70, 0x30};
678
587
 
679
588
  /*
680
589
  <ResponseMessage tag="0x42007b" type="Structure">
@@ -708,109 +617,89 @@ value="0c2ea7297180f82a984b2fd47d6327ce226f62e9017b91dc6e5d6dfd98747d97e89f17bf0
708
617
  </ResponseMessage>
709
618
  */
710
619
  static const uint8_t SUCCESS_GET_RESPONSE[] = {
711
- 0x42, 0x00, 0x7b, 0x01, 0x00, 0x00, 0x01, 0x58, 0x42, 0x00, 0x7a, 0x01, 0x00,
712
- 0x00, 0x00, 0x48, 0x42, 0x00, 0x69, 0x01, 0x00, 0x00, 0x00, 0x20, 0x42, 0x00,
713
- 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
714
- 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04,
715
- 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x92, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00,
716
- 0x00, 0x00, 0x00, 0x61, 0x59, 0xea, 0xe8, 0x42, 0x00, 0x0d, 0x02, 0x00, 0x00,
717
- 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x0f,
718
- 0x01, 0x00, 0x00, 0x01, 0x00, 0x42, 0x00, 0x5c, 0x05, 0x00, 0x00, 0x00, 0x04,
719
- 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x7f, 0x05, 0x00,
720
- 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00,
721
- 0x7c, 0x01, 0x00, 0x00, 0x00, 0xd8, 0x42, 0x00, 0x57, 0x05, 0x00, 0x00, 0x00,
722
- 0x04, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x94, 0x07,
723
- 0x00, 0x00, 0x00, 0x20, 0x79, 0x77, 0x78, 0x72, 0x53, 0x6a, 0x35, 0x54, 0x4c,
724
- 0x6a, 0x73, 0x77, 0x64, 0x31, 0x47, 0x34, 0x6f, 0x47, 0x46, 0x4a, 0x36, 0x68,
725
- 0x77, 0x57, 0x67, 0x74, 0x54, 0x73, 0x51, 0x69, 0x70, 0x30, 0x42, 0x00, 0x85,
726
- 0x01, 0x00, 0x00, 0x00, 0x98, 0x42, 0x00, 0x86, 0x05, 0x00, 0x00, 0x00, 0x04,
727
- 0x00, 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x40, 0x01, 0x00,
728
- 0x00, 0x00, 0x80, 0x42, 0x00, 0x42, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00,
729
- 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x45, 0x01, 0x00, 0x00, 0x00,
730
- 0x68, 0x42, 0x00, 0x43, 0x08, 0x00, 0x00, 0x00, 0x60, 0x0c, 0x2e, 0xa7, 0x29,
731
- 0x71, 0x80, 0xf8, 0x2a, 0x98, 0x4b, 0x2f, 0xd4, 0x7d, 0x63, 0x27, 0xce, 0x22,
732
- 0x6f, 0x62, 0xe9, 0x01, 0x7b, 0x91, 0xdc, 0x6e, 0x5d, 0x6d, 0xfd, 0x98, 0x74,
733
- 0x7d, 0x97, 0xe8, 0x9f, 0x17, 0xbf, 0x09, 0x26, 0xcf, 0xcc, 0x0a, 0xfb, 0x24,
734
- 0xe6, 0x9b, 0x7c, 0x00, 0x12, 0x1d, 0xda, 0x12, 0xd0, 0x15, 0x8c, 0x43, 0x75,
735
- 0xc3, 0x10, 0x84, 0xab, 0xf7, 0xf2, 0xe6, 0x04, 0x4e, 0xdc, 0x2f, 0x92, 0x80,
736
- 0x2b, 0xa3, 0xf6, 0x76, 0xd4, 0x70, 0xd2, 0xcb, 0xc4, 0xe3, 0x3a, 0x2a, 0x8e,
737
- 0x53, 0xdc, 0xed, 0x78, 0x28, 0xdd, 0x8a, 0x35, 0xf2, 0x68, 0x43, 0x7f, 0xf1,
738
- 0x41};
620
+ 0x42, 0x00, 0x7b, 0x01, 0x00, 0x00, 0x01, 0x58, 0x42, 0x00, 0x7a, 0x01, 0x00, 0x00, 0x00, 0x48, 0x42, 0x00, 0x69,
621
+ 0x01, 0x00, 0x00, 0x00, 0x20, 0x42, 0x00, 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00,
622
+ 0x00, 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x42,
623
+ 0x00, 0x92, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x61, 0x59, 0xea, 0xe8, 0x42, 0x00, 0x0d, 0x02,
624
+ 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x0f, 0x01, 0x00, 0x00, 0x01,
625
+ 0x00, 0x42, 0x00, 0x5c, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00,
626
+ 0x7f, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x7c, 0x01, 0x00,
627
+ 0x00, 0x00, 0xd8, 0x42, 0x00, 0x57, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x07, 0x00, 0x00, 0x00, 0x00,
628
+ 0x42, 0x00, 0x94, 0x07, 0x00, 0x00, 0x00, 0x20, 0x79, 0x77, 0x78, 0x72, 0x53, 0x6a, 0x35, 0x54, 0x4c, 0x6a, 0x73,
629
+ 0x77, 0x64, 0x31, 0x47, 0x34, 0x6f, 0x47, 0x46, 0x4a, 0x36, 0x68, 0x77, 0x57, 0x67, 0x74, 0x54, 0x73, 0x51, 0x69,
630
+ 0x70, 0x30, 0x42, 0x00, 0x85, 0x01, 0x00, 0x00, 0x00, 0x98, 0x42, 0x00, 0x86, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00,
631
+ 0x00, 0x00, 0x02, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x40, 0x01, 0x00, 0x00, 0x00, 0x80, 0x42, 0x00, 0x42, 0x05,
632
+ 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x45, 0x01, 0x00, 0x00, 0x00,
633
+ 0x68, 0x42, 0x00, 0x43, 0x08, 0x00, 0x00, 0x00, 0x60, 0x0c, 0x2e, 0xa7, 0x29, 0x71, 0x80, 0xf8, 0x2a, 0x98, 0x4b,
634
+ 0x2f, 0xd4, 0x7d, 0x63, 0x27, 0xce, 0x22, 0x6f, 0x62, 0xe9, 0x01, 0x7b, 0x91, 0xdc, 0x6e, 0x5d, 0x6d, 0xfd, 0x98,
635
+ 0x74, 0x7d, 0x97, 0xe8, 0x9f, 0x17, 0xbf, 0x09, 0x26, 0xcf, 0xcc, 0x0a, 0xfb, 0x24, 0xe6, 0x9b, 0x7c, 0x00, 0x12,
636
+ 0x1d, 0xda, 0x12, 0xd0, 0x15, 0x8c, 0x43, 0x75, 0xc3, 0x10, 0x84, 0xab, 0xf7, 0xf2, 0xe6, 0x04, 0x4e, 0xdc, 0x2f,
637
+ 0x92, 0x80, 0x2b, 0xa3, 0xf6, 0x76, 0xd4, 0x70, 0xd2, 0xcb, 0xc4, 0xe3, 0x3a, 0x2a, 0x8e, 0x53, 0xdc, 0xed, 0x78,
638
+ 0x28, 0xdd, 0x8a, 0x35, 0xf2, 0x68, 0x43, 0x7f, 0xf1, 0x41};
739
639
 
740
640
  static const uint8_t EXPECTED_SECRETDATA[] = {
741
- 0x94, 0x82, 0x4f, 0x44, 0xbe, 0xb2, 0x20, 0x73, 0x14, 0xad, 0x8b, 0x36,
742
- 0x38, 0xaf, 0x01, 0x45, 0xa5, 0x13, 0x80, 0x84, 0x44, 0x57, 0xdf, 0xde,
743
- 0x9f, 0xb6, 0x7b, 0xfb, 0xf9, 0x21, 0xf9, 0x00, 0xb2, 0x00, 0x9e, 0x07,
744
- 0xcf, 0x04, 0xc3, 0x5b, 0x9a, 0x98, 0x3b, 0xa9, 0x22, 0x83, 0x3d, 0x7a,
745
- 0x07, 0xc5, 0x90, 0x84, 0xe7, 0x63, 0xf0, 0x47, 0xf0, 0x1a, 0x4b, 0xfe,
746
- 0x03, 0xbc, 0xe3, 0x82, 0x96, 0x95, 0x88, 0xb8, 0x18, 0x63, 0x33, 0x15,
747
- 0x73, 0x95, 0xe2, 0xb1, 0x38, 0xde, 0x6c, 0x13, 0xf8, 0x98, 0x43, 0xbe,
748
- 0x3f, 0x85, 0x83, 0xd0, 0x11, 0x88, 0xb8, 0x0f, 0xb5, 0x8c, 0x2a, 0x1c};
749
-
750
- static void
751
- _test_key_broker_kmip (_mongocrypt_tester_t *tester)
752
- {
753
- mongocrypt_t *crypt;
754
- mongocrypt_status_t *status;
755
- _mongocrypt_key_broker_t kb;
756
- bson_t keydoc_bson;
757
- bson_iter_t iter;
758
- _mongocrypt_buffer_t id;
759
- _mongocrypt_buffer_t keydoc;
760
- mongocrypt_kms_ctx_t *kms;
761
- mongocrypt_binary_t *msg;
762
- _mongocrypt_opts_kms_providers_t *kms_providers;
763
- _mongocrypt_buffer_t secretdata;
764
-
765
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
766
- status = mongocrypt_status_new ();
767
- kms_providers = &crypt->opts.kms_providers;
768
- _mongocrypt_key_broker_init (&kb, crypt);
769
- _load_json_as_bson ("./test/data/key-document-kmip.json", &keydoc_bson);
770
-
771
- ASSERT_OR_PRINT_MSG (bson_iter_init_find (&iter, &keydoc_bson, "_id"),
641
+ 0x94, 0x82, 0x4f, 0x44, 0xbe, 0xb2, 0x20, 0x73, 0x14, 0xad, 0x8b, 0x36, 0x38, 0xaf, 0x01, 0x45,
642
+ 0xa5, 0x13, 0x80, 0x84, 0x44, 0x57, 0xdf, 0xde, 0x9f, 0xb6, 0x7b, 0xfb, 0xf9, 0x21, 0xf9, 0x00,
643
+ 0xb2, 0x00, 0x9e, 0x07, 0xcf, 0x04, 0xc3, 0x5b, 0x9a, 0x98, 0x3b, 0xa9, 0x22, 0x83, 0x3d, 0x7a,
644
+ 0x07, 0xc5, 0x90, 0x84, 0xe7, 0x63, 0xf0, 0x47, 0xf0, 0x1a, 0x4b, 0xfe, 0x03, 0xbc, 0xe3, 0x82,
645
+ 0x96, 0x95, 0x88, 0xb8, 0x18, 0x63, 0x33, 0x15, 0x73, 0x95, 0xe2, 0xb1, 0x38, 0xde, 0x6c, 0x13,
646
+ 0xf8, 0x98, 0x43, 0xbe, 0x3f, 0x85, 0x83, 0xd0, 0x11, 0x88, 0xb8, 0x0f, 0xb5, 0x8c, 0x2a, 0x1c};
647
+
648
+ static void _test_key_broker_kmip(_mongocrypt_tester_t *tester) {
649
+ mongocrypt_t *crypt;
650
+ mongocrypt_status_t *status;
651
+ _mongocrypt_key_broker_t kb;
652
+ bson_t keydoc_bson;
653
+ bson_iter_t iter;
654
+ _mongocrypt_buffer_t id;
655
+ _mongocrypt_buffer_t keydoc;
656
+ mongocrypt_kms_ctx_t *kms;
657
+ mongocrypt_binary_t *msg;
658
+ _mongocrypt_opts_kms_providers_t *kms_providers;
659
+ _mongocrypt_buffer_t secretdata;
660
+
661
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
662
+ status = mongocrypt_status_new();
663
+ kms_providers = &crypt->opts.kms_providers;
664
+ _mongocrypt_key_broker_init(&kb, crypt);
665
+ _load_json_as_bson("./test/data/key-document-kmip.json", &keydoc_bson);
666
+
667
+ ASSERT_OR_PRINT_MSG(bson_iter_init_find(&iter, &keydoc_bson, "_id"),
772
668
  "could not find _id in key-document-kmip.json");
773
- BSON_ASSERT (_mongocrypt_buffer_from_binary_iter (&id, &iter));
774
- ASSERT_OK (_mongocrypt_key_broker_request_id (&kb, &id), &kb);
775
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&kb), &kb);
776
-
777
- /* Add the key document. */
778
- _mongocrypt_buffer_from_bson (&keydoc, &keydoc_bson);
779
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &keydoc),
780
- &kb);
781
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
782
-
783
- /* There should be exactly one KMS request for KMIP. */
784
- kms = _mongocrypt_key_broker_next_kms (&kb);
785
- ASSERT_OR_PRINT_MSG (kms, "expected KMS context returned, got none");
786
-
787
- msg = mongocrypt_binary_new ();
788
- mongocrypt_kms_ctx_message (kms, msg);
789
- ASSERT_CMPBYTES (EXPECTED_GET_REQUEST,
790
- sizeof (EXPECTED_GET_REQUEST),
791
- mongocrypt_binary_data (msg),
792
- mongocrypt_binary_len (msg));
793
-
794
- ASSERT_OK (kms_ctx_feed_all (
795
- kms, SUCCESS_GET_RESPONSE, sizeof (SUCCESS_GET_RESPONSE)),
796
- kms);
797
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&kb, kms_providers), &kb);
798
-
799
- BSON_ASSERT (
800
- _mongocrypt_key_broker_decrypted_key_by_id (&kb, &id, &secretdata));
801
- ASSERT_CMPBYTES (secretdata.data,
802
- secretdata.len,
803
- EXPECTED_SECRETDATA,
804
- sizeof (EXPECTED_SECRETDATA));
805
-
806
- _mongocrypt_buffer_cleanup (&secretdata);
807
- mongocrypt_binary_destroy (msg);
808
- _mongocrypt_buffer_cleanup (&keydoc);
809
- _mongocrypt_buffer_cleanup (&id);
810
- bson_destroy (&keydoc_bson);
811
- _mongocrypt_key_broker_cleanup (&kb);
812
- mongocrypt_status_destroy (status);
813
- mongocrypt_destroy (crypt);
669
+ BSON_ASSERT(_mongocrypt_buffer_from_binary_iter(&id, &iter));
670
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&kb, &id), &kb);
671
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&kb), &kb);
672
+
673
+ /* Add the key document. */
674
+ _mongocrypt_buffer_from_bson(&keydoc, &keydoc_bson);
675
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &keydoc), &kb);
676
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
677
+
678
+ /* There should be exactly one KMS request for KMIP. */
679
+ kms = _mongocrypt_key_broker_next_kms(&kb);
680
+ ASSERT_OR_PRINT_MSG(kms, "expected KMS context returned, got none");
681
+
682
+ msg = mongocrypt_binary_new();
683
+ mongocrypt_kms_ctx_message(kms, msg);
684
+ ASSERT_CMPBYTES(EXPECTED_GET_REQUEST,
685
+ sizeof(EXPECTED_GET_REQUEST),
686
+ mongocrypt_binary_data(msg),
687
+ mongocrypt_binary_len(msg));
688
+
689
+ ASSERT_OK(kms_ctx_feed_all(kms, SUCCESS_GET_RESPONSE, sizeof(SUCCESS_GET_RESPONSE)), kms);
690
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&kb, kms_providers), &kb);
691
+
692
+ BSON_ASSERT(_mongocrypt_key_broker_decrypted_key_by_id(&kb, &id, &secretdata));
693
+ ASSERT_CMPBYTES(secretdata.data, secretdata.len, EXPECTED_SECRETDATA, sizeof(EXPECTED_SECRETDATA));
694
+
695
+ _mongocrypt_buffer_cleanup(&secretdata);
696
+ mongocrypt_binary_destroy(msg);
697
+ _mongocrypt_buffer_cleanup(&keydoc);
698
+ _mongocrypt_buffer_cleanup(&id);
699
+ bson_destroy(&keydoc_bson);
700
+ _mongocrypt_key_broker_cleanup(&kb);
701
+ mongocrypt_status_destroy(status);
702
+ mongocrypt_destroy(crypt);
814
703
  }
815
704
 
816
705
  /*
@@ -833,342 +722,303 @@ value="ResultReasonItemNotFound"/>
833
722
  </ResponseMessage>
834
723
  */
835
724
  static const uint8_t ERROR_GET_RESPOSE_NOTFOUND[] = {
836
- 0x42, 0x00, 0x7b, 0x01, 0x00, 0x00, 0x00, 0xa8, 0x42, 0x00, 0x7a, 0x01, 0x00,
837
- 0x00, 0x00, 0x48, 0x42, 0x00, 0x69, 0x01, 0x00, 0x00, 0x00, 0x20, 0x42, 0x00,
838
- 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
839
- 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04,
840
- 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x92, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00,
841
- 0x00, 0x00, 0x00, 0x61, 0x57, 0x1e, 0x81, 0x42, 0x00, 0x0d, 0x02, 0x00, 0x00,
842
- 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x0f,
843
- 0x01, 0x00, 0x00, 0x00, 0x50, 0x42, 0x00, 0x5c, 0x05, 0x00, 0x00, 0x00, 0x04,
844
- 0x00, 0x00, 0x00, 0x0a, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x7f, 0x05, 0x00,
845
- 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00,
846
- 0x7e, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00,
847
- 0x00, 0x42, 0x00, 0x7d, 0x07, 0x00, 0x00, 0x00, 0x18, 0x52, 0x65, 0x73, 0x75,
848
- 0x6c, 0x74, 0x52, 0x65, 0x61, 0x73, 0x6f, 0x6e, 0x49, 0x74, 0x65, 0x6d, 0x4e,
849
- 0x6f, 0x74, 0x46, 0x6f, 0x75, 0x6e, 0x64};
850
-
851
- static void
852
- _test_key_broker_kmip_notfound (_mongocrypt_tester_t *tester)
853
- {
854
- mongocrypt_t *crypt;
855
- mongocrypt_status_t *status;
856
- _mongocrypt_key_broker_t kb;
857
- bson_t keydoc_bson;
858
- bson_iter_t iter;
859
- _mongocrypt_buffer_t id;
860
- _mongocrypt_buffer_t keydoc;
861
- mongocrypt_kms_ctx_t *kms;
862
- _mongocrypt_opts_kms_providers_t *kms_providers;
863
- mongocrypt_binary_t *msg;
864
-
865
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
866
- status = mongocrypt_status_new ();
867
- kms_providers = &crypt->opts.kms_providers;
868
- _mongocrypt_key_broker_init (&kb, crypt);
869
- _load_json_as_bson ("./test/data/key-document-kmip.json", &keydoc_bson);
870
-
871
- ASSERT_OR_PRINT_MSG (bson_iter_init_find (&iter, &keydoc_bson, "_id"),
725
+ 0x42, 0x00, 0x7b, 0x01, 0x00, 0x00, 0x00, 0xa8, 0x42, 0x00, 0x7a, 0x01, 0x00, 0x00, 0x00, 0x48, 0x42, 0x00,
726
+ 0x69, 0x01, 0x00, 0x00, 0x00, 0x20, 0x42, 0x00, 0x6a, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01,
727
+ 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x6b, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00,
728
+ 0x00, 0x00, 0x42, 0x00, 0x92, 0x09, 0x00, 0x00, 0x00, 0x08, 0x00, 0x00, 0x00, 0x00, 0x61, 0x57, 0x1e, 0x81,
729
+ 0x42, 0x00, 0x0d, 0x02, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00, 0x42, 0x00,
730
+ 0x0f, 0x01, 0x00, 0x00, 0x00, 0x50, 0x42, 0x00, 0x5c, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x0a,
731
+ 0x00, 0x00, 0x00, 0x00, 0x42, 0x00, 0x7f, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00,
732
+ 0x00, 0x00, 0x42, 0x00, 0x7e, 0x05, 0x00, 0x00, 0x00, 0x04, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x00,
733
+ 0x42, 0x00, 0x7d, 0x07, 0x00, 0x00, 0x00, 0x18, 0x52, 0x65, 0x73, 0x75, 0x6c, 0x74, 0x52, 0x65, 0x61, 0x73,
734
+ 0x6f, 0x6e, 0x49, 0x74, 0x65, 0x6d, 0x4e, 0x6f, 0x74, 0x46, 0x6f, 0x75, 0x6e, 0x64};
735
+
736
+ static void _test_key_broker_kmip_notfound(_mongocrypt_tester_t *tester) {
737
+ mongocrypt_t *crypt;
738
+ mongocrypt_status_t *status;
739
+ _mongocrypt_key_broker_t kb;
740
+ bson_t keydoc_bson;
741
+ bson_iter_t iter;
742
+ _mongocrypt_buffer_t id;
743
+ _mongocrypt_buffer_t keydoc;
744
+ mongocrypt_kms_ctx_t *kms;
745
+ _mongocrypt_opts_kms_providers_t *kms_providers;
746
+ mongocrypt_binary_t *msg;
747
+
748
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
749
+ status = mongocrypt_status_new();
750
+ kms_providers = &crypt->opts.kms_providers;
751
+ _mongocrypt_key_broker_init(&kb, crypt);
752
+ _load_json_as_bson("./test/data/key-document-kmip.json", &keydoc_bson);
753
+
754
+ ASSERT_OR_PRINT_MSG(bson_iter_init_find(&iter, &keydoc_bson, "_id"),
872
755
  "could not find _id in key-document-kmip.json");
873
- BSON_ASSERT (_mongocrypt_buffer_from_binary_iter (&id, &iter));
874
- ASSERT_OK (_mongocrypt_key_broker_request_id (&kb, &id), &kb);
875
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&kb), &kb);
876
-
877
- /* Add the key document. */
878
- _mongocrypt_buffer_from_bson (&keydoc, &keydoc_bson);
879
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &keydoc),
880
- &kb);
881
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
882
-
883
- /* There should be exactly one KMS request for KMIP. */
884
- kms = _mongocrypt_key_broker_next_kms (&kb);
885
- ASSERT_OR_PRINT_MSG (kms, "expected KMS context returned, got none");
886
-
887
- msg = mongocrypt_binary_new ();
888
- mongocrypt_kms_ctx_message (kms, msg);
889
- ASSERT_CMPBYTES (EXPECTED_GET_REQUEST,
890
- sizeof (EXPECTED_GET_REQUEST),
891
- mongocrypt_binary_data (msg),
892
- mongocrypt_binary_len (msg));
893
-
894
- ASSERT_FAILS (kms_ctx_feed_all (kms,
895
- ERROR_GET_RESPOSE_NOTFOUND,
896
- sizeof (ERROR_GET_RESPOSE_NOTFOUND)),
756
+ BSON_ASSERT(_mongocrypt_buffer_from_binary_iter(&id, &iter));
757
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&kb, &id), &kb);
758
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&kb), &kb);
759
+
760
+ /* Add the key document. */
761
+ _mongocrypt_buffer_from_bson(&keydoc, &keydoc_bson);
762
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &keydoc), &kb);
763
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
764
+
765
+ /* There should be exactly one KMS request for KMIP. */
766
+ kms = _mongocrypt_key_broker_next_kms(&kb);
767
+ ASSERT_OR_PRINT_MSG(kms, "expected KMS context returned, got none");
768
+
769
+ msg = mongocrypt_binary_new();
770
+ mongocrypt_kms_ctx_message(kms, msg);
771
+ ASSERT_CMPBYTES(EXPECTED_GET_REQUEST,
772
+ sizeof(EXPECTED_GET_REQUEST),
773
+ mongocrypt_binary_data(msg),
774
+ mongocrypt_binary_len(msg));
775
+
776
+ ASSERT_FAILS(kms_ctx_feed_all(kms, ERROR_GET_RESPOSE_NOTFOUND, sizeof(ERROR_GET_RESPOSE_NOTFOUND)),
897
777
  kms,
898
778
  "ResultReasonItemNotFound");
899
779
 
900
- mongocrypt_binary_destroy (msg);
901
- _mongocrypt_buffer_cleanup (&keydoc);
902
- _mongocrypt_buffer_cleanup (&id);
903
- bson_destroy (&keydoc_bson);
904
- _mongocrypt_key_broker_cleanup (&kb);
905
- mongocrypt_status_destroy (status);
906
- mongocrypt_destroy (crypt);
780
+ mongocrypt_binary_destroy(msg);
781
+ _mongocrypt_buffer_cleanup(&keydoc);
782
+ _mongocrypt_buffer_cleanup(&id);
783
+ bson_destroy(&keydoc_bson);
784
+ _mongocrypt_key_broker_cleanup(&kb);
785
+ mongocrypt_status_destroy(status);
786
+ mongocrypt_destroy(crypt);
907
787
  }
908
788
 
789
+ static void _test_key_broker_request_any(_mongocrypt_tester_t *tester) {
790
+ mongocrypt_t *const crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
791
+ _mongocrypt_key_broker_t kb;
909
792
 
910
- static void
911
- _test_key_broker_request_any (_mongocrypt_tester_t *tester)
912
- {
913
- mongocrypt_t *const crypt =
914
- _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
915
- _mongocrypt_key_broker_t kb;
793
+ /* Can switch to any mode before any keys are requested. */
794
+ _mongocrypt_key_broker_init(&kb, crypt);
795
+ ASSERT_OK(_mongocrypt_key_broker_request_any(&kb), &kb);
796
+ _mongocrypt_key_broker_cleanup(&kb);
916
797
 
917
- /* Can switch to any mode before any keys are requested. */
918
- _mongocrypt_key_broker_init (&kb, crypt);
919
- ASSERT_OK (_mongocrypt_key_broker_request_any (&kb), &kb);
920
- _mongocrypt_key_broker_cleanup (&kb);
921
-
922
- /* If keys have already been requested, cannot switch to any mode.*/
923
- _mongocrypt_key_broker_init (&kb, crypt);
924
- _key_broker_add_name (&kb, "test");
925
- ASSERT_FAILS (_mongocrypt_key_broker_request_any (&kb),
798
+ /* If keys have already been requested, cannot switch to any mode.*/
799
+ _mongocrypt_key_broker_init(&kb, crypt);
800
+ _key_broker_add_name(&kb, "test");
801
+ ASSERT_FAILS(_mongocrypt_key_broker_request_any(&kb),
926
802
  &kb,
927
803
  "attempting to request any keys, but requests already made");
928
- _mongocrypt_key_broker_cleanup (&kb);
804
+ _mongocrypt_key_broker_cleanup(&kb);
929
805
 
930
- mongocrypt_destroy (crypt);
806
+ mongocrypt_destroy(crypt);
931
807
  }
932
808
 
933
-
934
- static void
935
- _test_key_broker_add_any (_mongocrypt_tester_t *tester)
936
- {
937
- mongocrypt_t *const crypt =
938
- _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
939
- _mongocrypt_opts_kms_providers_t *const kms_providers =
940
- &crypt->opts.kms_providers;
941
- _mongocrypt_key_broker_t kb;
942
- _mongocrypt_buffer_t key_id, key_doc;
943
-
944
- _gen_uuid_and_key (tester, 1, &key_id, &key_doc);
945
-
946
- /* Can add valid documents. */
947
- _mongocrypt_key_broker_init (&kb, crypt);
948
- ASSERT_OK (_mongocrypt_key_broker_request_any (&kb), &kb);
949
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc),
950
- &kb);
951
- ASSERT (_key_broker_num_satisfied (&kb) == 1);
952
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
953
- _mongocrypt_key_broker_cleanup (&kb);
954
-
955
- /* Still validates no duplicate/incompatible keys. */
956
- _mongocrypt_key_broker_init (&kb, crypt);
957
- ASSERT_OK (_mongocrypt_key_broker_request_any (&kb), &kb);
958
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc),
959
- &kb);
960
- ASSERT (_key_broker_num_satisfied (&kb) == 1);
961
- ASSERT_FAILS (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc),
809
+ static void _test_key_broker_add_any(_mongocrypt_tester_t *tester) {
810
+ mongocrypt_t *const crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
811
+ _mongocrypt_opts_kms_providers_t *const kms_providers = &crypt->opts.kms_providers;
812
+ _mongocrypt_key_broker_t kb;
813
+ _mongocrypt_buffer_t key_id, key_doc;
814
+
815
+ _gen_uuid_and_key(tester, 1, &key_id, &key_doc);
816
+
817
+ /* Can add valid documents. */
818
+ _mongocrypt_key_broker_init(&kb, crypt);
819
+ ASSERT_OK(_mongocrypt_key_broker_request_any(&kb), &kb);
820
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc), &kb);
821
+ ASSERT(_key_broker_num_satisfied(&kb) == 1);
822
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
823
+ _mongocrypt_key_broker_cleanup(&kb);
824
+
825
+ /* Still validates no duplicate/incompatible keys. */
826
+ _mongocrypt_key_broker_init(&kb, crypt);
827
+ ASSERT_OK(_mongocrypt_key_broker_request_any(&kb), &kb);
828
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc), &kb);
829
+ ASSERT(_key_broker_num_satisfied(&kb) == 1);
830
+ ASSERT_FAILS(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc),
962
831
  &kb,
963
832
  "keys returned have duplicate keyAltNames or _id");
964
- ASSERT (_key_broker_num_satisfied (&kb) == 1);
965
- _mongocrypt_key_broker_cleanup (&kb);
966
-
967
- /* Still requests KMS as needed. */
968
- _mongocrypt_key_broker_init (&kb, crypt);
969
- ASSERT_OK (_mongocrypt_key_broker_request_any (&kb), &kb);
970
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc),
971
- &kb);
972
- ASSERT (_key_broker_num_satisfied (&kb) == 1);
973
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
974
- {
975
- mongocrypt_kms_ctx_t *kms;
976
- kms = _mongocrypt_key_broker_next_kms (&kb);
977
- ASSERT_OK (kms, &kb);
978
- /* Key material should should be cached here. */
979
- _mongocrypt_tester_satisfy_kms (tester, kms);
980
- ASSERT_OK (!_mongocrypt_key_broker_next_kms (&kb), &kb);
981
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&kb, kms_providers), &kb);
982
- }
983
- _mongocrypt_key_broker_cleanup (&kb);
984
- _mongocrypt_key_broker_init (&kb, crypt);
985
- ASSERT_OK (_mongocrypt_key_broker_request_any (&kb), &kb);
986
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc),
987
- &kb);
988
- ASSERT (_key_broker_num_satisfied (&kb) == 1);
989
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
990
- /* Cached key material, should skip straight to done. */
991
- ASSERT (kb.state == KB_DONE);
992
-
993
- _mongocrypt_key_broker_cleanup (&kb);
994
-
995
- _mongocrypt_buffer_cleanup (&key_doc);
996
- _mongocrypt_buffer_cleanup (&key_id);
997
- mongocrypt_destroy (crypt);
833
+ ASSERT(_key_broker_num_satisfied(&kb) == 1);
834
+ _mongocrypt_key_broker_cleanup(&kb);
835
+
836
+ /* Still requests KMS as needed. */
837
+ _mongocrypt_key_broker_init(&kb, crypt);
838
+ ASSERT_OK(_mongocrypt_key_broker_request_any(&kb), &kb);
839
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc), &kb);
840
+ ASSERT(_key_broker_num_satisfied(&kb) == 1);
841
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
842
+ {
843
+ mongocrypt_kms_ctx_t *kms;
844
+ kms = _mongocrypt_key_broker_next_kms(&kb);
845
+ ASSERT_OK(kms, &kb);
846
+ /* Key material should should be cached here. */
847
+ _mongocrypt_tester_satisfy_kms(tester, kms);
848
+ ASSERT_OK(!_mongocrypt_key_broker_next_kms(&kb), &kb);
849
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&kb, kms_providers), &kb);
850
+ }
851
+ _mongocrypt_key_broker_cleanup(&kb);
852
+ _mongocrypt_key_broker_init(&kb, crypt);
853
+ ASSERT_OK(_mongocrypt_key_broker_request_any(&kb), &kb);
854
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc), &kb);
855
+ ASSERT(_key_broker_num_satisfied(&kb) == 1);
856
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
857
+ /* Cached key material, should skip straight to done. */
858
+ ASSERT(kb.state == KB_DONE);
859
+
860
+ _mongocrypt_key_broker_cleanup(&kb);
861
+
862
+ _mongocrypt_buffer_cleanup(&key_doc);
863
+ _mongocrypt_buffer_cleanup(&key_id);
864
+ mongocrypt_destroy(crypt);
998
865
  }
999
866
 
1000
867
  /* assert_filter_requests_id asserts that filter contains exactly one request
1001
868
  * for a key ID of expect. */
1002
- static void
1003
- assert_filter_requests_id (mongocrypt_binary_t *filter,
1004
- const _mongocrypt_buffer_t *expect)
1005
- {
1006
- bson_t filter_bson;
1007
- ASSERT (_mongocrypt_binary_to_bson (filter, &filter_bson));
1008
- bson_iter_t iter;
1009
- ASSERT (bson_iter_init (&iter, &filter_bson));
1010
- ASSERT (bson_iter_find_descendant (&iter, "$or.0._id.$in", &iter));
1011
- ASSERT (bson_iter_recurse (&iter, &iter));
1012
- ASSERT (bson_iter_next (&iter));
1013
- ASSERT (BSON_ITER_HOLDS_BINARY (&iter));
1014
-
1015
- _mongocrypt_buffer_t actual;
1016
- ASSERT (_mongocrypt_buffer_from_binary_iter (&actual, &iter));
1017
- ASSERT_CMPBUF (*expect, actual);
1018
-
1019
- /* Check that there are no additional _id's requested. */
1020
- ASSERT (!bson_iter_next (&iter));
1021
-
1022
- /* Check that there are no keyAltName requests. */
1023
- ASSERT (bson_iter_init (&iter, &filter_bson));
1024
- ASSERT (bson_iter_find_descendant (&iter, "$or.1.keyAltNames.$in", &iter));
1025
- ASSERT (bson_iter_recurse (&iter, &iter));
1026
- ASSERT (!bson_iter_next (&iter));
869
+ static void assert_filter_requests_id(mongocrypt_binary_t *filter, const _mongocrypt_buffer_t *expect) {
870
+ bson_t filter_bson;
871
+ ASSERT(_mongocrypt_binary_to_bson(filter, &filter_bson));
872
+ bson_iter_t iter;
873
+ ASSERT(bson_iter_init(&iter, &filter_bson));
874
+ ASSERT(bson_iter_find_descendant(&iter, "$or.0._id.$in", &iter));
875
+ ASSERT(bson_iter_recurse(&iter, &iter));
876
+ ASSERT(bson_iter_next(&iter));
877
+ ASSERT(BSON_ITER_HOLDS_BINARY(&iter));
878
+
879
+ _mongocrypt_buffer_t actual;
880
+ ASSERT(_mongocrypt_buffer_from_binary_iter(&actual, &iter));
881
+ ASSERT_CMPBUF(*expect, actual);
882
+
883
+ /* Check that there are no additional _id's requested. */
884
+ ASSERT(!bson_iter_next(&iter));
885
+
886
+ /* Check that there are no keyAltName requests. */
887
+ ASSERT(bson_iter_init(&iter, &filter_bson));
888
+ ASSERT(bson_iter_find_descendant(&iter, "$or.1.keyAltNames.$in", &iter));
889
+ ASSERT(bson_iter_recurse(&iter, &iter));
890
+ ASSERT(!bson_iter_next(&iter));
1027
891
  }
1028
892
 
1029
893
  /* Test that key requests can be added again after transitioning to DONE and
1030
894
  * calling _mongocrypt_key_broker_restart. */
1031
- static void
1032
- _test_key_broker_restart (_mongocrypt_tester_t *tester)
1033
- {
1034
- mongocrypt_t *crypt;
1035
- mongocrypt_status_t *status;
1036
- _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2;
1037
- _mongocrypt_key_broker_t kb;
1038
- _mongocrypt_opts_kms_providers_t *kms_providers;
1039
- mongocrypt_kms_ctx_t *kms;
1040
- mongocrypt_binary_t *filter;
1041
-
1042
- status = mongocrypt_status_new ();
1043
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
1044
- kms_providers = &crypt->opts.kms_providers;
1045
- _gen_uuid_and_key (tester, 1, &key_id1, &key_doc1);
1046
- _gen_uuid_and_key (tester, 2, &key_id2, &key_doc2);
1047
- _mongocrypt_key_broker_init (&kb, crypt);
1048
-
1049
- ASSERT (kb.state == KB_REQUESTING);
1050
- ASSERT_OK (_mongocrypt_key_broker_request_id (&kb, &key_id1), &kb);
1051
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&kb), &kb);
1052
-
1053
- filter = mongocrypt_binary_new ();
1054
- ASSERT_OK (_mongocrypt_key_broker_filter (&kb, filter), &kb);
1055
- assert_filter_requests_id (filter, &key_id1);
1056
- mongocrypt_binary_destroy (filter);
1057
-
1058
- ASSERT (kb.state == KB_ADDING_DOCS);
1059
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc1),
1060
- &kb);
1061
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
1062
-
1063
- ASSERT (kb.state == KB_DECRYPTING_KEY_MATERIAL);
1064
- kms = _mongocrypt_key_broker_next_kms (&kb);
1065
- ASSERT (kms);
1066
- _mongocrypt_tester_satisfy_kms (tester, kms);
1067
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&kb, kms_providers), &kb);
1068
-
1069
- /* Restart, and add request for key_id2. */
1070
- ASSERT (kb.state == KB_DONE);
1071
- ASSERT_OK (_mongocrypt_key_broker_restart (&kb), &kb);
1072
-
1073
- ASSERT (kb.state == KB_REQUESTING);
1074
- ASSERT_OK (_mongocrypt_key_broker_request_id (&kb, &key_id2), &kb);
1075
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&kb), &kb);
1076
-
1077
- filter = mongocrypt_binary_new ();
1078
- ASSERT_OK (_mongocrypt_key_broker_filter (&kb, filter), &kb);
1079
- assert_filter_requests_id (filter, &key_id2);
1080
- mongocrypt_binary_destroy (filter);
1081
-
1082
- ASSERT (kb.state == KB_ADDING_DOCS);
1083
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc2),
1084
- &kb);
1085
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
1086
-
1087
- ASSERT (kb.state == KB_DECRYPTING_KEY_MATERIAL);
1088
- kms = _mongocrypt_key_broker_next_kms (&kb);
1089
- ASSERT (kms);
1090
- _mongocrypt_tester_satisfy_kms (tester, kms);
1091
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&kb, kms_providers), &kb);
1092
- ASSERT (kb.state == KB_DONE);
1093
-
1094
- _mongocrypt_key_broker_cleanup (&kb);
1095
- _mongocrypt_buffer_cleanup (&key_doc2);
1096
- _mongocrypt_buffer_cleanup (&key_id2);
1097
- _mongocrypt_buffer_cleanup (&key_doc1);
1098
- _mongocrypt_buffer_cleanup (&key_id1);
1099
- mongocrypt_destroy (crypt);
1100
- mongocrypt_status_destroy (status);
895
+ static void _test_key_broker_restart(_mongocrypt_tester_t *tester) {
896
+ mongocrypt_t *crypt;
897
+ mongocrypt_status_t *status;
898
+ _mongocrypt_buffer_t key_id1, key_id2, key_doc1, key_doc2;
899
+ _mongocrypt_key_broker_t kb;
900
+ _mongocrypt_opts_kms_providers_t *kms_providers;
901
+ mongocrypt_kms_ctx_t *kms;
902
+ mongocrypt_binary_t *filter;
903
+
904
+ status = mongocrypt_status_new();
905
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
906
+ kms_providers = &crypt->opts.kms_providers;
907
+ _gen_uuid_and_key(tester, 1, &key_id1, &key_doc1);
908
+ _gen_uuid_and_key(tester, 2, &key_id2, &key_doc2);
909
+ _mongocrypt_key_broker_init(&kb, crypt);
910
+
911
+ ASSERT(kb.state == KB_REQUESTING);
912
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&kb, &key_id1), &kb);
913
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&kb), &kb);
914
+
915
+ filter = mongocrypt_binary_new();
916
+ ASSERT_OK(_mongocrypt_key_broker_filter(&kb, filter), &kb);
917
+ assert_filter_requests_id(filter, &key_id1);
918
+ mongocrypt_binary_destroy(filter);
919
+
920
+ ASSERT(kb.state == KB_ADDING_DOCS);
921
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc1), &kb);
922
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
923
+
924
+ ASSERT(kb.state == KB_DECRYPTING_KEY_MATERIAL);
925
+ kms = _mongocrypt_key_broker_next_kms(&kb);
926
+ ASSERT(kms);
927
+ _mongocrypt_tester_satisfy_kms(tester, kms);
928
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&kb, kms_providers), &kb);
929
+
930
+ /* Restart, and add request for key_id2. */
931
+ ASSERT(kb.state == KB_DONE);
932
+ ASSERT_OK(_mongocrypt_key_broker_restart(&kb), &kb);
933
+
934
+ ASSERT(kb.state == KB_REQUESTING);
935
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&kb, &key_id2), &kb);
936
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&kb), &kb);
937
+
938
+ filter = mongocrypt_binary_new();
939
+ ASSERT_OK(_mongocrypt_key_broker_filter(&kb, filter), &kb);
940
+ assert_filter_requests_id(filter, &key_id2);
941
+ mongocrypt_binary_destroy(filter);
942
+
943
+ ASSERT(kb.state == KB_ADDING_DOCS);
944
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc2), &kb);
945
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
946
+
947
+ ASSERT(kb.state == KB_DECRYPTING_KEY_MATERIAL);
948
+ kms = _mongocrypt_key_broker_next_kms(&kb);
949
+ ASSERT(kms);
950
+ _mongocrypt_tester_satisfy_kms(tester, kms);
951
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&kb, kms_providers), &kb);
952
+ ASSERT(kb.state == KB_DONE);
953
+
954
+ _mongocrypt_key_broker_cleanup(&kb);
955
+ _mongocrypt_buffer_cleanup(&key_doc2);
956
+ _mongocrypt_buffer_cleanup(&key_id2);
957
+ _mongocrypt_buffer_cleanup(&key_doc1);
958
+ _mongocrypt_buffer_cleanup(&key_id1);
959
+ mongocrypt_destroy(crypt);
960
+ mongocrypt_status_destroy(status);
1101
961
  }
1102
962
 
1103
963
  /* Test that a decrypted key can be returned while in the KB_REQUESTING state.
1104
964
  */
1105
- static void
1106
- _test_key_broker_get_decrypted_key_while_requesting (
1107
- _mongocrypt_tester_t *tester)
1108
- {
1109
- mongocrypt_t *crypt;
1110
- mongocrypt_status_t *status;
1111
- _mongocrypt_buffer_t key_id1, key_doc1, key_decrypted1, key_decrypted1_copy;
1112
- _mongocrypt_key_broker_t kb;
1113
- _mongocrypt_opts_kms_providers_t *kms_providers;
1114
- mongocrypt_kms_ctx_t *kms;
1115
-
1116
- status = mongocrypt_status_new ();
1117
- crypt = _mongocrypt_tester_mongocrypt (TESTER_MONGOCRYPT_DEFAULT);
1118
- kms_providers = &crypt->opts.kms_providers;
1119
- _gen_uuid_and_key (tester, 1, &key_id1, &key_doc1);
1120
- _mongocrypt_key_broker_init (&kb, crypt);
1121
-
1122
- ASSERT (kb.state == KB_REQUESTING);
1123
- ASSERT_OK (_mongocrypt_key_broker_request_id (&kb, &key_id1), &kb);
1124
- ASSERT_OK (_mongocrypt_key_broker_requests_done (&kb), &kb);
1125
-
1126
- ASSERT (kb.state == KB_ADDING_DOCS);
1127
- ASSERT_OK (_mongocrypt_key_broker_add_doc (&kb, kms_providers, &key_doc1),
1128
- &kb);
1129
- ASSERT_OK (_mongocrypt_key_broker_docs_done (&kb), &kb);
1130
-
1131
- ASSERT (kb.state == KB_DECRYPTING_KEY_MATERIAL);
1132
- kms = _mongocrypt_key_broker_next_kms (&kb);
1133
- ASSERT (kms);
1134
- _mongocrypt_tester_satisfy_kms (tester, kms);
1135
- ASSERT_OK (_mongocrypt_key_broker_kms_done (&kb, kms_providers), &kb);
1136
-
1137
- ASSERT (kb.state == KB_DONE);
1138
- ASSERT_OK (_mongocrypt_key_broker_decrypted_key_by_id (
1139
- &kb, &key_id1, &key_decrypted1),
1140
- &kb);
1141
-
1142
- /* Restart. */
1143
- ASSERT_OK (_mongocrypt_key_broker_restart (&kb), &kb);
1144
- ASSERT (kb.state == KB_REQUESTING);
1145
- ASSERT_OK (_mongocrypt_key_broker_decrypted_key_by_id (
1146
- &kb, &key_id1, &key_decrypted1_copy),
1147
- &kb);
1148
-
1149
- ASSERT_CMPBUF (key_decrypted1, key_decrypted1_copy);
1150
-
1151
- _mongocrypt_buffer_cleanup (&key_decrypted1_copy);
1152
- _mongocrypt_buffer_cleanup (&key_decrypted1);
1153
- _mongocrypt_key_broker_cleanup (&kb);
1154
- _mongocrypt_buffer_cleanup (&key_doc1);
1155
- _mongocrypt_buffer_cleanup (&key_id1);
1156
- mongocrypt_destroy (crypt);
1157
- mongocrypt_status_destroy (status);
965
+ static void _test_key_broker_get_decrypted_key_while_requesting(_mongocrypt_tester_t *tester) {
966
+ mongocrypt_t *crypt;
967
+ mongocrypt_status_t *status;
968
+ _mongocrypt_buffer_t key_id1, key_doc1, key_decrypted1, key_decrypted1_copy;
969
+ _mongocrypt_key_broker_t kb;
970
+ _mongocrypt_opts_kms_providers_t *kms_providers;
971
+ mongocrypt_kms_ctx_t *kms;
972
+
973
+ status = mongocrypt_status_new();
974
+ crypt = _mongocrypt_tester_mongocrypt(TESTER_MONGOCRYPT_DEFAULT);
975
+ kms_providers = &crypt->opts.kms_providers;
976
+ _gen_uuid_and_key(tester, 1, &key_id1, &key_doc1);
977
+ _mongocrypt_key_broker_init(&kb, crypt);
978
+
979
+ ASSERT(kb.state == KB_REQUESTING);
980
+ ASSERT_OK(_mongocrypt_key_broker_request_id(&kb, &key_id1), &kb);
981
+ ASSERT_OK(_mongocrypt_key_broker_requests_done(&kb), &kb);
982
+
983
+ ASSERT(kb.state == KB_ADDING_DOCS);
984
+ ASSERT_OK(_mongocrypt_key_broker_add_doc(&kb, kms_providers, &key_doc1), &kb);
985
+ ASSERT_OK(_mongocrypt_key_broker_docs_done(&kb), &kb);
986
+
987
+ ASSERT(kb.state == KB_DECRYPTING_KEY_MATERIAL);
988
+ kms = _mongocrypt_key_broker_next_kms(&kb);
989
+ ASSERT(kms);
990
+ _mongocrypt_tester_satisfy_kms(tester, kms);
991
+ ASSERT_OK(_mongocrypt_key_broker_kms_done(&kb, kms_providers), &kb);
992
+
993
+ ASSERT(kb.state == KB_DONE);
994
+ ASSERT_OK(_mongocrypt_key_broker_decrypted_key_by_id(&kb, &key_id1, &key_decrypted1), &kb);
995
+
996
+ /* Restart. */
997
+ ASSERT_OK(_mongocrypt_key_broker_restart(&kb), &kb);
998
+ ASSERT(kb.state == KB_REQUESTING);
999
+ ASSERT_OK(_mongocrypt_key_broker_decrypted_key_by_id(&kb, &key_id1, &key_decrypted1_copy), &kb);
1000
+
1001
+ ASSERT_CMPBUF(key_decrypted1, key_decrypted1_copy);
1002
+
1003
+ _mongocrypt_buffer_cleanup(&key_decrypted1_copy);
1004
+ _mongocrypt_buffer_cleanup(&key_decrypted1);
1005
+ _mongocrypt_key_broker_cleanup(&kb);
1006
+ _mongocrypt_buffer_cleanup(&key_doc1);
1007
+ _mongocrypt_buffer_cleanup(&key_id1);
1008
+ mongocrypt_destroy(crypt);
1009
+ mongocrypt_status_destroy(status);
1158
1010
  }
1159
1011
 
1160
- void
1161
- _mongocrypt_tester_install_key_broker (_mongocrypt_tester_t *tester)
1162
- {
1163
- INSTALL_TEST (_test_key_broker_get_key_filter);
1164
- INSTALL_TEST (_test_key_broker_add_key);
1165
- INSTALL_TEST (_test_key_broker_add_decrypted_key);
1166
- INSTALL_TEST (_test_key_broker_wrong_subtype);
1167
- INSTALL_TEST (_test_key_broker_multi_match);
1168
- INSTALL_TEST (_test_key_broker_kmip);
1169
- INSTALL_TEST (_test_key_broker_kmip_notfound);
1170
- INSTALL_TEST (_test_key_broker_request_any);
1171
- INSTALL_TEST (_test_key_broker_add_any);
1172
- INSTALL_TEST (_test_key_broker_restart);
1173
- INSTALL_TEST (_test_key_broker_get_decrypted_key_while_requesting);
1012
+ void _mongocrypt_tester_install_key_broker(_mongocrypt_tester_t *tester) {
1013
+ INSTALL_TEST(_test_key_broker_get_key_filter);
1014
+ INSTALL_TEST(_test_key_broker_add_key);
1015
+ INSTALL_TEST(_test_key_broker_add_decrypted_key);
1016
+ INSTALL_TEST(_test_key_broker_wrong_subtype);
1017
+ INSTALL_TEST(_test_key_broker_multi_match);
1018
+ INSTALL_TEST(_test_key_broker_kmip);
1019
+ INSTALL_TEST(_test_key_broker_kmip_notfound);
1020
+ INSTALL_TEST(_test_key_broker_request_any);
1021
+ INSTALL_TEST(_test_key_broker_add_any);
1022
+ INSTALL_TEST(_test_key_broker_restart);
1023
+ INSTALL_TEST(_test_key_broker_get_decrypted_key_while_requesting);
1174
1024
  }