elasticsearch-api 7.14.1 → 7.16.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (188) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +14 -35
  3. data/Rakefile +0 -14
  4. data/elasticsearch-api.gemspec +13 -5
  5. data/lib/elasticsearch/api/actions/bulk.rb +2 -2
  6. data/lib/elasticsearch/api/actions/cat/aliases.rb +1 -1
  7. data/lib/elasticsearch/api/actions/cat/allocation.rb +1 -1
  8. data/lib/elasticsearch/api/actions/cat/count.rb +1 -1
  9. data/lib/elasticsearch/api/actions/cat/fielddata.rb +1 -1
  10. data/lib/elasticsearch/api/actions/cat/health.rb +1 -1
  11. data/lib/elasticsearch/api/actions/cat/help.rb +1 -1
  12. data/lib/elasticsearch/api/actions/cat/indices.rb +1 -1
  13. data/lib/elasticsearch/api/actions/cat/master.rb +1 -1
  14. data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +1 -1
  15. data/lib/elasticsearch/api/actions/cat/nodes.rb +1 -1
  16. data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +1 -1
  17. data/lib/elasticsearch/api/actions/cat/plugins.rb +1 -1
  18. data/lib/elasticsearch/api/actions/cat/recovery.rb +1 -1
  19. data/lib/elasticsearch/api/actions/cat/repositories.rb +1 -1
  20. data/lib/elasticsearch/api/actions/cat/segments.rb +1 -1
  21. data/lib/elasticsearch/api/actions/cat/shards.rb +1 -1
  22. data/lib/elasticsearch/api/actions/cat/snapshots.rb +1 -1
  23. data/lib/elasticsearch/api/actions/cat/tasks.rb +1 -1
  24. data/lib/elasticsearch/api/actions/cat/templates.rb +1 -1
  25. data/lib/elasticsearch/api/actions/cat/thread_pool.rb +1 -1
  26. data/lib/elasticsearch/api/actions/clear_scroll.rb +1 -1
  27. data/lib/elasticsearch/api/actions/close_point_in_time.rb +1 -1
  28. data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +3 -3
  29. data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +1 -1
  30. data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +1 -1
  31. data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +1 -1
  32. data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +1 -1
  33. data/lib/elasticsearch/api/actions/cluster/get_settings.rb +1 -1
  34. data/lib/elasticsearch/api/actions/cluster/health.rb +1 -1
  35. data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +1 -1
  36. data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +1 -1
  37. data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +1 -1
  38. data/lib/elasticsearch/api/actions/cluster/put_settings.rb +1 -1
  39. data/lib/elasticsearch/api/actions/cluster/remote_info.rb +1 -1
  40. data/lib/elasticsearch/api/actions/cluster/reroute.rb +1 -1
  41. data/lib/elasticsearch/api/actions/cluster/state.rb +1 -1
  42. data/lib/elasticsearch/api/actions/cluster/stats.rb +1 -1
  43. data/lib/elasticsearch/api/actions/count.rb +7 -2
  44. data/lib/elasticsearch/api/actions/create.rb +1 -1
  45. data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +1 -1
  46. data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +1 -1
  47. data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +1 -1
  48. data/lib/elasticsearch/api/actions/delete.rb +1 -1
  49. data/lib/elasticsearch/api/actions/delete_by_query.rb +1 -7
  50. data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +1 -1
  51. data/lib/elasticsearch/api/actions/delete_script.rb +1 -1
  52. data/lib/elasticsearch/api/actions/exists.rb +1 -1
  53. data/lib/elasticsearch/api/actions/exists_source.rb +1 -1
  54. data/lib/elasticsearch/api/actions/explain.rb +1 -1
  55. data/lib/elasticsearch/api/actions/features/get_features.rb +1 -1
  56. data/lib/elasticsearch/api/actions/features/reset_features.rb +1 -1
  57. data/lib/elasticsearch/api/actions/field_caps.rb +1 -1
  58. data/lib/elasticsearch/api/actions/get.rb +1 -1
  59. data/lib/elasticsearch/api/actions/get_script.rb +1 -1
  60. data/lib/elasticsearch/api/actions/get_script_context.rb +1 -5
  61. data/lib/elasticsearch/api/actions/get_script_languages.rb +1 -5
  62. data/lib/elasticsearch/api/actions/get_source.rb +1 -1
  63. data/lib/elasticsearch/api/actions/index.rb +1 -1
  64. data/lib/elasticsearch/api/actions/indices/add_block.rb +1 -1
  65. data/lib/elasticsearch/api/actions/indices/analyze.rb +1 -1
  66. data/lib/elasticsearch/api/actions/indices/clear_cache.rb +1 -1
  67. data/lib/elasticsearch/api/actions/indices/clone.rb +1 -1
  68. data/lib/elasticsearch/api/actions/indices/close.rb +1 -1
  69. data/lib/elasticsearch/api/actions/indices/create.rb +1 -1
  70. data/lib/elasticsearch/api/actions/indices/delete.rb +2 -2
  71. data/lib/elasticsearch/api/actions/indices/delete_alias.rb +1 -1
  72. data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +6 -2
  73. data/lib/elasticsearch/api/actions/indices/delete_template.rb +1 -1
  74. data/lib/elasticsearch/api/actions/indices/disk_usage.rb +68 -0
  75. data/lib/elasticsearch/api/actions/indices/exists.rb +1 -1
  76. data/lib/elasticsearch/api/actions/indices/exists_alias.rb +1 -1
  77. data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +5 -2
  78. data/lib/elasticsearch/api/actions/indices/exists_template.rb +1 -1
  79. data/lib/elasticsearch/api/actions/indices/exists_type.rb +1 -1
  80. data/lib/elasticsearch/api/actions/indices/field_usage_stats.rb +66 -0
  81. data/lib/elasticsearch/api/actions/indices/flush.rb +1 -1
  82. data/lib/elasticsearch/api/actions/indices/flush_synced.rb +1 -1
  83. data/lib/elasticsearch/api/actions/indices/forcemerge.rb +1 -1
  84. data/lib/elasticsearch/api/actions/indices/get.rb +1 -1
  85. data/lib/elasticsearch/api/actions/indices/get_alias.rb +1 -1
  86. data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +1 -1
  87. data/lib/elasticsearch/api/actions/indices/get_index_template.rb +2 -2
  88. data/lib/elasticsearch/api/actions/indices/get_mapping.rb +1 -1
  89. data/lib/elasticsearch/api/actions/indices/get_settings.rb +1 -1
  90. data/lib/elasticsearch/api/actions/indices/get_template.rb +1 -1
  91. data/lib/elasticsearch/api/actions/indices/get_upgrade.rb +1 -1
  92. data/lib/elasticsearch/api/actions/indices/open.rb +1 -1
  93. data/lib/elasticsearch/api/actions/indices/put_alias.rb +1 -1
  94. data/lib/elasticsearch/api/actions/indices/put_index_template.rb +1 -1
  95. data/lib/elasticsearch/api/actions/indices/put_mapping.rb +1 -1
  96. data/lib/elasticsearch/api/actions/indices/put_settings.rb +1 -1
  97. data/lib/elasticsearch/api/actions/indices/put_template.rb +1 -1
  98. data/lib/elasticsearch/api/actions/indices/recovery.rb +1 -1
  99. data/lib/elasticsearch/api/actions/indices/refresh.rb +1 -1
  100. data/lib/elasticsearch/api/actions/indices/resolve_index.rb +1 -5
  101. data/lib/elasticsearch/api/actions/indices/rollover.rb +1 -1
  102. data/lib/elasticsearch/api/actions/indices/segments.rb +1 -1
  103. data/lib/elasticsearch/api/actions/indices/shard_stores.rb +1 -1
  104. data/lib/elasticsearch/api/actions/indices/shrink.rb +1 -1
  105. data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +1 -1
  106. data/lib/elasticsearch/api/actions/indices/simulate_template.rb +1 -1
  107. data/lib/elasticsearch/api/actions/indices/split.rb +1 -1
  108. data/lib/elasticsearch/api/actions/indices/stats.rb +1 -1
  109. data/lib/elasticsearch/api/actions/indices/update_aliases.rb +1 -1
  110. data/lib/elasticsearch/api/actions/indices/upgrade.rb +1 -1
  111. data/lib/elasticsearch/api/actions/indices/validate_query.rb +1 -1
  112. data/lib/elasticsearch/api/actions/info.rb +1 -1
  113. data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +1 -1
  114. data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +1 -1
  115. data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +1 -1
  116. data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +1 -1
  117. data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +3 -1
  118. data/lib/elasticsearch/api/actions/ingest/simulate.rb +1 -1
  119. data/lib/elasticsearch/api/actions/mget.rb +1 -1
  120. data/lib/elasticsearch/api/actions/msearch.rb +2 -2
  121. data/lib/elasticsearch/api/actions/msearch_template.rb +2 -2
  122. data/lib/elasticsearch/api/actions/mtermvectors.rb +1 -1
  123. data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +56 -0
  124. data/lib/elasticsearch/api/actions/{snapshot/get_features.rb → nodes/get_repositories_metering_info.rb} +15 -14
  125. data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +4 -2
  126. data/lib/elasticsearch/api/actions/nodes/info.rb +2 -2
  127. data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +1 -1
  128. data/lib/elasticsearch/api/actions/nodes/stats.rb +2 -2
  129. data/lib/elasticsearch/api/actions/nodes/usage.rb +1 -1
  130. data/lib/elasticsearch/api/actions/open_point_in_time.rb +5 -7
  131. data/lib/elasticsearch/api/actions/ping.rb +1 -1
  132. data/lib/elasticsearch/api/actions/put_script.rb +1 -1
  133. data/lib/elasticsearch/api/actions/rank_eval.rb +1 -5
  134. data/lib/elasticsearch/api/actions/reindex.rb +1 -1
  135. data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +1 -1
  136. data/lib/elasticsearch/api/actions/render_search_template.rb +1 -1
  137. data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +1 -1
  138. data/lib/elasticsearch/api/actions/scroll.rb +1 -1
  139. data/lib/elasticsearch/api/actions/search.rb +1 -1
  140. data/lib/elasticsearch/api/actions/search_mvt.rb +85 -0
  141. data/lib/elasticsearch/api/actions/search_shards.rb +1 -1
  142. data/lib/elasticsearch/api/actions/search_template.rb +1 -1
  143. data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +1 -5
  144. data/lib/elasticsearch/api/actions/shutdown/get_node.rb +1 -5
  145. data/lib/elasticsearch/api/actions/shutdown/put_node.rb +1 -5
  146. data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +1 -1
  147. data/lib/elasticsearch/api/actions/snapshot/clone.rb +1 -1
  148. data/lib/elasticsearch/api/actions/snapshot/create.rb +1 -1
  149. data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +1 -1
  150. data/lib/elasticsearch/api/actions/snapshot/delete.rb +1 -1
  151. data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +1 -1
  152. data/lib/elasticsearch/api/actions/snapshot/get.rb +1 -1
  153. data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +1 -1
  154. data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +1 -1
  155. data/lib/elasticsearch/api/actions/snapshot/restore.rb +1 -1
  156. data/lib/elasticsearch/api/actions/snapshot/status.rb +1 -1
  157. data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +1 -1
  158. data/lib/elasticsearch/api/actions/tasks/cancel.rb +1 -1
  159. data/lib/elasticsearch/api/actions/tasks/get.rb +1 -1
  160. data/lib/elasticsearch/api/actions/tasks/list.rb +1 -1
  161. data/lib/elasticsearch/api/actions/termvectors.rb +1 -1
  162. data/lib/elasticsearch/api/actions/update.rb +1 -1
  163. data/lib/elasticsearch/api/actions/update_by_query.rb +1 -7
  164. data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +1 -1
  165. data/lib/elasticsearch/api/utils.rb +7 -3
  166. data/lib/elasticsearch/api/version.rb +1 -1
  167. data/spec/elasticsearch/api/actions/count_spec.rb +2 -5
  168. data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → indices/disk_usage_spec.rb} +19 -5
  169. data/spec/elasticsearch/api/actions/{benchmark_spec.rb → indices/field_usage_stats_spec.rb} +18 -6
  170. data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +51 -0
  171. data/spec/elasticsearch/api/actions/{snapshot/get_features_spec.rb → nodes/get_repositories_metering_info_spec.rb} +10 -4
  172. data/spec/elasticsearch/api/actions/open_point_in_time_spec.rb +2 -12
  173. data/spec/elasticsearch/api/actions/{remote/info_spec.rb → search_mvt_spec.rb} +26 -9
  174. data/spec/elasticsearch/api/rest_api_yaml_spec.rb +1 -2
  175. data/spec/elasticsearch/api/utils_spec.rb +9 -21
  176. data/spec/rest_yaml_tests_helper.rb +59 -8
  177. data/spec/spec_helper.rb +5 -1
  178. data/utils/thor/.rubocop.yml +2 -0
  179. data/utils/thor/generate_source.rb +17 -11
  180. data/utils/thor/generator/endpoint_specifics.rb +3 -1
  181. data/utils/thor/templates/_perform_request.erb +1 -1
  182. metadata +53 -26
  183. data/lib/elasticsearch/api/actions/abort_benchmark.rb +0 -41
  184. data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
  185. data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
  186. data/lib/elasticsearch/api/actions/nodes/shutdown.rb +0 -56
  187. data/lib/elasticsearch/api/actions/remote/info.rb +0 -37
  188. data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +0 -76
