couchbase 3.0.0 → 3.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (901) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1 -1
  3. data/ext/CMakeLists.txt +86 -169
  4. data/ext/build_version.hxx.in +3 -2
  5. data/ext/cmake/Backtrace.cmake +35 -0
  6. data/ext/cmake/BuildTracing.cmake +6 -0
  7. data/ext/cmake/Cache.cmake +29 -0
  8. data/ext/cmake/CompilerWarnings.cmake +78 -0
  9. data/ext/cmake/PreventInSourceBuilds.cmake +18 -0
  10. data/ext/cmake/Sanitizers.cmake +66 -0
  11. data/ext/cmake/StandardProjectSettings.cmake +40 -0
  12. data/ext/cmake/StaticAnalyzers.cmake +37 -0
  13. data/ext/cmake/Testing.cmake +52 -0
  14. data/ext/cmake/ThirdPartyDependencies.cmake +20 -0
  15. data/ext/cmake/VersionInfo.cmake +37 -0
  16. data/ext/couchbase/bucket.hxx +37 -12
  17. data/ext/couchbase/capabilities.hxx +117 -0
  18. data/ext/couchbase/cbcrypto/cbcrypto.cc +15 -15
  19. data/ext/couchbase/cluster.hxx +34 -2
  20. data/ext/couchbase/cluster_options.hxx +1 -0
  21. data/ext/couchbase/configuration.hxx +228 -52
  22. data/ext/couchbase/couchbase.cxx +914 -35
  23. data/ext/couchbase/diagnostics.hxx +251 -0
  24. data/ext/couchbase/document_id.hxx +3 -1
  25. data/ext/couchbase/errors.hxx +10 -1
  26. data/ext/couchbase/io/http_command.hxx +11 -7
  27. data/ext/couchbase/io/http_context.hxx +37 -0
  28. data/ext/couchbase/io/http_message.hxx +9 -0
  29. data/ext/couchbase/io/http_parser.hxx +2 -0
  30. data/ext/couchbase/io/http_session.hxx +100 -14
  31. data/ext/couchbase/io/http_session_manager.hxx +65 -5
  32. data/ext/couchbase/io/mcbp_command.hxx +16 -7
  33. data/ext/couchbase/io/mcbp_session.hxx +193 -51
  34. data/ext/couchbase/io/query_cache.hxx +61 -0
  35. data/ext/couchbase/io/retry_context.hxx +1 -2
  36. data/ext/couchbase/io/retry_orchestrator.hxx +16 -0
  37. data/ext/couchbase/io/retry_strategy.hxx +1 -1
  38. data/ext/couchbase/io/streams.hxx +61 -10
  39. data/ext/couchbase/operations.hxx +13 -0
  40. data/ext/couchbase/operations/analytics_dataset_create.hxx +1 -1
  41. data/ext/couchbase/operations/analytics_dataset_drop.hxx +1 -1
  42. data/ext/couchbase/operations/analytics_dataset_get_all.hxx +1 -1
  43. data/ext/couchbase/operations/analytics_dataverse_create.hxx +1 -1
  44. data/ext/couchbase/operations/analytics_dataverse_drop.hxx +1 -1
  45. data/ext/couchbase/operations/analytics_get_pending_mutations.hxx +1 -1
  46. data/ext/couchbase/operations/analytics_index_create.hxx +1 -1
  47. data/ext/couchbase/operations/analytics_index_drop.hxx +1 -1
  48. data/ext/couchbase/operations/analytics_index_get_all.hxx +1 -1
  49. data/ext/couchbase/operations/analytics_link_connect.hxx +1 -1
  50. data/ext/couchbase/operations/analytics_link_disconnect.hxx +1 -1
  51. data/ext/couchbase/operations/bucket_create.hxx +11 -5
  52. data/ext/couchbase/operations/bucket_drop.hxx +1 -1
  53. data/ext/couchbase/operations/bucket_flush.hxx +1 -1
  54. data/ext/couchbase/operations/bucket_get.hxx +1 -1
  55. data/ext/couchbase/operations/bucket_get_all.hxx +1 -1
  56. data/ext/couchbase/operations/bucket_settings.hxx +43 -4
  57. data/ext/couchbase/operations/bucket_update.hxx +11 -5
  58. data/ext/couchbase/operations/cluster_developer_preview_enable.hxx +1 -1
  59. data/ext/couchbase/operations/collection_create.hxx +3 -1
  60. data/ext/couchbase/operations/collection_drop.hxx +1 -1
  61. data/ext/couchbase/operations/collections_manifest_get.hxx +70 -0
  62. data/ext/couchbase/operations/document_analytics.hxx +6 -1
  63. data/ext/couchbase/operations/document_get_projected.hxx +1 -1
  64. data/ext/couchbase/operations/document_query.hxx +85 -8
  65. data/ext/couchbase/operations/document_search.hxx +14 -4
  66. data/ext/couchbase/operations/document_view.hxx +1 -1
  67. data/ext/couchbase/operations/group_drop.hxx +71 -0
  68. data/ext/couchbase/operations/group_get.hxx +75 -0
  69. data/ext/couchbase/operations/group_get_all.hxx +70 -0
  70. data/ext/couchbase/operations/group_upsert.hxx +118 -0
  71. data/ext/couchbase/operations/query_index_build_deferred.hxx +1 -1
  72. data/ext/couchbase/operations/query_index_create.hxx +1 -1
  73. data/ext/couchbase/operations/query_index_drop.hxx +1 -1
  74. data/ext/couchbase/operations/query_index_get_all.hxx +3 -2
  75. data/ext/couchbase/operations/rbac.hxx +276 -0
  76. data/ext/couchbase/operations/role_get_all.hxx +70 -0
  77. data/ext/couchbase/operations/scope_create.hxx +6 -2
  78. data/ext/couchbase/operations/scope_drop.hxx +1 -1
  79. data/ext/couchbase/operations/scope_get_all.hxx +1 -1
  80. data/ext/couchbase/operations/search_get_stats.hxx +59 -0
  81. data/ext/couchbase/operations/search_index_analyze_document.hxx +1 -1
  82. data/ext/couchbase/operations/search_index_control_ingest.hxx +1 -1
  83. data/ext/couchbase/operations/search_index_control_plan_freeze.hxx +1 -1
  84. data/ext/couchbase/operations/search_index_control_query.hxx +1 -1
  85. data/ext/couchbase/operations/search_index_drop.hxx +1 -1
  86. data/ext/couchbase/operations/search_index_get.hxx +1 -1
  87. data/ext/couchbase/operations/search_index_get_all.hxx +1 -1
  88. data/ext/couchbase/operations/search_index_get_documents_count.hxx +24 -16
  89. data/ext/couchbase/operations/search_index_get_stats.hxx +81 -0
  90. data/ext/couchbase/operations/search_index_upsert.hxx +1 -1
  91. data/ext/couchbase/operations/user_drop.hxx +72 -0
  92. data/ext/couchbase/operations/user_get.hxx +76 -0
  93. data/ext/couchbase/operations/user_get_all.hxx +71 -0
  94. data/ext/couchbase/operations/user_upsert.hxx +125 -0
  95. data/ext/couchbase/operations/view_index_drop.hxx +1 -1
  96. data/ext/couchbase/operations/view_index_get.hxx +1 -1
  97. data/ext/couchbase/operations/view_index_get_all.hxx +1 -1
  98. data/ext/couchbase/operations/view_index_upsert.hxx +1 -1
  99. data/ext/couchbase/origin.hxx +4 -4
  100. data/ext/couchbase/platform/terminate_handler.cc +5 -4
  101. data/ext/couchbase/protocol/client_opcode.hxx +38 -38
  102. data/ext/couchbase/protocol/client_response.hxx +2 -2
  103. data/ext/couchbase/protocol/cmd_cluster_map_change_notification.hxx +6 -3
  104. data/ext/couchbase/protocol/cmd_get_cluster_config.hxx +3 -1
  105. data/ext/couchbase/protocol/magic.hxx +6 -6
  106. data/ext/couchbase/protocol/server_opcode.hxx +2 -2
  107. data/ext/couchbase/protocol/status.hxx +57 -57
  108. data/ext/couchbase/service_type.hxx +1 -1
  109. data/ext/couchbase/utils/connection_string.hxx +12 -3
  110. data/ext/couchbase/version.hxx +1 -1
  111. data/ext/extconf.rb +21 -9
  112. data/ext/test/test_helper.hxx +141 -0
  113. data/ext/test/test_helper_native.hxx +59 -0
  114. data/ext/test/test_helper_ruby.hxx +72 -0
  115. data/ext/test/test_native_diagnostics.cxx +385 -0
  116. data/ext/test/test_native_trivial_crud.cxx +83 -0
  117. data/ext/test/test_ruby_trivial_crud.cxx +35 -0
  118. data/ext/test/test_ruby_trivial_query.cxx +34 -0
  119. data/ext/third_party/asio/asio/include/asio.hpp +35 -0
  120. data/ext/third_party/asio/asio/include/asio/any_io_executor.hpp +71 -0
  121. data/ext/third_party/asio/asio/include/asio/associated_allocator.hpp +1 -7
  122. data/ext/third_party/asio/asio/include/asio/associated_executor.hpp +36 -19
  123. data/ext/third_party/asio/asio/include/asio/async_result.hpp +1 -8
  124. data/ext/third_party/asio/asio/include/asio/awaitable.hpp +14 -4
  125. data/ext/third_party/asio/asio/include/asio/basic_datagram_socket.hpp +12 -7
  126. data/ext/third_party/asio/asio/include/asio/basic_deadline_timer.hpp +4 -4
  127. data/ext/third_party/asio/asio/include/asio/basic_raw_socket.hpp +11 -7
  128. data/ext/third_party/asio/asio/include/asio/basic_seq_packet_socket.hpp +9 -4
  129. data/ext/third_party/asio/asio/include/asio/basic_serial_port.hpp +6 -6
  130. data/ext/third_party/asio/asio/include/asio/basic_signal_set.hpp +4 -4
  131. data/ext/third_party/asio/asio/include/asio/basic_socket.hpp +5 -5
  132. data/ext/third_party/asio/asio/include/asio/basic_socket_acceptor.hpp +13 -7
  133. data/ext/third_party/asio/asio/include/asio/basic_stream_socket.hpp +7 -3
  134. data/ext/third_party/asio/asio/include/asio/basic_waitable_timer.hpp +52 -4
  135. data/ext/third_party/asio/asio/include/asio/bind_executor.hpp +10 -15
  136. data/ext/third_party/asio/asio/include/asio/buffer.hpp +6 -4
  137. data/ext/third_party/asio/asio/include/asio/co_spawn.hpp +380 -9
  138. data/ext/third_party/asio/asio/include/asio/defer.hpp +4 -1
  139. data/ext/third_party/asio/asio/include/asio/detached.hpp +50 -0
  140. data/ext/third_party/asio/asio/include/asio/detail/atomic_count.hpp +19 -0
  141. data/ext/third_party/asio/asio/include/asio/detail/bind_handler.hpp +144 -26
  142. data/ext/third_party/asio/asio/include/asio/detail/blocking_executor_op.hpp +107 -0
  143. data/ext/third_party/asio/asio/include/asio/detail/buffer_sequence_adapter.hpp +106 -0
  144. data/ext/third_party/asio/asio/include/asio/detail/bulk_executor_op.hpp +88 -0
  145. data/ext/third_party/asio/asio/include/asio/detail/completion_handler.hpp +10 -5
  146. data/ext/third_party/asio/asio/include/asio/detail/conditionally_enabled_event.hpp +8 -0
  147. data/ext/third_party/asio/asio/include/asio/detail/config.hpp +360 -37
  148. data/ext/third_party/asio/asio/include/asio/detail/deadline_timer_service.hpp +17 -2
  149. data/ext/third_party/asio/asio/include/asio/detail/descriptor_ops.hpp +24 -6
  150. data/ext/third_party/asio/asio/include/asio/detail/descriptor_read_op.hpp +32 -14
  151. data/ext/third_party/asio/asio/include/asio/detail/descriptor_write_op.hpp +32 -14
  152. data/ext/third_party/asio/asio/include/asio/detail/executor_function.hpp +133 -34
  153. data/ext/third_party/asio/asio/include/asio/detail/handler_alloc_helpers.hpp +42 -0
  154. data/ext/third_party/asio/asio/include/asio/detail/handler_invoke_helpers.hpp +23 -0
  155. data/ext/third_party/asio/asio/include/asio/detail/handler_tracking.hpp +26 -0
  156. data/ext/third_party/asio/asio/include/asio/detail/handler_work.hpp +370 -45
  157. data/ext/third_party/asio/asio/include/asio/detail/impl/descriptor_ops.ipp +208 -74
  158. data/ext/third_party/asio/asio/include/asio/detail/impl/handler_tracking.ipp +39 -1
  159. data/ext/third_party/asio/asio/include/asio/detail/impl/reactive_serial_port_service.ipp +12 -15
  160. data/ext/third_party/asio/asio/include/asio/detail/impl/scheduler.ipp +37 -0
  161. data/ext/third_party/asio/asio/include/asio/detail/impl/signal_set_service.ipp +2 -1
  162. data/ext/third_party/asio/asio/include/asio/detail/impl/socket_ops.ipp +661 -274
  163. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_executor_service.hpp +210 -4
  164. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.hpp +8 -9
  165. data/ext/third_party/asio/asio/include/asio/detail/impl/strand_service.ipp +5 -4
  166. data/ext/third_party/asio/asio/include/asio/detail/impl/win_iocp_io_context.ipp +15 -6
  167. data/ext/third_party/asio/asio/include/asio/detail/io_object_impl.hpp +32 -50
  168. data/ext/third_party/asio/asio/include/asio/detail/memory.hpp +3 -0
  169. data/ext/third_party/asio/asio/include/asio/detail/null_event.hpp +6 -0
  170. data/ext/third_party/asio/asio/include/asio/detail/pop_options.hpp +1 -1
  171. data/ext/third_party/asio/asio/include/asio/detail/posix_event.hpp +13 -0
  172. data/ext/third_party/asio/asio/include/asio/detail/push_options.hpp +1 -1
  173. data/ext/third_party/asio/asio/include/asio/detail/reactive_descriptor_service.hpp +38 -13
  174. data/ext/third_party/asio/asio/include/asio/detail/reactive_null_buffers_op.hpp +12 -6
  175. data/ext/third_party/asio/asio/include/asio/detail/reactive_serial_port_service.hpp +2 -3
  176. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_accept_op.hpp +36 -24
  177. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_connect_op.hpp +17 -10
  178. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recv_op.hpp +38 -16
  179. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvfrom_op.hpp +36 -14
  180. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_recvmsg_op.hpp +21 -11
  181. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_send_op.hpp +43 -17
  182. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_sendto_op.hpp +39 -17
  183. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service.hpp +44 -21
  184. data/ext/third_party/asio/asio/include/asio/detail/reactive_socket_service_base.hpp +41 -18
  185. data/ext/third_party/asio/asio/include/asio/detail/reactive_wait_op.hpp +12 -6
  186. data/ext/third_party/asio/asio/include/asio/detail/reactor_op.hpp +3 -1
  187. data/ext/third_party/asio/asio/include/asio/detail/resolve_endpoint_op.hpp +10 -8
  188. data/ext/third_party/asio/asio/include/asio/detail/resolve_query_op.hpp +11 -9
  189. data/ext/third_party/asio/asio/include/asio/detail/scheduler.hpp +8 -0
  190. data/ext/third_party/asio/asio/include/asio/detail/signal_handler.hpp +7 -5
  191. data/ext/third_party/asio/asio/include/asio/detail/socket_ops.hpp +46 -0
  192. data/ext/third_party/asio/asio/include/asio/detail/source_location.hpp +45 -0
  193. data/ext/third_party/asio/asio/include/asio/detail/std_event.hpp +12 -0
  194. data/ext/third_party/asio/asio/include/asio/detail/strand_executor_service.hpp +25 -1
  195. data/ext/third_party/asio/asio/include/asio/detail/strand_service.hpp +4 -1
  196. data/ext/third_party/asio/asio/include/asio/detail/thread_info_base.hpp +58 -0
  197. data/ext/third_party/asio/asio/include/asio/detail/type_traits.hpp +59 -0
  198. data/ext/third_party/asio/asio/include/asio/detail/variadic_templates.hpp +144 -1
  199. data/ext/third_party/asio/asio/include/asio/detail/wait_handler.hpp +9 -6
  200. data/ext/third_party/asio/asio/include/asio/detail/win_event.hpp +13 -0
  201. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_read_op.hpp +9 -5
  202. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_handle_write_op.hpp +9 -5
  203. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_io_context.hpp +5 -1
  204. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_null_buffers_op.hpp +10 -6
  205. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_op.hpp +9 -5
  206. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_overlapped_ptr.hpp +18 -6
  207. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_accept_op.hpp +15 -11
  208. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_connect_op.hpp +10 -5
  209. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recv_op.hpp +8 -4
  210. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvfrom_op.hpp +8 -4
  211. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_recvmsg_op.hpp +8 -4
  212. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_socket_send_op.hpp +8 -4
  213. data/ext/third_party/asio/asio/include/asio/detail/win_iocp_wait_op.hpp +10 -5
  214. data/ext/third_party/asio/asio/include/asio/detail/winrt_resolve_op.hpp +8 -4
  215. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_connect_op.hpp +8 -4
  216. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_recv_op.hpp +8 -4
  217. data/ext/third_party/asio/asio/include/asio/detail/winrt_socket_send_op.hpp +8 -4
  218. data/ext/third_party/asio/asio/include/asio/detail/work_dispatcher.hpp +81 -6
  219. data/ext/third_party/asio/asio/include/asio/detail/wrapped_handler.hpp +45 -9
  220. data/ext/third_party/asio/asio/include/asio/dispatch.hpp +4 -1
  221. data/ext/third_party/asio/asio/include/asio/execution.hpp +48 -0
  222. data/ext/third_party/asio/asio/include/asio/execution/allocator.hpp +249 -0
  223. data/ext/third_party/asio/asio/include/asio/execution/any_executor.hpp +2264 -0
  224. data/ext/third_party/asio/asio/include/asio/execution/bad_executor.hpp +47 -0
  225. data/ext/third_party/asio/asio/include/asio/execution/blocking.hpp +1351 -0
  226. data/ext/third_party/asio/asio/include/asio/execution/blocking_adaptation.hpp +1064 -0
  227. data/ext/third_party/asio/asio/include/asio/execution/bulk_execute.hpp +390 -0
  228. data/ext/third_party/asio/asio/include/asio/execution/bulk_guarantee.hpp +1018 -0
  229. data/ext/third_party/asio/asio/include/asio/execution/connect.hpp +486 -0
  230. data/ext/third_party/asio/asio/include/asio/execution/context.hpp +185 -0
  231. data/ext/third_party/asio/asio/include/asio/execution/context_as.hpp +201 -0
  232. data/ext/third_party/asio/asio/include/asio/execution/detail/as_invocable.hpp +152 -0
  233. data/ext/third_party/asio/asio/include/asio/execution/detail/as_operation.hpp +105 -0
  234. data/ext/third_party/asio/asio/include/asio/execution/detail/as_receiver.hpp +128 -0
  235. data/ext/third_party/asio/asio/include/asio/execution/detail/bulk_sender.hpp +261 -0
  236. data/ext/third_party/asio/asio/include/asio/execution/detail/submit_receiver.hpp +233 -0
  237. data/ext/third_party/asio/asio/include/asio/execution/detail/void_receiver.hpp +90 -0
  238. data/ext/third_party/asio/asio/include/asio/execution/execute.hpp +264 -0
  239. data/ext/third_party/asio/asio/include/asio/execution/executor.hpp +238 -0
  240. data/ext/third_party/asio/asio/include/asio/execution/impl/bad_executor.ipp +40 -0
  241. data/ext/third_party/asio/asio/include/asio/execution/impl/receiver_invocation_error.ipp +36 -0
  242. data/ext/third_party/asio/asio/include/asio/execution/invocable_archetype.hpp +71 -0
  243. data/ext/third_party/asio/asio/include/asio/execution/mapping.hpp +917 -0
  244. data/ext/third_party/asio/asio/include/asio/execution/occupancy.hpp +178 -0
  245. data/ext/third_party/asio/asio/include/asio/execution/operation_state.hpp +94 -0
  246. data/ext/third_party/asio/asio/include/asio/execution/outstanding_work.hpp +721 -0
  247. data/ext/third_party/asio/asio/include/asio/execution/prefer_only.hpp +327 -0
  248. data/ext/third_party/asio/asio/include/asio/execution/receiver.hpp +280 -0
  249. data/ext/third_party/asio/asio/include/asio/execution/receiver_invocation_error.hpp +48 -0
  250. data/ext/third_party/asio/asio/include/asio/execution/relationship.hpp +720 -0
  251. data/ext/third_party/asio/asio/include/asio/execution/schedule.hpp +290 -0
  252. data/ext/third_party/asio/asio/include/asio/execution/scheduler.hpp +86 -0
  253. data/ext/third_party/asio/asio/include/asio/execution/sender.hpp +311 -0
  254. data/ext/third_party/asio/asio/include/asio/execution/set_done.hpp +253 -0
  255. data/ext/third_party/asio/asio/include/asio/execution/set_error.hpp +253 -0
  256. data/ext/third_party/asio/asio/include/asio/execution/set_value.hpp +486 -0
  257. data/ext/third_party/asio/asio/include/asio/execution/start.hpp +250 -0
  258. data/ext/third_party/asio/asio/include/asio/execution/submit.hpp +450 -0
  259. data/ext/third_party/asio/asio/include/asio/executor.hpp +7 -1
  260. data/ext/third_party/asio/asio/include/asio/executor_work_guard.hpp +126 -9
  261. data/ext/third_party/asio/asio/include/asio/handler_alloc_hook.hpp +28 -5
  262. data/ext/third_party/asio/asio/include/asio/handler_invoke_hook.hpp +29 -3
  263. data/ext/third_party/asio/asio/include/asio/impl/awaitable.hpp +14 -0
  264. data/ext/third_party/asio/asio/include/asio/impl/buffered_read_stream.hpp +44 -8
  265. data/ext/third_party/asio/asio/include/asio/impl/buffered_write_stream.hpp +44 -8
  266. data/ext/third_party/asio/asio/include/asio/impl/co_spawn.hpp +145 -7
  267. data/ext/third_party/asio/asio/include/asio/impl/compose.hpp +124 -22
  268. data/ext/third_party/asio/asio/include/asio/impl/connect.hpp +52 -8
  269. data/ext/third_party/asio/asio/include/asio/impl/defer.hpp +147 -12
  270. data/ext/third_party/asio/asio/include/asio/impl/dispatch.hpp +142 -12
  271. data/ext/third_party/asio/asio/include/asio/impl/executor.hpp +15 -101
  272. data/ext/third_party/asio/asio/include/asio/impl/executor.ipp +5 -0
  273. data/ext/third_party/asio/asio/include/asio/impl/handler_alloc_hook.ipp +13 -4
  274. data/ext/third_party/asio/asio/include/asio/impl/io_context.hpp +144 -57
  275. data/ext/third_party/asio/asio/include/asio/impl/multiple_exceptions.ipp +49 -0
  276. data/ext/third_party/asio/asio/include/asio/impl/post.hpp +147 -12
  277. data/ext/third_party/asio/asio/include/asio/impl/read.hpp +85 -18
  278. data/ext/third_party/asio/asio/include/asio/impl/read_at.hpp +59 -14
  279. data/ext/third_party/asio/asio/include/asio/impl/read_until.hpp +241 -56
  280. data/ext/third_party/asio/asio/include/asio/impl/redirect_error.hpp +22 -4
  281. data/ext/third_party/asio/asio/include/asio/impl/spawn.hpp +58 -22
  282. data/ext/third_party/asio/asio/include/asio/impl/src.hpp +3 -0
  283. data/ext/third_party/asio/asio/include/asio/impl/system_context.ipp +16 -4
  284. data/ext/third_party/asio/asio/include/asio/impl/system_executor.hpp +113 -12
  285. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.hpp +260 -37
  286. data/ext/third_party/asio/asio/include/asio/impl/thread_pool.ipp +61 -7
  287. data/ext/third_party/asio/asio/include/asio/impl/use_awaitable.hpp +5 -2
  288. data/ext/third_party/asio/asio/include/asio/impl/use_future.hpp +147 -6
  289. data/ext/third_party/asio/asio/include/asio/impl/write.hpp +75 -14
  290. data/ext/third_party/asio/asio/include/asio/impl/write_at.hpp +53 -11
  291. data/ext/third_party/asio/asio/include/asio/io_context.hpp +706 -48
  292. data/ext/third_party/asio/asio/include/asio/io_context_strand.hpp +3 -1
  293. data/ext/third_party/asio/asio/include/asio/ip/basic_resolver.hpp +4 -4
  294. data/ext/third_party/asio/asio/include/asio/is_applicable_property.hpp +61 -0
  295. data/ext/third_party/asio/asio/include/asio/multiple_exceptions.hpp +58 -0
  296. data/ext/third_party/asio/asio/include/asio/posix/basic_descriptor.hpp +4 -4
  297. data/ext/third_party/asio/asio/include/asio/posix/basic_stream_descriptor.hpp +5 -5
  298. data/ext/third_party/asio/asio/include/asio/post.hpp +4 -1
  299. data/ext/third_party/asio/asio/include/asio/prefer.hpp +656 -0
  300. data/ext/third_party/asio/asio/include/asio/query.hpp +296 -0
  301. data/ext/third_party/asio/asio/include/asio/read_until.hpp +6 -6
  302. data/ext/third_party/asio/asio/include/asio/require.hpp +524 -0
  303. data/ext/third_party/asio/asio/include/asio/require_concept.hpp +310 -0
  304. data/ext/third_party/asio/asio/include/asio/spawn.hpp +12 -4
  305. data/ext/third_party/asio/asio/include/asio/ssl/detail/buffered_handshake_op.hpp +5 -0
  306. data/ext/third_party/asio/asio/include/asio/ssl/detail/engine.hpp +5 -0
  307. data/ext/third_party/asio/asio/include/asio/ssl/detail/handshake_op.hpp +5 -0
  308. data/ext/third_party/asio/asio/include/asio/ssl/detail/impl/engine.ipp +16 -3
  309. data/ext/third_party/asio/asio/include/asio/ssl/detail/io.hpp +38 -4
  310. data/ext/third_party/asio/asio/include/asio/ssl/detail/read_op.hpp +5 -0
  311. data/ext/third_party/asio/asio/include/asio/ssl/detail/shutdown_op.hpp +5 -0
  312. data/ext/third_party/asio/asio/include/asio/ssl/detail/stream_core.hpp +36 -2
  313. data/ext/third_party/asio/asio/include/asio/ssl/detail/write_op.hpp +10 -1
  314. data/ext/third_party/asio/asio/include/asio/ssl/stream.hpp +15 -0
  315. data/ext/third_party/asio/asio/include/asio/static_thread_pool.hpp +31 -0
  316. data/ext/third_party/asio/asio/include/asio/strand.hpp +232 -9
  317. data/ext/third_party/asio/asio/include/asio/system_context.hpp +12 -3
  318. data/ext/third_party/asio/asio/include/asio/system_executor.hpp +557 -24
  319. data/ext/third_party/asio/asio/include/asio/thread_pool.hpp +913 -37
  320. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_free.hpp +114 -0
  321. data/ext/third_party/asio/asio/include/asio/traits/bulk_execute_member.hpp +114 -0
  322. data/ext/third_party/asio/asio/include/asio/traits/connect_free.hpp +112 -0
  323. data/ext/third_party/asio/asio/include/asio/traits/connect_member.hpp +112 -0
  324. data/ext/third_party/asio/asio/include/asio/traits/equality_comparable.hpp +100 -0
  325. data/ext/third_party/asio/asio/include/asio/traits/execute_free.hpp +108 -0
  326. data/ext/third_party/asio/asio/include/asio/traits/execute_member.hpp +108 -0
  327. data/ext/third_party/asio/asio/include/asio/traits/prefer_free.hpp +108 -0
  328. data/ext/third_party/asio/asio/include/asio/traits/prefer_member.hpp +108 -0
  329. data/ext/third_party/asio/asio/include/asio/traits/query_free.hpp +108 -0
  330. data/ext/third_party/asio/asio/include/asio/traits/query_member.hpp +108 -0
  331. data/ext/third_party/asio/asio/include/asio/traits/query_static_constexpr_member.hpp +108 -0
  332. data/ext/third_party/asio/asio/include/asio/traits/require_concept_free.hpp +108 -0
  333. data/ext/third_party/asio/asio/include/asio/traits/require_concept_member.hpp +108 -0
  334. data/ext/third_party/asio/asio/include/asio/traits/require_free.hpp +108 -0
  335. data/ext/third_party/asio/asio/include/asio/traits/require_member.hpp +108 -0
  336. data/ext/third_party/asio/asio/include/asio/traits/schedule_free.hpp +108 -0
  337. data/ext/third_party/asio/asio/include/asio/traits/schedule_member.hpp +108 -0
  338. data/ext/third_party/asio/asio/include/asio/traits/set_done_free.hpp +108 -0
  339. data/ext/third_party/asio/asio/include/asio/traits/set_done_member.hpp +108 -0
  340. data/ext/third_party/asio/asio/include/asio/traits/set_error_free.hpp +112 -0
  341. data/ext/third_party/asio/asio/include/asio/traits/set_error_member.hpp +112 -0
  342. data/ext/third_party/asio/asio/include/asio/traits/set_value_free.hpp +234 -0
  343. data/ext/third_party/asio/asio/include/asio/traits/set_value_member.hpp +234 -0
  344. data/ext/third_party/asio/asio/include/asio/traits/start_free.hpp +108 -0
  345. data/ext/third_party/asio/asio/include/asio/traits/start_member.hpp +108 -0
  346. data/ext/third_party/asio/asio/include/asio/traits/static_query.hpp +108 -0
  347. data/ext/third_party/asio/asio/include/asio/traits/static_require.hpp +123 -0
  348. data/ext/third_party/asio/asio/include/asio/traits/static_require_concept.hpp +123 -0
  349. data/ext/third_party/asio/asio/include/asio/traits/submit_free.hpp +112 -0
  350. data/ext/third_party/asio/asio/include/asio/traits/submit_member.hpp +112 -0
  351. data/ext/third_party/asio/asio/include/asio/ts/executor.hpp +1 -0
  352. data/ext/third_party/asio/asio/include/asio/ts/netfwd.hpp +67 -8
  353. data/ext/third_party/asio/asio/include/asio/use_awaitable.hpp +63 -4
  354. data/ext/third_party/asio/asio/include/asio/version.hpp +1 -1
  355. data/ext/third_party/asio/asio/include/asio/windows/basic_object_handle.hpp +4 -4
  356. data/ext/third_party/asio/asio/include/asio/windows/basic_overlapped_handle.hpp +2 -2
  357. data/ext/third_party/asio/asio/include/asio/windows/basic_random_access_handle.hpp +5 -5
  358. data/ext/third_party/asio/asio/include/asio/windows/basic_stream_handle.hpp +5 -5
  359. data/ext/third_party/asio/asio/include/asio/windows/overlapped_ptr.hpp +4 -2
  360. data/ext/third_party/gsl/CMakeLists.txt +13 -5
  361. data/ext/third_party/gsl/include/gsl/gsl_assert +1 -1
  362. data/ext/third_party/gsl/include/gsl/gsl_byte +3 -3
  363. data/ext/third_party/gsl/include/gsl/gsl_narrow +52 -0
  364. data/ext/third_party/gsl/include/gsl/gsl_util +8 -50
  365. data/ext/third_party/gsl/include/gsl/multi_span +0 -10
  366. data/ext/third_party/gsl/include/gsl/pointers +14 -28
  367. data/ext/third_party/gsl/include/gsl/span +98 -46
  368. data/ext/third_party/gsl/include/gsl/string_span +37 -47
  369. data/ext/third_party/http_parser/http_parser.c +17 -10
  370. data/ext/third_party/http_parser/http_parser.h +4 -2
  371. data/ext/third_party/json/include/tao/json/basic_value.hpp +3 -2
  372. data/ext/third_party/json/include/tao/json/binary.hpp +4 -4
  373. data/ext/third_party/json/include/tao/json/binary_view.hpp +2 -2
  374. data/ext/third_party/json/include/tao/json/binding.hpp +2 -2
  375. data/ext/third_party/json/include/tao/json/binding/factory.hpp +8 -7
  376. data/ext/third_party/json/include/tao/json/binding/internal/array.hpp +2 -1
  377. data/ext/third_party/json/include/tao/json/binding/internal/object.hpp +6 -5
  378. data/ext/third_party/json/include/tao/json/binding/versions.hpp +3 -1
  379. data/ext/third_party/json/include/tao/json/cbor.hpp +1 -0
  380. data/ext/third_party/json/include/tao/json/cbor/consume_file.hpp +7 -7
  381. data/ext/third_party/json/include/tao/json/cbor/events/from_binary.hpp +43 -0
  382. data/ext/third_party/json/include/tao/json/cbor/events/from_file.hpp +4 -4
  383. data/ext/third_party/json/include/tao/json/cbor/events/from_string.hpp +3 -3
  384. data/ext/third_party/json/include/tao/json/cbor/from_binary.hpp +32 -0
  385. data/ext/third_party/json/include/tao/json/cbor/from_file.hpp +5 -5
  386. data/ext/third_party/json/include/tao/json/cbor/internal/grammar.hpp +2 -1
  387. data/ext/third_party/json/include/tao/json/consume_file.hpp +7 -7
  388. data/ext/third_party/json/include/tao/json/contrib/internal/indirect_traits.hpp +13 -6
  389. data/ext/third_party/json/include/tao/json/contrib/position.hpp +15 -15
  390. data/ext/third_party/json/include/tao/json/contrib/reference.hpp +5 -7
  391. data/ext/third_party/json/include/tao/json/contrib/schema.hpp +58 -35
  392. data/ext/third_party/json/include/tao/json/contrib/shared_ptr_traits.hpp +12 -4
  393. data/ext/third_party/json/include/tao/json/contrib/unique_ptr_traits.hpp +12 -4
  394. data/ext/third_party/json/include/tao/json/contrib/unordered_map_traits.hpp +1 -1
  395. data/ext/third_party/json/include/tao/json/contrib/unordered_set_traits.hpp +2 -2
  396. data/ext/third_party/json/include/tao/json/events/compare.hpp +2 -12
  397. data/ext/third_party/json/include/tao/json/events/from_file.hpp +4 -4
  398. data/ext/third_party/json/include/tao/json/events/from_string.hpp +2 -2
  399. data/ext/third_party/json/include/tao/json/events/invalid_string_to_binary.hpp +1 -1
  400. data/ext/third_party/json/include/tao/json/events/key_camel_case_to_snake_case.hpp +3 -3
  401. data/ext/third_party/json/include/tao/json/events/key_snake_case_to_camel_case.hpp +1 -1
  402. data/ext/third_party/json/include/tao/json/events/tee.hpp +2 -2
  403. data/ext/third_party/json/include/tao/json/events/to_pretty_stream.hpp +1 -1
  404. data/ext/third_party/json/include/tao/json/events/to_stream.hpp +1 -1
  405. data/ext/third_party/json/include/tao/json/events/transformer.hpp +3 -3
  406. data/ext/third_party/json/include/tao/json/events/validate_event_order.hpp +3 -3
  407. data/ext/third_party/json/include/tao/json/events/virtual_ref.hpp +6 -0
  408. data/ext/third_party/json/include/tao/json/external/pegtl.hpp +4 -13
  409. data/ext/third_party/json/include/tao/json/external/pegtl/argv_input.hpp +3 -5
  410. data/ext/third_party/json/include/tao/json/external/pegtl/ascii.hpp +5 -18
  411. data/ext/third_party/json/include/tao/json/external/pegtl/buffer_input.hpp +3 -3
  412. data/ext/third_party/json/include/tao/json/external/pegtl/change_action.hpp +2 -2
  413. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_state.hpp +6 -6
  414. data/ext/third_party/json/include/tao/json/external/pegtl/change_action_and_states.hpp +5 -5
  415. data/ext/third_party/json/include/tao/json/external/pegtl/change_control.hpp +2 -2
  416. data/ext/third_party/json/include/tao/json/external/pegtl/change_state.hpp +6 -6
  417. data/ext/third_party/json/include/tao/json/external/pegtl/change_states.hpp +5 -5
  418. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/alphabet.hpp +52 -52
  419. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze.hpp +176 -0
  420. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/analyze_traits.hpp +275 -0
  421. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/control_action.hpp +77 -0
  422. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/coverage.hpp +151 -0
  423. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/forward.hpp +16 -0
  424. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/http.hpp +37 -18
  425. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/internal.hpp +20 -22
  426. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf16.hpp +6 -10
  427. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf32.hpp +6 -10
  428. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/icu/utf8.hpp +2 -4
  429. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/if_then.hpp +11 -10
  430. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/integer.hpp +116 -131
  431. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian.hpp +4 -4
  432. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian_gcc.hpp +2 -2
  433. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/endian_win.hpp +2 -2
  434. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_mask_uint.hpp +9 -9
  435. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_mask_uint8.hpp +9 -10
  436. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_uint.hpp +9 -9
  437. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_uint8.hpp +9 -10
  438. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_utf16.hpp +10 -10
  439. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/peek_utf32.hpp +9 -9
  440. data/ext/third_party/json/include/tao/json/external/pegtl/{internal → contrib/internal}/read_uint.hpp +3 -3
  441. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/internal/set_stack_guard.hpp +52 -0
  442. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree.hpp +80 -201
  443. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/parse_tree_to_dot.hpp +11 -10
  444. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print.hpp +75 -0
  445. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/print_coverage.hpp +53 -0
  446. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/raw_string.hpp +45 -36
  447. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_first_state.hpp +33 -50
  448. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/remove_last_states.hpp +117 -0
  449. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_one_min_max.hpp +43 -11
  450. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/rep_string.hpp +1 -2
  451. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/shuffle_states.hpp +193 -0
  452. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/state_control.hpp +118 -0
  453. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/trace.hpp +227 -0
  454. data/ext/third_party/json/include/tao/json/external/pegtl/{uint16.hpp → contrib/uint16.hpp} +5 -5
  455. data/ext/third_party/json/include/tao/json/external/pegtl/{uint32.hpp → contrib/uint32.hpp} +5 -5
  456. data/ext/third_party/json/include/tao/json/external/pegtl/{uint64.hpp → contrib/uint64.hpp} +5 -5
  457. data/ext/third_party/json/include/tao/json/external/pegtl/{uint8.hpp → contrib/uint8.hpp} +5 -5
  458. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/unescape.hpp +14 -14
  459. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/uri.hpp +1 -1
  460. data/ext/third_party/json/include/tao/json/external/pegtl/{utf16.hpp → contrib/utf16.hpp} +5 -5
  461. data/ext/third_party/json/include/tao/json/external/pegtl/{utf32.hpp → contrib/utf32.hpp} +5 -5
  462. data/ext/third_party/json/include/tao/json/external/pegtl/cstream_input.hpp +2 -3
  463. data/ext/third_party/json/include/tao/json/external/pegtl/{internal/demangle.hpp → demangle.hpp} +12 -14
  464. data/ext/third_party/json/include/tao/json/external/pegtl/disable_action.hpp +2 -2
  465. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input.hpp +2 -2
  466. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_failure.hpp +2 -2
  467. data/ext/third_party/json/include/tao/json/external/pegtl/discard_input_on_success.hpp +2 -2
  468. data/ext/third_party/json/include/tao/json/external/pegtl/enable_action.hpp +2 -2
  469. data/ext/third_party/json/include/tao/json/external/pegtl/file_input.hpp +1 -1
  470. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action.hpp +19 -9
  471. data/ext/third_party/json/include/tao/json/external/pegtl/internal/action_input.hpp +7 -8
  472. data/ext/third_party/json/include/tao/json/external/pegtl/internal/any.hpp +14 -14
  473. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply.hpp +9 -9
  474. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply0.hpp +8 -7
  475. data/ext/third_party/json/include/tao/json/external/pegtl/internal/apply_single.hpp +4 -4
  476. data/ext/third_party/json/include/tao/json/external/pegtl/internal/at.hpp +17 -15
  477. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bof.hpp +7 -6
  478. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bol.hpp +8 -8
  479. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump.hpp +4 -4
  480. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bump_help.hpp +3 -3
  481. data/ext/third_party/json/include/tao/json/external/pegtl/internal/bytes.hpp +17 -10
  482. data/ext/third_party/json/include/tao/json/external/pegtl/internal/control.hpp +19 -9
  483. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_crlf_eol.hpp +2 -2
  484. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cr_eol.hpp +2 -2
  485. data/ext/third_party/json/include/tao/json/external/pegtl/internal/crlf_eol.hpp +2 -2
  486. data/ext/third_party/json/include/tao/json/external/pegtl/internal/cstream_reader.hpp +1 -1
  487. data/ext/third_party/json/include/tao/json/external/pegtl/internal/{always_false.hpp → dependent_false.hpp} +3 -8
  488. data/ext/third_party/json/include/tao/json/external/pegtl/internal/disable.hpp +19 -9
  489. data/ext/third_party/json/include/tao/json/external/pegtl/internal/discard.hpp +7 -6
  490. data/ext/third_party/json/include/tao/json/external/pegtl/internal/enable.hpp +19 -9
  491. data/ext/third_party/json/include/tao/json/external/pegtl/internal/{skip_control.hpp → enable_control.hpp} +5 -5
  492. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eof.hpp +7 -6
  493. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eol.hpp +8 -7
  494. data/ext/third_party/json/include/tao/json/external/pegtl/internal/eolf.hpp +8 -7
  495. data/ext/third_party/json/include/tao/json/external/pegtl/internal/failure.hpp +32 -0
  496. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_posix.hpp +61 -10
  497. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_mapper_win32.hpp +27 -33
  498. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_reader.hpp +29 -26
  499. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply.hpp +3 -7
  500. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_apply0.hpp +3 -7
  501. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_match.hpp +4 -20
  502. data/ext/third_party/json/include/tao/json/external/pegtl/internal/has_unwind.hpp +21 -0
  503. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_apply.hpp +8 -7
  504. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must.hpp +8 -9
  505. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_must_else.hpp +2 -0
  506. data/ext/third_party/json/include/tao/json/external/pegtl/internal/if_then_else.hpp +7 -7
  507. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istream_reader.hpp +1 -2
  508. data/ext/third_party/json/include/tao/json/external/pegtl/internal/istring.hpp +11 -11
  509. data/ext/third_party/json/include/tao/json/external/pegtl/internal/iterator.hpp +7 -10
  510. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_crlf_eol.hpp +2 -2
  511. data/ext/third_party/json/include/tao/json/external/pegtl/internal/lf_eol.hpp +2 -2
  512. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail.hpp +4 -2
  513. data/ext/third_party/json/include/tao/json/external/pegtl/internal/list_tail_pad.hpp +1 -1
  514. data/ext/third_party/json/include/tao/json/external/pegtl/internal/marker.hpp +3 -5
  515. data/ext/third_party/json/include/tao/json/external/pegtl/internal/minus.hpp +21 -0
  516. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply.hpp +5 -2
  517. data/ext/third_party/json/include/tao/json/external/pegtl/internal/missing_apply0.hpp +5 -2
  518. data/ext/third_party/json/include/tao/json/external/pegtl/internal/must.hpp +16 -24
  519. data/ext/third_party/json/include/tao/json/external/pegtl/internal/not_at.hpp +17 -15
  520. data/ext/third_party/json/include/tao/json/external/pegtl/internal/one.hpp +23 -12
  521. data/ext/third_party/json/include/tao/json/external/pegtl/internal/opt.hpp +16 -16
  522. data/ext/third_party/json/include/tao/json/external/pegtl/internal/path_to_string.hpp +26 -0
  523. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_char.hpp +5 -5
  524. data/ext/third_party/json/include/tao/json/external/pegtl/internal/peek_utf8.hpp +12 -13
  525. data/ext/third_party/json/include/tao/json/external/pegtl/internal/plus.hpp +18 -11
  526. data/ext/third_party/json/include/tao/json/external/pegtl/internal/raise.hpp +8 -17
  527. data/ext/third_party/json/include/tao/json/external/pegtl/internal/range.hpp +22 -17
  528. data/ext/third_party/json/include/tao/json/external/pegtl/internal/ranges.hpp +28 -18
  529. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rematch.hpp +12 -9
  530. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep.hpp +26 -25
  531. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_min_max.hpp +23 -21
  532. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rep_opt.hpp +24 -9
  533. data/ext/third_party/json/include/tao/json/external/pegtl/internal/require.hpp +10 -10
  534. data/ext/third_party/json/include/tao/json/external/pegtl/internal/rules.hpp +4 -4
  535. data/ext/third_party/json/include/tao/json/external/pegtl/internal/seq.hpp +18 -33
  536. data/ext/third_party/json/include/tao/json/external/pegtl/internal/sor.hpp +24 -17
  537. data/ext/third_party/json/include/tao/json/external/pegtl/internal/star.hpp +13 -8
  538. data/ext/third_party/json/include/tao/json/external/pegtl/internal/state.hpp +21 -11
  539. data/ext/third_party/json/include/tao/json/external/pegtl/internal/string.hpp +11 -11
  540. data/ext/third_party/json/include/tao/json/external/pegtl/internal/success.hpp +32 -0
  541. data/ext/third_party/json/include/tao/json/external/pegtl/internal/try_catch_type.hpp +16 -16
  542. data/ext/third_party/json/include/tao/json/external/pegtl/internal/until.hpp +18 -14
  543. data/ext/third_party/json/include/tao/json/external/pegtl/istream_input.hpp +2 -3
  544. data/ext/third_party/json/include/tao/json/external/pegtl/match.hpp +125 -29
  545. data/ext/third_party/json/include/tao/json/external/pegtl/memory_input.hpp +32 -48
  546. data/ext/third_party/json/include/tao/json/external/pegtl/mmap_input.hpp +16 -16
  547. data/ext/third_party/json/include/tao/json/external/pegtl/must_if.hpp +64 -0
  548. data/ext/third_party/json/include/tao/json/external/pegtl/normal.hpp +25 -25
  549. data/ext/third_party/json/include/tao/json/external/pegtl/nothing.hpp +1 -2
  550. data/ext/third_party/json/include/tao/json/external/pegtl/parse.hpp +6 -8
  551. data/ext/third_party/json/include/tao/json/external/pegtl/parse_error.hpp +80 -35
  552. data/ext/third_party/json/include/tao/json/external/pegtl/position.hpp +18 -10
  553. data/ext/third_party/json/include/tao/json/external/pegtl/read_input.hpp +18 -38
  554. data/ext/third_party/json/include/tao/json/external/pegtl/rules.hpp +6 -5
  555. data/ext/third_party/json/include/tao/json/external/pegtl/string_input.hpp +3 -5
  556. data/ext/third_party/json/include/tao/json/external/pegtl/type_list.hpp +46 -0
  557. data/ext/third_party/json/include/tao/json/external/pegtl/visit.hpp +66 -0
  558. data/ext/third_party/json/include/tao/json/from_file.hpp +5 -5
  559. data/ext/third_party/json/include/tao/json/internal/action.hpp +3 -3
  560. data/ext/third_party/json/include/tao/json/internal/dependent_false.hpp +14 -0
  561. data/ext/third_party/json/include/tao/json/internal/errors.hpp +17 -17
  562. data/ext/third_party/json/include/tao/json/internal/format.hpp +0 -2
  563. data/ext/third_party/json/include/tao/json/internal/grammar.hpp +17 -17
  564. data/ext/third_party/json/include/tao/json/internal/pair.hpp +1 -1
  565. data/ext/third_party/json/include/tao/json/internal/sha256.hpp +8 -8
  566. data/ext/third_party/json/include/tao/json/internal/single.hpp +1 -1
  567. data/ext/third_party/json/include/tao/json/internal/type_traits.hpp +12 -29
  568. data/ext/third_party/json/include/tao/json/jaxn/consume_file.hpp +7 -7
  569. data/ext/third_party/json/include/tao/json/jaxn/events/from_file.hpp +4 -4
  570. data/ext/third_party/json/include/tao/json/jaxn/events/from_string.hpp +2 -2
  571. data/ext/third_party/json/include/tao/json/jaxn/from_file.hpp +5 -5
  572. data/ext/third_party/json/include/tao/json/jaxn/internal/action.hpp +6 -6
  573. data/ext/third_party/json/include/tao/json/jaxn/internal/bunescape_action.hpp +2 -2
  574. data/ext/third_party/json/include/tao/json/jaxn/internal/errors.hpp +43 -43
  575. data/ext/third_party/json/include/tao/json/jaxn/internal/grammar.hpp +36 -36
  576. data/ext/third_party/json/include/tao/json/jaxn/internal/integer.hpp +10 -11
  577. data/ext/third_party/json/include/tao/json/jaxn/is_identifier.hpp +2 -2
  578. data/ext/third_party/json/include/tao/json/jaxn/parts_parser.hpp +1 -3
  579. data/ext/third_party/json/include/tao/json/message_extension.hpp +2 -2
  580. data/ext/third_party/json/include/tao/json/msgpack.hpp +1 -0
  581. data/ext/third_party/json/include/tao/json/msgpack/consume_file.hpp +7 -7
  582. data/ext/third_party/json/include/tao/json/msgpack/events/from_binary.hpp +43 -0
  583. data/ext/third_party/json/include/tao/json/msgpack/events/from_file.hpp +4 -4
  584. data/ext/third_party/json/include/tao/json/msgpack/events/from_string.hpp +4 -4
  585. data/ext/third_party/json/include/tao/json/msgpack/events/to_stream.hpp +4 -4
  586. data/ext/third_party/json/include/tao/json/msgpack/from_binary.hpp +32 -0
  587. data/ext/third_party/json/include/tao/json/msgpack/from_file.hpp +5 -5
  588. data/ext/third_party/json/include/tao/json/msgpack/internal/grammar.hpp +2 -1
  589. data/ext/third_party/json/include/tao/json/operators.hpp +0 -4
  590. data/ext/third_party/json/include/tao/json/parts_parser.hpp +3 -7
  591. data/ext/third_party/json/include/tao/json/self_contained.hpp +6 -18
  592. data/ext/third_party/json/include/tao/json/span.hpp +94 -166
  593. data/ext/third_party/json/include/tao/json/ubjson.hpp +1 -0
  594. data/ext/third_party/json/include/tao/json/ubjson/consume_file.hpp +7 -7
  595. data/ext/third_party/json/include/tao/json/ubjson/events/from_binary.hpp +43 -0
  596. data/ext/third_party/json/include/tao/json/ubjson/events/from_file.hpp +4 -4
  597. data/ext/third_party/json/include/tao/json/ubjson/events/from_string.hpp +3 -3
  598. data/ext/third_party/json/include/tao/json/ubjson/from_binary.hpp +32 -0
  599. data/ext/third_party/json/include/tao/json/ubjson/from_file.hpp +5 -5
  600. data/ext/third_party/json/include/tao/json/ubjson/internal/grammar.hpp +5 -3
  601. data/ext/third_party/json/include/tao/json/utf8.hpp +1 -1
  602. data/ext/third_party/snappy/snappy.cc +6 -2
  603. data/ext/third_party/spdlog/CMakeLists.txt +24 -57
  604. data/ext/third_party/spdlog/cmake/version.rc.in +1 -1
  605. data/ext/third_party/spdlog/include/spdlog/async.h +3 -3
  606. data/ext/third_party/spdlog/include/spdlog/cfg/argv.h +3 -4
  607. data/ext/third_party/spdlog/include/spdlog/cfg/env.h +6 -4
  608. data/ext/third_party/spdlog/include/spdlog/cfg/helpers-inl.h +22 -6
  609. data/ext/third_party/spdlog/include/spdlog/cfg/helpers.h +3 -2
  610. data/ext/third_party/spdlog/include/spdlog/common.h +1 -2
  611. data/ext/third_party/spdlog/include/spdlog/details/fmt_helper.h +9 -1
  612. data/ext/third_party/spdlog/include/spdlog/details/os.h +1 -1
  613. data/ext/third_party/spdlog/include/spdlog/details/registry-inl.h +21 -7
  614. data/ext/third_party/spdlog/include/spdlog/details/registry.h +6 -3
  615. data/ext/third_party/spdlog/include/spdlog/details/synchronous_factory.h +1 -1
  616. data/ext/third_party/spdlog/include/spdlog/details/tcp_client-windows.h +1 -1
  617. data/ext/third_party/spdlog/include/spdlog/details/tcp_client.h +8 -7
  618. data/ext/third_party/spdlog/include/spdlog/fmt/bin_to_hex.h +2 -2
  619. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/chrono.h +66 -62
  620. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/color.h +35 -37
  621. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/compile.h +173 -103
  622. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/core.h +538 -445
  623. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format-inl.h +114 -64
  624. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/format.h +1152 -1071
  625. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/locale.h +16 -16
  626. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/os.h +450 -0
  627. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ostream.h +37 -13
  628. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/posix.h +1 -1
  629. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/printf.h +93 -63
  630. data/ext/third_party/spdlog/include/spdlog/fmt/bundled/ranges.h +35 -36
  631. data/ext/third_party/spdlog/include/spdlog/fmt/chrono.h +20 -0
  632. data/ext/third_party/spdlog/include/spdlog/fmt/fmt.h +2 -0
  633. data/ext/third_party/spdlog/include/spdlog/logger-inl.h +5 -1
  634. data/ext/third_party/spdlog/include/spdlog/logger.h +50 -76
  635. data/ext/third_party/spdlog/include/spdlog/pattern_formatter-inl.h +23 -8
  636. data/ext/third_party/spdlog/include/spdlog/pattern_formatter.h +3 -3
  637. data/ext/third_party/spdlog/include/spdlog/sinks/daily_file_sink.h +1 -1
  638. data/ext/third_party/spdlog/include/spdlog/sinks/msvc_sink.h +5 -5
  639. data/ext/third_party/spdlog/include/spdlog/sinks/ringbuffer_sink.h +6 -4
  640. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks-inl.h +32 -3
  641. data/ext/third_party/spdlog/include/spdlog/sinks/stdout_sinks.h +7 -0
  642. data/ext/third_party/spdlog/include/spdlog/sinks/wincolor_sink-inl.h +4 -14
  643. data/ext/third_party/spdlog/include/spdlog/spdlog-inl.h +11 -1
  644. data/ext/third_party/spdlog/include/spdlog/spdlog.h +23 -68
  645. data/ext/third_party/spdlog/include/spdlog/stopwatch.h +61 -0
  646. data/ext/third_party/spdlog/include/spdlog/version.h +2 -2
  647. data/ext/third_party/spdlog/src/fmt.cpp +21 -147
  648. data/lib/couchbase/cluster.rb +111 -1
  649. data/lib/couchbase/collection_options.rb +18 -1
  650. data/lib/couchbase/errors.rb +3 -0
  651. data/lib/couchbase/management/bucket_manager.rb +36 -3
  652. data/lib/couchbase/management/search_index_manager.rb +42 -1
  653. data/lib/couchbase/management/user_manager.rb +155 -48
  654. data/lib/couchbase/query_options.rb +7 -0
  655. data/lib/couchbase/scope.rb +1 -0
  656. data/lib/couchbase/search_options.rb +69 -1
  657. data/lib/couchbase/version.rb +1 -1
  658. metadata +172 -268
  659. data/.rubocop.yml +0 -227
  660. data/.rubocop_todo.yml +0 -47
  661. data/.yardopts +0 -1
  662. data/CONTRIBUTING.md +0 -110
  663. data/Gemfile +0 -37
  664. data/Rakefile +0 -51
  665. data/couchbase.gemspec +0 -79
  666. data/examples/analytics.rb +0 -236
  667. data/examples/auth.rb +0 -33
  668. data/examples/crud.rb +0 -34
  669. data/examples/managing_analytics_indexes.rb +0 -86
  670. data/examples/managing_buckets.rb +0 -61
  671. data/examples/managing_collections.rb +0 -71
  672. data/examples/managing_query_indexes.rb +0 -83
  673. data/examples/managing_search_indexes.rb +0 -77
  674. data/examples/managing_view_indexes.rb +0 -68
  675. data/examples/query.rb +0 -32
  676. data/examples/query_with_consistency.rb +0 -86
  677. data/examples/search.rb +0 -202
  678. data/examples/search_with_consistency.rb +0 -97
  679. data/examples/subdocument.rb +0 -63
  680. data/examples/view.rb +0 -59
  681. data/ext/.clang-format +0 -15
  682. data/ext/.clang-tidy +0 -22
  683. data/ext/.cmake-format.yaml +0 -8
  684. data/ext/.gitignore +0 -2
  685. data/ext/.idea/.name +0 -1
  686. data/ext/.idea/dictionaries/couchbase_terms.xml +0 -14
  687. data/ext/.idea/ext.iml +0 -2
  688. data/ext/.idea/misc.xml +0 -16
  689. data/ext/.idea/modules.xml +0 -8
  690. data/ext/.idea/vcs.xml +0 -12
  691. data/ext/test/main.cxx +0 -184
  692. data/ext/third_party/asio/.appveyor.yml +0 -107
  693. data/ext/third_party/asio/.cirrus.yml +0 -16
  694. data/ext/third_party/asio/.gitignore +0 -3
  695. data/ext/third_party/asio/.travis.yml +0 -323
  696. data/ext/third_party/asio/asio/.gitignore +0 -23
  697. data/ext/third_party/asio/asio/COPYING +0 -4
  698. data/ext/third_party/asio/asio/INSTALL +0 -5
  699. data/ext/third_party/asio/asio/LICENSE_1_0.txt +0 -23
  700. data/ext/third_party/asio/asio/Makefile.am +0 -19
  701. data/ext/third_party/asio/asio/README +0 -4
  702. data/ext/third_party/asio/asio/asio.manifest +0 -4865
  703. data/ext/third_party/asio/asio/autogen.sh +0 -55
  704. data/ext/third_party/asio/asio/boost_asio.manifest +0 -5193
  705. data/ext/third_party/asio/asio/boostify.pl +0 -603
  706. data/ext/third_party/asio/asio/configure.ac +0 -182
  707. data/ext/third_party/asio/asio/include/.gitignore +0 -2
  708. data/ext/third_party/asio/asio/include/Makefile.am +0 -484
  709. data/ext/third_party/asio/asio/include/asio/detail/io_object_executor.hpp +0 -167
  710. data/ext/third_party/asio/asio/include/asio/impl/src.cpp +0 -25
  711. data/ext/third_party/asio/asio/release.pl +0 -440
  712. data/ext/third_party/asio/asio/src/.gitignore +0 -11
  713. data/ext/third_party/asio/asio/src/Makefile.am +0 -23
  714. data/ext/third_party/asio/asio/src/Makefile.mgw +0 -204
  715. data/ext/third_party/asio/asio/src/Makefile.msc +0 -497
  716. data/ext/third_party/asio/asio/src/asio.cpp +0 -11
  717. data/ext/third_party/asio/asio/src/asio_ssl.cpp +0 -11
  718. data/ext/third_party/asio/asio/src/doc/.gitignore +0 -5
  719. data/ext/third_party/asio/asio/src/doc/Jamfile.v2 +0 -62
  720. data/ext/third_party/asio/asio/src/doc/asio.png +0 -0
  721. data/ext/third_party/asio/asio/src/doc/asio.qbk +0 -127
  722. data/ext/third_party/asio/asio/src/doc/asioref.sty +0 -90
  723. data/ext/third_party/asio/asio/src/doc/asioref.xsl +0 -94
  724. data/ext/third_party/asio/asio/src/doc/boost_bind_dox.txt +0 -5
  725. data/ext/third_party/asio/asio/src/doc/doxy2qbk.pl +0 -22
  726. data/ext/third_party/asio/asio/src/doc/examples.qbk +0 -564
  727. data/ext/third_party/asio/asio/src/doc/history.qbk +0 -1794
  728. data/ext/third_party/asio/asio/src/doc/index.xml +0 -13
  729. data/ext/third_party/asio/asio/src/doc/makepdf.pl +0 -26
  730. data/ext/third_party/asio/asio/src/doc/net_ts.qbk +0 -479
  731. data/ext/third_party/asio/asio/src/doc/noncopyable_dox.txt +0 -3
  732. data/ext/third_party/asio/asio/src/doc/overview.qbk +0 -103
  733. data/ext/third_party/asio/asio/src/doc/overview/allocation.qbk +0 -89
  734. data/ext/third_party/asio/asio/src/doc/overview/async.qbk +0 -185
  735. data/ext/third_party/asio/asio/src/doc/overview/async_op1.dot +0 -78
  736. data/ext/third_party/asio/asio/src/doc/overview/async_op1.png +0 -0
  737. data/ext/third_party/asio/asio/src/doc/overview/async_op2.dot +0 -78
  738. data/ext/third_party/asio/asio/src/doc/overview/async_op2.png +0 -0
  739. data/ext/third_party/asio/asio/src/doc/overview/basics.qbk +0 -106
  740. data/ext/third_party/asio/asio/src/doc/overview/bsd_sockets.qbk +0 -270
  741. data/ext/third_party/asio/asio/src/doc/overview/buffers.qbk +0 -163
  742. data/ext/third_party/asio/asio/src/doc/overview/concurrency_hint.qbk +0 -88
  743. data/ext/third_party/asio/asio/src/doc/overview/coroutine.qbk +0 -51
  744. data/ext/third_party/asio/asio/src/doc/overview/coroutines_ts.qbk +0 -97
  745. data/ext/third_party/asio/asio/src/doc/overview/cpp2011.qbk +0 -271
  746. data/ext/third_party/asio/asio/src/doc/overview/handler_tracking.qbk +0 -220
  747. data/ext/third_party/asio/asio/src/doc/overview/implementation.qbk +0 -305
  748. data/ext/third_party/asio/asio/src/doc/overview/iostreams.qbk +0 -72
  749. data/ext/third_party/asio/asio/src/doc/overview/line_based.qbk +0 -118
  750. data/ext/third_party/asio/asio/src/doc/overview/other_protocols.qbk +0 -94
  751. data/ext/third_party/asio/asio/src/doc/overview/posix.qbk +0 -152
  752. data/ext/third_party/asio/asio/src/doc/overview/proactor.dot +0 -100
  753. data/ext/third_party/asio/asio/src/doc/overview/proactor.png +0 -0
  754. data/ext/third_party/asio/asio/src/doc/overview/protocols.qbk +0 -149
  755. data/ext/third_party/asio/asio/src/doc/overview/rationale.qbk +0 -54
  756. data/ext/third_party/asio/asio/src/doc/overview/reactor.qbk +0 -44
  757. data/ext/third_party/asio/asio/src/doc/overview/serial_ports.qbk +0 -45
  758. data/ext/third_party/asio/asio/src/doc/overview/signals.qbk +0 -44
  759. data/ext/third_party/asio/asio/src/doc/overview/spawn.qbk +0 -102
  760. data/ext/third_party/asio/asio/src/doc/overview/ssl.qbk +0 -124
  761. data/ext/third_party/asio/asio/src/doc/overview/strands.qbk +0 -114
  762. data/ext/third_party/asio/asio/src/doc/overview/streams.qbk +0 -62
  763. data/ext/third_party/asio/asio/src/doc/overview/sync_op.dot +0 -67
  764. data/ext/third_party/asio/asio/src/doc/overview/sync_op.png +0 -0
  765. data/ext/third_party/asio/asio/src/doc/overview/threads.qbk +0 -67
  766. data/ext/third_party/asio/asio/src/doc/overview/timers.qbk +0 -52
  767. data/ext/third_party/asio/asio/src/doc/overview/windows.qbk +0 -126
  768. data/ext/third_party/asio/asio/src/doc/project-root.jam +0 -1
  769. data/ext/third_party/asio/asio/src/doc/quickref.xml +0 -561
  770. data/ext/third_party/asio/asio/src/doc/reference.dox +0 -264
  771. data/ext/third_party/asio/asio/src/doc/reference.qbk +0 -125973
  772. data/ext/third_party/asio/asio/src/doc/reference.xsl +0 -1831
  773. data/ext/third_party/asio/asio/src/doc/release_checklist.htm +0 -68
  774. data/ext/third_party/asio/asio/src/doc/requirements/AcceptHandler.qbk +0 -72
  775. data/ext/third_party/asio/asio/src/doc/requirements/AcceptableProtocol.qbk +0 -25
  776. data/ext/third_party/asio/asio/src/doc/requirements/AsyncRandomAccessReadDevice.qbk +0 -56
  777. data/ext/third_party/asio/asio/src/doc/requirements/AsyncRandomAccessWriteDevice.qbk +0 -57
  778. data/ext/third_party/asio/asio/src/doc/requirements/AsyncReadStream.qbk +0 -50
  779. data/ext/third_party/asio/asio/src/doc/requirements/AsyncWriteStream.qbk +0 -48
  780. data/ext/third_party/asio/asio/src/doc/requirements/BufferedHandshakeHandler.qbk +0 -55
  781. data/ext/third_party/asio/asio/src/doc/requirements/CompletionCondition.qbk +0 -42
  782. data/ext/third_party/asio/asio/src/doc/requirements/CompletionHandler.qbk +0 -63
  783. data/ext/third_party/asio/asio/src/doc/requirements/ConnectCondition.qbk +0 -34
  784. data/ext/third_party/asio/asio/src/doc/requirements/ConnectHandler.qbk +0 -72
  785. data/ext/third_party/asio/asio/src/doc/requirements/ConstBufferSequence.qbk +0 -53
  786. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer.qbk +0 -16
  787. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer_v1.qbk +0 -93
  788. data/ext/third_party/asio/asio/src/doc/requirements/DynamicBuffer_v2.qbk +0 -94
  789. data/ext/third_party/asio/asio/src/doc/requirements/Endpoint.qbk +0 -97
  790. data/ext/third_party/asio/asio/src/doc/requirements/EndpointSequence.qbk +0 -30
  791. data/ext/third_party/asio/asio/src/doc/requirements/ExecutionContext.qbk +0 -36
  792. data/ext/third_party/asio/asio/src/doc/requirements/Executor.qbk +0 -141
  793. data/ext/third_party/asio/asio/src/doc/requirements/GettableSerialPortOption.qbk +0 -33
  794. data/ext/third_party/asio/asio/src/doc/requirements/GettableSocketOption.qbk +0 -67
  795. data/ext/third_party/asio/asio/src/doc/requirements/Handler.qbk +0 -64
  796. data/ext/third_party/asio/asio/src/doc/requirements/HandshakeHandler.qbk +0 -72
  797. data/ext/third_party/asio/asio/src/doc/requirements/InternetProtocol.qbk +0 -47
  798. data/ext/third_party/asio/asio/src/doc/requirements/IoControlCommand.qbk +0 -34
  799. data/ext/third_party/asio/asio/src/doc/requirements/IoObjectService.qbk +0 -62
  800. data/ext/third_party/asio/asio/src/doc/requirements/IteratorConnectHandler.qbk +0 -81
  801. data/ext/third_party/asio/asio/src/doc/requirements/LegacyCompletionHandler.qbk +0 -65
  802. data/ext/third_party/asio/asio/src/doc/requirements/MoveAcceptHandler.qbk +0 -61
  803. data/ext/third_party/asio/asio/src/doc/requirements/MutableBufferSequence.qbk +0 -54
  804. data/ext/third_party/asio/asio/src/doc/requirements/ProtoAllocator.qbk +0 -19
  805. data/ext/third_party/asio/asio/src/doc/requirements/Protocol.qbk +0 -56
  806. data/ext/third_party/asio/asio/src/doc/requirements/RangeConnectHandler.qbk +0 -82
  807. data/ext/third_party/asio/asio/src/doc/requirements/ReadHandler.qbk +0 -79
  808. data/ext/third_party/asio/asio/src/doc/requirements/ResolveHandler.qbk +0 -82
  809. data/ext/third_party/asio/asio/src/doc/requirements/Service.qbk +0 -40
  810. data/ext/third_party/asio/asio/src/doc/requirements/SettableSerialPortOption.qbk +0 -33
  811. data/ext/third_party/asio/asio/src/doc/requirements/SettableSocketOption.qbk +0 -54
  812. data/ext/third_party/asio/asio/src/doc/requirements/ShutdownHandler.qbk +0 -72
  813. data/ext/third_party/asio/asio/src/doc/requirements/SignalHandler.qbk +0 -79
  814. data/ext/third_party/asio/asio/src/doc/requirements/SyncRandomAccessReadDevice.qbk +0 -49
  815. data/ext/third_party/asio/asio/src/doc/requirements/SyncRandomAccessWriteDevice.qbk +0 -49
  816. data/ext/third_party/asio/asio/src/doc/requirements/SyncReadStream.qbk +0 -41
  817. data/ext/third_party/asio/asio/src/doc/requirements/SyncWriteStream.qbk +0 -39
  818. data/ext/third_party/asio/asio/src/doc/requirements/TimeTraits.qbk +0 -72
  819. data/ext/third_party/asio/asio/src/doc/requirements/WaitHandler.qbk +0 -72
  820. data/ext/third_party/asio/asio/src/doc/requirements/WaitTraits.qbk +0 -52
  821. data/ext/third_party/asio/asio/src/doc/requirements/WriteHandler.qbk +0 -79
  822. data/ext/third_party/asio/asio/src/doc/requirements/asynchronous_operations.qbk +0 -300
  823. data/ext/third_party/asio/asio/src/doc/requirements/asynchronous_socket_operations.qbk +0 -39
  824. data/ext/third_party/asio/asio/src/doc/requirements/read_write_operations.qbk +0 -34
  825. data/ext/third_party/asio/asio/src/doc/requirements/synchronous_socket_operations.qbk +0 -37
  826. data/ext/third_party/asio/asio/src/doc/std_exception_dox.txt +0 -7
  827. data/ext/third_party/asio/asio/src/doc/tutorial.dox +0 -226
  828. data/ext/third_party/asio/asio/src/doc/tutorial.qbk +0 -2387
  829. data/ext/third_party/asio/asio/src/doc/tutorial.xsl +0 -437
  830. data/ext/third_party/asio/asio/src/doc/using.qbk +0 -309
  831. data/ext/third_party/asio/asio/tsify.pl +0 -574
  832. data/ext/third_party/gsl/.clang-format +0 -34
  833. data/ext/third_party/gsl/.github/workflows/main.yml +0 -94
  834. data/ext/third_party/gsl/.gitignore +0 -16
  835. data/ext/third_party/gsl/.travis.yml +0 -551
  836. data/ext/third_party/gsl/CMakeSettings.json +0 -18
  837. data/ext/third_party/gsl/CONTRIBUTING.md +0 -29
  838. data/ext/third_party/gsl/GSL.natvis +0 -98
  839. data/ext/third_party/gsl/README.md +0 -124
  840. data/ext/third_party/gsl/appveyor.yml +0 -128
  841. data/ext/third_party/http_parser/.gitignore +0 -30
  842. data/ext/third_party/http_parser/.mailmap +0 -8
  843. data/ext/third_party/http_parser/.travis.yml +0 -13
  844. data/ext/third_party/http_parser/AUTHORS +0 -68
  845. data/ext/third_party/http_parser/Makefile +0 -160
  846. data/ext/third_party/http_parser/README.md +0 -246
  847. data/ext/third_party/http_parser/bench.c +0 -128
  848. data/ext/third_party/http_parser/http_parser.gyp +0 -111
  849. data/ext/third_party/http_parser/test.c +0 -4600
  850. data/ext/third_party/json/.appveyor.yml +0 -44
  851. data/ext/third_party/json/.clang-format +0 -84
  852. data/ext/third_party/json/.conan/build.py +0 -80
  853. data/ext/third_party/json/.conan/test_package/CMakeLists.txt +0 -12
  854. data/ext/third_party/json/.conan/test_package/conanfile.py +0 -24
  855. data/ext/third_party/json/.conan/test_package/test_package.cpp +0 -16
  856. data/ext/third_party/json/.gitignore +0 -3
  857. data/ext/third_party/json/.travis.yml +0 -173
  858. data/ext/third_party/json/Makefile +0 -77
  859. data/ext/third_party/json/README.md +0 -149
  860. data/ext/third_party/json/conanfile.py +0 -28
  861. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/analyze_cycles.hpp +0 -127
  862. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/counted.hpp +0 -23
  863. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/generic.hpp +0 -31
  864. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/grammar_info.hpp +0 -32
  865. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/insert_guard.hpp +0 -51
  866. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/insert_rules.hpp +0 -25
  867. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/rule_info.hpp +0 -29
  868. data/ext/third_party/json/include/tao/json/external/pegtl/analysis/rule_type.hpp +0 -21
  869. data/ext/third_party/json/include/tao/json/external/pegtl/analyze.hpp +0 -21
  870. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/counter.hpp +0 -54
  871. data/ext/third_party/json/include/tao/json/external/pegtl/contrib/tracer.hpp +0 -158
  872. data/ext/third_party/json/include/tao/json/external/pegtl/internal/alnum.hpp +0 -18
  873. data/ext/third_party/json/include/tao/json/external/pegtl/internal/alpha.hpp +0 -18
  874. data/ext/third_party/json/include/tao/json/external/pegtl/internal/dusel_mode.hpp +0 -23
  875. data/ext/third_party/json/include/tao/json/external/pegtl/internal/duseltronik.hpp +0 -187
  876. data/ext/third_party/json/include/tao/json/external/pegtl/internal/file_opener.hpp +0 -72
  877. data/ext/third_party/json/include/tao/json/external/pegtl/internal/trivial.hpp +0 -32
  878. data/ext/third_party/snappy/.appveyor.yml +0 -36
  879. data/ext/third_party/snappy/.gitignore +0 -8
  880. data/ext/third_party/snappy/.travis.yml +0 -98
  881. data/ext/third_party/snappy/AUTHORS +0 -1
  882. data/ext/third_party/snappy/CONTRIBUTING.md +0 -26
  883. data/ext/third_party/snappy/NEWS +0 -188
  884. data/ext/third_party/snappy/README.md +0 -148
  885. data/ext/third_party/snappy/docs/README.md +0 -72
  886. data/ext/third_party/snappy/format_description.txt +0 -110
  887. data/ext/third_party/snappy/framing_format.txt +0 -135
  888. data/ext/third_party/snappy/snappy-test.cc +0 -613
  889. data/ext/third_party/snappy/snappy-test.h +0 -526
  890. data/ext/third_party/snappy/snappy_compress_fuzzer.cc +0 -60
  891. data/ext/third_party/snappy/snappy_uncompress_fuzzer.cc +0 -58
  892. data/ext/third_party/snappy/snappy_unittest.cc +0 -1512
  893. data/ext/third_party/spdlog/.clang-format +0 -108
  894. data/ext/third_party/spdlog/.clang-tidy +0 -54
  895. data/ext/third_party/spdlog/.gitattributes +0 -1
  896. data/ext/third_party/spdlog/.gitignore +0 -83
  897. data/ext/third_party/spdlog/.travis.yml +0 -112
  898. data/ext/third_party/spdlog/INSTALL +0 -24
  899. data/ext/third_party/spdlog/README.md +0 -423
  900. data/ext/third_party/spdlog/appveyor.yml +0 -51
  901. data/ext/third_party/spdlog/include/spdlog/cfg/log_levels.h +0 -47
