couchbase 3.4.3 → 3.4.5
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 +22 -1
- data/ext/couchbase/core/bucket.cxx +183 -152
- data/ext/couchbase/core/bucket.hxx +17 -4
- data/ext/couchbase/core/cluster.hxx +41 -13
- data/ext/couchbase/core/cluster_options.hxx +3 -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/impl/build_deferred_query_indexes.cxx +115 -50
- data/ext/couchbase/core/impl/cluster.cxx +6 -0
- data/ext/couchbase/core/impl/create_bucket.cxx +158 -0
- data/ext/couchbase/core/impl/create_collection.cxx +83 -0
- data/ext/couchbase/core/impl/create_query_index.cxx +172 -59
- data/ext/couchbase/core/impl/create_scope.cxx +69 -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_collection.cxx +76 -0
- data/ext/couchbase/core/impl/drop_query_index.cxx +138 -59
- data/ext/couchbase/core/impl/drop_scope.cxx +68 -0
- data/ext/couchbase/core/impl/flush_bucket.cxx +66 -0
- data/ext/couchbase/core/impl/get_all_buckets.cxx +178 -0
- data/ext/couchbase/core/impl/get_all_query_indexes.cxx +67 -37
- data/ext/couchbase/core/impl/get_all_scopes.cxx +94 -0
- data/ext/couchbase/core/impl/get_bucket.cxx +168 -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/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 +178 -0
- data/ext/couchbase/core/impl/lookup_in_all_replicas.hxx +80 -0
- data/ext/couchbase/core/impl/lookup_in_any_replica.cxx +169 -0
- data/ext/couchbase/core/impl/lookup_in_any_replica.hxx +75 -0
- data/ext/couchbase/core/impl/lookup_in_replica.cxx +104 -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/query.cxx +1 -0
- data/ext/couchbase/core/impl/query_error_context.cxx +75 -0
- data/ext/couchbase/core/impl/update_bucket.cxx +133 -0
- data/ext/couchbase/core/impl/update_collection.cxx +83 -0
- data/ext/couchbase/core/impl/watch_query_indexes.cxx +53 -29
- 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_session.hxx +24 -1
- data/ext/couchbase/core/io/mcbp_command.hxx +9 -2
- data/ext/couchbase/core/io/mcbp_session.cxx +80 -43
- data/ext/couchbase/core/io/mcbp_session.hxx +4 -3
- 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/management/bucket_settings.hxx +8 -5
- data/ext/couchbase/core/management/bucket_settings_json.hxx +12 -2
- data/ext/couchbase/core/meta/features.hxx +42 -0
- data/ext/couchbase/core/operations/document_lookup_in.cxx +8 -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_query.cxx +11 -0
- data/ext/couchbase/core/operations/document_query.hxx +1 -0
- data/ext/couchbase/core/operations/management/CMakeLists.txt +1 -0
- data/ext/couchbase/core/operations/management/bucket_create.cxx +30 -9
- data/ext/couchbase/core/operations/management/bucket_update.cxx +27 -6
- data/ext/couchbase/core/operations/management/collection_create.cxx +5 -1
- data/ext/couchbase/core/operations/management/collection_create.hxx +1 -0
- data/ext/couchbase/core/operations/management/collection_update.cxx +87 -0
- data/ext/couchbase/core/operations/management/collection_update.hxx +54 -0
- data/ext/couchbase/core/operations/management/collections.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_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/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 +3 -4
- data/ext/couchbase/core/topology/capabilities.hxx +4 -0
- data/ext/couchbase/core/topology/capabilities_fmt.hxx +11 -0
- data/ext/couchbase/core/topology/collections_manifest.hxx +2 -0
- data/ext/couchbase/core/topology/collections_manifest_fmt.hxx +1 -1
- data/ext/couchbase/core/topology/collections_manifest_json.hxx +3 -0
- data/ext/couchbase/core/topology/configuration.hxx +20 -0
- data/ext/couchbase/core/topology/configuration_json.hxx +8 -1
- data/ext/couchbase/core/utils/connection_string.cxx +62 -47
- data/ext/couchbase/core/utils/connection_string.hxx +1 -0
- data/ext/couchbase/couchbase/analytics_error_context.hxx +1 -1
- data/ext/couchbase/couchbase/behavior_options.hxx +19 -2
- data/ext/couchbase/couchbase/bucket.hxx +14 -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 +14 -0
- data/ext/couchbase/couchbase/collection.hxx +111 -0
- data/ext/couchbase/couchbase/collection_manager.hxx +160 -0
- data/ext/couchbase/couchbase/collection_query_index_manager.hxx +7 -48
- data/ext/couchbase/couchbase/create_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/create_collection_options.hxx +44 -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/create_scope_options.hxx +41 -0
- data/ext/couchbase/couchbase/drop_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/drop_collection_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/drop_scope_options.hxx +41 -0
- data/ext/couchbase/couchbase/error_codes.hxx +1 -2
- data/ext/couchbase/couchbase/error_context.hxx +10 -2
- data/ext/couchbase/couchbase/flush_bucket_options.hxx +41 -0
- data/ext/couchbase/{core/topology/error_map_fmt.hxx → couchbase/fmt/key_value_error_map_attribute.hxx} +21 -21
- 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_all_scopes_options.hxx +44 -0
- 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/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 +119 -0
- data/ext/couchbase/couchbase/management/collection_spec.hxx +29 -0
- data/ext/couchbase/couchbase/management/scope_spec.hxx +29 -0
- data/ext/couchbase/couchbase/manager_error_context.hxx +29 -53
- data/ext/couchbase/couchbase/mutate_in_options.hxx +2 -2
- 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/remove_options.hxx +2 -2
- data/ext/couchbase/couchbase/replace_options.hxx +3 -3
- data/ext/couchbase/couchbase/security_options.hxx +15 -0
- data/ext/couchbase/couchbase/subdocument_error_context.hxx +4 -2
- data/ext/couchbase/couchbase/touch_options.hxx +2 -2
- data/ext/couchbase/couchbase/unlock_options.hxx +2 -2
- data/ext/couchbase/couchbase/update_bucket_options.hxx +41 -0
- data/ext/couchbase/couchbase/update_collection_options.hxx +44 -0
- data/ext/couchbase/couchbase/upsert_options.hxx +3 -3
- data/ext/couchbase/couchbase/watch_query_indexes_options.hxx +0 -31
- data/ext/couchbase/test/CMakeLists.txt +1 -0
- data/ext/couchbase/test/test_integration_collections.cxx +6 -0
- data/ext/couchbase/test/test_integration_crud.cxx +5 -0
- data/ext/couchbase/test/test_integration_examples.cxx +137 -1
- data/ext/couchbase/test/test_integration_management.cxx +1009 -309
- data/ext/couchbase/test/test_integration_query.cxx +19 -7
- data/ext/couchbase/test/test_integration_range_scan.cxx +351 -112
- data/ext/couchbase/test/test_integration_search.cxx +10 -1
- data/ext/couchbase/test/test_integration_subdoc.cxx +721 -7
- data/ext/couchbase/test/test_transaction_public_async_api.cxx +13 -12
- data/ext/couchbase/test/test_transaction_public_blocking_api.cxx +27 -21
- data/ext/couchbase/test/test_unit_connection_string.cxx +29 -0
- data/ext/couchbase/test/test_unit_query.cxx +75 -0
- data/ext/couchbase.cxx +735 -60
- data/ext/revisions.rb +3 -3
- data/lib/couchbase/cluster.rb +1 -1
- data/lib/couchbase/collection.rb +108 -0
- data/lib/couchbase/collection_options.rb +100 -1
- data/lib/couchbase/errors.rb +5 -0
- data/lib/couchbase/key_value_scan.rb +125 -0
- data/lib/couchbase/management/bucket_manager.rb +22 -15
- data/lib/couchbase/management/collection_manager.rb +158 -9
- data/lib/couchbase/options.rb +151 -0
- data/lib/couchbase/scope.rb +1 -1
- data/lib/couchbase/utils/time.rb +14 -1
- data/lib/couchbase/version.rb +1 -1
- metadata +59 -8
- data/ext/couchbase/core/impl/collection_query_index_manager.cxx +0 -93
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-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
|
+
#pragma once
|
|
19
|
+
|
|
20
|
+
#include "core/error_context/key_value.hxx"
|
|
21
|
+
#include "core/impl/subdoc/command.hxx"
|
|
22
|
+
#include "core/io/mcbp_context.hxx"
|
|
23
|
+
#include "core/io/retry_context.hxx"
|
|
24
|
+
#include "core/protocol/client_request.hxx"
|
|
25
|
+
#include "core/protocol/cmd_lookup_in_replica.hxx"
|
|
26
|
+
#include "core/public_fwd.hxx"
|
|
27
|
+
#include "core/timeout_defaults.hxx"
|
|
28
|
+
|
|
29
|
+
#include <couchbase/lookup_in_result.hxx>
|
|
30
|
+
#include <couchbase/subdocument_error_context.hxx>
|
|
31
|
+
|
|
32
|
+
namespace couchbase::core::impl
|
|
33
|
+
{
|
|
34
|
+
struct lookup_in_replica_response {
|
|
35
|
+
struct entry {
|
|
36
|
+
std::string path;
|
|
37
|
+
couchbase::codec::binary value;
|
|
38
|
+
std::size_t original_index;
|
|
39
|
+
bool exists;
|
|
40
|
+
protocol::subdoc_opcode opcode;
|
|
41
|
+
key_value_status_code status;
|
|
42
|
+
std::error_code ec{};
|
|
43
|
+
};
|
|
44
|
+
subdocument_error_context ctx{};
|
|
45
|
+
couchbase::cas cas{};
|
|
46
|
+
std::vector<entry> fields{};
|
|
47
|
+
bool deleted{ false };
|
|
48
|
+
};
|
|
49
|
+
|
|
50
|
+
struct lookup_in_replica_request {
|
|
51
|
+
using response_type = lookup_in_replica_response;
|
|
52
|
+
using encoded_request_type = protocol::client_request<protocol::lookup_in_replica_request_body>;
|
|
53
|
+
using encoded_response_type = protocol::client_response<protocol::lookup_in_replica_response_body>;
|
|
54
|
+
|
|
55
|
+
document_id id;
|
|
56
|
+
std::vector<couchbase::core::impl::subdoc::command> specs{};
|
|
57
|
+
std::optional<std::chrono::milliseconds> timeout{};
|
|
58
|
+
std::shared_ptr<couchbase::tracing::request_span> parent_span{ nullptr };
|
|
59
|
+
std::uint16_t partition{};
|
|
60
|
+
std::uint32_t opaque{};
|
|
61
|
+
io::retry_context<false> retries{};
|
|
62
|
+
|
|
63
|
+
[[nodiscard]] std::error_code encode_to(encoded_request_type& encoded, mcbp_context&& context);
|
|
64
|
+
|
|
65
|
+
[[nodiscard]] lookup_in_replica_response make_response(key_value_error_context&& ctx, const encoded_response_type& encoded) const;
|
|
66
|
+
};
|
|
67
|
+
} // namespace couchbase::core::impl
|
|
@@ -0,0 +1,100 @@
|
|
|
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 "internal_manager_error_context.hxx"
|
|
19
|
+
|
|
20
|
+
#include <couchbase/manager_error_context.hxx>
|
|
21
|
+
|
|
22
|
+
namespace couchbase
|
|
23
|
+
{
|
|
24
|
+
manager_error_context::manager_error_context()
|
|
25
|
+
: internal_{ nullptr }
|
|
26
|
+
{
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
manager_error_context::manager_error_context(internal_manager_error_context ctx)
|
|
30
|
+
: internal_{ std::make_unique<internal_manager_error_context>(std::move(ctx)) }
|
|
31
|
+
{
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
manager_error_context::manager_error_context(manager_error_context&& other) = default;
|
|
35
|
+
|
|
36
|
+
manager_error_context&
|
|
37
|
+
manager_error_context::operator=(manager_error_context&& other) = default;
|
|
38
|
+
|
|
39
|
+
manager_error_context::~manager_error_context() = default;
|
|
40
|
+
|
|
41
|
+
auto
|
|
42
|
+
manager_error_context::ec() const -> std::error_code
|
|
43
|
+
{
|
|
44
|
+
return internal_->ec();
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
auto
|
|
48
|
+
manager_error_context::last_dispatched_from() const -> const std::optional<std::string>&
|
|
49
|
+
{
|
|
50
|
+
return internal_->last_dispatched_from();
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
auto
|
|
54
|
+
manager_error_context::last_dispatched_to() const -> const std::optional<std::string>&
|
|
55
|
+
{
|
|
56
|
+
return internal_->last_dispatched_to();
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
auto
|
|
60
|
+
manager_error_context::retry_attempts() const -> std::size_t
|
|
61
|
+
{
|
|
62
|
+
return internal_->retry_attempts();
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
auto
|
|
66
|
+
manager_error_context::retry_reasons() const -> const std::set<retry_reason>&
|
|
67
|
+
{
|
|
68
|
+
return internal_->retry_reasons();
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
auto
|
|
72
|
+
manager_error_context::retried_because_of(couchbase::retry_reason reason) const -> bool
|
|
73
|
+
{
|
|
74
|
+
return internal_->retried_because_of(reason);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
auto
|
|
78
|
+
manager_error_context::path() const -> const std::string&
|
|
79
|
+
{
|
|
80
|
+
return internal_->path();
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
auto
|
|
84
|
+
manager_error_context::content() const -> const std::string&
|
|
85
|
+
{
|
|
86
|
+
return internal_->content();
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
auto
|
|
90
|
+
manager_error_context::client_context_id() const -> const std::string&
|
|
91
|
+
{
|
|
92
|
+
return internal_->client_context_id();
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
auto
|
|
96
|
+
manager_error_context::http_status() const -> std::uint32_t
|
|
97
|
+
{
|
|
98
|
+
return internal_->http_status();
|
|
99
|
+
}
|
|
100
|
+
} // namespace couchbase
|
|
@@ -0,0 +1,75 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-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 <couchbase/query_error_context.hxx>
|
|
19
|
+
|
|
20
|
+
#include <couchbase/fmt/retry_reason.hxx>
|
|
21
|
+
|
|
22
|
+
#include <tao/json/to_string.hpp>
|
|
23
|
+
|
|
24
|
+
namespace couchbase
|
|
25
|
+
{
|
|
26
|
+
auto
|
|
27
|
+
query_error_context::to_json() const -> std::string
|
|
28
|
+
{
|
|
29
|
+
tao::json::value json = {
|
|
30
|
+
{
|
|
31
|
+
"ec",
|
|
32
|
+
tao::json::value{
|
|
33
|
+
{ "value", ec().value() },
|
|
34
|
+
{ "message", ec().message() },
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
{ "operation_id", operation_id() },
|
|
38
|
+
{ "retry_attempts", retry_attempts() },
|
|
39
|
+
{ "client_context_id", client_context_id_ },
|
|
40
|
+
{ "statement", statement_ },
|
|
41
|
+
{ "method", statement_ },
|
|
42
|
+
{ "path", statement_ },
|
|
43
|
+
{ "http_status", http_status_ },
|
|
44
|
+
{ "http_body", http_body_ },
|
|
45
|
+
{ "hostname", hostname_ },
|
|
46
|
+
{ "port", port_ },
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
if (const auto& val = parameters_; val.has_value()) {
|
|
50
|
+
json["parameters"] = val.value();
|
|
51
|
+
}
|
|
52
|
+
if (first_error_code_ > 0) {
|
|
53
|
+
json["first_error_code"] = first_error_code_;
|
|
54
|
+
}
|
|
55
|
+
if (!first_error_message_.empty()) {
|
|
56
|
+
json["first_error_message"] = first_error_message_;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
if (const auto& reasons = retry_reasons(); !reasons.empty()) {
|
|
60
|
+
tao::json::value reasons_json = tao::json::empty_array;
|
|
61
|
+
for (const auto& reason : reasons) {
|
|
62
|
+
reasons_json.emplace_back(fmt::format("{}", reason));
|
|
63
|
+
}
|
|
64
|
+
json["retry_reasons"] = reasons_json;
|
|
65
|
+
}
|
|
66
|
+
if (const auto& val = last_dispatched_from(); val.has_value()) {
|
|
67
|
+
json["last_dispatched_from"] = val.value();
|
|
68
|
+
}
|
|
69
|
+
if (const auto& val = last_dispatched_to(); val.has_value()) {
|
|
70
|
+
json["last_dispatched_to"] = val.value();
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
return tao::json::to_string(json, 2);
|
|
74
|
+
}
|
|
75
|
+
} // namespace couchbase
|
|
@@ -0,0 +1,133 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-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 <couchbase/manager_error_context.hxx>
|
|
19
|
+
#include <utility>
|
|
20
|
+
|
|
21
|
+
#include "core/cluster.hxx"
|
|
22
|
+
#include "core/operations/management/bucket_update.hxx"
|
|
23
|
+
#include "couchbase/bucket_manager.hxx"
|
|
24
|
+
|
|
25
|
+
namespace couchbase
|
|
26
|
+
{
|
|
27
|
+
template<typename Response>
|
|
28
|
+
static manager_error_context
|
|
29
|
+
build_context(Response& resp)
|
|
30
|
+
{
|
|
31
|
+
return manager_error_context(internal_manager_error_context{ resp.ctx.ec,
|
|
32
|
+
resp.ctx.last_dispatched_to,
|
|
33
|
+
resp.ctx.last_dispatched_from,
|
|
34
|
+
resp.ctx.retry_attempts,
|
|
35
|
+
std::move(resp.ctx.retry_reasons),
|
|
36
|
+
std::move(resp.ctx.client_context_id),
|
|
37
|
+
resp.ctx.http_status,
|
|
38
|
+
std::move(resp.ctx.http_body),
|
|
39
|
+
std::move(resp.ctx.path) });
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
static core::operations::management::bucket_update_request
|
|
43
|
+
build_update_bucket_request(couchbase::core::management::cluster::bucket_settings bucket_settings,
|
|
44
|
+
const update_bucket_options::built& options)
|
|
45
|
+
{
|
|
46
|
+
core::operations::management::bucket_update_request request{ std::move(bucket_settings), {}, options.timeout };
|
|
47
|
+
return request;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
static couchbase::core::management::cluster::bucket_settings
|
|
51
|
+
map_bucket_settings(const couchbase::management::cluster::bucket_settings& bucket)
|
|
52
|
+
{
|
|
53
|
+
couchbase::core::management::cluster::bucket_settings bucket_settings{};
|
|
54
|
+
|
|
55
|
+
bucket_settings.name = bucket.name;
|
|
56
|
+
bucket_settings.ram_quota_mb = bucket.ram_quota_mb;
|
|
57
|
+
bucket_settings.max_expiry = bucket.max_expiry;
|
|
58
|
+
bucket_settings.minimum_durability_level = bucket.minimum_durability_level;
|
|
59
|
+
bucket_settings.num_replicas = bucket.num_replicas;
|
|
60
|
+
bucket_settings.replica_indexes = bucket.replica_indexes;
|
|
61
|
+
bucket_settings.flush_enabled = bucket.flush_enabled;
|
|
62
|
+
bucket_settings.history_retention_collection_default = bucket.history_retention_collection_default;
|
|
63
|
+
bucket_settings.history_retention_bytes = bucket.history_retention_bytes;
|
|
64
|
+
bucket_settings.history_retention_duration = bucket.history_retention_duration;
|
|
65
|
+
switch (bucket.conflict_resolution_type) {
|
|
66
|
+
case management::cluster::bucket_conflict_resolution::unknown:
|
|
67
|
+
bucket_settings.conflict_resolution_type = core::management::cluster::bucket_conflict_resolution::unknown;
|
|
68
|
+
break;
|
|
69
|
+
case management::cluster::bucket_conflict_resolution::timestamp:
|
|
70
|
+
bucket_settings.conflict_resolution_type = core::management::cluster::bucket_conflict_resolution::timestamp;
|
|
71
|
+
break;
|
|
72
|
+
case management::cluster::bucket_conflict_resolution::sequence_number:
|
|
73
|
+
bucket_settings.conflict_resolution_type = core::management::cluster::bucket_conflict_resolution::sequence_number;
|
|
74
|
+
break;
|
|
75
|
+
case management::cluster::bucket_conflict_resolution::custom:
|
|
76
|
+
bucket_settings.conflict_resolution_type = core::management::cluster::bucket_conflict_resolution::custom;
|
|
77
|
+
break;
|
|
78
|
+
}
|
|
79
|
+
switch (bucket.eviction_policy) {
|
|
80
|
+
case management::cluster::bucket_eviction_policy::unknown:
|
|
81
|
+
bucket_settings.eviction_policy = core::management::cluster::bucket_eviction_policy::unknown;
|
|
82
|
+
break;
|
|
83
|
+
case management::cluster::bucket_eviction_policy::full:
|
|
84
|
+
bucket_settings.eviction_policy = core::management::cluster::bucket_eviction_policy::full;
|
|
85
|
+
break;
|
|
86
|
+
case management::cluster::bucket_eviction_policy::value_only:
|
|
87
|
+
bucket_settings.eviction_policy = core::management::cluster::bucket_eviction_policy::value_only;
|
|
88
|
+
break;
|
|
89
|
+
case management::cluster::bucket_eviction_policy::no_eviction:
|
|
90
|
+
bucket_settings.eviction_policy = core::management::cluster::bucket_eviction_policy::no_eviction;
|
|
91
|
+
break;
|
|
92
|
+
case management::cluster::bucket_eviction_policy::not_recently_used:
|
|
93
|
+
bucket_settings.eviction_policy = core::management::cluster::bucket_eviction_policy::not_recently_used;
|
|
94
|
+
break;
|
|
95
|
+
}
|
|
96
|
+
switch (bucket.bucket_type) {
|
|
97
|
+
case management::cluster::bucket_type::unknown:
|
|
98
|
+
bucket_settings.bucket_type = core::management::cluster::bucket_type::unknown;
|
|
99
|
+
break;
|
|
100
|
+
case management::cluster::bucket_type::couchbase:
|
|
101
|
+
bucket_settings.bucket_type = core::management::cluster::bucket_type::couchbase;
|
|
102
|
+
break;
|
|
103
|
+
case management::cluster::bucket_type::memcached:
|
|
104
|
+
bucket_settings.bucket_type = core::management::cluster::bucket_type::memcached;
|
|
105
|
+
break;
|
|
106
|
+
case management::cluster::bucket_type::ephemeral:
|
|
107
|
+
bucket_settings.bucket_type = core::management::cluster::bucket_type::ephemeral;
|
|
108
|
+
break;
|
|
109
|
+
}
|
|
110
|
+
return bucket_settings;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
void
|
|
114
|
+
bucket_manager::update_bucket(const management::cluster::bucket_settings& bucket_settings,
|
|
115
|
+
const update_bucket_options& options,
|
|
116
|
+
update_bucket_handler&& handler) const
|
|
117
|
+
{
|
|
118
|
+
auto request = build_update_bucket_request(map_bucket_settings(bucket_settings), options.build());
|
|
119
|
+
|
|
120
|
+
core_->execute(std::move(request), [handler = std::move(handler)](core::operations::management::bucket_update_response resp) mutable {
|
|
121
|
+
return handler(build_context(resp));
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
auto
|
|
126
|
+
bucket_manager::update_bucket(const management::cluster::bucket_settings& bucket_settings, const update_bucket_options& options) const
|
|
127
|
+
-> std::future<manager_error_context>
|
|
128
|
+
{
|
|
129
|
+
auto barrier = std::make_shared<std::promise<manager_error_context>>();
|
|
130
|
+
update_bucket(bucket_settings, options, [barrier](auto ctx) mutable { barrier->set_value(std::move(ctx)); });
|
|
131
|
+
return barrier->get_future();
|
|
132
|
+
}
|
|
133
|
+
} // namespace couchbase
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
/* -*- Mode: C++; tab-width: 4; c-basic-offset: 4; indent-tabs-mode: nil -*- */
|
|
2
|
+
/*
|
|
3
|
+
* Copyright 2020-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 <couchbase/manager_error_context.hxx>
|
|
19
|
+
|
|
20
|
+
#include "core/cluster.hxx"
|
|
21
|
+
#include "core/operations/management/collection_update.hxx"
|
|
22
|
+
#include "couchbase/collection_manager.hxx"
|
|
23
|
+
|
|
24
|
+
namespace couchbase
|
|
25
|
+
{
|
|
26
|
+
template<typename Response>
|
|
27
|
+
static manager_error_context
|
|
28
|
+
build_context(Response& resp)
|
|
29
|
+
{
|
|
30
|
+
return manager_error_context(internal_manager_error_context{ resp.ctx.ec,
|
|
31
|
+
resp.ctx.last_dispatched_to,
|
|
32
|
+
resp.ctx.last_dispatched_from,
|
|
33
|
+
resp.ctx.retry_attempts,
|
|
34
|
+
std::move(resp.ctx.retry_reasons),
|
|
35
|
+
std::move(resp.ctx.client_context_id),
|
|
36
|
+
resp.ctx.http_status,
|
|
37
|
+
std::move(resp.ctx.http_body),
|
|
38
|
+
std::move(resp.ctx.path) });
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
static core::operations::management::collection_update_request
|
|
42
|
+
build_collection_update_request(std::string bucket_name,
|
|
43
|
+
std::string scope_name,
|
|
44
|
+
std::string collection_name,
|
|
45
|
+
const update_collection_settings& settings,
|
|
46
|
+
const update_collection_options::built& options)
|
|
47
|
+
{
|
|
48
|
+
core::operations::management::collection_update_request request{
|
|
49
|
+
std::move(bucket_name), std::move(scope_name), std::move(collection_name), settings.max_expiry, settings.history, {},
|
|
50
|
+
options.timeout
|
|
51
|
+
};
|
|
52
|
+
return request;
|
|
53
|
+
}
|
|
54
|
+
|
|
55
|
+
void
|
|
56
|
+
collection_manager::update_collection(std::string scope_name,
|
|
57
|
+
std::string collection_name,
|
|
58
|
+
const couchbase::update_collection_settings& settings,
|
|
59
|
+
const couchbase::update_collection_options& options,
|
|
60
|
+
couchbase::update_collection_handler&& handler) const
|
|
61
|
+
{
|
|
62
|
+
auto request =
|
|
63
|
+
build_collection_update_request(bucket_name_, std::move(scope_name), std::move(collection_name), settings, options.build());
|
|
64
|
+
|
|
65
|
+
core_->execute(std::move(request),
|
|
66
|
+
[handler = std::move(handler)](core::operations::management::collection_update_response resp) mutable {
|
|
67
|
+
return handler(build_context(resp));
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
|
|
71
|
+
auto
|
|
72
|
+
collection_manager::update_collection(std::string scope_name,
|
|
73
|
+
std::string collection_name,
|
|
74
|
+
const couchbase::update_collection_settings& settings,
|
|
75
|
+
const couchbase::update_collection_options& options) const -> std::future<manager_error_context>
|
|
76
|
+
{
|
|
77
|
+
auto barrier = std::make_shared<std::promise<manager_error_context>>();
|
|
78
|
+
update_collection(std::move(scope_name), std::move(collection_name), settings, options, [barrier](auto ctx) mutable {
|
|
79
|
+
barrier->set_value(std::move(ctx));
|
|
80
|
+
});
|
|
81
|
+
return barrier->get_future();
|
|
82
|
+
}
|
|
83
|
+
} // namespace couchbase
|
|
@@ -24,16 +24,6 @@
|
|
|
24
24
|
|
|
25
25
|
namespace couchbase::core::impl
|
|
26
26
|
{
|
|
27
|
-
|
|
28
|
-
template<typename Response>
|
|
29
|
-
static manager_error_context
|
|
30
|
-
build_context(Response& resp, std::optional<std::error_code> ec = {})
|
|
31
|
-
{
|
|
32
|
-
return { ec ? ec.value() : resp.ctx.ec, resp.ctx.last_dispatched_to, resp.ctx.last_dispatched_from,
|
|
33
|
-
resp.ctx.retry_attempts, std::move(resp.ctx.retry_reasons), std::move(resp.ctx.client_context_id),
|
|
34
|
-
resp.ctx.http_status, std::move(resp.ctx.http_body), std::move(resp.ctx.path) };
|
|
35
|
-
}
|
|
36
|
-
|
|
37
27
|
class watch_context : public std::enable_shared_from_this<watch_context>
|
|
38
28
|
{
|
|
39
29
|
|
|
@@ -50,9 +40,18 @@ class watch_context : public std::enable_shared_from_this<watch_context>
|
|
|
50
40
|
std::chrono::milliseconds timeout_{ options_.timeout.value_or(core_->origin().second.options().query_timeout) };
|
|
51
41
|
std::atomic<size_t> attempts_{ 0 };
|
|
52
42
|
|
|
53
|
-
|
|
43
|
+
template<typename Response>
|
|
44
|
+
void finish(Response& resp, std::optional<std::error_code> ec = {})
|
|
54
45
|
{
|
|
55
|
-
handler_(
|
|
46
|
+
handler_({ manager_error_context(internal_manager_error_context{ ec ? ec.value() : resp.ctx.ec,
|
|
47
|
+
resp.ctx.last_dispatched_to,
|
|
48
|
+
resp.ctx.last_dispatched_from,
|
|
49
|
+
resp.ctx.retry_attempts,
|
|
50
|
+
std::move(resp.ctx.retry_reasons),
|
|
51
|
+
std::move(resp.ctx.client_context_id),
|
|
52
|
+
resp.ctx.http_status,
|
|
53
|
+
std::move(resp.ctx.http_body),
|
|
54
|
+
std::move(resp.ctx.path) }) });
|
|
56
55
|
timer_.cancel();
|
|
57
56
|
}
|
|
58
57
|
std::chrono::milliseconds remaining()
|
|
@@ -79,9 +78,9 @@ class watch_context : public std::enable_shared_from_this<watch_context>
|
|
|
79
78
|
complete &= it != resp.indexes.end() && it->state == "online";
|
|
80
79
|
}
|
|
81
80
|
if (complete || resp.ctx.ec == couchbase::errc::common::ambiguous_timeout) {
|
|
82
|
-
finish(
|
|
81
|
+
finish(resp);
|
|
83
82
|
} else if (remaining().count() <= 0) {
|
|
84
|
-
finish(
|
|
83
|
+
finish(resp, couchbase::errc::common::ambiguous_timeout);
|
|
85
84
|
complete = true;
|
|
86
85
|
}
|
|
87
86
|
return complete;
|
|
@@ -141,28 +140,53 @@ class watch_context : public std::enable_shared_from_this<watch_context>
|
|
|
141
140
|
core_->execute(req, resp_fn);
|
|
142
141
|
}
|
|
143
142
|
};
|
|
143
|
+
} // namespace couchbase::core::impl
|
|
144
144
|
|
|
145
|
+
namespace couchbase
|
|
146
|
+
{
|
|
145
147
|
void
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
query_context query_ctx,
|
|
151
|
-
std::string collection_name,
|
|
152
|
-
watch_query_indexes_handler&& handler)
|
|
148
|
+
query_index_manager::watch_indexes(std::string bucket_name,
|
|
149
|
+
std::vector<std::string> index_names,
|
|
150
|
+
const couchbase::watch_query_indexes_options& options,
|
|
151
|
+
couchbase::watch_query_indexes_handler&& handler)
|
|
153
152
|
{
|
|
154
|
-
auto ctx = std::make_shared<watch_context>(
|
|
153
|
+
auto ctx = std::make_shared<couchbase::core::impl::watch_context>(
|
|
154
|
+
core_, std::move(bucket_name), std::move(index_names), options.build(), core::query_context{}, "", std::move(handler));
|
|
155
155
|
ctx->execute();
|
|
156
156
|
}
|
|
157
157
|
|
|
158
|
+
auto
|
|
159
|
+
query_index_manager::watch_indexes(std::string bucket_name,
|
|
160
|
+
std::vector<std::string> index_names,
|
|
161
|
+
const couchbase::watch_query_indexes_options& options) -> std::future<manager_error_context>
|
|
162
|
+
{
|
|
163
|
+
auto barrier = std::make_shared<std::promise<manager_error_context>>();
|
|
164
|
+
watch_indexes(
|
|
165
|
+
std::move(bucket_name), std::move(index_names), options, [barrier](auto ctx) mutable { barrier->set_value(std::move(ctx)); });
|
|
166
|
+
return barrier->get_future();
|
|
167
|
+
}
|
|
168
|
+
|
|
158
169
|
void
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
couchbase::watch_query_indexes_options::built options,
|
|
163
|
-
watch_query_indexes_handler&& handler)
|
|
170
|
+
collection_query_index_manager::watch_indexes(std::vector<std::string> index_names,
|
|
171
|
+
const watch_query_indexes_options& options,
|
|
172
|
+
watch_query_indexes_handler&& handler) const
|
|
164
173
|
{
|
|
165
|
-
|
|
174
|
+
auto ctx = std::make_shared<couchbase::core::impl::watch_context>(core_,
|
|
175
|
+
bucket_name_,
|
|
176
|
+
std::move(index_names),
|
|
177
|
+
options.build(),
|
|
178
|
+
core::query_context(bucket_name_, scope_name_),
|
|
179
|
+
collection_name_,
|
|
180
|
+
std::move(handler));
|
|
181
|
+
ctx->execute();
|
|
166
182
|
}
|
|
167
183
|
|
|
168
|
-
|
|
184
|
+
auto
|
|
185
|
+
collection_query_index_manager::watch_indexes(std::vector<std::string> index_names, const couchbase::watch_query_indexes_options& options)
|
|
186
|
+
-> std::future<manager_error_context>
|
|
187
|
+
{
|
|
188
|
+
auto barrier = std::make_shared<std::promise<manager_error_context>>();
|
|
189
|
+
watch_indexes(std::move(index_names), options, [barrier](auto ctx) mutable { barrier->set_value(std::move(ctx)); });
|
|
190
|
+
return barrier->get_future();
|
|
191
|
+
}
|
|
192
|
+
} // namespace couchbase
|