@@ -25,12 +25,14 @@ module Elasticsearch
25
25
  # @option arguments [String] :routing Specific routing value
26
26
  # @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when unavailable (missing or closed)
27
27
  # @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are open, closed or both. (options: open, closed, hidden, none, all)
28
- # @option arguments [String] :keep_alive Specific the time to live for the point in time
28
+ # @option arguments [String] :keep_alive Specific the time to live for the point in time (*Required*)
29
29
  # @option arguments [Hash] :headers Custom HTTP headers
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/point-in-time-api.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/point-in-time-api.html
32
32
  #
33
33
  def open_point_in_time(arguments = {})
34
+ raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
35
+
34
36
  headers = arguments.delete(:headers) || {}
35
37
 
36
38
  arguments = arguments.clone
@@ -38,11 +40,7 @@ module Elasticsearch
38
40
  _index = arguments.delete(:index)
39
41
 
40
42
  method = Elasticsearch::API::HTTP_POST
41
- path = if _index
42
- "#{Utils.__listify(_index)}/_pit"
43
- else
44
- "_pit"
45
- end
43
+ path = "#{Utils.__listify(_index)}/_pit"
46
44
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
47
45
 
48
46
  body = nil
@@ -22,7 +22,7 @@ module Elasticsearch
22
22
  #