@@ -19,6 +19,7 @@
19
19
 
20
20
  #include <io/http_session.hxx>
21
21
  #include <service_type.hxx>
22
+ #include <io/http_context.hxx>
22
23
 
23
24
  #include <random>
24
25
 
@@ -48,9 +49,27 @@ class http_session_manager : public std::enable_shared_from_this<http_session_ma
48
49
  }
49
50
  }
50
51
 
52
+ void export_diag_info(diag::diagnostics_result& res)
53
+ {
54
+ std::scoped_lock lock(sessions_mutex_);
55
+
56
+ for (const auto& list : busy_sessions_) {
57
+ for (const auto& session : list.second) {
58
+ res.services[list.first].emplace_back(session->diag_info());
59
+ }
60
+ }
61
+ for (const auto& list : idle_sessions_) {
62
+ for (const auto& session : list.second) {
63
+ res.services[list.first].emplace_back(session->diag_info());
64
+ }
65
+ }
66
+ }
67
+
51
68
  std::shared_ptr<http_session> check_out(service_type type, const couchbase::cluster_credentials& credentials)
52
69
  {
53
70
  std::scoped_lock lock(sessions_mutex_);
71
+ idle_sessions_[type].remove_if([](const auto& s) -> bool { return !s; });
72
+ busy_sessions_[type].remove_if([](const auto& s) -> bool { return !s; });
54
73
  if (idle_sessions_[type].empty()) {
55
74
  std::string hostname;
56
75
  std::uint16_t port = 0;
@@ -61,21 +80,38 @@ class http_session_manager : public std::enable_shared_from_this<http_session_ma
61
80
  config_.nodes.size();
62
81
  std::shared_ptr<http_session> session;
63
82
  if (options_.enable_tls) {
64
- session = std::make_shared<http_session>(client_id_, ctx_, tls_, credentials, hostname, std::to_string(port));
83
+ session = std::make_shared<http_session>(type,
84
+ client_id_,
85
+ ctx_,
86
+ tls_,
87
+ credentials,
88
+ hostname,
89
+ std::to_string(port),
90
+ http_context{ config_, options_, query_cache_ });
65
91
  } else {
66
- session = std::make_shared<http_session>(client_id_, ctx_, credentials, hostname, std::to_string(port));
92
+ session = std::make_shared<http_session>(
93
+ type, client_id_, ctx_, credentials, hostname, std::to_string(port), http_context{ config_, options_, query_cache_ });
67
94
  }
68
95
  session->start();
96
+
69
97
  session->on_stop([type, id = session->id(), self = this->shared_from_this()]() {
70
- std::scoped_lock inner_lock(self->sessions_mutex_);
71
- self->busy_sessions_[type].remove_if([id](const auto& s) -> bool { return s->id() == id; });
72
- self->idle_sessions_[type].remove_if([id](const auto& s) -> bool { return s->id() == id; });
98
+ for (auto& s : self->busy_sessions_[type]) {
99
+ if (s && s->id() == id) {
100
+ s.reset();
101
+ }
102
+ }
103
+ for (auto& s : self->idle_sessions_[type]) {
104
+ if (s && s->id() == id) {
105
+ s.reset();
106
+ }
107
+ }
73
108
  });
74
109
  busy_sessions_[type].push_back(session);
75
110
  return session;
76
111
  }
77
112
  auto session = idle_sessions_[type].front();
78
113
  idle_sessions_[type].pop_front();
114
+ session->reset_idle();
79
115
  busy_sessions_[type].push_back(session);
80
116
  return session;
81
117
  }
