couchbase 3.7.0 → 3.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (286) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +3 -3
  3. data/ext/CMakeLists.txt +4 -1
  4. data/ext/cache/extconf_include.rb +4 -3
  5. data/ext/cache/mozilla-ca-bundle.crt +66 -93
  6. data/ext/cache/mozilla-ca-bundle.sha256 +1 -1
  7. data/ext/couchbase/CMakeLists.txt +24 -11
  8. data/ext/couchbase/cmake/APKBUILD.in +17 -1
  9. data/ext/couchbase/cmake/Bundler.cmake +9 -1
  10. data/ext/couchbase/cmake/Cache.cmake +48 -19
  11. data/ext/couchbase/cmake/CompilerOptions.cmake +3 -1
  12. data/ext/couchbase/cmake/OpenSSL.cmake +10 -2
  13. data/ext/couchbase/cmake/Packaging.cmake +48 -8
  14. data/ext/couchbase/cmake/ThirdPartyDependencies.cmake +43 -1
  15. data/ext/couchbase/cmake/build_config.hxx.in +2 -0
  16. data/ext/couchbase/cmake/couchbase-cxx-client.spec.in +18 -0
  17. data/ext/couchbase/cmake/tarball_glob.txt +10 -0
  18. data/ext/couchbase/core/app_telemetry_meter.cxx +1 -0
  19. data/ext/couchbase/core/app_telemetry_reporter.cxx +45 -43
  20. data/ext/couchbase/core/app_telemetry_reporter.hxx +4 -3
  21. data/ext/couchbase/core/bucket.cxx +128 -13
  22. data/ext/couchbase/core/bucket.hxx +12 -2
  23. data/ext/couchbase/core/cluster.cxx +304 -152
  24. data/ext/couchbase/core/cluster.hxx +32 -0
  25. data/ext/couchbase/core/cluster_credentials.cxx +25 -0
  26. data/ext/couchbase/core/cluster_credentials.hxx +5 -0
  27. data/ext/couchbase/core/cluster_label_listener.cxx +72 -0
  28. data/ext/couchbase/core/cluster_label_listener.hxx +46 -0
  29. data/ext/couchbase/core/cluster_options.hxx +4 -0
  30. data/ext/couchbase/core/deprecation_utils.hxx +26 -0
  31. data/ext/couchbase/core/error.hxx +27 -0
  32. data/ext/couchbase/core/free_form_http_request.hxx +0 -2
  33. data/ext/couchbase/core/http_component.cxx +12 -48
  34. data/ext/couchbase/core/impl/analytics.cxx +3 -2
  35. data/ext/couchbase/core/impl/analytics.hxx +2 -1
  36. data/ext/couchbase/core/impl/analytics_index_manager.cxx +249 -137
  37. data/ext/couchbase/core/impl/binary_collection.cxx +134 -58
  38. data/ext/couchbase/core/impl/bucket_manager.cxx +87 -35
  39. data/ext/couchbase/core/impl/collection.cxx +560 -245
  40. data/ext/couchbase/core/impl/collection_manager.cxx +89 -49
  41. data/ext/couchbase/core/impl/dns_srv_tracker.cxx +4 -4
  42. data/ext/couchbase/core/impl/error.cxx +20 -13
  43. data/ext/couchbase/core/impl/error.hxx +15 -10
  44. data/ext/couchbase/core/impl/get_all_replicas.hxx +1 -1
  45. data/ext/couchbase/core/impl/get_any_replica.hxx +2 -1
  46. data/ext/couchbase/core/impl/get_replica.hxx +2 -0
  47. data/ext/couchbase/core/impl/lookup_in_replica.hxx +1 -1
  48. data/ext/couchbase/core/impl/observability_recorder.cxx +161 -0
  49. data/ext/couchbase/core/impl/observability_recorder.hxx +77 -0
  50. data/ext/couchbase/core/impl/observe_seqno.hxx +2 -0
  51. data/ext/couchbase/core/impl/public_bucket.cxx +31 -7
  52. data/ext/couchbase/core/impl/public_cluster.cxx +107 -19
  53. data/ext/couchbase/core/impl/query.cxx +6 -3
  54. data/ext/couchbase/core/impl/query.hxx +3 -1
  55. data/ext/couchbase/core/impl/query_index_manager.cxx +267 -102
  56. data/ext/couchbase/core/impl/scope.cxx +53 -11
  57. data/ext/couchbase/core/impl/search.cxx +8 -4
  58. data/ext/couchbase/core/impl/search.hxx +6 -2
  59. data/ext/couchbase/core/impl/search_index_manager.cxx +131 -41
  60. data/ext/couchbase/core/impl/with_cancellation.hxx +75 -0
  61. data/ext/couchbase/core/io/config_tracker.cxx +9 -9
  62. data/ext/couchbase/core/io/config_tracker.hxx +2 -1
  63. data/ext/couchbase/core/io/http_command.hxx +98 -49
  64. data/ext/couchbase/core/io/http_context.hxx +2 -0
  65. data/ext/couchbase/core/io/http_session.cxx +23 -10
  66. data/ext/couchbase/core/io/http_session.hxx +17 -9
  67. data/ext/couchbase/core/io/http_session_manager.hxx +163 -228
  68. data/ext/couchbase/core/io/http_traits.hxx +0 -7
  69. data/ext/couchbase/core/io/mcbp_command.hxx +123 -44
  70. data/ext/couchbase/core/io/mcbp_session.cxx +251 -26
  71. data/ext/couchbase/core/io/mcbp_session.hxx +9 -1
  72. data/ext/couchbase/core/io/mcbp_traits.hxx +0 -8
  73. data/ext/couchbase/core/io/streams.cxx +3 -3
  74. data/ext/couchbase/core/io/streams.hxx +3 -2
  75. data/ext/couchbase/core/meta/features.hxx +15 -0
  76. data/ext/couchbase/core/meta/version.cxx +13 -0
  77. data/ext/couchbase/core/meta/version.hxx +3 -0
  78. data/ext/couchbase/core/metrics/constants.hxx +23 -0
  79. data/ext/couchbase/core/metrics/logging_meter.cxx +5 -5
  80. data/ext/couchbase/core/metrics/meter_wrapper.cxx +65 -63
  81. data/ext/couchbase/core/metrics/meter_wrapper.hxx +12 -10
  82. data/ext/couchbase/core/operations/document_analytics.hxx +0 -5
  83. data/ext/couchbase/core/operations/document_append.hxx +0 -4
  84. data/ext/couchbase/core/operations/document_decrement.hxx +0 -5
  85. data/ext/couchbase/core/operations/document_exists.hxx +0 -7
  86. data/ext/couchbase/core/operations/document_get.hxx +0 -7
  87. data/ext/couchbase/core/operations/document_get_all_replicas.hxx +77 -27
  88. data/ext/couchbase/core/operations/document_get_and_lock.hxx +0 -9
  89. data/ext/couchbase/core/operations/document_get_and_touch.hxx +0 -9
  90. data/ext/couchbase/core/operations/document_get_any_replica.hxx +83 -2
  91. data/ext/couchbase/core/operations/document_get_projected.hxx +0 -9
  92. data/ext/couchbase/core/operations/document_increment.hxx +0 -5
  93. data/ext/couchbase/core/operations/document_insert.hxx +0 -4
  94. data/ext/couchbase/core/operations/document_lookup_in.hxx +0 -9
  95. data/ext/couchbase/core/operations/document_lookup_in_all_replicas.hxx +46 -4
  96. data/ext/couchbase/core/operations/document_lookup_in_any_replica.hxx +121 -43
  97. data/ext/couchbase/core/operations/document_mutate_in.hxx +0 -5
  98. data/ext/couchbase/core/operations/document_prepend.hxx +0 -4
  99. data/ext/couchbase/core/operations/document_query.hxx +0 -4
  100. data/ext/couchbase/core/operations/document_remove.hxx +0 -4
  101. data/ext/couchbase/core/operations/document_replace.hxx +0 -4
  102. data/ext/couchbase/core/operations/document_search.hxx +0 -7
  103. data/ext/couchbase/core/operations/document_touch.hxx +0 -7
  104. data/ext/couchbase/core/operations/document_unlock.hxx +0 -6
  105. data/ext/couchbase/core/operations/document_upsert.hxx +0 -4
  106. data/ext/couchbase/core/operations/document_view.cxx +2 -0
  107. data/ext/couchbase/core/operations/document_view.hxx +10 -13
  108. data/ext/couchbase/core/operations/http_noop.hxx +2 -0
  109. data/ext/couchbase/core/operations/management/analytics_dataset_create.hxx +2 -0
  110. data/ext/couchbase/core/operations/management/analytics_dataset_drop.hxx +2 -0
  111. data/ext/couchbase/core/operations/management/analytics_dataset_get_all.hxx +2 -0
  112. data/ext/couchbase/core/operations/management/analytics_dataverse_create.hxx +2 -0
  113. data/ext/couchbase/core/operations/management/analytics_dataverse_drop.hxx +2 -0
  114. data/ext/couchbase/core/operations/management/analytics_get_pending_mutations.hxx +2 -0
  115. data/ext/couchbase/core/operations/management/analytics_index_create.hxx +2 -0
  116. data/ext/couchbase/core/operations/management/analytics_index_drop.hxx +2 -0
  117. data/ext/couchbase/core/operations/management/analytics_index_get_all.hxx +2 -0
  118. data/ext/couchbase/core/operations/management/analytics_link_connect.hxx +2 -0
  119. data/ext/couchbase/core/operations/management/analytics_link_create.hxx +2 -0
  120. data/ext/couchbase/core/operations/management/analytics_link_disconnect.hxx +2 -0
  121. data/ext/couchbase/core/operations/management/analytics_link_drop.hxx +2 -0
  122. data/ext/couchbase/core/operations/management/analytics_link_get_all.hxx +2 -0
  123. data/ext/couchbase/core/operations/management/analytics_link_replace.hxx +2 -0
  124. data/ext/couchbase/core/operations/management/bucket_create.hxx +2 -0
  125. data/ext/couchbase/core/operations/management/bucket_describe.hxx +2 -0
  126. data/ext/couchbase/core/operations/management/bucket_drop.hxx +2 -0
  127. data/ext/couchbase/core/operations/management/bucket_flush.hxx +2 -0
  128. data/ext/couchbase/core/operations/management/bucket_get.hxx +2 -0
  129. data/ext/couchbase/core/operations/management/bucket_get_all.hxx +2 -0
  130. data/ext/couchbase/core/operations/management/bucket_update.hxx +2 -0
  131. data/ext/couchbase/core/operations/management/change_password.hxx +2 -0
  132. data/ext/couchbase/core/operations/management/cluster_describe.hxx +2 -0
  133. data/ext/couchbase/core/operations/management/cluster_developer_preview_enable.hxx +2 -0
  134. data/ext/couchbase/core/operations/management/collection_create.hxx +2 -0
  135. data/ext/couchbase/core/operations/management/collection_drop.hxx +2 -0
  136. data/ext/couchbase/core/operations/management/collection_update.hxx +2 -0
  137. data/ext/couchbase/core/operations/management/collections_manifest_get.hxx +2 -0
  138. data/ext/couchbase/core/operations/management/error_utils.cxx +4 -1
  139. data/ext/couchbase/core/operations/management/eventing_deploy_function.hxx +2 -0
  140. data/ext/couchbase/core/operations/management/eventing_drop_function.hxx +2 -0
  141. data/ext/couchbase/core/operations/management/eventing_get_all_functions.hxx +2 -0
  142. data/ext/couchbase/core/operations/management/eventing_get_function.hxx +2 -0
  143. data/ext/couchbase/core/operations/management/eventing_get_status.hxx +2 -0
  144. data/ext/couchbase/core/operations/management/eventing_pause_function.hxx +2 -0
  145. data/ext/couchbase/core/operations/management/eventing_resume_function.hxx +2 -0
  146. data/ext/couchbase/core/operations/management/eventing_undeploy_function.hxx +2 -0
  147. data/ext/couchbase/core/operations/management/eventing_upsert_function.hxx +2 -0
  148. data/ext/couchbase/core/operations/management/freeform.hxx +2 -0
  149. data/ext/couchbase/core/operations/management/group_drop.hxx +2 -0
  150. data/ext/couchbase/core/operations/management/group_get.hxx +2 -0
  151. data/ext/couchbase/core/operations/management/group_get_all.hxx +2 -0
  152. data/ext/couchbase/core/operations/management/group_upsert.hxx +2 -0
  153. data/ext/couchbase/core/operations/management/query_index_build.hxx +2 -0
  154. data/ext/couchbase/core/operations/management/query_index_build_deferred.hxx +68 -30
  155. data/ext/couchbase/core/operations/management/query_index_create.hxx +2 -0
  156. data/ext/couchbase/core/operations/management/query_index_drop.hxx +2 -0
  157. data/ext/couchbase/core/operations/management/query_index_get_all.hxx +4 -3
  158. data/ext/couchbase/core/operations/management/query_index_get_all_deferred.hxx +2 -1
  159. data/ext/couchbase/core/operations/management/role_get_all.hxx +2 -0
  160. data/ext/couchbase/core/operations/management/scope_create.hxx +2 -0
  161. data/ext/couchbase/core/operations/management/scope_drop.hxx +2 -0
  162. data/ext/couchbase/core/operations/management/scope_get_all.hxx +2 -0
  163. data/ext/couchbase/core/operations/management/search_get_stats.hxx +2 -0
  164. data/ext/couchbase/core/operations/management/search_index_analyze_document.hxx +2 -0
  165. data/ext/couchbase/core/operations/management/search_index_control_ingest.hxx +2 -0
  166. data/ext/couchbase/core/operations/management/search_index_control_plan_freeze.hxx +2 -0
  167. data/ext/couchbase/core/operations/management/search_index_control_query.hxx +2 -0
  168. data/ext/couchbase/core/operations/management/search_index_drop.hxx +2 -0
  169. data/ext/couchbase/core/operations/management/search_index_get.hxx +2 -0
  170. data/ext/couchbase/core/operations/management/search_index_get_all.hxx +2 -0
  171. data/ext/couchbase/core/operations/management/search_index_get_documents_count.hxx +2 -0
  172. data/ext/couchbase/core/operations/management/search_index_get_stats.hxx +2 -0
  173. data/ext/couchbase/core/operations/management/search_index_upsert.hxx +2 -0
  174. data/ext/couchbase/core/operations/management/user_drop.hxx +2 -0
  175. data/ext/couchbase/core/operations/management/user_get.hxx +2 -0
  176. data/ext/couchbase/core/operations/management/user_get_all.hxx +2 -0
  177. data/ext/couchbase/core/operations/management/user_upsert.hxx +2 -0
  178. data/ext/couchbase/core/operations/management/view_index_drop.hxx +2 -0
  179. data/ext/couchbase/core/operations/management/view_index_get.hxx +2 -0
  180. data/ext/couchbase/core/operations/management/view_index_get_all.hxx +2 -0
  181. data/ext/couchbase/core/operations/management/view_index_upsert.hxx +2 -0
  182. data/ext/couchbase/core/operations/operation_traits.hxx +6 -0
  183. data/ext/couchbase/core/operations.hxx +0 -1
  184. data/ext/couchbase/core/operations_fwd.hxx +8 -0
  185. data/ext/couchbase/core/origin.cxx +67 -12
  186. data/ext/couchbase/core/origin.hxx +13 -8
  187. data/ext/couchbase/core/orphan_reporter.cxx +164 -0
  188. data/ext/couchbase/core/orphan_reporter.hxx +65 -0
  189. data/ext/couchbase/core/sasl/CMakeLists.txt +1 -0
  190. data/ext/couchbase/core/sasl/client.cc +6 -0
  191. data/ext/couchbase/core/sasl/mechanism.cc +2 -1
  192. data/ext/couchbase/core/sasl/mechanism.h +2 -1
  193. data/ext/couchbase/core/sasl/oauthbearer/oauthbearer.cc +41 -0
  194. data/ext/couchbase/core/sasl/oauthbearer/oauthbearer.h +47 -0
  195. data/ext/couchbase/core/tls_context_provider.cxx +44 -0
  196. data/ext/couchbase/core/tls_context_provider.hxx +44 -0
  197. data/ext/couchbase/core/tracing/attribute_helpers.hxx +45 -0
  198. data/ext/couchbase/core/tracing/constants.hxx +148 -68
  199. data/ext/couchbase/core/tracing/threshold_logging_options.hxx +0 -3
  200. data/ext/couchbase/core/tracing/threshold_logging_tracer.cxx +122 -170
  201. data/ext/couchbase/core/tracing/tracer_wrapper.cxx +17 -24
  202. data/ext/couchbase/core/tracing/tracer_wrapper.hxx +8 -10
  203. data/ext/couchbase/core/tracing/wrapper_sdk_tracer.cxx +114 -0
  204. data/ext/couchbase/core/tracing/wrapper_sdk_tracer.hxx +85 -0
  205. data/ext/couchbase/core/transactions/attempt_context_impl.cxx +16 -14
  206. data/ext/couchbase/core/transactions/attempt_context_impl.hxx +4 -4
  207. data/ext/couchbase/core/transactions/transactions.cxx +1 -1
  208. data/ext/couchbase/core/transactions/transactions_cleanup.cxx +1 -2
  209. data/ext/couchbase/core/utils/byteswap.hxx +12 -0
  210. data/ext/couchbase/core/utils/concurrent_fixed_priority_queue.hxx +102 -0
  211. data/ext/couchbase/core/utils/connection_string.cxx +2 -0
  212. data/ext/couchbase/couchbase/certificate_authenticator.hxx +1 -0
  213. data/ext/couchbase/couchbase/cluster.hxx +47 -0
  214. data/ext/couchbase/couchbase/cluster_options.hxx +16 -0
  215. data/ext/couchbase/couchbase/collection.hxx +60 -15
  216. data/ext/couchbase/couchbase/error_codes.hxx +48 -48
  217. data/ext/couchbase/couchbase/jwt_authenticator.hxx +52 -0
  218. data/ext/couchbase/couchbase/metrics/meter.hxx +2 -1
  219. data/ext/couchbase/couchbase/metrics/otel_meter.hxx +75 -80
  220. data/ext/couchbase/couchbase/network_options.hxx +19 -0
  221. data/ext/couchbase/couchbase/password_authenticator.hxx +1 -0
  222. data/ext/couchbase/couchbase/tracing/otel_tracer.hxx +15 -17
  223. data/ext/couchbase/couchbase/tracing/request_span.hxx +2 -2
  224. data/ext/couchbase.cxx +4 -0
  225. data/ext/extconf.rb +1 -0
  226. data/ext/rcb_analytics.cxx +157 -47
  227. data/ext/rcb_backend.cxx +118 -71
  228. data/ext/rcb_buckets.cxx +39 -16
  229. data/ext/rcb_collections.cxx +36 -12
  230. data/ext/rcb_crud.cxx +587 -294
  231. data/ext/rcb_hdr_histogram.cxx +219 -0
  232. data/ext/rcb_hdr_histogram.hxx +28 -0
  233. data/ext/rcb_multi.cxx +142 -59
  234. data/ext/rcb_observability.cxx +132 -0
  235. data/ext/rcb_observability.hxx +49 -0
  236. data/ext/rcb_query.cxx +77 -27
  237. data/ext/rcb_search.cxx +92 -31
  238. data/ext/rcb_users.cxx +69 -26
  239. data/ext/rcb_utils.cxx +91 -0
  240. data/ext/rcb_utils.hxx +141 -168
  241. data/ext/rcb_views.cxx +36 -12
  242. data/lib/active_support/cache/couchbase_store.rb +6 -6
  243. data/lib/couchbase/authenticator.rb +14 -0
  244. data/lib/couchbase/binary_collection.rb +37 -22
  245. data/lib/couchbase/bucket.rb +46 -31
  246. data/lib/couchbase/cluster.rb +146 -61
  247. data/lib/couchbase/collection.rb +257 -186
  248. data/lib/couchbase/datastructures/couchbase_list.rb +81 -50
  249. data/lib/couchbase/datastructures/couchbase_map.rb +86 -50
  250. data/lib/couchbase/datastructures/couchbase_queue.rb +64 -38
  251. data/lib/couchbase/datastructures/couchbase_set.rb +57 -41
  252. data/lib/couchbase/deprecations.rb +1 -1
  253. data/lib/couchbase/diagnostics.rb +8 -8
  254. data/lib/couchbase/errors.rb +6 -0
  255. data/lib/couchbase/management/analytics_index_manager.rb +90 -59
  256. data/lib/couchbase/management/bucket_manager.rb +73 -45
  257. data/lib/couchbase/management/collection_manager.rb +86 -43
  258. data/lib/couchbase/management/collection_query_index_manager.rb +56 -33
  259. data/lib/couchbase/management/query_index_manager.rb +88 -36
  260. data/lib/couchbase/management/scope_search_index_manager.rb +119 -52
  261. data/lib/couchbase/management/search_index_manager.rb +401 -178
  262. data/lib/couchbase/management/user_manager.rb +343 -174
  263. data/lib/couchbase/management/view_index_manager.rb +166 -73
  264. data/lib/couchbase/metrics/logging_meter.rb +108 -0
  265. data/lib/couchbase/metrics/logging_value_recorder.rb +50 -0
  266. data/lib/couchbase/metrics/meter.rb +27 -0
  267. data/lib/couchbase/metrics/noop_meter.rb +30 -0
  268. data/lib/couchbase/metrics/noop_value_recorder.rb +27 -0
  269. data/lib/couchbase/metrics/value_recorder.rb +25 -0
  270. data/lib/couchbase/options.rb +69 -3
  271. data/lib/couchbase/protostellar/cluster.rb +3 -0
  272. data/lib/couchbase/scope.rb +62 -48
  273. data/lib/couchbase/search_options.rb +18 -18
  274. data/lib/couchbase/tracing/noop_span.rb +29 -0
  275. data/lib/couchbase/tracing/noop_tracer.rb +29 -0
  276. data/lib/couchbase/tracing/request_span.rb +34 -0
  277. data/lib/couchbase/tracing/request_tracer.rb +28 -0
  278. data/lib/couchbase/tracing/threshold_logging_span.rb +112 -0
  279. data/lib/couchbase/tracing/threshold_logging_tracer.rb +231 -0
  280. data/lib/couchbase/utils/hdr_histogram.rb +55 -0
  281. data/lib/couchbase/utils/observability.rb +257 -0
  282. data/lib/couchbase/utils/observability_constants.rb +200 -0
  283. data/lib/couchbase/utils/stdlib_logger_adapter.rb +1 -3
  284. data/lib/couchbase/version.rb +1 -1
  285. data/lib/couchbase.rb +2 -2
  286. metadata +58 -6