23
23
  # @option arguments [Hash] :headers Custom HTTP headers
24
24
  #
25
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/index.html
25
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/index.html
26
26
  #
27
27
  def ping(arguments = {})
28
28
  headers = arguments.delete(:headers) || {}
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  # @option arguments [Hash] :body The document (*Required*)
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-scripting.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-scripting.html
31
31
  #
32
32
  def put_script(arguments = {})
33
33
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -19,10 +19,6 @@ module Elasticsearch
19
19
  module API
20
20
  module Actions
21
21
  # Allows to evaluate the quality of ranked search results over a set of typical search queries
22
- # This functionality is Experimental and may be changed or removed
23
- # completely in a future release. Elastic will take a best effort approach
24
- # to fix any issues, but experimental features are not subject to the
25
- # support SLA of official GA features.
26
22
  #
27
23
  # @option arguments [List] :index A comma-separated list of index names to search; use `_all` or empty string to perform the operation on all indices
28
24
  # @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when unavailable (missing or closed)
@@ -32,7 +28,7 @@ module Elasticsearch
32
28
  # @option arguments [Hash] :headers Custom HTTP headers
33
29
  # @option arguments [Hash] :body The ranking evaluation search definition, including search requests, document ratings and ranking metric definition. (*Required*)
34
30
  #