@@ -86,9 +122,32 @@ class http_session_manager : public std::enable_shared_from_this<http_session_ma
86
122
  return session->stop();
87
123
  }
88
124
  if (!session->is_stopped()) {
125
+ session->set_idle(options_.idle_http_connection_timeout);
89
126
  std::scoped_lock lock(sessions_mutex_);
90
127
  spdlog::debug("{} put HTTP session back to idle connections", session->log_prefix());
91
128
  idle_sessions_[type].push_back(session);
129
+ busy_sessions_[type].remove_if([id = session->id()](const auto& s) -> bool { return !s || s->id() == id; });
130
+ }
131
+ }
132
+
133
+ void close()
134
+ {
135
+ {
136
+ for (auto& sessions : idle_sessions_) {
137
+ for (auto& s : sessions.second) {
138
+ if (s) {
139
+ s->reset_idle();
140
+ s.reset();
141
+ }
142
+ }
143
+ }
144
+ }
145
+ {
146
+ for (auto& sessions : busy_sessions_) {
147
+ for (auto& s : sessions.second) {
148
+ s.reset();
149
+ }
150
+ }
92
151
  }
93
152
  }
94
153
 
@@ -118,5 +177,6 @@ class http_session_manager : public std::enable_shared_from_this<http_session_ma
118
177
  std::map<service_type, std::list<std::shared_ptr<http_session>>> idle_sessions_{};