@@ -27,72 +27,151 @@ namespace couchbase::core::tracing
27
27
  {
28
28
  namespace operation
29
29
  {
30
- constexpr auto step_dispatch = "cb.dispatch_to_server";
31
- constexpr auto step_request_encoding = "cb.request_encoding";
32
- constexpr auto http_query = "cb.query";
33
- constexpr auto http_analytics = "cb.analytics";
34
- constexpr auto http_search = "cb.search";
35
- constexpr auto http_views = "cb.views";
36
- constexpr auto http_manager = "cb.manager";
37
- constexpr auto http_eventing = "cb.eventing";
38
- constexpr auto http_manager_analytics = "cb.manager_analytics";
39
- constexpr auto http_manager_query = "cb.manager_query";
40
- constexpr auto http_manager_buckets = "cb.manager_buckets";
41
- constexpr auto http_manager_collections = "cb.manager_collections";
42
- constexpr auto http_manager_search = "cb.manager_search";
43
- constexpr auto http_manager_users = "cb.manager_users";
44
- constexpr auto http_manager_views = "cb.manager_views";
45
- constexpr auto mcbp_get = "cb.get";
46
- constexpr auto mcbp_get_replica = "cb.get_replica";
47
- constexpr auto mcbp_upsert = "cb.upsert";
48
- constexpr auto mcbp_replace = "cb.replace";
49
- constexpr auto mcbp_insert = "cb.insert";
50
- constexpr auto mcbp_remove = "cb.remove";
51
- constexpr auto mcbp_get_and_lock = "cb.get_and_lock";
52
- constexpr auto mcbp_get_and_touch = "cb.get_and_touch";
53
- constexpr auto mcbp_exists = "cb.exists";
54
- constexpr auto mcbp_touch = "cb.touch";
55
- constexpr auto mcbp_unlock = "cb.unlock";
56
- constexpr auto mcbp_lookup_in = "cb.lookup_in";
57
- constexpr auto mcbp_mutate_in = "cb.mutate_in";
58
- constexpr auto mcbp_append = "cb.append";
59
- constexpr auto mcbp_prepend = "cb.prepend";
60
- constexpr auto mcbp_increment = "cb.increment";
61
- constexpr auto mcbp_decrement = "cb.decrement";
62
- constexpr auto mcbp_observe = "cb.observe";
63
- constexpr auto mcbp_range_scan_create = "cb.range_scan_create";
64
- constexpr auto mcbp_range_scan_continue = "cb.range_scan_continue";
65
- constexpr auto mcbp_range_scan_cancel = "cb.range_scan_cancel";
66
- /* multi-command operations */
67
- constexpr auto mcbp_get_all_replicas = "cb.get_all_replicas";
68
- constexpr auto mcbp_get_any_replica = "cb.get_any_replica";
69
- constexpr auto mcbp_list = "cb.list";
70
- constexpr auto mcbp_set = "cb.set";
71
- constexpr auto mcbp_map = "cb.map";
72
- constexpr auto mcbp_queue = "cb.queue";
73
- constexpr auto mcbp_ping = "cb.ping";
74
-
75
- constexpr auto mcbp_internal = "cb.internal";
30
+ constexpr auto step_dispatch = "dispatch_to_server";
31
+ constexpr auto step_request_encoding = "request_encoding";
32
+
33
+ constexpr auto query = "query";
34
+ constexpr auto analytics = "analytics";
35
+ constexpr auto search = "search";
36
+ constexpr auto views = "views";
37
+ constexpr auto manager = "manager";
38
+ constexpr auto eventing = "eventing";
39
+
40
+ // KV operations
41
+ constexpr auto mcbp_get = "get";
42
+ constexpr auto mcbp_get_replica = "get_replica";
43
+ constexpr auto mcbp_upsert = "upsert";
44
+ constexpr auto mcbp_replace = "replace";
45
+ constexpr auto mcbp_insert = "insert";
46
+ constexpr auto mcbp_remove = "remove";
47
+ constexpr auto mcbp_get_and_lock = "get_and_lock";
48
+ constexpr auto mcbp_get_and_touch = "get_and_touch";
49
+ constexpr auto mcbp_exists = "exists";
50
+ constexpr auto mcbp_touch = "touch";
51
+ constexpr auto mcbp_unlock = "unlock";
52
+ constexpr auto mcbp_lookup_in = "lookup_in";
53
+ constexpr auto mcbp_lookup_in_replica = "lookup_in_replica";
54
+ constexpr auto mcbp_mutate_in = "mutate_in";
55
+ constexpr auto mcbp_append = "append";
56
+ constexpr auto mcbp_prepend = "prepend";
57
+ constexpr auto mcbp_increment = "increment";
58
+ constexpr auto mcbp_decrement = "decrement";
59
+ constexpr auto mcbp_range_scan_create = "range_scan_create";
60
+ constexpr auto mcbp_range_scan_continue = "range_scan_continue";
61
+ constexpr auto mcbp_range_scan_cancel = "range_scan_cancel";
62
+ constexpr auto mcbp_internal = "internal";
63
+
64
+ // Multi-command operations
65
+ constexpr auto mcbp_get_all_replicas = "get_all_replicas";
66
+ constexpr auto mcbp_get_any_replica = "get_any_replica";
67
+ constexpr auto mcbp_lookup_in_all_replicas = "lookup_in_all_replicas";
68
+ constexpr auto mcbp_lookup_in_any_replica = "lookup_in_any_replica";
69
+ constexpr auto mcbp_scan = "scan";
70
+ constexpr auto ping = "ping";
71
+ constexpr auto diagnostics = "diagnostics";
72
+
73
+ // Collection management operations
74
+ constexpr auto mgr_collections_create_collection = "manager_collections_create_collection";
75
+ constexpr auto mgr_collections_drop_collection = "manager_collections_drop_collection";
76
+ constexpr auto mgr_collections_update_collection = "manager_collections_update_collection";
77
+ constexpr auto mgr_collections_create_scope = "manager_collections_create_scope";
78
+ constexpr auto mgr_collections_drop_scope = "manager_collections_drop_scope";
79
+ constexpr auto mgr_collections_get_all_scopes = "manager_collections_get_all_scopes";
80
+
81
+ // Bucket management operations
82
+ constexpr auto mgr_buckets_get_bucket = "manager_buckets_get_bucket";
83
+ constexpr auto mgr_buckets_get_all_buckets = "manager_buckets_get_all_buckets";
84
+ constexpr auto mgr_buckets_create_bucket = "manager_buckets_create_bucket";
85
+ constexpr auto mgr_buckets_update_bucket = "manager_buckets_update_bucket";
86
+ constexpr auto mgr_buckets_drop_bucket = "manager_buckets_drop_bucket";
87
+ constexpr auto mgr_buckets_flush_bucket = "manager_buckets_flush_bucket";
88
+
89
+ // Query index management operations
90
+ constexpr auto mgr_query_build_deferred_indexes = "manager_query_build_deferred_indexes";
91
+ constexpr auto mgr_query_create_index = "manager_query_create_index";
92
+ constexpr auto mgr_query_create_primary_index = "manager_query_create_primary_index";
93
+ constexpr auto mgr_query_drop_index = "manager_query_drop_index";
94
+ constexpr auto mgr_query_drop_primary_index = "manager_query_drop_primary_index";
95
+ constexpr auto mgr_query_get_all_indexes = "manager_query_get_all_indexes";
96
+ constexpr auto mgr_query_watch_indexes = "manager_query_watch_indexes";
97
+ constexpr auto mgr_query_get_all_deferred_indexes = "manager_query_get_all_deferred_indexes";
98
+ constexpr auto mgr_query_build_indexes = "manager_query_build_indexes";
99
+
100
+ // Search index management operations
101
+ constexpr auto mgr_search_get_index = "manager_search_get_index";
102
+ constexpr auto mgr_search_get_all_indexes = "manager_search_get_all_indexes";
103
+ constexpr auto mgr_search_upsert_index = "manager_search_upsert_index";
104
+ constexpr auto mgr_search_drop_index = "manager_search_drop_index";
105
+ constexpr auto mgr_search_get_indexed_documents_count =
106
+ "manager_search_get_indexed_documents_count";
107
+ constexpr auto mgr_search_pause_ingest = "manager_search_pause_ingest";
108
+ constexpr auto mgr_search_resume_ingest = "manager_search_resume_ingest";
109
+ constexpr auto mgr_search_allow_querying = "manager_search_allow_querying";
110
+ constexpr auto mgr_search_disallow_querying = "manager_search_disallow_querying";
111
+ constexpr auto mgr_search_freeze_plan = "manager_search_freeze_plan";
112
+ constexpr auto mgr_search_unfreeze_plan = "manager_search_unfreeze_plan";
113
+ constexpr auto mgr_search_analyze_document = "manager_search_analyze_document";
114
+
115
+ // Analytics index management operations
116
+ constexpr auto mgr_analytics_create_dataverse = "manager_analytics_create_dataverse";
117
+ constexpr auto mgr_analytics_drop_dataverse = "manager_analytics_drop_dataverse";
118
+ constexpr auto mgr_analytics_create_dataset = "manager_analytics_create_dataset";
119
+ constexpr auto mgr_analytics_drop_dataset = "manager_analytics_drop_dataset";
120
+ constexpr auto mgr_analytics_get_all_datasets = "manager_analytics_get_all_datasets";
121
+ constexpr auto mgr_analytics_create_index = "manager_analytics_create_index";
122
+ constexpr auto mgr_analytics_drop_index = "manager_analytics_drop_index";
123
+ constexpr auto mgr_analytics_get_all_indexes = "manager_analytics_get_all_indexes";
124
+ constexpr auto mgr_analytics_connect_link = "manager_analytics_connect_link";
125
+ constexpr auto mgr_analytics_disconnect_link = "manager_analytics_disconnect_link";
126
+ constexpr auto mgr_analytics_get_pending_mutations = "manager_analytics_get_pending_mutations";
127
+ constexpr auto mgr_analytics_create_link = "manager_analytics_create_link";
128
+ constexpr auto mgr_analytics_replace_link = "manager_analytics_replace_link";
129
+ constexpr auto mgr_analytics_drop_link = "manager_analytics_drop_link";
130
+ constexpr auto mgr_analytics_get_links = "manager_analytics_get_links";
76
131
  } // namespace operation
77
132
 
78
133
  namespace attributes
79
134
  {
80
- constexpr auto system = "db.system";
81
- constexpr auto cluster_name = "db.couchbase.cluster_name";
82
- constexpr auto cluster_uuid = "db.couchbase.cluster_uuid";
83
-
84
- constexpr auto span_kind = "span.kind";
85
- constexpr auto component = "db.couchbase.component";
86
- constexpr auto instance = "db.instance";
87
-
88
- constexpr auto orphan = "cb.orphan";
89
- constexpr auto service = "cb.service";
90
- constexpr auto operation_id = "cb.operation_id";
91
-
92
- constexpr auto server_duration = "cb.server_duration";
93
- constexpr auto local_id = "cb.local_id";
94
- constexpr auto local_socket = "cb.local_socket";
95
- constexpr auto remote_socket = "cb.remote_socket";
135
+ // Attributes present on all spans
136
+ namespace common
137
+ {
138
+ constexpr auto system = "db.system.name";
139
+ constexpr auto cluster_name = "couchbase.cluster.name";
140
+ constexpr auto cluster_uuid = "couchbase.cluster.uuid";
141
+ } // namespace common
142
+
143
+ // Operation-level attributes
144
+ namespace op
145
+ {
146
+ constexpr auto service = "couchbase.service";
147
+ constexpr auto retry_count = "couchbase.retries";
148
+ constexpr auto durability_level = "couchbase.durability";
149
+ constexpr auto bucket_name = "db.namespace";
150
+ constexpr auto scope_name = "couchbase.scope.name";
151
+ constexpr auto collection_name = "couchbase.collection.name";
152
+ constexpr auto query_statement = "db.query.text";
153
+ constexpr auto operation_name = "db.operation.name";
154
+ constexpr auto error_type = "error.type";
155
+ } // namespace op
156
+
157
+ // Dispatch-level attributes
158
+ namespace dispatch
159
+ {
160
+ constexpr auto server_duration = "couchbase.server_duration";
161
+ constexpr auto local_id = "couchbase.local_id";
162
+ constexpr auto server_address = "server.address";
163
+ constexpr auto server_port = "server.port";
164
+ constexpr auto peer_address = "network.peer.address";
165
+ constexpr auto peer_port = "network.peer.port";
166
+ constexpr auto network_transport = "network.transport";
167
+ constexpr auto operation_id = "couchbase.operation_id";
168
+ } // namespace dispatch
169
+
170
+ // Reserved attributes for internal use
171
+ namespace reserved
172
+ {
173
+ constexpr auto target_unit = "__unit";
174
+ } // namespace reserved
96
175
  } // namespace attributes
97
176
 
98
177
  namespace service
@@ -104,6 +183,7 @@ constexpr auto view = "views";
104
183
  constexpr auto analytics = "analytics";
105
184
  constexpr auto management = "management";
106
185
  constexpr auto eventing = "eventing";
186
+ constexpr auto transactions = "transactions";
107
187
  } // namespace service