35
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/search-rank-eval.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-rank-eval.html
36
32
  #
37
33
  def rank_eval(arguments = {})
38
34
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Hash] :headers Custom HTTP headers
34
34
  # @option arguments [Hash] :body The search definition using the Query DSL and the prototype for the index request. (*Required*)
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-reindex.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-reindex.html
37
37
  #
38
38
  def reindex(arguments = {})
39
39
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -24,7 +24,7 @@ module Elasticsearch
24
24
  # @option arguments [Number] :requests_per_second The throttle to set on this request in floating sub-requests per second. -1 means set no throttle. (*Required*)
25
25
  # @option arguments [Hash] :headers Custom HTTP headers
26
26
  #
27
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-reindex.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-reindex.html
28
28
  #
29
29
  def reindex_rethrottle(arguments = {})
30
30
  raise ArgumentError, "Required argument 'task_id' missing" unless arguments[:task_id]
@@ -24,7 +24,7 @@ module Elasticsearch
24
24
  # @option arguments [Hash] :headers Custom HTTP headers
25
25
  # @option arguments [Hash] :body The search definition template and its params
26
26
  #
27
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/render-search-template-api.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/render-search-template-api.html
28
28
  #
29
29
  def render_search_template(arguments = {})
30
30
  headers = arguments.delete(:headers) || {}
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  # @option arguments [Hash] :body The script to execute
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.14/painless-execute-api.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.16/painless-execute-api.html
31
31
  #