119
178
  std::size_t next_index_{ 0 };
120
179
  std::mutex sessions_mutex_{};
180
+ query_cache query_cache_{};
121
181
  };
122
182
  } // namespace couchbase::io
@@ -17,6 +17,8 @@
17
17
 
18
18
  #pragma once
19
19
 
20
+ #include <platform/uuid.h>
21
+
20
22
  #include <io/mcbp_session.hxx>
21
23
  #include <io/retry_orchestrator.hxx>
22
24
 
@@ -41,12 +43,14 @@ struct mcbp_command : public std::enable_shared_from_this<mcbp_command<Manager,
41
43
  std::shared_ptr<io::mcbp_session> session_{};
42
44
  mcbp_command_handler handler_{};
43
45
  std::shared_ptr<Manager> manager_{};
46
+ std::string id_;
44
47
 
45
48
  mcbp_command(asio::io_context& ctx, std::shared_ptr<Manager> manager, Request req)
46
49
  : deadline(ctx)
47
50
  , retry_backoff(ctx)
48
51
  , request(req)
49
52
  , manager_(manager)
53
+ , id_(uuid::to_string(uuid::random()))
50
54
  {
51
55
  }
52
56
 
@@ -85,6 +89,9 @@ struct mcbp_command : public std::enable_shared_from_this<mcbp_command<Manager,
85
89
 