108
188
 
109
189
  constexpr auto
@@ -111,22 +191,22 @@ span_name_for_http_service(service_type type)
111
191
  {
112
192
  switch (type) {
113
193
  case service_type::query:
114
- return operation::http_query;
194
+ return operation::query;
115
195
 
116
196
  case service_type::analytics:
117
- return operation::http_analytics;
197
+ return operation::analytics;
118
198
 
119
199
  case service_type::search:
120
- return operation::http_search;
200
+ return operation::search;
121
201
 
122
202
  case service_type::view:
123
- return operation::http_views;
203
+ return operation::views;
124
204
 
125
205
  case service_type::management:
126
- return operation::http_manager;
206
+ return operation::manager;
127
207
 
128
208
  case service_type::eventing:
129
- return operation::http_eventing;
209
+ return operation::eventing;
130
210
 
131
211
  case service_type::key_value:
132
212
  return "unexpected_http_service";
@@ -24,9 +24,6 @@
24
24
  namespace couchbase::core::tracing
25
25
  {
26
26
  struct threshold_logging_options {
27
- std::chrono::milliseconds orphaned_emit_interval{ std::chrono::seconds{ 10 } };
28
- std::size_t orphaned_sample_size{ 64 };
29
-
30
27
  std::chrono::milliseconds threshold_emit_interval{ std::chrono::seconds{ 10 } };
31
28
  std::size_t threshold_sample_size{ 64 };
32
29
  std::chrono::milliseconds key_value_threshold{ 500 };