32
32
  def scripts_painless_execute(arguments = {})
33
33
  headers = arguments.delete(:headers) || {}
@@ -31,7 +31,7 @@ module Elasticsearch
31
31
  # Deprecated since version 7.0.0
32
32
  #
33
33
  #
34
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/search-request-body.html#request-body-search-scroll
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-request-body.html#request-body-search-scroll
35
35
  #
36
36
  def scroll(arguments = {})
37
37
  headers = arguments.delete(:headers) || {}
@@ -73,7 +73,7 @@ module Elasticsearch
73
73
  # Deprecated since version 7.0.0
74
74
  #
75
75
  #
76
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/search-search.html
76
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-search.html
77
77
  #
78
78
  def search(arguments = {})
79
79
  headers = arguments.delete(:headers) || {}
@@ -0,0 +1,85 @@
1
+ # Licensed to Elasticsearch B.V. under one or more contributor
2
+ # license agreements. See the NOTICE file distributed with
3
+ # this work for additional information regarding copyright
4
+ # ownership. Elasticsearch B.V. licenses this file to you under
5
+ # the Apache License, Version 2.0 (the "License"); you may
6
+ # 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,
12
+ # software distributed under the License is distributed on an
13
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
14
+ # KIND, either express or implied. See the License for the
15
+ # specific language governing permissions and limitations
16
+ # under the License.
17
+
18
+ module Elasticsearch
19
+ module API
20
+ module Actions
21
+ # Searches a vector tile for geospatial values. Returns results as a binary Mapbox vector tile.
22
+ # This functionality is Experimental and may be changed or removed
23
+ # completely in a future release. Elastic will take a best effort approach
24
+ # to fix any issues, but experimental features are not subject to the
25
+ # support SLA of official GA features.
26
+ #
27
+ # @option arguments [List] :index Comma-separated list of data streams, indices, or aliases to search
28
+ # @option arguments [String] :field Field containing geospatial data to return
29
+ # @option arguments [Integer] :zoom Zoom level for the vector tile to search
30
+ # @option arguments [Integer] :x X coordinate for the vector tile to search
31
+ # @option arguments [Integer] :y Y coordinate for the vector tile to search
32
+ # @option arguments [Boolean] :exact_bounds If false, the meta layer's feature is the bounding box of the tile. If true, the meta layer's feature is a bounding box resulting from a `geo_bounds` aggregation.
33
+ # @option arguments [Integer] :extent Size, in pixels, of a side of the vector tile.
34
+ # @option arguments [Integer] :grid_precision Additional zoom levels available through the aggs layer. Accepts 0-8.
35
+ # @option arguments [String] :grid_type Determines the geometry type for features in the aggs layer. (options: grid, point, centroid)
36
+ # @option arguments [Integer] :size Maximum number of features to return in the hits layer. Accepts 0-10000.
37
+ # @option arguments [Boolean|long] :track_total_hits Indicate if the number of documents that match the query should be tracked. A number can also be specified, to accurately track the total hit count up to the number.
38
+ # @option arguments [Hash] :headers Custom HTTP headers
39
+ # @option arguments [Hash] :body Search request body.
40
+ #
41
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-vector-tile-api.html
42
+ #
43
+ def search_mvt(arguments = {})
44
+ raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
45
+ raise ArgumentError, "Required argument 'field' missing" unless arguments[:field]
46
+ raise ArgumentError, "Required argument 'zoom' missing" unless arguments[:zoom]
47
+ raise ArgumentError, "Required argument 'x' missing" unless arguments[:x]
48
+ raise ArgumentError, "Required argument 'y' missing" unless arguments[:y]
49
+
50
+ headers = arguments.delete(:headers) || {}
51
+
52
+ arguments = arguments.clone
53
+
54
+ _index = arguments.delete(:index)
55
+
56
+ _field = arguments.delete(:field)
57
+
58
+ _zoom = arguments.delete(:zoom)
59
+
60
+ _x = arguments.delete(:x)
61
+
62
+ _y = arguments.delete(:y)
63
+
64
+ method = Elasticsearch::API::HTTP_POST
65
+ path = "#{Utils.__listify(_index)}/_mvt/#{Utils.__listify(_field)}/#{Utils.__listify(_zoom)}/#{Utils.__listify(_x)}/#{Utils.__listify(_y)}"
66
+ params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
67
+
68
+ body = arguments[:body]
69
+ perform_request(method, path, params, body, headers).body
70
+ end
71
+
72
+ # Register this action with its valid params when the module is loaded.
73
+ #
74
+ # @since 6.2.0
75
+ ParamsRegistry.register(:search_mvt, [
76
+ :exact_bounds,
77
+ :extent,
78
+ :grid_precision,
79
+ :grid_type,
80
+ :size,
81
+ :track_total_hits
82
+ ].freeze)
83
+ end
84
+ end
85
+ end
@@ -29,7 +29,7 @@ module Elasticsearch
29
29
  # @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are open, closed or both. (options: open, closed, hidden, none, all)