86
90
  void request_collection_id()
87
91
  {
92
+ if (session_->is_stopped()) {
93
+ return manager_->map_and_send(this->shared_from_this());
94
+ }
88
95
  protocol::client_request<protocol::get_collection_id_request_body> req;
89
96
  req.opaque(session_->next_opaque());
90
97
  req.body().collection_path(request.id.collection);
@@ -97,9 +104,9 @@ struct mcbp_command : public std::enable_shared_from_this<mcbp_command<Manager,
97
104
  }
98
105
  if (ec == std::make_error_code(error::common_errc::collection_not_found)) {
99
106
  if (self->request.id.collection_uid) {
100
- return self->handle_unknown_collection();
107
+ return self->invoke_handler(ec);
101
108
  }
102
- return self->invoke_handler(ec);
109
+ return self->handle_unknown_collection();
103
110
  }
104
111
  if (ec) {
105
112
  return self->invoke_handler(ec);
@@ -115,12 +122,13 @@ struct mcbp_command : public std::enable_shared_from_this<mcbp_command<Manager,
115
122
  {
116
123
  auto backoff = std::chrono::milliseconds(500);
117
124
  auto time_left = deadline.expiry() - std::chrono::steady_clock::now();
118
- spdlog::debug("{} unknown collection response for \"{}/{}/{}\", time_left={}ms",
125
+ spdlog::debug(R"({} unknown collection response for "{}/{}/{}", time_left={}ms, id="{}")",
119
126
  session_->log_prefix(),
120
127
  request.id.bucket,
121
128
  request.id.collection,
122
129
  request.id.key,
123
- std::chrono::duration_cast<std::chrono::milliseconds>(time_left).count());
130
+ std::chrono::duration_cast<std::chrono::milliseconds>(time_left).count(),
131
+ id_);
124
132
  if (time_left < backoff) {
125
133
  return invoke_handler(std::make_error_code(request.retries.idempotent ? error::common_errc::unambiguous_timeout
126
134
  : error::common_errc::ambiguous_timeout));
@@ -138,18 +146,19 @@ struct mcbp_command : public std::enable_shared_from_this<mcbp_command<Manager,
138
146
  {
139
147
  opaque_ = session_->next_opaque();
140
148
  request.opaque = *opaque_;
141
- if (!request.id.collection_uid) {
149
+ if (request.id.use_collections && !request.id.collection_uid) {
142
150
  if (session_->supports_feature(protocol::hello_feature::collections)) {
143
151
  auto collection_id = session_->get_collection_uid(request.id.collection);
144
152
  if (collection_id) {
145
153
  request.id.collection_uid = *collection_id;
146
154
  } else {
147
- spdlog::debug("{} no cache entry for collection, resolve collection id for \"{}/{}/{}\", timeout={}ms",
155
+ spdlog::debug(R"({} no cache entry for collection, resolve collection id for "{}/{}/{}", timeout={}ms, id="{}")",
148
156
  session_->log_prefix(),
149
157
  request.id.bucket,
150
158
  request.id.collection,
151
159
  request.id.key,
152
- request.timeout.count());
160
+ request.timeout.count(),
161
+ id_);
153
162
  return request_collection_id();
154
163
  }
155
164
  } else {
@@ -53,6 +53,7 @@
53
53
  #include <origin.hxx>
54
54
  #include <errors.hxx>
55
55
  #include <version.hxx>
56
+ #include <diagnostics.hxx>
56
57
 
57
58
  namespace couchbase::io
58
59
  {
@@ -202,14 +203,20 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
202
203
  return auth_success();
203
204
  }
204
205
  } else {
205
- spdlog::warn("{} unexpected message status during bootstrap: {}", session_->log_prefix_, resp.error_message());
206
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={})",
207
+ session_->log_prefix_,
208
+ resp.error_message(),
209
+ resp.opaque());
206
210
  return complete(std::make_error_code(error::network_errc::handshake_failure));
207
211
  }
208
212
  } break;
209
213
  case protocol::client_opcode::sasl_list_mechs: {
210
214
  protocol::client_response<protocol::sasl_list_mechs_response_body> resp(msg);
211
215
  if (resp.status() != protocol::status::success) {
212
- spdlog::warn("{} unexpected message status during bootstrap: {}", session_->log_prefix_, resp.error_message());
216
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={})",
217
+ session_->log_prefix_,
218
+ resp.error_message(),
219
+ resp.opaque());
213
220
  return complete(std::make_error_code(error::common_errc::authentication_failure));
214
221
  }
215
222
  } break;
@@ -232,14 +239,15 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
232
239
  req.body().sasl_data(sasl_payload);
233
240
  session_->write_and_flush(req.data());
234
241
  } else {
235
- spdlog::error("{} unable to authenticate: sasl_code={}", session_->log_prefix_, sasl_code);
242
+ spdlog::error(
243
+ "{} unable to authenticate: (sasl_code={}, opaque={})", session_->log_prefix_, sasl_code, resp.opaque());
236
244
  return complete(std::make_error_code(error::common_errc::authentication_failure));
237
245
  }
