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.
Files changed (179) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +2 -2
  3. data/ext/couchbase/CMakeLists.txt +22 -1
  4. data/ext/couchbase/core/bucket.cxx +183 -152
  5. data/ext/couchbase/core/bucket.hxx +17 -4
  6. data/ext/couchbase/core/cluster.hxx +41 -13
  7. data/ext/couchbase/core/cluster_options.hxx +3 -0
  8. data/ext/couchbase/core/crud_component.cxx +51 -22
  9. data/ext/couchbase/core/error_context/key_value.cxx +2 -1
  10. data/ext/couchbase/core/error_context/key_value.hxx +10 -12
  11. data/ext/couchbase/core/impl/build_deferred_query_indexes.cxx +115 -50
  12. data/ext/couchbase/core/impl/cluster.cxx +6 -0
  13. data/ext/couchbase/core/impl/create_bucket.cxx +158 -0
  14. data/ext/couchbase/core/impl/create_collection.cxx +83 -0
  15. data/ext/couchbase/core/impl/create_query_index.cxx +172 -59
  16. data/ext/couchbase/core/impl/create_scope.cxx +69 -0
  17. data/ext/couchbase/core/impl/dns_srv_tracker.cxx +2 -1
  18. data/ext/couchbase/core/impl/drop_bucket.cxx +66 -0
  19. data/ext/couchbase/core/impl/drop_collection.cxx +76 -0
  20. data/ext/couchbase/core/impl/drop_query_index.cxx +138 -59
  21. data/ext/couchbase/core/impl/drop_scope.cxx +68 -0
  22. data/ext/couchbase/core/impl/flush_bucket.cxx +66 -0
  23. data/ext/couchbase/core/impl/get_all_buckets.cxx +178 -0
  24. data/ext/couchbase/core/impl/get_all_query_indexes.cxx +67 -37
  25. data/ext/couchbase/core/impl/get_all_scopes.cxx +94 -0
  26. data/ext/couchbase/core/impl/get_bucket.cxx +168 -0
  27. data/ext/couchbase/core/impl/internal_manager_error_context.cxx +113 -0
  28. data/ext/couchbase/core/impl/internal_manager_error_context.hxx +60 -0
  29. data/ext/couchbase/core/impl/key_value_error_category.cxx +2 -4
  30. data/ext/couchbase/core/impl/key_value_error_context.cxx +98 -0
  31. data/ext/couchbase/core/impl/lookup_in.cxx +1 -0
  32. data/ext/couchbase/core/impl/lookup_in_all_replicas.cxx +178 -0
  33. data/ext/couchbase/core/impl/lookup_in_all_replicas.hxx +80 -0
  34. data/ext/couchbase/core/impl/lookup_in_any_replica.cxx +169 -0
  35. data/ext/couchbase/core/impl/lookup_in_any_replica.hxx +75 -0
  36. data/ext/couchbase/core/impl/lookup_in_replica.cxx +104 -0
  37. data/ext/couchbase/core/impl/lookup_in_replica.hxx +67 -0
  38. data/ext/couchbase/core/impl/manager_error_context.cxx +100 -0
  39. data/ext/couchbase/core/impl/query.cxx +1 -0
  40. data/ext/couchbase/core/impl/query_error_context.cxx +75 -0
  41. data/ext/couchbase/core/impl/update_bucket.cxx +133 -0
  42. data/ext/couchbase/core/impl/update_collection.cxx +83 -0
  43. data/ext/couchbase/core/impl/watch_query_indexes.cxx +53 -29
  44. data/ext/couchbase/core/io/dns_client.cxx +111 -40
  45. data/ext/couchbase/core/io/dns_config.cxx +5 -4
  46. data/ext/couchbase/core/io/http_session.hxx +24 -1
  47. data/ext/couchbase/core/io/mcbp_command.hxx +9 -2
  48. data/ext/couchbase/core/io/mcbp_session.cxx +80 -43
  49. data/ext/couchbase/core/io/mcbp_session.hxx +4 -3
  50. data/ext/couchbase/core/logger/custom_rotating_file_sink.cxx +1 -1
  51. data/ext/couchbase/core/logger/logger.cxx +80 -20
  52. data/ext/couchbase/core/logger/logger.hxx +31 -0
  53. data/ext/couchbase/core/management/bucket_settings.hxx +8 -5
  54. data/ext/couchbase/core/management/bucket_settings_json.hxx +12 -2
  55. data/ext/couchbase/core/meta/features.hxx +42 -0
  56. data/ext/couchbase/core/operations/document_lookup_in.cxx +8 -1
  57. data/ext/couchbase/core/operations/document_lookup_in_all_replicas.hxx +192 -0
  58. data/ext/couchbase/core/operations/document_lookup_in_any_replica.hxx +188 -0
  59. data/ext/couchbase/core/operations/document_query.cxx +11 -0
  60. data/ext/couchbase/core/operations/document_query.hxx +1 -0
  61. data/ext/couchbase/core/operations/management/CMakeLists.txt +1 -0
  62. data/ext/couchbase/core/operations/management/bucket_create.cxx +30 -9
  63. data/ext/couchbase/core/operations/management/bucket_update.cxx +27 -6
  64. data/ext/couchbase/core/operations/management/collection_create.cxx +5 -1
  65. data/ext/couchbase/core/operations/management/collection_create.hxx +1 -0
  66. data/ext/couchbase/core/operations/management/collection_update.cxx +87 -0
  67. data/ext/couchbase/core/operations/management/collection_update.hxx +54 -0
  68. data/ext/couchbase/core/operations/management/collections.hxx +1 -0
  69. data/ext/couchbase/core/operations.hxx +2 -0
  70. data/ext/couchbase/core/origin.cxx +270 -0
  71. data/ext/couchbase/core/origin.hxx +2 -0
  72. data/ext/couchbase/core/protocol/client_response.hxx +1 -0
  73. data/ext/couchbase/core/protocol/cmd_hello.hxx +1 -0
  74. data/ext/couchbase/core/protocol/cmd_lookup_in_replica.cxx +107 -0
  75. data/ext/couchbase/core/protocol/cmd_lookup_in_replica.hxx +137 -0
  76. data/ext/couchbase/core/protocol/hello_feature.hxx +6 -0
  77. data/ext/couchbase/core/protocol/hello_feature_fmt.hxx +3 -0
  78. data/ext/couchbase/core/protocol/status.cxx +2 -2
  79. data/ext/couchbase/core/range_scan_options.cxx +3 -27
  80. data/ext/couchbase/core/range_scan_options.hxx +13 -17
  81. data/ext/couchbase/core/range_scan_orchestrator.cxx +388 -170
  82. data/ext/couchbase/core/range_scan_orchestrator.hxx +13 -2
  83. data/ext/couchbase/core/range_scan_orchestrator_options.hxx +5 -3
  84. data/ext/couchbase/core/scan_options.hxx +0 -19
  85. data/ext/couchbase/core/scan_result.cxx +19 -5
  86. data/ext/couchbase/core/scan_result.hxx +5 -2
  87. data/ext/couchbase/core/timeout_defaults.hxx +3 -4
  88. data/ext/couchbase/core/topology/capabilities.hxx +4 -0
  89. data/ext/couchbase/core/topology/capabilities_fmt.hxx +11 -0
  90. data/ext/couchbase/core/topology/collections_manifest.hxx +2 -0
  91. data/ext/couchbase/core/topology/collections_manifest_fmt.hxx +1 -1
  92. data/ext/couchbase/core/topology/collections_manifest_json.hxx +3 -0
  93. data/ext/couchbase/core/topology/configuration.hxx +20 -0
  94. data/ext/couchbase/core/topology/configuration_json.hxx +8 -1
  95. data/ext/couchbase/core/utils/connection_string.cxx +62 -47
  96. data/ext/couchbase/core/utils/connection_string.hxx +1 -0
  97. data/ext/couchbase/couchbase/analytics_error_context.hxx +1 -1
  98. data/ext/couchbase/couchbase/behavior_options.hxx +19 -2
  99. data/ext/couchbase/couchbase/bucket.hxx +14 -0
  100. data/ext/couchbase/couchbase/bucket_manager.hxx +135 -0
  101. data/ext/couchbase/couchbase/build_query_index_options.hxx +0 -30
  102. data/ext/couchbase/couchbase/cluster.hxx +14 -0
  103. data/ext/couchbase/couchbase/collection.hxx +111 -0
  104. data/ext/couchbase/couchbase/collection_manager.hxx +160 -0
  105. data/ext/couchbase/couchbase/collection_query_index_manager.hxx +7 -48
  106. data/ext/couchbase/couchbase/create_bucket_options.hxx +41 -0
  107. data/ext/couchbase/couchbase/create_collection_options.hxx +44 -0
  108. data/ext/couchbase/couchbase/create_primary_query_index_options.hxx +0 -29
  109. data/ext/couchbase/couchbase/create_query_index_options.hxx +0 -33
  110. data/ext/couchbase/couchbase/create_scope_options.hxx +41 -0
  111. data/ext/couchbase/couchbase/drop_bucket_options.hxx +41 -0
  112. data/ext/couchbase/couchbase/drop_collection_options.hxx +41 -0
  113. data/ext/couchbase/couchbase/drop_primary_query_index_options.hxx +0 -30
  114. data/ext/couchbase/couchbase/drop_query_index_options.hxx +0 -31
  115. data/ext/couchbase/couchbase/drop_scope_options.hxx +41 -0
  116. data/ext/couchbase/couchbase/error_codes.hxx +1 -2
  117. data/ext/couchbase/couchbase/error_context.hxx +10 -2
  118. data/ext/couchbase/couchbase/flush_bucket_options.hxx +41 -0
  119. data/ext/couchbase/{core/topology/error_map_fmt.hxx → couchbase/fmt/key_value_error_map_attribute.hxx} +21 -21
  120. data/ext/couchbase/couchbase/get_all_buckets_options.hxx +44 -0
  121. data/ext/couchbase/couchbase/get_all_query_indexes_options.hxx +0 -30
  122. data/ext/couchbase/couchbase/get_all_scopes_options.hxx +44 -0
  123. data/ext/couchbase/couchbase/get_and_lock_options.hxx +2 -2
  124. data/ext/couchbase/couchbase/get_and_touch_options.hxx +2 -2
  125. data/ext/couchbase/couchbase/get_bucket_options.hxx +43 -0
  126. data/ext/couchbase/couchbase/get_options.hxx +2 -2
  127. data/ext/couchbase/couchbase/insert_options.hxx +3 -3
  128. data/ext/couchbase/couchbase/key_value_error_context.hxx +7 -2
  129. data/ext/couchbase/couchbase/lookup_in_all_replicas_options.hxx +109 -0
  130. data/ext/couchbase/couchbase/lookup_in_any_replica_options.hxx +101 -0
  131. data/ext/couchbase/couchbase/lookup_in_options.hxx +2 -2
  132. data/ext/couchbase/couchbase/lookup_in_replica_result.hxx +74 -0
  133. data/ext/couchbase/couchbase/lookup_in_result.hxx +26 -0
  134. data/ext/couchbase/couchbase/management/bucket_settings.hxx +119 -0
  135. data/ext/couchbase/couchbase/management/collection_spec.hxx +29 -0
  136. data/ext/couchbase/couchbase/management/scope_spec.hxx +29 -0
  137. data/ext/couchbase/couchbase/manager_error_context.hxx +29 -53
  138. data/ext/couchbase/couchbase/mutate_in_options.hxx +2 -2
  139. data/ext/couchbase/couchbase/query_error_context.hxx +3 -1
  140. data/ext/couchbase/couchbase/query_index_manager.hxx +16 -83
  141. data/ext/couchbase/couchbase/query_options.hxx +18 -0
  142. data/ext/couchbase/couchbase/remove_options.hxx +2 -2
  143. data/ext/couchbase/couchbase/replace_options.hxx +3 -3
  144. data/ext/couchbase/couchbase/security_options.hxx +15 -0
  145. data/ext/couchbase/couchbase/subdocument_error_context.hxx +4 -2
  146. data/ext/couchbase/couchbase/touch_options.hxx +2 -2
  147. data/ext/couchbase/couchbase/unlock_options.hxx +2 -2
  148. data/ext/couchbase/couchbase/update_bucket_options.hxx +41 -0
  149. data/ext/couchbase/couchbase/update_collection_options.hxx +44 -0
  150. data/ext/couchbase/couchbase/upsert_options.hxx +3 -3
  151. data/ext/couchbase/couchbase/watch_query_indexes_options.hxx +0 -31
  152. data/ext/couchbase/test/CMakeLists.txt +1 -0
  153. data/ext/couchbase/test/test_integration_collections.cxx +6 -0
  154. data/ext/couchbase/test/test_integration_crud.cxx +5 -0
  155. data/ext/couchbase/test/test_integration_examples.cxx +137 -1
  156. data/ext/couchbase/test/test_integration_management.cxx +1009 -309
  157. data/ext/couchbase/test/test_integration_query.cxx +19 -7
  158. data/ext/couchbase/test/test_integration_range_scan.cxx +351 -112
  159. data/ext/couchbase/test/test_integration_search.cxx +10 -1
  160. data/ext/couchbase/test/test_integration_subdoc.cxx +721 -7
  161. data/ext/couchbase/test/test_transaction_public_async_api.cxx +13 -12
  162. data/ext/couchbase/test/test_transaction_public_blocking_api.cxx +27 -21
  163. data/ext/couchbase/test/test_unit_connection_string.cxx +29 -0
  164. data/ext/couchbase/test/test_unit_query.cxx +75 -0
  165. data/ext/couchbase.cxx +735 -60
  166. data/ext/revisions.rb +3 -3
  167. data/lib/couchbase/cluster.rb +1 -1
  168. data/lib/couchbase/collection.rb +108 -0
  169. data/lib/couchbase/collection_options.rb +100 -1
  170. data/lib/couchbase/errors.rb +5 -0
  171. data/lib/couchbase/key_value_scan.rb +125 -0
  172. data/lib/couchbase/management/bucket_manager.rb +22 -15
  173. data/lib/couchbase/management/collection_manager.rb +158 -9
  174. data/lib/couchbase/options.rb +151 -0
  175. data/lib/couchbase/scope.rb +1 -1
  176. data/lib/couchbase/utils/time.rb +14 -1
  177. data/lib/couchbase/version.rb +1 -1
  178. metadata +59 -8
  179. 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