30
30
  # @option arguments [Hash] :headers Custom HTTP headers
31
31
  #
32
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/search-shards.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-shards.html
33
33
  #
34
34
  def search_shards(arguments = {})
35
35
  headers = arguments.delete(:headers) || {}
@@ -43,7 +43,7 @@ module Elasticsearch
43
43
  # Deprecated since version 7.0.0
44
44
  #
45
45
  #
46
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/search-template.html
46
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/search-template.html
47
47
  #
48
48
  def search_template(arguments = {})
49
49
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -19,11 +19,7 @@ module Elasticsearch
19
19
  module API
20
20
  module Shutdown
21
21
  module Actions
22
- # Removes a node from the shutdown list
23
- # This functionality is Experimental and may be changed or removed
24
- # completely in a future release. Elastic will take a best effort approach
25
- # to fix any issues, but experimental features are not subject to the
26
- # support SLA of official GA features.
22
+ # Removes a node from the shutdown list. Designed for indirect use by ECE/ESS and ECK. Direct use is not supported.
27
23
  #
28
24
  # @option arguments [String] :node_id The node id of node to be removed from the shutdown state
29
25
  # @option arguments [Hash] :headers Custom HTTP headers
@@ -19,11 +19,7 @@ module Elasticsearch
19
19
  module API
20
20
  module Shutdown
21
21
  module Actions
22
- # Retrieve status of a node or nodes that are currently marked as shutting down
23
- # This functionality is Experimental and may be changed or removed
24
- # completely in a future release. Elastic will take a best effort approach
25
- # to fix any issues, but experimental features are not subject to the
26
- # support SLA of official GA features.
22
+ # Retrieve status of a node or nodes that are currently marked as shutting down. Designed for indirect use by ECE/ESS and ECK. Direct use is not supported.
27
23
  #
28
24
  # @option arguments [String] :node_id Which node for which to retrieve the shutdown status
29
25
  # @option arguments [Hash] :headers Custom HTTP headers
@@ -19,11 +19,7 @@ module Elasticsearch
19
19
  module API
20
20
  module Shutdown
21
21
  module Actions
22
- # Adds a node to be shut down
23
- # This functionality is Experimental and may be changed or removed
24
- # completely in a future release. Elastic will take a best effort approach
25
- # to fix any issues, but experimental features are not subject to the
26
- # support SLA of official GA features.
22
+ # Adds a node to be shut down. Designed for indirect use by ECE/ESS and ECK. Direct use is not supported.
27
23
  #
28
24
  # @option arguments [String] :node_id The node id of node to be shut down
29
25
  # @option arguments [Hash] :headers Custom HTTP headers
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :timeout Explicit operation timeout
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/clean-up-snapshot-repo-api.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/clean-up-snapshot-repo-api.html
30
30
  #
31
31
  def cleanup_repository(arguments = {})
32
32
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -28,7 +28,7 @@ module Elasticsearch
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  # @option arguments [Hash] :body The snapshot clone definition (*Required*)
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
32
32
  #
33
33
  def clone(arguments = {})
34
34
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -28,7 +28,7 @@ module Elasticsearch
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  # @option arguments [Hash] :body The snapshot definition
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
32
32
  #
33
33
  def create(arguments = {})
34
34
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -28,7 +28,7 @@ module Elasticsearch
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  # @option arguments [Hash] :body The repository definition (*Required*)
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
32
32
  #
33
33
  def create_repository(arguments = {})