238
246
  } else {
239
- spdlog::warn("{} unexpected message status during bootstrap: {} (opcode={})",
247
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={})",
240
248
  session_->log_prefix_,
241
249
  resp.error_message(),
242
- opcode);
250
+ resp.opaque());
243
251
  return complete(std::make_error_code(error::common_errc::authentication_failure));
244
252
  }
245
253
  } break;
@@ -255,10 +263,11 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
255
263
  if (resp.status() == protocol::status::success) {
256
264
  session_->error_map_.emplace(resp.body().errmap());
257
265
  } else {
258
- spdlog::warn("{} unexpected message status during bootstrap: {} (opcode={})",
266
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={}, {:n})",
259
267
  session_->log_prefix_,
260
268
  resp.error_message(),
261
- opcode);
269
+ resp.opaque(),
270
+ spdlog::to_hex(msg.header_data()));
262
271
  return complete(std::make_error_code(error::network_errc::protocol_error));
263
272
  }
264
273
  } break;
@@ -267,6 +276,13 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
267
276
  if (resp.status() == protocol::status::success) {
268
277
  spdlog::debug("{} selected bucket: {}", session_->log_prefix_, session_->bucket_name_.value_or(""));
269
278
  session_->bucket_selected_ = true;
279
+ } else if (resp.status() == protocol::status::not_found) {
280
+ spdlog::debug("{} kv_engine node does not have configuration propagated yet (opcode={}, status={}, opaque={})",
281
+ session_->log_prefix_,
282
+ opcode,
283
+ resp.status(),
284
+ resp.opaque());
285
+ return complete(std::make_error_code(error::network_errc::configuration_not_available));
270
286
  } else if (resp.status() == protocol::status::no_access) {
271
287
  spdlog::debug("{} unable to select bucket: {}, probably the bucket does not exist",
272
288
  session_->log_prefix_,
@@ -274,7 +290,11 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
274
290
  session_->bucket_selected_ = false;
275
291
  return complete(std::make_error_code(error::common_errc::bucket_not_found));
276
292
  } else {
277
- spdlog::warn("{} unexpected message status during bootstrap: {}", session_->log_prefix_, resp.error_message());
293
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={}, {:n})",
294
+ session_->log_prefix_,
295
+ resp.error_message(),
296
+ resp.opaque(),
297
+ spdlog::to_hex(msg.header_data()));
278
298
  return complete(std::make_error_code(error::common_errc::bucket_not_found));
