couchbase 3.4.2 → 3.4.4
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.
- checksums.yaml +4 -4
- data/README.md +2 -2
- data/ext/couchbase/CMakeLists.txt +71 -7
- data/ext/couchbase/cmake/Documentation.cmake +0 -1
- data/ext/couchbase/cmake/OpenSSL.cmake +98 -3
- data/ext/couchbase/cmake/Testing.cmake +12 -4
- data/ext/couchbase/cmake/build_config.hxx.in +3 -0
- data/ext/couchbase/core/bucket.cxx +183 -151
- data/ext/couchbase/core/bucket.hxx +23 -1
- data/ext/couchbase/core/cluster.hxx +51 -13
- data/ext/couchbase/core/cluster_options.cxx +2 -2
- data/ext/couchbase/core/cluster_options.hxx +7 -6
- data/ext/couchbase/core/cluster_options_fwd.hxx +26 -0
- data/ext/couchbase/core/config_profile.hxx +1 -54
- data/ext/couchbase/core/config_profiles.cxx +79 -0
- data/ext/couchbase/core/config_profiles.hxx +56 -0
- data/ext/couchbase/core/crud_component.cxx +51 -22
- data/ext/couchbase/core/error_context/key_value.cxx +2 -1
- data/ext/couchbase/core/error_context/key_value.hxx +10 -12
- data/ext/couchbase/core/error_context/search.hxx +1 -1
- data/ext/couchbase/core/impl/analytics.cxx +1 -0
- data/ext/couchbase/core/impl/boolean_field_query.cxx +40 -0
- data/ext/couchbase/core/impl/boolean_query.cxx +62 -0
- data/ext/couchbase/core/impl/build_deferred_query_indexes.cxx +115 -50
- data/ext/couchbase/core/impl/cluster.cxx +8 -0
- data/ext/couchbase/core/impl/conjunction_query.cxx +51 -0
- data/ext/couchbase/core/impl/create_bucket.cxx +155 -0
- data/ext/couchbase/core/impl/create_query_index.cxx +172 -59
- data/ext/couchbase/core/impl/date_range.cxx +89 -0
- data/ext/couchbase/core/impl/date_range_facet.cxx +54 -0
- data/ext/couchbase/core/impl/date_range_facet_result.cxx +64 -0
- data/ext/couchbase/core/impl/date_range_query.cxx +125 -0
- data/ext/couchbase/core/impl/disjunction_query.cxx +51 -0
- data/ext/couchbase/core/impl/dns_srv_tracker.cxx +2 -1
- data/ext/couchbase/core/impl/drop_bucket.cxx +66 -0
- data/ext/couchbase/core/impl/drop_query_index.cxx +138 -59
- data/ext/couchbase/core/impl/encoded_search_facet.hxx +29 -0
- data/ext/couchbase/core/impl/encoded_search_query.hxx +29 -0
- data/ext/couchbase/core/impl/encoded_search_sort.hxx +29 -0
- data/ext/couchbase/core/impl/flush_bucket.cxx +66 -0
- data/ext/couchbase/core/impl/geo_bounding_box_query.cxx +46 -0
- data/ext/couchbase/core/impl/geo_distance_query.cxx +43 -0
- data/ext/couchbase/core/impl/geo_polygon_query.cxx +46 -0
- data/ext/couchbase/core/impl/get_all_buckets.cxx +163 -0
- data/ext/couchbase/core/impl/get_all_query_indexes.cxx +67 -37
- data/ext/couchbase/core/impl/get_bucket.cxx +153 -0
- data/ext/couchbase/core/impl/internal_date_range_facet_result.cxx +80 -0
- data/ext/couchbase/core/impl/internal_date_range_facet_result.hxx +48 -0
- data/ext/couchbase/core/impl/internal_manager_error_context.cxx +113 -0
- data/ext/couchbase/core/impl/internal_manager_error_context.hxx +60 -0
- data/ext/couchbase/core/impl/internal_numeric_range_facet_result.cxx +80 -0
- data/ext/couchbase/core/impl/internal_numeric_range_facet_result.hxx +48 -0
- data/ext/couchbase/core/impl/internal_search_error_context.cxx +141 -0
- data/ext/couchbase/core/impl/internal_search_error_context.hxx +61 -0
- data/ext/couchbase/core/impl/internal_search_meta_data.cxx +60 -0
- data/ext/couchbase/core/impl/internal_search_meta_data.hxx +41 -0
- data/ext/couchbase/core/impl/internal_search_result.cxx +84 -0
- data/ext/couchbase/core/impl/internal_search_result.hxx +43 -0
- data/ext/couchbase/core/impl/internal_search_row.cxx +82 -0
- data/ext/couchbase/core/impl/internal_search_row.hxx +56 -0
- data/ext/couchbase/core/impl/internal_search_row_location.hxx +32 -0
- data/ext/couchbase/core/impl/internal_search_row_locations.cxx +137 -0
- data/ext/couchbase/core/impl/internal_search_row_locations.hxx +45 -0
- data/ext/couchbase/core/impl/internal_term_facet_result.cxx +80 -0
- data/ext/couchbase/core/impl/internal_term_facet_result.hxx +48 -0
- data/ext/couchbase/core/impl/key_value_error_category.cxx +2 -4
- data/ext/couchbase/core/impl/key_value_error_context.cxx +98 -0
- data/ext/couchbase/core/impl/lookup_in.cxx +1 -0
- data/ext/couchbase/core/impl/lookup_in_all_replicas.cxx +176 -0
- data/ext/couchbase/core/impl/lookup_in_all_replicas.hxx +80 -0
- data/ext/couchbase/core/impl/lookup_in_any_replica.cxx +167 -0
- data/ext/couchbase/core/impl/lookup_in_any_replica.hxx +75 -0
- data/ext/couchbase/core/impl/lookup_in_replica.cxx +97 -0
- data/ext/couchbase/core/impl/lookup_in_replica.hxx +67 -0
- data/ext/couchbase/core/impl/manager_error_context.cxx +100 -0
- data/ext/couchbase/core/impl/match_all_query.cxx +35 -0
- data/ext/couchbase/core/impl/match_none_query.cxx +35 -0
- data/ext/couchbase/core/impl/match_phrase_query.cxx +43 -0
- data/ext/couchbase/core/impl/match_query.cxx +59 -0
- data/ext/couchbase/core/impl/numeric_range.cxx +49 -0
- data/ext/couchbase/core/impl/numeric_range_facet.cxx +54 -0
- data/ext/couchbase/core/impl/numeric_range_facet_result.cxx +64 -0
- data/ext/couchbase/core/impl/numeric_range_query.cxx +56 -0
- data/ext/couchbase/core/impl/phrase_query.cxx +42 -0
- data/ext/couchbase/core/impl/prefix_query.cxx +40 -0
- data/ext/couchbase/core/impl/query.cxx +1 -0
- data/ext/couchbase/core/impl/query_error_context.cxx +75 -0
- data/ext/couchbase/core/impl/query_string_query.cxx +37 -0
- data/ext/couchbase/core/impl/regexp_query.cxx +40 -0
- data/ext/couchbase/core/impl/search.cxx +191 -0
- data/ext/couchbase/core/impl/search_error_context.cxx +147 -0
- data/ext/couchbase/core/impl/search_meta_data.cxx +46 -0
- data/ext/couchbase/core/impl/search_result.cxx +66 -0
- data/ext/couchbase/core/impl/search_row.cxx +74 -0
- data/ext/couchbase/core/impl/search_row_location.cxx +64 -0
- data/ext/couchbase/core/impl/search_row_locations.cxx +66 -0
- data/ext/couchbase/core/impl/search_sort_field.cxx +104 -0
- data/ext/couchbase/core/impl/search_sort_id.cxx +43 -0
- data/ext/couchbase/core/impl/search_sort_score.cxx +43 -0
- data/ext/couchbase/core/impl/term_facet.cxx +36 -0
- data/ext/couchbase/core/impl/term_facet_result.cxx +64 -0
- data/ext/couchbase/core/impl/term_query.cxx +56 -0
- data/ext/couchbase/core/impl/term_range_query.cxx +57 -0
- data/ext/couchbase/core/impl/update_bucket.cxx +130 -0
- data/ext/couchbase/core/impl/watch_query_indexes.cxx +53 -29
- data/ext/couchbase/core/impl/wildcard_query.cxx +40 -0
- data/ext/couchbase/core/io/dns_client.cxx +111 -40
- data/ext/couchbase/core/io/dns_config.cxx +5 -4
- data/ext/couchbase/core/io/http_context.hxx +1 -1
- data/ext/couchbase/core/io/http_session.hxx +34 -1
- data/ext/couchbase/core/io/http_session_manager.hxx +5 -3
- data/ext/couchbase/core/io/mcbp_command.hxx +9 -2
- data/ext/couchbase/core/io/mcbp_session.cxx +106 -42
- data/ext/couchbase/core/io/mcbp_session.hxx +4 -3
- data/ext/couchbase/core/io/retry_orchestrator.hxx +3 -2
- data/ext/couchbase/core/json_string.hxx +5 -0
- data/ext/couchbase/core/logger/custom_rotating_file_sink.cxx +1 -1
- data/ext/couchbase/core/logger/logger.cxx +80 -20
- data/ext/couchbase/core/logger/logger.hxx +31 -0
- data/ext/couchbase/core/meta/features.hxx +25 -0
- data/ext/couchbase/core/meta/version.cxx +18 -4
- data/ext/couchbase/core/mozilla_ca_bundle.hxx +39 -0
- data/ext/couchbase/core/operations/document_analytics.cxx +1 -0
- data/ext/couchbase/core/operations/document_analytics.hxx +1 -0
- data/ext/couchbase/core/operations/document_append.hxx +1 -1
- data/ext/couchbase/core/operations/document_decrement.hxx +1 -1
- data/ext/couchbase/core/operations/document_exists.hxx +1 -1
- data/ext/couchbase/core/operations/document_get.hxx +1 -1
- data/ext/couchbase/core/operations/document_get_and_lock.hxx +1 -1
- data/ext/couchbase/core/operations/document_get_and_touch.hxx +1 -1
- data/ext/couchbase/core/operations/document_get_projected.hxx +1 -1
- data/ext/couchbase/core/operations/document_increment.hxx +1 -1
- data/ext/couchbase/core/operations/document_insert.hxx +1 -1
- data/ext/couchbase/core/operations/document_lookup_in.hxx +1 -1
- data/ext/couchbase/core/operations/document_lookup_in_all_replicas.hxx +192 -0
- data/ext/couchbase/core/operations/document_lookup_in_any_replica.hxx +188 -0
- data/ext/couchbase/core/operations/document_mutate_in.hxx +1 -1
- data/ext/couchbase/core/operations/document_prepend.hxx +1 -1
- data/ext/couchbase/core/operations/document_query.cxx +13 -0
- data/ext/couchbase/core/operations/document_query.hxx +7 -0
- data/ext/couchbase/core/operations/document_remove.hxx +1 -1
- data/ext/couchbase/core/operations/document_replace.hxx +1 -1
- data/ext/couchbase/core/operations/document_search.cxx +4 -1
- data/ext/couchbase/core/operations/document_search.hxx +2 -1
- data/ext/couchbase/core/operations/document_touch.hxx +1 -1
- data/ext/couchbase/core/operations/document_unlock.hxx +1 -1
- data/ext/couchbase/core/operations/document_upsert.hxx +1 -1
- data/ext/couchbase/core/operations/document_view.hxx +1 -0
- data/ext/couchbase/core/operations.hxx +2 -0
- data/ext/couchbase/core/origin.cxx +270 -0
- data/ext/couchbase/core/origin.hxx +2 -0
- data/ext/couchbase/core/protocol/client_request.hxx +11 -2
- data/ext/couchbase/core/protocol/client_response.hxx +1 -0
- data/ext/couchbase/core/protocol/cmd_hello.hxx +1 -0
- data/ext/couchbase/core/protocol/cmd_lookup_in_replica.cxx +107 -0
- data/ext/couchbase/core/protocol/cmd_lookup_in_replica.hxx +137 -0
- data/ext/couchbase/core/protocol/hello_feature.hxx +6 -0
- data/ext/couchbase/core/protocol/hello_feature_fmt.hxx +3 -0
- data/ext/couchbase/core/protocol/status.cxx +2 -2
- data/ext/couchbase/core/public_fwd.hxx +21 -0
- data/ext/couchbase/core/range_scan_options.cxx +3 -27
- data/ext/couchbase/core/range_scan_options.hxx +13 -17
- data/ext/couchbase/core/range_scan_orchestrator.cxx +388 -170
- data/ext/couchbase/core/range_scan_orchestrator.hxx +13 -2
- data/ext/couchbase/core/range_scan_orchestrator_options.hxx +5 -3
- data/ext/couchbase/core/scan_options.hxx +0 -19
- data/ext/couchbase/core/scan_result.cxx +19 -5
- data/ext/couchbase/core/scan_result.hxx +5 -2
- data/ext/couchbase/core/timeout_defaults.hxx +2 -3
- data/ext/couchbase/core/tls_verify_mode.hxx +26 -0
- data/ext/couchbase/core/topology/capabilities.hxx +3 -0
- data/ext/couchbase/core/topology/capabilities_fmt.hxx +8 -0
- data/ext/couchbase/core/topology/collections_manifest_fmt.hxx +1 -1
- data/ext/couchbase/core/topology/configuration.cxx +15 -2
- data/ext/couchbase/core/topology/configuration.hxx +20 -1
- data/ext/couchbase/core/topology/configuration_json.hxx +6 -1
- data/ext/couchbase/core/transactions/attempt_context_testing_hooks.cxx +93 -0
- data/ext/couchbase/core/transactions/attempt_context_testing_hooks.hxx +48 -75
- data/ext/couchbase/core/transactions/cleanup_testing_hooks.cxx +52 -0
- data/ext/couchbase/core/transactions/cleanup_testing_hooks.hxx +17 -31
- data/ext/couchbase/core/transactions/exceptions.hxx +12 -9
- data/ext/couchbase/core/utils/connection_string.cxx +75 -43
- data/ext/couchbase/core/utils/connection_string.hxx +1 -0
- data/ext/couchbase/core/utils/json.cxx +4 -1
- data/ext/couchbase/couchbase/analytics_error_context.hxx +1 -1
- data/ext/couchbase/couchbase/behavior_options.hxx +27 -1
- data/ext/couchbase/couchbase/boolean_field_query.hxx +77 -0
- data/ext/couchbase/couchbase/boolean_query.hxx +223 -0
- data/ext/couchbase/couchbase/bucket_manager.hxx +135 -0
- data/ext/couchbase/couchbase/build_query_index_options.hxx +0 -30
- data/ext/couchbase/couchbase/cluster.hxx +56 -1
- data/ext/couchbase/couchbase/collection.hxx +111 -0
- data/ext/couchbase/couchbase/collection_query_index_manager.hxx +7 -48
- data/ext/couchbase/couchbase/conjunction_query.hxx +88 -0
- data/ext/couchbase/couchbase/create_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/create_primary_query_index_options.hxx +0 -29
- data/ext/couchbase/couchbase/create_query_index_options.hxx +0 -33
- data/ext/couchbase/couchbase/date_range.hxx +69 -0
- data/ext/couchbase/couchbase/date_range_facet.hxx +56 -0
- data/ext/couchbase/couchbase/date_range_facet_result.hxx +55 -0
- data/ext/couchbase/couchbase/date_range_query.hxx +265 -0
- data/ext/couchbase/couchbase/disjunction_query.hxx +109 -0
- data/ext/couchbase/couchbase/doc_id_query.hxx +111 -0
- data/ext/couchbase/couchbase/drop_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/drop_primary_query_index_options.hxx +0 -30
- data/ext/couchbase/couchbase/drop_query_index_options.hxx +0 -31
- data/ext/couchbase/couchbase/error_codes.hxx +1 -2
- data/ext/couchbase/couchbase/error_context.hxx +17 -8
- data/ext/couchbase/couchbase/flush_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/fmt/analytics_scan_consistency.hxx +52 -0
- data/ext/couchbase/{core/topology/error_map_fmt.hxx → couchbase/fmt/key_value_error_map_attribute.hxx} +21 -21
- data/ext/couchbase/couchbase/fmt/search_scan_consistency.hxx +49 -0
- data/ext/couchbase/couchbase/geo_bounding_box_query.hxx +107 -0
- data/ext/couchbase/couchbase/geo_distance_query.hxx +109 -0
- data/ext/couchbase/couchbase/geo_point.hxx +32 -0
- data/ext/couchbase/couchbase/geo_polygon_query.hxx +85 -0
- data/ext/couchbase/couchbase/get_all_buckets_options.hxx +44 -0
- data/ext/couchbase/couchbase/get_all_query_indexes_options.hxx +0 -30
- data/ext/couchbase/couchbase/get_and_lock_options.hxx +2 -2
- data/ext/couchbase/couchbase/get_and_touch_options.hxx +2 -2
- data/ext/couchbase/couchbase/get_bucket_options.hxx +43 -0
- data/ext/couchbase/couchbase/get_options.hxx +2 -2
- data/ext/couchbase/couchbase/highlight_style.hxx +45 -0
- data/ext/couchbase/couchbase/insert_options.hxx +3 -3
- data/ext/couchbase/couchbase/key_value_error_context.hxx +7 -2
- data/ext/couchbase/couchbase/lookup_in_all_replicas_options.hxx +109 -0
- data/ext/couchbase/couchbase/lookup_in_any_replica_options.hxx +101 -0
- data/ext/couchbase/couchbase/lookup_in_options.hxx +2 -2
- data/ext/couchbase/couchbase/lookup_in_replica_result.hxx +74 -0
- data/ext/couchbase/couchbase/lookup_in_result.hxx +26 -0
- data/ext/couchbase/couchbase/management/bucket_settings.hxx +116 -0
- data/ext/couchbase/couchbase/manager_error_context.hxx +29 -53
- data/ext/couchbase/couchbase/match_all_query.hxx +43 -0
- data/ext/couchbase/couchbase/match_none_query.hxx +43 -0
- data/ext/couchbase/couchbase/match_operator.hxx +45 -0
- data/ext/couchbase/couchbase/match_phrase_query.hxx +108 -0
- data/ext/couchbase/couchbase/match_query.hxx +163 -0
- data/ext/couchbase/couchbase/mutate_in_options.hxx +2 -2
- data/ext/couchbase/couchbase/numeric_range.hxx +58 -0
- data/ext/couchbase/couchbase/numeric_range_facet.hxx +56 -0
- data/ext/couchbase/couchbase/numeric_range_facet_result.hxx +55 -0
- data/ext/couchbase/couchbase/numeric_range_query.hxx +143 -0
- data/ext/couchbase/couchbase/phrase_query.hxx +93 -0
- data/ext/couchbase/couchbase/prefix_query.hxx +82 -0
- data/ext/couchbase/couchbase/query_error_context.hxx +3 -1
- data/ext/couchbase/couchbase/query_index_manager.hxx +16 -83
- data/ext/couchbase/couchbase/query_options.hxx +18 -0
- data/ext/couchbase/couchbase/query_string_query.hxx +72 -0
- data/ext/couchbase/couchbase/regexp_query.hxx +82 -0
- data/ext/couchbase/couchbase/remove_options.hxx +2 -2
- data/ext/couchbase/couchbase/replace_options.hxx +3 -3
- data/ext/couchbase/couchbase/scope.hxx +40 -0
- data/ext/couchbase/couchbase/search_date_range.hxx +68 -0
- data/ext/couchbase/couchbase/search_error_context.hxx +138 -0
- data/ext/couchbase/couchbase/search_facet.hxx +60 -0
- data/ext/couchbase/couchbase/search_facet_result.hxx +50 -0
- data/ext/couchbase/couchbase/search_meta_data.hxx +85 -0
- data/ext/couchbase/couchbase/search_metrics.hxx +127 -0
- data/ext/couchbase/couchbase/search_numeric_range.hxx +69 -0
- data/ext/couchbase/couchbase/search_options.hxx +509 -0
- data/ext/couchbase/couchbase/search_query.hxx +69 -0
- data/ext/couchbase/couchbase/search_result.hxx +77 -0
- data/ext/couchbase/couchbase/search_row.hxx +104 -0
- data/ext/couchbase/couchbase/search_row_location.hxx +55 -0
- data/ext/couchbase/couchbase/search_row_locations.hxx +86 -0
- data/ext/couchbase/couchbase/search_scan_consistency.hxx +34 -0
- data/ext/couchbase/couchbase/search_sort.hxx +58 -0
- data/ext/couchbase/couchbase/search_sort_field.hxx +117 -0
- data/ext/couchbase/couchbase/search_sort_field_missing.hxx +26 -0
- data/ext/couchbase/couchbase/search_sort_field_mode.hxx +27 -0
- data/ext/couchbase/couchbase/search_sort_field_type.hxx +28 -0
- data/ext/couchbase/couchbase/search_sort_id.hxx +60 -0
- data/ext/couchbase/couchbase/search_sort_score.hxx +60 -0
- data/ext/couchbase/couchbase/search_term_range.hxx +51 -0
- data/ext/couchbase/couchbase/security_options.hxx +18 -0
- data/ext/couchbase/couchbase/subdocument_error_context.hxx +4 -2
- data/ext/couchbase/couchbase/term_facet.hxx +48 -0
- data/ext/couchbase/couchbase/term_facet_result.hxx +55 -0
- data/ext/couchbase/couchbase/term_query.hxx +151 -0
- data/ext/couchbase/couchbase/term_range_query.hxx +142 -0
- data/ext/couchbase/couchbase/touch_options.hxx +2 -2
- data/ext/couchbase/couchbase/tracing/request_span.hxx +63 -0
- data/ext/couchbase/couchbase/tracing/request_tracer.hxx +2 -40
- data/ext/couchbase/couchbase/transactions/async_attempt_context.hxx +83 -4
- data/ext/couchbase/couchbase/transactions/attempt_context.hxx +67 -0
- data/ext/couchbase/couchbase/transactions/transaction_get_result.hxx +2 -0
- data/ext/couchbase/couchbase/transactions/transaction_keyspace.hxx +11 -1
- data/ext/couchbase/couchbase/transactions/transaction_options.hxx +79 -8
- data/ext/couchbase/couchbase/transactions/transaction_query_options.hxx +128 -15
- data/ext/couchbase/couchbase/transactions/transaction_query_result.hxx +4 -0
- data/ext/couchbase/couchbase/transactions/transaction_result.hxx +1 -1
- data/ext/couchbase/couchbase/transactions/transactions_cleanup_config.hxx +5 -3
- data/ext/couchbase/couchbase/transactions/transactions_config.hxx +9 -5
- data/ext/couchbase/couchbase/transactions/transactions_query_config.hxx +6 -3
- data/ext/couchbase/couchbase/transactions.hxx +34 -1
- data/ext/couchbase/couchbase/unlock_options.hxx +2 -2
- data/ext/couchbase/couchbase/update_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/upsert_options.hxx +3 -3
- data/ext/couchbase/couchbase/watch_query_indexes_options.hxx +0 -31
- data/ext/couchbase/couchbase/wildcard_query.hxx +83 -0
- data/ext/couchbase/test/CMakeLists.txt +8 -5
- data/ext/couchbase/test/benchmark_helper_integration.hxx +2 -2
- data/ext/couchbase/test/test_helper.hxx +5 -5
- data/ext/couchbase/test/test_integration_analytics.cxx +28 -6
- data/ext/couchbase/test/test_integration_collections.cxx +13 -3
- data/ext/couchbase/test/test_integration_connect.cxx +7 -3
- data/ext/couchbase/test/test_integration_crud.cxx +18 -3
- data/ext/couchbase/test/test_integration_diagnostics.cxx +11 -5
- data/ext/couchbase/test/test_integration_durability.cxx +12 -7
- data/ext/couchbase/test/test_integration_examples.cxx +419 -11
- data/ext/couchbase/test/test_integration_management.cxx +867 -368
- data/ext/couchbase/test/test_integration_query.cxx +87 -17
- data/ext/couchbase/test/test_integration_range_scan.cxx +363 -124
- data/ext/couchbase/test/test_integration_read_replica.cxx +48 -11
- data/ext/couchbase/test/test_integration_search.cxx +32 -3
- data/ext/couchbase/test/test_integration_subdoc.cxx +717 -11
- data/ext/couchbase/test/test_integration_tracer.cxx +5 -0
- data/ext/couchbase/test/test_integration_transcoders.cxx +13 -5
- data/ext/couchbase/test/{test_transaction_transaction_context.cxx → test_transaction_context.cxx} +1 -1
- data/ext/couchbase/test/test_transaction_examples.cxx +195 -0
- data/ext/couchbase/test/{test_transaction_transaction_public_async_api.cxx → test_transaction_public_async_api.cxx} +13 -12
- data/ext/couchbase/test/{test_transaction_transaction_public_blocking_api.cxx → test_transaction_public_blocking_api.cxx} +27 -21
- data/ext/couchbase/test/{test_transaction_transaction_simple.cxx → test_transaction_simple.cxx} +17 -5
- data/ext/couchbase/test/{test_transaction_transaction_simple_async.cxx → test_transaction_simple_async.cxx} +19 -21
- data/ext/couchbase/test/test_unit_config_profiles.cxx +1 -1
- data/ext/couchbase/test/test_unit_connection_string.cxx +29 -0
- data/ext/couchbase/test/test_unit_json_transcoder.cxx +4 -0
- data/ext/couchbase/test/test_unit_query.cxx +75 -0
- data/ext/couchbase/test/test_unit_search.cxx +427 -0
- data/ext/couchbase/test/test_unit_transaction_utils.cxx +10 -1
- data/ext/couchbase/test/test_unit_utils.cxx +8 -4
- data/ext/couchbase.cxx +641 -45
- data/ext/revisions.rb +3 -3
- data/lib/couchbase/authenticator.rb +0 -1
- data/lib/couchbase/cluster.rb +1 -5
- data/lib/couchbase/collection.rb +108 -0
- data/lib/couchbase/collection_options.rb +100 -0
- data/lib/couchbase/config_profiles.rb +1 -1
- data/lib/couchbase/errors.rb +5 -0
- data/lib/couchbase/json_transcoder.rb +12 -5
- data/lib/couchbase/key_value_scan.rb +125 -0
- data/lib/couchbase/management/collection_query_index_manager.rb +54 -15
- data/lib/couchbase/management/query_index_manager.rb +70 -5
- data/lib/couchbase/options.rb +151 -0
- data/lib/couchbase/raw_binary_transcoder.rb +37 -0
- data/lib/couchbase/raw_json_transcoder.rb +38 -0
- data/lib/couchbase/raw_string_transcoder.rb +40 -0
- data/lib/couchbase/scope.rb +1 -1
- data/lib/couchbase/search_options.rb +5 -0
- data/lib/couchbase/transcoder_flags.rb +62 -0
- data/lib/couchbase/utils/time.rb +14 -1
- data/lib/couchbase/version.rb +1 -1
- metadata +175 -13
- data/ext/couchbase/core/config_profile.cxx +0 -47
- data/ext/couchbase/core/impl/collection_query_index_manager.cxx +0 -93
|
@@ -25,6 +25,7 @@
|
|
|
25
25
|
#include "core/transactions/cleanup_testing_hooks.hxx"
|
|
26
26
|
#include "service_type.hxx"
|
|
27
27
|
#include "timeout_defaults.hxx"
|
|
28
|
+
#include "tls_verify_mode.hxx"
|
|
28
29
|
|
|
29
30
|
#include <couchbase/best_effort_retry_strategy.hxx>
|
|
30
31
|
#include <couchbase/metrics/meter.hxx>
|
|
@@ -32,16 +33,10 @@
|
|
|
32
33
|
#include <couchbase/transactions/transactions_config.hxx>
|
|
33
34
|
|
|
34
35
|
#include <chrono>
|
|
35
|
-
#include <list>
|
|
36
36
|
#include <string>
|
|
37
37
|
|
|
38
38
|
namespace couchbase::core
|
|
39
39
|
{
|
|
40
|
-
enum class tls_verify_mode {
|
|
41
|
-
none,
|
|
42
|
-
peer,
|
|
43
|
-
};
|
|
44
|
-
|
|
45
40
|
struct cluster_options {
|
|
46
41
|
std::chrono::milliseconds bootstrap_timeout = timeout_defaults::bootstrap_timeout;
|
|
47
42
|
std::chrono::milliseconds resolve_timeout = timeout_defaults::resolve_timeout;
|
|
@@ -55,7 +50,10 @@ struct cluster_options {
|
|
|
55
50
|
std::chrono::milliseconds management_timeout = timeout_defaults::management_timeout;
|
|
56
51
|
|
|
57
52
|
bool enable_tls{ false };
|
|
53
|
+
bool tls_disable_deprecated_protocols{ true };
|
|
54
|
+
bool tls_disable_v1_2{ false };
|
|
58
55
|
std::string trust_certificate{};
|
|
56
|
+
std::string trust_certificate_value{};
|
|
59
57
|
bool enable_mutation_tokens{ true };
|
|
60
58
|
bool enable_tcp_keep_alive{ true };
|
|
61
59
|
io::ip_protocol use_ip_protocol{ io::ip_protocol::any };
|
|
@@ -86,6 +84,9 @@ struct cluster_options {
|
|
|
86
84
|
couchbase::transactions::transactions_config::built transactions{};
|
|
87
85
|
|
|
88
86
|
[[nodiscard]] std::chrono::milliseconds default_timeout_for(service_type type) const;
|
|
87
|
+
|
|
88
|
+
bool dump_configuration{ false };
|
|
89
|
+
bool disable_mozilla_ca_certificates{ false };
|
|
89
90
|
void apply_profile(std::string profile_name);
|
|
90
91
|
};
|
|
91
92
|
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-2021 Couchbase, Inc.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
#pragma once
|
|
19
|
+
|
|
20
|
+
namespace couchbase
|
|
21
|
+
{
|
|
22
|
+
namespace core
|
|
23
|
+
{
|
|
24
|
+
struct cluster_options;
|
|
25
|
+
} // namespace core
|
|
26
|
+
} // namespace couchbase
|
|
@@ -16,13 +16,7 @@
|
|
|
16
16
|
*/
|
|
17
17
|
#pragma once
|
|
18
18
|
|
|
19
|
-
#include "
|
|
20
|
-
#include <chrono>
|
|
21
|
-
#include <fmt/core.h>
|
|
22
|
-
#include <map>
|
|
23
|
-
#include <mutex>
|
|
24
|
-
#include <stdexcept>
|
|
25
|
-
#include <string>
|
|
19
|
+
#include "cluster_options_fwd.hxx"
|
|
26
20
|
|
|
27
21
|
namespace couchbase::core
|
|
28
22
|
{
|
|
@@ -32,51 +26,4 @@ class config_profile
|
|
|
32
26
|
virtual ~config_profile() = default;
|
|
33
27
|
virtual void apply(cluster_options&) = 0;
|
|
34
28
|
};
|
|
35
|
-
|
|
36
|
-
class development_profile : public config_profile
|
|
37
|
-
{
|
|
38
|
-
public:
|
|
39
|
-
void apply(couchbase::core::cluster_options& opts) override;
|
|
40
|
-
};
|
|
41
|
-
|
|
42
|
-
// this class just registers the known profiles defined above, and allows access to them.
|
|
43
|
-
class config_profiles
|
|
44
|
-
{
|
|
45
|
-
private:
|
|
46
|
-
std::map<std::string, std::shared_ptr<couchbase::core::config_profile>> profiles_;
|
|
47
|
-
std::mutex mut_;
|
|
48
|
-
|
|
49
|
-
public:
|
|
50
|
-
config_profiles() noexcept
|
|
51
|
-
{
|
|
52
|
-
// add all known profiles (above) to the map
|
|
53
|
-
register_profile<development_profile>("wan_development");
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
void apply(const std::string& profile_name, couchbase::core::cluster_options& opts)
|
|
57
|
-
{
|
|
58
|
-
std::lock_guard<std::mutex> lock(mut_);
|
|
59
|
-
auto it = profiles_.find(profile_name);
|
|
60
|
-
if (it != profiles_.end()) {
|
|
61
|
-
it->second->apply(opts);
|
|
62
|
-
} else {
|
|
63
|
-
throw std::invalid_argument(fmt::format("unknown profile '{}'", profile_name));
|
|
64
|
-
}
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
template<typename T, typename... Args>
|
|
68
|
-
void register_profile(const std::string& name, Args... args)
|
|
69
|
-
{
|
|
70
|
-
// This will just add it, doesn't look to see if it is overwriting an existing profile.
|
|
71
|
-
// TODO: perhaps add a template Args param?
|
|
72
|
-
// TODO: should we make this thread-safe? Easy enough here, but we'd need to make the
|
|
73
|
-
// singleton thread-safe too.
|
|
74
|
-
std::lock_guard<std::mutex> lock(mut_);
|
|
75
|
-
profiles_.emplace(std::make_pair(name, std::make_shared<T>(args...)));
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
|
|
79
|
-
config_profiles&
|
|
80
|
-
known_profiles();
|
|
81
|
-
|
|
82
29
|
} // namespace couchbase::core
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-2021 Couchbase, Inc.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
#include "config_profiles.hxx"
|
|
19
|
+
|
|
20
|
+
#include "cluster_options.hxx"
|
|
21
|
+
|
|
22
|
+
#include <fmt/core.h>
|
|
23
|
+
|
|
24
|
+
#include <chrono>
|
|
25
|
+
#include <stdexcept>
|
|
26
|
+
|
|
27
|
+
namespace couchbase::core
|
|
28
|
+
{
|
|
29
|
+
class development_profile : public config_profile
|
|
30
|
+
{
|
|
31
|
+
public:
|
|
32
|
+
void apply(couchbase::core::cluster_options& opts) override
|
|
33
|
+
{
|
|
34
|
+
opts.key_value_timeout = std::chrono::seconds(20);
|
|
35
|
+
opts.key_value_durable_timeout = std::chrono::seconds(20);
|
|
36
|
+
opts.connect_timeout = std::chrono::seconds(20);
|
|
37
|
+
opts.view_timeout = std::chrono::minutes(2);
|
|
38
|
+
opts.query_timeout = std::chrono::minutes(2);
|
|
39
|
+
opts.analytics_timeout = std::chrono::minutes(2);
|
|
40
|
+
opts.search_timeout = std::chrono::minutes(2);
|
|
41
|
+
opts.management_timeout = std::chrono::minutes(2);
|
|
42
|
+
|
|
43
|
+
// C++SDK specific
|
|
44
|
+
opts.dns_config = couchbase::core::io::dns::dns_config{
|
|
45
|
+
opts.dns_config.nameserver(),
|
|
46
|
+
opts.dns_config.port(),
|
|
47
|
+
std::chrono::seconds(20), // timeout to make DNS-SRV query
|
|
48
|
+
};
|
|
49
|
+
opts.resolve_timeout = std::chrono::seconds(20); // timeout to resolve hostnames
|
|
50
|
+
opts.bootstrap_timeout = std::chrono::minutes(2); // overall timeout to bootstrap
|
|
51
|
+
}
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
config_profiles::config_profiles() noexcept
|
|
55
|
+
{
|
|
56
|
+
// add all known profiles (above) to the map
|
|
57
|
+
register_profile<development_profile>("wan_development");
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
void
|
|
61
|
+
config_profiles::apply(const std::string& profile_name, couchbase::core::cluster_options& opts)
|
|
62
|
+
{
|
|
63
|
+
std::lock_guard<std::mutex> lock(mut_);
|
|
64
|
+
auto it = profiles_.find(profile_name);
|
|
65
|
+
if (it != profiles_.end()) {
|
|
66
|
+
it->second->apply(opts);
|
|
67
|
+
} else {
|
|
68
|
+
throw std::invalid_argument(fmt::format("unknown profile '{}'", profile_name));
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
config_profiles&
|
|
73
|
+
known_profiles()
|
|
74
|
+
{
|
|
75
|
+
static config_profiles profiles{};
|
|
76
|
+
return profiles;
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
} // namespace couchbase::core
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-2021 Couchbase, Inc.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
#pragma once
|
|
18
|
+
|
|
19
|
+
#include "cluster_options_fwd.hxx"
|
|
20
|
+
#include "config_profile.hxx"
|
|
21
|
+
|
|
22
|
+
#include <map>
|
|
23
|
+
#include <memory>
|
|
24
|
+
#include <mutex>
|
|
25
|
+
#include <string>
|
|
26
|
+
|
|
27
|
+
namespace couchbase::core
|
|
28
|
+
{
|
|
29
|
+
// this class just registers the known profiles defined above, and allows access to them.
|
|
30
|
+
class config_profiles
|
|
31
|
+
{
|
|
32
|
+
private:
|
|
33
|
+
std::map<std::string, std::shared_ptr<config_profile>, std::less<>> profiles_;
|
|
34
|
+
mutable std::mutex mut_;
|
|
35
|
+
|
|
36
|
+
public:
|
|
37
|
+
config_profiles() noexcept;
|
|
38
|
+
|
|
39
|
+
void apply(const std::string& profile_name, couchbase::core::cluster_options& opts);
|
|
40
|
+
|
|
41
|
+
template<typename T, typename... Args>
|
|
42
|
+
void register_profile(const std::string& name, Args... args)
|
|
43
|
+
{
|
|
44
|
+
// This will just add it, doesn't look to see if it is overwriting an existing profile.
|
|
45
|
+
// TODO: perhaps add a template Args param?
|
|
46
|
+
// TODO: should we make this thread-safe? Easy enough here, but we'd need to make the
|
|
47
|
+
// singleton thread-safe too.
|
|
48
|
+
const std::scoped_lock lock(mut_);
|
|
49
|
+
profiles_.emplace(std::make_pair(name, std::make_shared<T>(args...)));
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
config_profiles&
|
|
54
|
+
known_profiles();
|
|
55
|
+
|
|
56
|
+
} // namespace couchbase::core
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
2
|
/*
|
|
3
|
-
* Copyright 2020-
|
|
3
|
+
* Copyright 2020-2023 Couchbase, Inc.
|
|
4
4
|
*
|
|
5
5
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
6
|
* you may not use this file except in compliance with the License.
|
|
@@ -39,6 +39,8 @@
|
|
|
39
39
|
|
|
40
40
|
#include <tl/expected.hpp>
|
|
41
41
|
|
|
42
|
+
#include <random>
|
|
43
|
+
|
|
42
44
|
namespace couchbase::core
|
|
43
45
|
{
|
|
44
46
|
static std::pair<std::vector<std::byte>, std::error_code>
|
|
@@ -53,17 +55,40 @@ serialize_range_scan_create_options(const range_scan_create_options& options)
|
|
|
53
55
|
body["collection"] = fmt::format("{:x}", options.collection_id);
|
|
54
56
|
}
|
|
55
57
|
|
|
56
|
-
if (std::holds_alternative<range_scan>(options.scan_type)) {
|
|
57
|
-
const auto& range = std::
|
|
58
|
+
if (std::holds_alternative<range_scan>(options.scan_type) || std::holds_alternative<prefix_scan>(options.scan_type)) {
|
|
59
|
+
const auto& range = (std::holds_alternative<range_scan>(options.scan_type))
|
|
60
|
+
? std::get<range_scan>(options.scan_type)
|
|
61
|
+
: std::get<prefix_scan>(options.scan_type).to_range_scan();
|
|
62
|
+
|
|
63
|
+
const auto& from = range.from.value_or(scan_term{ "" });
|
|
64
|
+
const auto& to = range.to.value_or(scan_term{ "\xf4\x8f\xfb\xfb" });
|
|
65
|
+
|
|
58
66
|
body["range"] = {
|
|
59
|
-
{
|
|
60
|
-
{
|
|
67
|
+
{ from.exclusive ? "excl_start" : "start", base64::encode(from.term) },
|
|
68
|
+
{ to.exclusive ? "excl_end" : "end", base64::encode(to.term) },
|
|
61
69
|
};
|
|
62
70
|
} else if (std::holds_alternative<sampling_scan>(options.scan_type)) {
|
|
63
71
|
const auto& sampling = std::get<sampling_scan>(options.scan_type);
|
|
72
|
+
|
|
73
|
+
// The limit in sampling scan is required to be greater than 0
|
|
74
|
+
if (sampling.limit <= 0) {
|
|
75
|
+
return { {}, errc::common::invalid_argument };
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
std::uint64_t seed{};
|
|
79
|
+
if (sampling.seed.has_value()) {
|
|
80
|
+
seed = sampling.seed.value();
|
|
81
|
+
} else {
|
|
82
|
+
// Generate random uint64 as seed
|
|
83
|
+
std::random_device rd;
|
|
84
|
+
std::mt19937_64 gen(rd());
|
|
85
|
+
std::uniform_int_distribution<std::uint64_t> dis;
|
|
86
|
+
seed = dis(gen);
|
|
87
|
+
}
|
|
88
|
+
|
|
64
89
|
body["sampling"] = {
|
|
65
90
|
{ "samples", sampling.limit },
|
|
66
|
-
{ "seed",
|
|
91
|
+
{ "seed", seed },
|
|
67
92
|
};
|
|
68
93
|
} else {
|
|
69
94
|
return { {}, errc::common::invalid_argument };
|
|
@@ -75,7 +100,7 @@ serialize_range_scan_create_options(const range_scan_create_options& options)
|
|
|
75
100
|
{ "vb_uuid", std::to_string(snapshot.vbucket_uuid) },
|
|
76
101
|
{ "seqno", snapshot.sequence_number },
|
|
77
102
|
{ "timeout_ms",
|
|
78
|
-
(options.timeout == std::chrono::milliseconds::zero()) ? timeout_defaults::
|
|
103
|
+
(options.timeout == std::chrono::milliseconds::zero()) ? timeout_defaults::key_value_scan_timeout.count()
|
|
79
104
|
: options.timeout.count() },
|
|
80
105
|
};
|
|
81
106
|
if (snapshot.sequence_number_exists) {
|
|
@@ -98,7 +123,7 @@ parse_range_scan_keys(gsl::span<std::byte> data, range_scan_item_callback&& item
|
|
|
98
123
|
if (remaining.size() < key_length) {
|
|
99
124
|
return errc::network::protocol_error;
|
|
100
125
|
}
|
|
101
|
-
item_callback(range_scan_item{ { remaining.
|
|
126
|
+
item_callback(range_scan_item{ { reinterpret_cast<const char*>(remaining.data()), key_length } });
|
|
102
127
|
if (remaining.size() == key_length) {
|
|
103
128
|
return {};
|
|
104
129
|
}
|
|
@@ -130,13 +155,13 @@ parse_range_scan_documents(gsl::span<std::byte> data, range_scan_item_callback&&
|
|
|
130
155
|
body.datatype = data[24];
|
|
131
156
|
data = gsl::make_span(data.data() + header_offset, data.size() - header_offset);
|
|
132
157
|
|
|
133
|
-
std::
|
|
158
|
+
std::string key{};
|
|
134
159
|
{
|
|
135
160
|
auto [key_length, remaining] = utils::decode_unsigned_leb128<std::size_t>(data, core::utils::leb_128_no_throw{});
|
|
136
161
|
if (remaining.size() < key_length) {
|
|
137
162
|
return errc::network::protocol_error;
|
|
138
163
|
}
|
|
139
|
-
key = { remaining.
|
|
164
|
+
key = { reinterpret_cast<const char*>(remaining.data()), key_length };
|
|
140
165
|
data = gsl::make_span(remaining.data() + key_length, remaining.size() - key_length);
|
|
141
166
|
}
|
|
142
167
|
|
|
@@ -242,19 +267,10 @@ class crud_component_impl
|
|
|
242
267
|
if (error) {
|
|
243
268
|
return cb({}, error);
|
|
244
269
|
}
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
case 4:
|
|
248
|
-
ids_only = mcbp::big_endian::read_uint32(response->extras_, 0) == 0;
|
|
249
|
-
break;
|
|
250
|
-
|
|
251
|
-
case 0:
|
|
252
|
-
ids_only = options.ids_only; // support servers before MB-54267. TODO: remove after server GA
|
|
253
|
-
break;
|
|
254
|
-
|
|
255
|
-
default:
|
|
256
|
-
return cb({}, errc::network::protocol_error);
|
|
270
|
+
if (response->extras_.size() != 4) {
|
|
271
|
+
return cb({}, errc::network::protocol_error);
|
|
257
272
|
}
|
|
273
|
+
bool ids_only = mcbp::big_endian::read_uint32(response->extras_, 0) == 0;
|
|
258
274
|
|
|
259
275
|
if (auto ec = parse_range_scan_data(response->value_, std::move(item_cb), ids_only); ec) {
|
|
260
276
|
return cb({}, ec);
|
|
@@ -276,6 +292,19 @@ class crud_component_impl
|
|
|
276
292
|
|
|
277
293
|
req->persistent_ = true;
|
|
278
294
|
req->vbucket_ = vbucket_id;
|
|
295
|
+
|
|
296
|
+
if (options.timeout != std::chrono::milliseconds::zero()) {
|
|
297
|
+
auto timer = std::make_shared<asio::steady_timer>(io_);
|
|
298
|
+
timer->expires_after(options.timeout);
|
|
299
|
+
timer->async_wait([req](auto error) {
|
|
300
|
+
if (error == asio::error::operation_aborted) {
|
|
301
|
+
return;
|
|
302
|
+
}
|
|
303
|
+
req->cancel(couchbase::errc::common::unambiguous_timeout);
|
|
304
|
+
});
|
|
305
|
+
req->set_deadline(timer);
|
|
306
|
+
}
|
|
307
|
+
|
|
279
308
|
mcbp::buffer_writer buf{ scan_uuid.size() + sizeof(std::uint32_t) * 3 };
|
|
280
309
|
buf.write(scan_uuid);
|
|
281
310
|
buf.write_uint32(options.batch_item_limit);
|
|
@@ -24,7 +24,7 @@ key_value_error_context
|
|
|
24
24
|
make_key_value_error_context(std::error_code ec, const document_id& id)
|
|
25
25
|
{
|
|
26
26
|
return {
|
|
27
|
-
ec, {}, {}, 0, {}, id.key(), id.bucket(), id.scope(), id.collection(), 0, {}, {}, {}, {},
|
|
27
|
+
{}, ec, {}, {}, 0, {}, id.key(), id.bucket(), id.scope(), id.collection(), 0, {}, {}, {}, {},
|
|
28
28
|
};
|
|
29
29
|
}
|
|
30
30
|
|
|
@@ -36,6 +36,7 @@ make_subdocument_error_context(const key_value_error_context& ctx,
|
|
|
36
36
|
bool deleted)
|
|
37
37
|
{
|
|
38
38
|
return {
|
|
39
|
+
ctx.operation_id(),
|
|
39
40
|
ec,
|
|
40
41
|
ctx.last_dispatched_to(),
|
|
41
42
|
ctx.last_dispatched_from(),
|
|
@@ -43,23 +43,21 @@ make_key_value_error_context(std::error_code ec, std::uint16_t status_code, cons
|
|
|
43
43
|
const auto& scope = command->request.id.scope();
|
|
44
44
|
const auto& bucket = command->request.id.bucket();
|
|
45
45
|
std::uint32_t opaque = (ec && response.opaque() == 0) ? command->request.opaque : response.opaque();
|
|
46
|
-
|
|
47
|
-
auto retry_attempts = command->request.retries.retry_attempts();
|
|
48
|
-
auto retry_reasons = command->request.retries.retry_reasons();
|
|
49
|
-
std::optional<std::string> last_dispatched_from{};
|
|
50
|
-
std::optional<std::string> last_dispatched_to{};
|
|
46
|
+
std::optional<key_value_status_code> status{};
|
|
51
47
|
std::optional<key_value_error_map_info> error_map_info{};
|
|
52
|
-
if (
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
if (status_code) {
|
|
48
|
+
if (status_code != 0xffffU) {
|
|
49
|
+
status = response.status();
|
|
50
|
+
if (command->session_ && status_code > 0) {
|
|
56
51
|
error_map_info = command->session_->decode_error_code(status_code);
|
|
57
52
|
}
|
|
58
53
|
}
|
|
54
|
+
auto retry_attempts = command->request.retries.retry_attempts();
|
|
55
|
+
auto retry_reasons = command->request.retries.retry_reasons();
|
|
59
56
|
|
|
60
|
-
return {
|
|
61
|
-
|
|
62
|
-
|
|
57
|
+
return { command->id_,
|
|
58
|
+
ec,
|
|
59
|
+
command->last_dispatched_to_,
|
|
60
|
+
command->last_dispatched_from_,
|
|
63
61
|
retry_attempts,
|
|
64
62
|
std::move(retry_reasons),
|
|
65
63
|
key,
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2023-Present Couchbase, Inc.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
#include "encoded_search_query.hxx"
|
|
19
|
+
|
|
20
|
+
#include <couchbase/boolean_field_query.hxx>
|
|
21
|
+
|
|
22
|
+
namespace couchbase
|
|
23
|
+
{
|
|
24
|
+
auto
|
|
25
|
+
boolean_field_query::encode() const -> encoded_search_query
|
|
26
|
+
{
|
|
27
|
+
encoded_search_query built;
|
|
28
|
+
|
|
29
|
+
built.query = tao::json::empty_object;
|
|
30
|
+
if (boost_) {
|
|
31
|
+
built.query["boost"] = boost_.value();
|
|
32
|
+
}
|
|
33
|
+
built.query["bool"] = bool_;
|
|
34
|
+
if (field_) {
|
|
35
|
+
built.query["field"] = field_.value();
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
return built;
|
|
39
|
+
}
|
|
40
|
+
} // namespace couchbase
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2023-Present Couchbase, Inc.
|
|
4
|
+
*
|
|
5
|
+
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
6
|
+
* you may not use this file except in compliance with the License.
|
|
7
|
+
* You may obtain a copy of the License at
|
|
8
|
+
*
|
|
9
|
+
* http://www.apache.org/licenses/LICENSE-2.0
|
|
10
|
+
*
|
|
11
|
+
* Unless required by applicable law or agreed to in writing, software
|
|
12
|
+
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
13
|
+
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
14
|
+
* See the License for the specific language governing permissions and
|
|
15
|
+
* limitations under the License.
|
|
16
|
+
*/
|
|
17
|
+
|
|
18
|
+
#include "encoded_search_query.hxx"
|
|
19
|
+
|
|
20
|
+
#include <couchbase/boolean_query.hxx>
|
|
21
|
+
|
|
22
|
+
#include <couchbase/error_codes.hxx>
|
|
23
|
+
|
|
24
|
+
namespace couchbase
|
|
25
|
+
{
|
|
26
|
+
auto
|
|
27
|
+
boolean_query::encode() const -> encoded_search_query
|
|
28
|
+
{
|
|
29
|
+
if (!must_ && !should_ && !must_not_) {
|
|
30
|
+
return { errc::common::invalid_argument };
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
encoded_search_query built;
|
|
34
|
+
built.query = tao::json::empty_object;
|
|
35
|
+
if (boost_) {
|
|
36
|
+
built.query["boost"] = boost_.value();
|
|
37
|
+
}
|
|
38
|
+
if (must_) {
|
|
39
|
+
auto encoded = must_->encode();
|
|
40
|
+
if (encoded.ec) {
|
|
41
|
+
return { encoded.ec };
|
|
42
|
+
}
|
|
43
|
+
built.query["must"] = encoded.query;
|
|
44
|
+
}
|
|
45
|
+
if (must_not_) {
|
|
46
|
+
auto encoded = must_not_->encode();
|
|
47
|
+
if (encoded.ec) {
|
|
48
|
+
return { encoded.ec };
|
|
49
|
+
}
|
|
50
|
+
built.query["must_not"] = encoded.query;
|
|
51
|
+
}
|
|
52
|
+
if (should_) {
|
|
53
|
+
auto encoded = should_->encode();
|
|
54
|
+
if (encoded.ec) {
|
|
55
|
+
return { encoded.ec };
|
|
56
|
+
}
|
|
57
|
+
built.query["should"] = encoded.query;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
return built;
|
|
61
|
+
}
|
|
62
|
+
} // namespace couchbase
|