34
34
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :master_timeout Explicit operation timeout for connection to master node
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
30
30
  #
31
31
  def delete(arguments = {})
32
32
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :timeout Explicit operation timeout
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
30
30
  #
31
31
  def delete_repository(arguments = {})
32
32
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Boolean] :verbose Whether to show verbose snapshot info or only show the basic info found in the repository index blob
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
34
34
  #
35
35
  def get(arguments = {})
36
36
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Boolean] :local Return local information, do not retrieve the state from master node (default: false)
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
30
30
  #
31
31
  def get_repository(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -35,7 +35,7 @@ module Elasticsearch
35
35
  # @option arguments [Boolean] :rarely_abort_writes Whether to rarely abort writes before they complete. Defaults to 'true'.
36
36
  # @option arguments [Hash] :headers Custom HTTP headers
37
37
  #
38
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
38
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
39
39
  #
40
40
  def repository_analyze(arguments = {})
41
41
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -28,7 +28,7 @@ module Elasticsearch
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  # @option arguments [Hash] :body Details of what to restore
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
32
32
  #
33
33
  def restore(arguments = {})
34
34
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Boolean] :ignore_unavailable Whether to ignore unavailable snapshots, defaults to false which means a SnapshotMissingException is thrown
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
31
31
  #
32
32
  def status(arguments = {})
33
33
  headers = arguments.delete(:headers) || {}
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :timeout Explicit operation timeout
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-snapshots.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/modules-snapshots.html
30
30
  #
31
31
  def verify_repository(arguments = {})
32
32
  raise ArgumentError, "Required argument 'repository' missing" unless arguments[:repository]
@@ -32,7 +32,7 @@ module Elasticsearch
32
32
  # @option arguments [Boolean] :wait_for_completion Should the request block until the cancellation of the task and its descendant tasks is completed. Defaults to false
33
33
  # @option arguments [Hash] :headers Custom HTTP headers
34
34
  #
35
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/tasks.html
35
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/tasks.html
36
36
  #
37
37
  def cancel(arguments = {})
38
38
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Time] :timeout Explicit operation timeout
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/tasks.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/tasks.html
34
34
  #