279
299
  }
280
300
  } break;
@@ -283,6 +303,13 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
283
303
  if (resp.status() == protocol::status::success) {
284
304
  session_->update_configuration(resp.body().config());
285
305
  complete({});
306
+ } else if (resp.status() == protocol::status::not_found) {
307
+ spdlog::debug("{} kv_engine node does not have configuration propagated yet (opcode={}, status={}, opaque={})",
308
+ session_->log_prefix_,
309
+ opcode,
310
+ resp.status(),
311
+ resp.opaque());
312
+ return complete(std::make_error_code(error::network_errc::configuration_not_available));
286
313
  } else if (resp.status() == protocol::status::no_bucket && !session_->bucket_name_) {
287
314
  // bucket-less session, but the server wants bucket
288
315
  session_->supports_gcccp_ = false;
@@ -292,10 +319,11 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
292
319
  make_blank_configuration(session_->endpoint_address_, session_->endpoint_.port(), 0));
293
320
  complete({});
294
321
  } else {
295
- spdlog::warn("{} unexpected message status during bootstrap: {} (opcode={})",
322
+ spdlog::warn("{} unexpected message status during bootstrap: {} (opaque={}, {:n})",
296
323
  session_->log_prefix_,
297
324
  resp.error_message(),
298
- opcode);
325
+ resp.opaque(),
326
+ spdlog::to_hex(msg.header_data()));
299
327
  return complete(std::make_error_code(error::network_errc::protocol_error));
300
328
  }
301
329
  } break;
@@ -353,9 +381,13 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
353
381
  session_->update_configuration(resp.body().config());
354
382
  }
355
383
  } else {
356
- spdlog::warn("{} unexpected message status: {}", session_->log_prefix_, resp.error_message());
384
+ spdlog::warn("{} unexpected message status: {} (opaque={})",
385
+ session_->log_prefix_,
386
+ resp.error_message(),
387
+ resp.opaque());
357
388
  }
358
389
  } break;
390
+ case protocol::client_opcode::get_collections_manifest:
359
391
  case protocol::client_opcode::get_collection_id:
360
392
  case protocol::client_opcode::get:
361
393
  case protocol::client_opcode::get_and_lock:
@@ -376,8 +408,9 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
376
408
  auto handler = session_->command_handlers_.find(opaque);
377
409
  if (handler != session_->command_handlers_.end()) {
378
410
  auto ec = session_->map_status_code(opcode, status);
379
- spdlog::trace("{} MCBP invoke operation handler: opaque={}, status={}, ec={}",
411
+ spdlog::trace("{} MCBP invoke operation handler: opcode={}, opaque={}, status={}, ec={}",
380
412
  session_->log_prefix_,
413
+ opcode,
381
414
  opaque,
382
415
  protocol::status_to_string(status),
383
416
  ec.message());
@@ -385,14 +418,20 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
385
418
  session_->command_handlers_.erase(handler);
386
419
  fun(ec, retry_reason::do_not_retry, std::move(msg));
387
420
  } else {
388
- spdlog::debug("{} unexpected orphan response: opcode={}, opaque={}",
421
+ spdlog::debug("{} unexpected orphan response: opcode={}, opaque={}, status={}",
389
422
  session_->log_prefix_,
390
- msg.header.opcode,
391
- msg.header.opaque);
423
+ opcode,
424
+ msg.header.opaque,
425
+ protocol::status_to_string(status));
392
426
  }
393
427
  } break;
394
428
  default:
395
- spdlog::warn("{} unexpected client response: {}", session_->log_prefix_, opcode);
429
+ spdlog::warn("{} unexpected client response: opcode={}, opaque={}{:a}{:a})",
430
+ session_->log_prefix_,
431
+ opcode,
432
+ msg.header.opaque,
433
+ spdlog::to_hex(msg.header_data()),
434
+ spdlog::to_hex(msg.body));
396
435
  }
397
436
  break;
398
437
  case protocol::magic::server_request:
@@ -400,23 +439,34 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
400
439
  switch (auto opcode = static_cast<protocol::server_opcode>(msg.header.opcode)) {
401
440
  case protocol::server_opcode::cluster_map_change_notification: {
402
441
  protocol::server_request<protocol::cluster_map_change_notification_request_body> req(msg);
403
- if (session_) {
404
- if ((!req.body().config().bucket.has_value() && req.body().bucket().empty()) ||
442
+ std::optional<configuration> config = req.body().config();
443
+ if (session_ && config.has_value()) {
444
+ if ((!config->bucket.has_value() && req.body().bucket().empty()) ||
405
445
  (session_->bucket_name_.has_value() && !req.body().bucket().empty() &&
406
446
  session_->bucket_name_.value() == req.body().bucket())) {
407
- session_->update_configuration(req.body().config());
447
+ session_->update_configuration(std::move(config.value()));
408
448
  }
409
449
  }
410
450
  } break;
411
451
  default:
412
- spdlog::warn("{} unexpected server request: {}", session_->log_prefix_, opcode);
452
+ spdlog::warn("{} unexpected server request: opcode={:x}, opaque={}{:a}{:a}",
453
+ session_->log_prefix_,
454
+ opcode,
455
+ msg.header.opaque,
456
+ spdlog::to_hex(msg.header_data()),
457
+ spdlog::to_hex(msg.body));
413
458
  }
414
459
  break;
415
460
  case protocol::magic::client_request:
416
461
  case protocol::magic::alt_client_request:
417
462
  case protocol::magic::server_response:
418
- spdlog::warn(
419
- "{} unexpected magic: {}, opcode={}, opaque={}", session_->log_prefix_, magic, msg.header.opcode, msg.header.opaque);
463
+ spdlog::warn("{} unexpected magic: {} (opcode={:x}, opaque={}){:a}{:a}",
464
+ session_->log_prefix_,
465
+ magic,
466
+ msg.header.opcode,
467
+ msg.header.opaque,
468
+ spdlog::to_hex(msg.header_data()),
469
+ spdlog::to_hex(msg.body));
420
470
  break;
421
471
  }
422
472
  }
@@ -453,7 +503,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
453
503
  , bucket_name_(std::move(bucket_name))
454
504
  , supported_features_(known_features)
455
505
  {
456
- log_prefix_ = fmt::format("[{}/{}/{}/{}]", stream_->log_prefix(), client_id_, id_, bucket_name_.value_or("-"));
506
+ log_prefix_ = fmt::format("[{}/{}/{}/{}]", client_id_, id_, stream_->log_prefix(), bucket_name_.value_or("-"));
457
507
  }
458
508
 
459
509
  mcbp_session(const std::string& client_id,
@@ -474,7 +524,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
474
524
  , bucket_name_(std::move(bucket_name))
475
525
  , supported_features_(known_features)
476
526
  {
477
- log_prefix_ = fmt::format("[{}/{}/{}/{}]", stream_->log_prefix(), client_id_, id_, bucket_name_.value_or("-"));
527
+ log_prefix_ = fmt::format("[{}/{}/{}/{}]", client_id_, id_, stream_->log_prefix(), bucket_name_.value_or("-"));
478
528
  }
479
529
 
480
530
  ~mcbp_session()
@@ -487,6 +537,19 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
487
537
  return log_prefix_;
488
538
  }
489
539
 
540
+ [[nodiscard]] diag::endpoint_diag_info diag_info() const
541
+ {
542
+ return { service_type::kv,
543
+ id_,
544
+ last_active_.time_since_epoch().count() == 0 ? std::nullopt
545
+ : std::make_optional(std::chrono::duration_cast<std::chrono::microseconds>(
546
+ std::chrono::steady_clock::now() - last_active_)),
547
+ fmt::format("{}:{}", endpoint_address_, endpoint_.port()),
548
+ fmt::format("{}:{}", local_endpoint_address_, local_endpoint_.port()),
549
+ state_,
550
+ bucket_name_ };
551
+ }
552
+
490
553
  void bootstrap(std::function<void(std::error_code, configuration)>&& handler, bool retry_on_bucket_not_found = false)