@@ -161,6 +161,7 @@ build_query_request(std::string statement, query_options::built options)
161
161
  options.readonly,
162
162
  options.flex_index,
163
163
  options.preserve_expiry,
164
+ options.use_replica,
164
165
  options.max_parallelism,
165
166
  options.scan_cap,
166
167
  options.scan_wait,
@@ -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
- void finish(manager_error_context error_ctx)
43
+ template<typename Response>
44
+ void finish(Response& resp, std::optional<std::error_code> ec = {})
54
45
  {
55
- handler_(error_ctx);
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(build_context(resp));
81
+ finish(resp);
83
82
  } else if (remaining().count() <= 0) {
84
- finish(build_context(resp, couchbase::errc::common::ambiguous_timeout));
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
- initiate_watch_query_indexes(std::shared_ptr<couchbase::core::cluster> core,
147
- std::string bucket_name,
148
- std::vector<std::string> index_names,
149
- couchbase::watch_query_indexes_options::built options,
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>(core, bucket_name, index_names, options, query_ctx, collection_name, std::move(handler));
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
- initiate_watch_query_indexes(std::shared_ptr<couchbase::core::cluster> core,
160
- std::string bucket_name,
161
- std::vector<std::string> index_names,
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
- initiate_watch_query_indexes(core, std::move(bucket_name), std::move(index_names), options, {}, "", std::move(handler));
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
- } // namespace couchbase::core::impl
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