35
35
  def get(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -34,7 +34,7 @@ module Elasticsearch
34
34
  # @option arguments [Time] :timeout Explicit operation timeout
35
35
  # @option arguments [Hash] :headers Custom HTTP headers
36
36
  #
37
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/tasks.html
37
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/tasks.html
38
38
  #
39
39
  def list(arguments = {})
40
40
  headers = arguments.delete(:headers) || {}
@@ -42,7 +42,7 @@ module Elasticsearch
42
42
  # Deprecated since version 7.0.0
43
43
  #
44
44
  #
45
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-termvectors.html
45
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-termvectors.html
46
46
  #
47
47
  def termvectors(arguments = {})
48
48
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -43,7 +43,7 @@ module Elasticsearch
43
43
  # Deprecated since version 7.0.0
44
44
  #
45
45
  #
46
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-update.html
46
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-update.html
47
47
  #
48
48
  def update(arguments = {})
49
49
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -43,9 +43,6 @@ module Elasticsearch
43
43
  # @option arguments [Number] :size Deprecated, please use `max_docs` instead
44
44
  # @option arguments [Number] :max_docs Maximum number of documents to process (default: all documents)
45
45
  # @option arguments [List] :sort A comma-separated list of <field>:<direction> pairs
46
- # @option arguments [List] :_source True or false to return the _source field or not, or a list of fields to return
47
- # @option arguments [List] :_source_excludes A list of fields to exclude from the returned _source field
48
- # @option arguments [List] :_source_includes A list of fields to extract and return from the _source field
49
46
  # @option arguments [Number] :terminate_after The maximum number of documents to collect for each shard, upon reaching which the query execution will terminate early.
50
47
  # @option arguments [List] :stats Specific 'tag' of the request for logging and statistical purposes
51
48
  # @option arguments [Boolean] :version Specify whether to return document version as part of a hit
@@ -66,7 +63,7 @@ module Elasticsearch
66
63
  # Deprecated since version 7.0.0
67
64
  #
68
65
  #
69
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-update-by-query.html
66
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-update-by-query.html
70
67
  #
71
68
  def update_by_query(arguments = {})
72
69
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -115,9 +112,6 @@ module Elasticsearch
115
112
  :size,
116
113
  :max_docs,
117
114
  :sort,
118
- :_source,
119
- :_source_excludes,
120
- :_source_includes,
121
115
  :terminate_after,
122
116
  :stats,
123
117
  :version,
@@ -24,7 +24,7 @@ module Elasticsearch
24
24
  # @option arguments [Number] :requests_per_second The throttle to set on this request in floating sub-requests per second. -1 means set no throttle. (*Required*)
25
25
  # @option arguments [Hash] :headers Custom HTTP headers
26
26
  #
27
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-update-by-query.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.16/docs-update-by-query.html
28
28
  #
29
29
  def update_by_query_rethrottle(arguments = {})
30
30
  raise ArgumentError, "Required argument 'task_id' missing" unless arguments[:task_id]
@@ -14,14 +14,13 @@
14
14
  # KIND, either express or implied. See the License for the
15
15
  # specific language governing permissions and limitations
16
16
  # under the License.
17
+ require 'erb'
17
18
 
18
19
  module Elasticsearch
19
20
  module API
20
-
21
21
  # Generic utility methods
22
22
  #
23
23
  module Utils
24
-
25
24
  # URL-escape a string
26
25
  #
27
26
  # @example
@@ -31,7 +30,7 @@ module Elasticsearch
31
30
  # @api private
32
31
  def __escape(string)
33
32
  return string if string == '*'
34
- defined?(EscapeUtils) ? EscapeUtils.escape_url(string.to_s) : CGI.escape(string.to_s)
33
+ ERB::Util.url_encode(string.to_s)
35
34
  end
36
35
 
37
36
  # Create a "list" of values from arguments, ignoring nil values and encoding special characters.
@@ -282,6 +281,11 @@ module Elasticsearch
282
281
  end
283
282
  end
284
283
 
284
+ def ndjson_headers(headers)
285
+ headers.merge!('Content-Type' => 'application/x-ndjson') unless ['1', 'true'].include?(ENV['ELASTIC_CLIENT_APIVERSIONING'])
286
+ headers
287
+ end
288
+
285
289
  extend self
286
290
  end
287
291
  end
@@ -17,6 +17,6 @@
17
17
 
18
18
  module Elasticsearch
19
19
  module API
20
- VERSION = '7.14.1'.freeze
20
+ VERSION = '7.16.3'.freeze
21
21
  end
22
22
  end
@@ -18,10 +18,9 @@
18
18
  require 'spec_helper'
19
19
 
20
20
  describe 'client#count' do
21
-
22
21
  let(:expected_args) do
23
22
  [
24
- 'POST',
23
+ 'GET',
25
24
  '_count',
26
25
  {},
27
26
  nil,
@@ -34,10 +33,9 @@ describe 'client#count' do
34
33
  end
35
34
 
36
35
  context 'when an index and type are specified' do
37
-
38
36
  let(:expected_args) do
39
37
  [
40
- 'POST',
38
+ 'GET',
41
39
  'foo,bar/t1,t2/_count',
42
40
  {},
43
41
  nil,
@@ -51,7 +49,6 @@ describe 'client#count' do
51
49
  end
52
50
 
53
51
  context 'when there is a query provided' do
54
-
55
52
  let(:expected_args) do
56
53
  [
57
54
  'POST',
@@ -17,18 +17,32 @@
17
17
 
18
18
  require 'spec_helper'
19
19
 
20
- describe 'client#abort_benchmark' do
21
-
20
+ describe 'client.indices#disk_usage' do
22
21
  let(:expected_args) do
23
22
  [
24
23
  'POST',
25
- '_bench/abort/foo',
24
+ "#{index}/_disk_usage",
26
25
  {},
27
- nil
26
+ nil,
27
+ {}
28
28
  ]
29
29
  end
30
30
 
31
+ let(:index) { 'foo' }
32
+
31
33
  it 'performs the request' do
32
- expect(client_double.abort_benchmark(name: 'foo'))
34
+ expect(client_double.indices.disk_usage(index: index)).to eq({})
35
+ end
36
+
37
+ context 'when there is no index specified' do
38
+ let(:client) do
39
+ Class.new { include Elasticsearch::API }.new
40
+ end
41
+
42
+ it 'raises an exception' do
43
+ expect do
44
+ client.indices.disk_usage
45
+ end.to raise_exception(ArgumentError)
46
+ end
33
47
  end
34
48
  end