491
554
  {
492
555
  retry_bootstrap_on_bucket_not_found_ = retry_on_bucket_not_found;
@@ -509,6 +572,17 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
509
572
  if (stopped_) {
510
573
  return;
511
574
  }
575
+ state_ = diag::endpoint_state::connecting;
576
+ if (stream_->is_open()) {
577
+ std::string old_id = stream_->id();
578
+ stream_->reopen();
579
+ spdlog::trace(R"({} reopen socket connection "{}" -> "{}", host="{}", port={})",
580
+ log_prefix_,
581
+ old_id,
582
+ stream_->id(),
583
+ bootstrap_hostname_,
584
+ bootstrap_port_);
585
+ }
512
586
  if (origin_.exhausted()) {
513
587
  auto backoff = std::chrono::milliseconds(500);
514
588
  spdlog::debug("{} reached the end of list of bootstrap nodes, waiting for {}ms before restart", log_prefix_, backoff.count());
@@ -524,9 +598,9 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
524
598
  }
525
599
  std::tie(bootstrap_hostname_, bootstrap_port_) = origin_.next_address();
526
600
  log_prefix_ = fmt::format("[{}/{}/{}/{}] <{}:{}>",
527
- stream_->log_prefix(),
528
601
  client_id_,
529
602
  id_,
603
+ stream_->log_prefix(),
530
604
  bucket_name_.value_or("-"),
531
605
  bootstrap_hostname_,
532
606
  bootstrap_port_);
@@ -541,6 +615,11 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
541
615
  return id_;
542
616
  }
543
617
 
618
+ [[nodiscard]] bool is_stopped() const
619
+ {
620
+ return stopped_;
621
+ }
622
+
544
623
  void on_stop(std::function<void(io::retry_reason)> handler)
545
624
  {
546
625
  on_stop_handler_ = std::move(handler);
@@ -551,6 +630,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
551
630
  if (stopped_) {
552
631
  return;
553
632
  }
633
+ state_ = diag::endpoint_state::disconnecting;
554
634
  spdlog::debug("{} stop MCBP connection, reason={}", log_prefix_, reason);
555
635
  stopped_ = true;
556
636
  bootstrap_deadline_.cancel();
@@ -578,6 +658,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
578
658
  on_stop_handler_(reason);
579
659
  }
580
660
  on_stop_handler_ = nullptr;
661
+ state_ = diag::endpoint_state::disconnected;
581
662
  }
582
663
 
583
664
  void write(const std::vector<uint8_t>& buf)
@@ -636,7 +717,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
636
717
  }
637
718
  auto handler = command_handlers_.find(opaque);
638
719
  if (handler != command_handlers_.end()) {
639
- spdlog::debug("{} MCBP cancel operation, opaque={}, ec={}", log_prefix_, opaque, ec.message());
720
+ spdlog::debug("{} MCBP cancel operation, opaque={}, ec={} ({})", log_prefix_, opaque, ec.value(), ec.message());
640
721
  handler->second(ec, reason, {});
641
722
  command_handlers_.erase(handler);
642
723
  return true;
@@ -654,7 +735,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
654
735
  return supported_features_;
655
736
  }
656
737
 
657
- [[nodiscard]] bool supports_gcccp()
738
+ [[nodiscard]] bool supports_gcccp() const
658
739
  {
659
740
  return supports_gcccp_;
660
741
  }
@@ -849,18 +930,46 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
849
930
  if (stopped_) {
850
931
  return;
851
932
  }
852
- if (!config_ || config.rev > config_->rev) {
853
- for (auto& node : config.nodes) {
854
- if (node.hostname.empty()) {
855
- node.hostname = bootstrap_hostname_;
933
+ if (config_) {
934
+ if (config_->vbmap && config.vbmap && config_->vbmap->size() != config.vbmap->size()) {
935
+ spdlog::debug("{} received a configuration with a different number of vbuckets, ignoring", log_prefix_);
936
+ return;
937
+ }
938
+ if (config_->rev && config.rev) {
939
+ if (*config_->rev == *config.rev) {
940
+ spdlog::debug("{} received a configuration with identical revision (rev={}), ignoring", log_prefix_, *config.rev);
941
+ return;
942
+ }
943
+ if (*config_->rev > *config.rev) {
944
+ spdlog::debug("{} received a configuration with older revision, ignoring", log_prefix_);
945
+ return;
856
946
  }
857
947
  }
858
- config_.emplace(config);
859
- spdlog::debug("{} received new configuration: {}", log_prefix_, config_.value());
860
- for (auto& listener : config_listeners_) {
861
- listener(*config_);
948
+ }
949
+ bool this_node_found = false;
950
+ for (auto& node : config.nodes) {
951
+ if (node.hostname.empty()) {
952
+ node.hostname = bootstrap_hostname_;
953
+ }
954
+ if (node.this_node) {
955
+ this_node_found = true;
956
+ }
957
+ }
958
+ if (!this_node_found) {
959
+ for (auto& node : config.nodes) {
960
+ if (node.hostname == bootstrap_hostname_) {
961
+ if ((node.services_plain.key_value && std::to_string(node.services_plain.key_value.value()) == bootstrap_port_) ||
962
+ (node.services_tls.key_value && std::to_string(node.services_tls.key_value.value()) == bootstrap_port_)) {
963
+ node.this_node = true;
964
+ }
965
+ }
862
966
  }
863
967
  }
968
+ config_.emplace(config);
969
+ spdlog::debug("{} received new configuration: {}", log_prefix_, config_.value());
970
+ for (auto& listener : config_listeners_) {
971
+ listener(*config_);
972
+ }
864
973
  }
865
974
 
866
975
  void handle_not_my_vbucket(io::mcbp_message&& msg)
@@ -887,7 +996,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
887
996
  log_prefix_,
888
997
  static_cast<protocol::client_opcode>(msg.header.opcode),
889
998
  msg.header.opaque,
890
- config.rev);
999
+ config.rev_str());
891
1000
  update_configuration(std::move(config));
892
1001
  }
893
1002
  }
@@ -909,8 +1018,11 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
909
1018
  private:
910
1019
  void invoke_bootstrap_handler(std::error_code ec)
911
1020
  {
1021
+ if (ec == std::make_error_code(error::network_errc::configuration_not_available)) {
1022
+ return initiate_bootstrap();
1023
+ }
912
1024
  if (retry_bootstrap_on_bucket_not_found_ && ec == std::make_error_code(error::common_errc::bucket_not_found)) {
913
- spdlog::debug(R"({} server returned {}, it must be transient condition, retrying)", log_prefix_, ec.message());
1025
+ spdlog::debug(R"({} server returned {} ({}), it must be transient condition, retrying)", log_prefix_, ec.value(), ec.message());
914
1026
  return initiate_bootstrap();
915
1027
  }
916
1028
 
@@ -922,6 +1034,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
922
1034
  if (ec) {
923
1035
  return stop(retry_reason::node_not_available);
924
1036
  }
1037
+ state_ = diag::endpoint_state::connected;
925
1038
  bootstrapped_ = true;
926
1039
  handler_ = std::make_unique<normal_handler>(shared_from_this());
927
1040
  std::scoped_lock lock(pending_buffer_mutex_);
@@ -939,8 +1052,9 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
939
1052
  if (stopped_) {
940
1053
  return;
941
1054
  }
1055
+ last_active_ = std::chrono::steady_clock::now();
942
1056
  if (ec) {
943
- spdlog::error("{} error on resolve: {}", log_prefix_, ec.message());
1057
+ spdlog::error("{} error on resolve: {} ({})", log_prefix_, ec.value(), ec.message());
944
1058
  return initiate_bootstrap();
945
1059
  }
946
1060
  endpoints_ = endpoints;
@@ -954,6 +1068,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
954
1068
  if (stopped_) {
955
1069
  return;
956
1070
  }
1071
+ last_active_ = std::chrono::steady_clock::now();
957
1072
  if (it != endpoints_.end()) {
958
1073
  spdlog::debug("{} connecting to {}:{}", log_prefix_, it->endpoint().address().to_string(), it->endpoint().port());
959
1074
  connection_deadline_.expires_after(timeout_defaults::connect_timeout);
@@ -969,19 +1084,27 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
969
1084
  if (stopped_) {
970
1085
  return;
971
1086
  }
1087
+ last_active_ = std::chrono::steady_clock::now();
972
1088
  if (!stream_->is_open() || ec) {
973
- spdlog::warn(
974
- "{} unable to connect to {}:{}: {}", log_prefix_, it->endpoint().address().to_string(), it->endpoint().port(), ec.message());
1089
+ spdlog::warn("{} unable to connect to {}:{}: {} ({}), is_open={}",
1090
+ log_prefix_,
1091
+ it->endpoint().address().to_string(),
1092
+ it->endpoint().port(),
1093
+ ec.value(),
1094
+ ec.message(),
1095
+ stream_->is_open());
975
1096
  do_connect(++it);
976
1097
  } else {
977
1098
  stream_->set_options();
1099
+ local_endpoint_ = stream_->local_endpoint();
1100
+ local_endpoint_address_ = local_endpoint_.address().to_string();
978
1101
  endpoint_ = it->endpoint();
979
1102
  endpoint_address_ = endpoint_.address().to_string();
980
1103
  spdlog::debug("{} connected to {}:{}", log_prefix_, endpoint_address_, it->endpoint().port());
981
1104
  log_prefix_ = fmt::format("[{}/{}/{}/{}] <{}/{}:{}>",
982
- stream_->log_prefix(),
983
1105
  client_id_,
984
1106
  id_,
1107
+ stream_->log_prefix(),
985
1108
  bucket_name_.value_or("-"),
986
1109
  bootstrap_hostname_,
987
1110
  endpoint_address_,
@@ -1006,21 +1129,33 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1006
1129
 
1007
1130
  void do_read()
1008
1131
  {
1009
- if (stopped_) {
1010
- return;
1011
- }
1012
- if (reading_) {
1132
+ if (stopped_ || reading_ || !stream_->is_open()) {
1013
1133
  return;
1014
1134
  }
1015
1135
  reading_ = true;
1016
1136
  stream_->async_read_some(
1017
- asio::buffer(input_buffer_), [self = shared_from_this()](std::error_code ec, std::size_t bytes_transferred) {
1137
+ asio::buffer(input_buffer_),
1138
+ [self = shared_from_this(), stream_id = stream_->id()](std::error_code ec, std::size_t bytes_transferred) {
1018
1139
  if (ec == asio::error::operation_aborted || self->stopped_) {
1019
1140
  return;
1020
1141
  }
1142
+ self->last_active_ = std::chrono::steady_clock::now();
1021
1143
  if (ec) {
1022
- spdlog::error("{} IO error while reading from the socket: {}, pending_handlers={}",
1144
+ if (stream_id != self->stream_->id()) {
1145
+ spdlog::error(
1146
+ R"({} ignore IO error while reading from the socket: {} ({}), pending_handlers={}, old_id="{}", new_id="{}")",
1147
+ self->log_prefix_,
1148
+ ec.value(),
1149
+ ec.message(),
1150
+ self->command_handlers_.size(),
1151
+ stream_id,
1152
+ self->stream_->id());
1153
+ return;
1154
+ }
1155
+ spdlog::error(R"({} IO error while reading from the socket("{}"): {} ({}), pending_handlers={})",
1023
1156
  self->log_prefix_,
1157
+ self->stream_->id(),
1158
+ ec.value(),
1024
1159
  ec.message(),
1025
1160
  self->command_handlers_.size());
1026
1161
  return self->stop(retry_reason::socket_closed_while_in_flight);
@@ -1045,7 +1180,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1045
1180
  break;
1046
1181
  case mcbp_parser::need_data:
1047
1182
  self->reading_ = false;
1048
- if (!self->stopped_) {
1183
+ if (!self->stopped_ && self->stream_->is_open()) {
1049
1184
  self->do_read();
1050
1185
  }
1051
1186
  return;
@@ -1058,7 +1193,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1058
1193
 
1059
1194
  void do_write()
1060
1195
  {
1061
- if (stopped_) {
1196
+ if (stopped_ || !stream_->is_open()) {
1062
1197
  return;
1063
1198
  }
1064
1199
  std::scoped_lock lock(writing_buffer_mutex_, output_buffer_mutex_);
@@ -1075,9 +1210,12 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1075
1210
  if (ec == asio::error::operation_aborted || self->stopped_) {
1076
1211
  return;
1077
1212
  }
1213
+ self->last_active_ = std::chrono::steady_clock::now();
1078
1214
  if (ec) {
1079
- spdlog::error("{} IO error while writing to the socket: {}, pending_handlers={}",
1215
+ spdlog::error(R"({} IO error while writing to the socket("{}"): {} ({}), pending_handlers={})",
1080
1216
  self->log_prefix_,
1217
+ self->stream_->id(),
1218
+ ec.value(),
1081
1219
  ec.message(),
1082
1220
  self->command_handlers_.size());
1083
1221
  return self->stop(retry_reason::socket_closed_while_in_flight);
@@ -1092,7 +1230,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1092
1230
  }
1093
1231
 
1094
1232
  std::string client_id_;
1095
- std::string id_;
1233
+ const std::string id_;
1096
1234
  asio::io_context& ctx_;
1097
1235
  asio::ip::tcp::resolver resolver_;
1098
1236
  std::unique_ptr<stream_impl> stream_;
@@ -1128,6 +1266,8 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1128
1266
  std::string bootstrap_port_{};
1129
1267
  asio::ip::tcp::endpoint endpoint_{}; // connected endpoint
1130
1268
  std::string endpoint_address_{}; // cached string with endpoint address
1269
+ asio::ip::tcp::endpoint local_endpoint_{};
1270
+ std::string local_endpoint_address_{};
1131
1271
  asio::ip::tcp::resolver::results_type endpoints_;
1132
1272
  std::vector<protocol::hello_feature> supported_features_;
1133
1273
  std::optional<configuration> config_;
@@ -1137,5 +1277,7 @@ class mcbp_session : public std::enable_shared_from_this<mcbp_session>
1137
1277
  std::atomic_bool reading_{ false };
1138
1278
 
1139
1279
  std::string log_prefix_{};
1280
+ std::chrono::time_point<std::chrono::steady_clock> last_active_{};
1281
+ diag::endpoint_state state_{ diag::endpoint_state::disconnected };
1140
1282
  };
1141
1283
  } // namespace couchbase::io