elasticsearch-api 7.11.2 → 7.17.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (214) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +4 -4
  3. data/README.md +22 -45
  4. data/Rakefile +35 -65
  5. data/elasticsearch-api.gemspec +14 -8
  6. data/lib/elasticsearch/api/actions/bulk.rb +2 -2
  7. data/lib/elasticsearch/api/actions/cat/aliases.rb +1 -1
  8. data/lib/elasticsearch/api/actions/cat/allocation.rb +1 -1
  9. data/lib/elasticsearch/api/actions/cat/count.rb +1 -1
  10. data/lib/elasticsearch/api/actions/cat/fielddata.rb +1 -1
  11. data/lib/elasticsearch/api/actions/cat/health.rb +1 -1
  12. data/lib/elasticsearch/api/actions/cat/help.rb +1 -1
  13. data/lib/elasticsearch/api/actions/cat/indices.rb +1 -1
  14. data/lib/elasticsearch/api/actions/cat/master.rb +1 -1
  15. data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +1 -1
  16. data/lib/elasticsearch/api/actions/cat/nodes.rb +4 -2
  17. data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +1 -1
  18. data/lib/elasticsearch/api/actions/cat/plugins.rb +3 -1
  19. data/lib/elasticsearch/api/actions/cat/recovery.rb +1 -1
  20. data/lib/elasticsearch/api/actions/cat/repositories.rb +1 -1
  21. data/lib/elasticsearch/api/actions/cat/segments.rb +1 -1
  22. data/lib/elasticsearch/api/actions/cat/shards.rb +1 -1
  23. data/lib/elasticsearch/api/actions/cat/snapshots.rb +1 -1
  24. data/lib/elasticsearch/api/actions/cat/tasks.rb +1 -1
  25. data/lib/elasticsearch/api/actions/cat/templates.rb +1 -1
  26. data/lib/elasticsearch/api/actions/cat/thread_pool.rb +1 -1
  27. data/lib/elasticsearch/api/actions/clear_scroll.rb +1 -1
  28. data/lib/elasticsearch/api/actions/{abort_benchmark.rb → close_point_in_time.rb} +13 -12
  29. data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +3 -3
  30. data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +1 -1
  31. data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +1 -1
  32. data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +2 -1
  33. data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +1 -1
  34. data/lib/elasticsearch/api/actions/cluster/get_settings.rb +1 -1
  35. data/lib/elasticsearch/api/actions/cluster/health.rb +1 -1
  36. data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +1 -1
  37. data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +1 -1
  38. data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +1 -1
  39. data/lib/elasticsearch/api/actions/cluster/put_settings.rb +1 -1
  40. data/lib/elasticsearch/api/actions/cluster/remote_info.rb +1 -1
  41. data/lib/elasticsearch/api/actions/cluster/reroute.rb +1 -1
  42. data/lib/elasticsearch/api/actions/cluster/state.rb +1 -1
  43. data/lib/elasticsearch/api/actions/cluster/stats.rb +1 -1
  44. data/lib/elasticsearch/api/actions/count.rb +7 -2
  45. data/lib/elasticsearch/api/actions/create.rb +1 -1
  46. data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +1 -1
  47. data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +1 -1
  48. data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +1 -1
  49. data/lib/elasticsearch/api/actions/delete.rb +1 -1
  50. data/lib/elasticsearch/api/actions/delete_by_query.rb +1 -7
  51. data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +1 -1
  52. data/lib/elasticsearch/api/actions/delete_script.rb +1 -1
  53. data/lib/elasticsearch/api/actions/exists.rb +2 -1
  54. data/lib/elasticsearch/api/actions/exists_source.rb +2 -1
  55. data/lib/elasticsearch/api/actions/explain.rb +6 -6
  56. data/lib/elasticsearch/api/actions/{nodes/shutdown.rb → features/get_features.rb} +16 -21
  57. data/lib/elasticsearch/api/actions/features/params_registry.rb +60 -0
  58. data/lib/elasticsearch/api/actions/features/reset_features.rb +47 -0
  59. data/lib/elasticsearch/api/actions/field_caps.rb +6 -6
  60. data/lib/elasticsearch/api/actions/get.rb +1 -1
  61. data/lib/elasticsearch/api/actions/get_script.rb +1 -1
  62. data/lib/elasticsearch/api/actions/get_script_context.rb +1 -5
  63. data/lib/elasticsearch/api/actions/get_script_languages.rb +1 -5
  64. data/lib/elasticsearch/api/actions/get_source.rb +1 -1
  65. data/lib/elasticsearch/api/actions/index.rb +1 -1
  66. data/lib/elasticsearch/api/actions/indices/add_block.rb +1 -1
  67. data/lib/elasticsearch/api/actions/indices/analyze.rb +6 -6
  68. data/lib/elasticsearch/api/actions/indices/clear_cache.rb +1 -1
  69. data/lib/elasticsearch/api/actions/indices/clone.rb +1 -1
  70. data/lib/elasticsearch/api/actions/indices/close.rb +2 -2
  71. data/lib/elasticsearch/api/actions/indices/create.rb +1 -1
  72. data/lib/elasticsearch/api/actions/indices/delete.rb +2 -2
  73. data/lib/elasticsearch/api/actions/indices/delete_alias.rb +1 -1
  74. data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +6 -2
  75. data/lib/elasticsearch/api/actions/indices/delete_template.rb +1 -1
  76. data/lib/elasticsearch/api/actions/indices/disk_usage.rb +68 -0
  77. data/lib/elasticsearch/api/actions/indices/exists.rb +2 -1
  78. data/lib/elasticsearch/api/actions/indices/exists_alias.rb +2 -1
  79. data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +6 -2
  80. data/lib/elasticsearch/api/actions/indices/exists_template.rb +2 -1
  81. data/lib/elasticsearch/api/actions/indices/exists_type.rb +2 -1
  82. data/lib/elasticsearch/api/actions/indices/field_usage_stats.rb +66 -0
  83. data/lib/elasticsearch/api/actions/indices/flush.rb +1 -1
  84. data/lib/elasticsearch/api/actions/indices/flush_synced.rb +1 -1
  85. data/lib/elasticsearch/api/actions/indices/forcemerge.rb +1 -1
  86. data/lib/elasticsearch/api/actions/indices/get.rb +1 -1
  87. data/lib/elasticsearch/api/actions/indices/get_alias.rb +1 -1
  88. data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +1 -1
  89. data/lib/elasticsearch/api/actions/indices/get_index_template.rb +2 -2
  90. data/lib/elasticsearch/api/actions/indices/get_mapping.rb +1 -1
  91. data/lib/elasticsearch/api/actions/indices/get_settings.rb +1 -1
  92. data/lib/elasticsearch/api/actions/indices/get_template.rb +1 -1
  93. data/lib/elasticsearch/api/actions/indices/get_upgrade.rb +1 -1
  94. data/lib/elasticsearch/api/actions/indices/open.rb +1 -1
  95. data/lib/elasticsearch/api/actions/indices/put_alias.rb +1 -1
  96. data/lib/elasticsearch/api/actions/indices/put_index_template.rb +1 -1
  97. data/lib/elasticsearch/api/actions/indices/put_mapping.rb +1 -1
  98. data/lib/elasticsearch/api/actions/indices/put_settings.rb +1 -1
  99. data/lib/elasticsearch/api/actions/indices/put_template.rb +1 -1
  100. data/lib/elasticsearch/api/actions/indices/recovery.rb +1 -1
  101. data/lib/elasticsearch/api/actions/indices/refresh.rb +1 -1
  102. data/lib/elasticsearch/api/actions/indices/resolve_index.rb +1 -5
  103. data/lib/elasticsearch/api/actions/indices/rollover.rb +1 -1
  104. data/lib/elasticsearch/api/actions/indices/segments.rb +1 -1
  105. data/lib/elasticsearch/api/actions/indices/shard_stores.rb +1 -1
  106. data/lib/elasticsearch/api/actions/indices/shrink.rb +1 -1
  107. data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +1 -1
  108. data/lib/elasticsearch/api/actions/indices/simulate_template.rb +1 -1
  109. data/lib/elasticsearch/api/actions/indices/split.rb +1 -1
  110. data/lib/elasticsearch/api/actions/indices/stats.rb +1 -1
  111. data/lib/elasticsearch/api/actions/indices/update_aliases.rb +1 -1
  112. data/lib/elasticsearch/api/actions/indices/upgrade.rb +1 -1
  113. data/lib/elasticsearch/api/actions/indices/validate_query.rb +8 -8
  114. data/lib/elasticsearch/api/actions/info.rb +1 -1
  115. data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +1 -1
  116. data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +43 -0
  117. data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +3 -1
  118. data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +1 -1
  119. data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +3 -1
  120. data/lib/elasticsearch/api/actions/ingest/simulate.rb +1 -1
  121. data/lib/elasticsearch/api/actions/mget.rb +1 -1
  122. data/lib/elasticsearch/api/actions/msearch.rb +3 -3
  123. data/lib/elasticsearch/api/actions/msearch_template.rb +3 -3
  124. data/lib/elasticsearch/api/actions/mtermvectors.rb +8 -8
  125. data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +56 -0
  126. data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +52 -0
  127. data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +4 -2
  128. data/lib/elasticsearch/api/actions/nodes/info.rb +2 -2
  129. data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +1 -1
  130. data/lib/elasticsearch/api/actions/nodes/stats.rb +5 -3
  131. data/lib/elasticsearch/api/actions/nodes/usage.rb +1 -1
  132. data/lib/elasticsearch/api/actions/open_point_in_time.rb +62 -0
  133. data/lib/elasticsearch/api/actions/ping.rb +3 -3
  134. data/lib/elasticsearch/api/actions/put_script.rb +1 -1
  135. data/lib/elasticsearch/api/actions/rank_eval.rb +1 -5
  136. data/lib/elasticsearch/api/actions/reindex.rb +1 -1
  137. data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +1 -1
  138. data/lib/elasticsearch/api/actions/render_search_template.rb +6 -6
  139. data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +2 -2
  140. data/lib/elasticsearch/api/actions/scroll.rb +6 -6
  141. data/lib/elasticsearch/api/actions/search.rb +11 -9
  142. data/lib/elasticsearch/api/actions/search_mvt.rb +85 -0
  143. data/lib/elasticsearch/api/actions/search_shards.rb +1 -1
  144. data/lib/elasticsearch/api/actions/search_template.rb +2 -2
  145. data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +48 -0
  146. data/lib/elasticsearch/api/actions/shutdown/get_node.rb +50 -0
  147. data/lib/elasticsearch/api/actions/shutdown/params_registry.rb +60 -0
  148. data/lib/elasticsearch/api/actions/shutdown/put_node.rb +50 -0
  149. data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +1 -1
  150. data/lib/elasticsearch/api/actions/snapshot/clone.rb +1 -1
  151. data/lib/elasticsearch/api/actions/snapshot/create.rb +1 -1
  152. data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +1 -1
  153. data/lib/elasticsearch/api/actions/snapshot/delete.rb +1 -1
  154. data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +1 -1
  155. data/lib/elasticsearch/api/actions/snapshot/get.rb +5 -1
  156. data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +1 -1
  157. data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +76 -0
  158. data/lib/elasticsearch/api/actions/snapshot/restore.rb +1 -1
  159. data/lib/elasticsearch/api/actions/snapshot/status.rb +1 -1
  160. data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +1 -1
  161. data/lib/elasticsearch/api/actions/tasks/cancel.rb +1 -1
  162. data/lib/elasticsearch/api/actions/tasks/get.rb +1 -1
  163. data/lib/elasticsearch/api/actions/tasks/list.rb +1 -1
  164. data/lib/elasticsearch/api/actions/termvectors.rb +11 -10
  165. data/lib/elasticsearch/api/actions/update.rb +1 -1
  166. data/lib/elasticsearch/api/actions/update_by_query.rb +1 -7
  167. data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +1 -1
  168. data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/features.rb} +12 -13
  169. data/lib/elasticsearch/api/namespace/security.rb +36 -0
  170. data/lib/elasticsearch/api/namespace/shutdown.rb +37 -0
  171. data/lib/elasticsearch/api/utils.rb +7 -3
  172. data/lib/elasticsearch/api/version.rb +1 -1
  173. data/lib/elasticsearch/api.rb +3 -1
  174. data/spec/elasticsearch/api/actions/{benchmark_spec.rb → close_point_in_time_spec.rb} +6 -6
  175. data/spec/elasticsearch/api/actions/count_spec.rb +2 -5
  176. data/spec/elasticsearch/api/actions/{remote/info_spec.rb → features/get_features_spec.rb} +7 -8
  177. data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +34 -0
  178. data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +16 -3
  179. data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +48 -0
  180. data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +46 -0
  181. data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +34 -0
  182. data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +51 -0
  183. data/spec/elasticsearch/api/actions/nodes/get_repositories_metering_info_spec.rb +44 -0
  184. data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → open_point_in_time_spec.rb} +5 -5
  185. data/spec/elasticsearch/api/actions/search_mvt_spec.rb +52 -0
  186. data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +44 -0
  187. data/spec/elasticsearch/api/actions/shutdown/get_node_spec.rb +46 -0
  188. data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +50 -0
  189. data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +48 -0
  190. data/spec/elasticsearch/api/rest_api_yaml_spec.rb +24 -5
  191. data/spec/elasticsearch/api/utils_spec.rb +9 -21
  192. data/spec/rest_yaml_tests_helper.rb +76 -62
  193. data/spec/skipped_tests.yml +29 -0
  194. data/spec/spec_helper.rb +9 -2
  195. data/utils/Gemfile +4 -3
  196. data/utils/README.md +6 -1
  197. data/utils/thor/.rubocop.yml +2 -0
  198. data/utils/thor/generate_source.rb +18 -13
  199. data/utils/thor/generator/endpoint_specifics.rb +7 -1
  200. data/utils/thor/generator/files_helper.rb +38 -20
  201. data/utils/thor/templates/_documentation_top.erb +19 -0
  202. data/utils/thor/templates/_method_setup.erb +18 -0
  203. data/utils/thor/templates/_params_registry.erb +19 -0
  204. data/utils/thor/templates/_perform_request.erb +20 -2
  205. data/utils/thor/templates/test.erb +16 -3
  206. data/utils/thor/templates/test_helper.rb +0 -4
  207. metadata +68 -44
  208. data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
  209. data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
  210. data/lib/elasticsearch/api/actions/indices/freeze.rb +0 -56
  211. data/lib/elasticsearch/api/actions/indices/unfreeze.rb +0 -56
  212. data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +0 -85
  213. data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +0 -85
  214. data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +0 -76
@@ -24,9 +24,9 @@ module Elasticsearch
24
24
  # @option arguments [Boolean] :include_yes_decisions Return 'YES' decisions in explanation (default: false)
25
25
  # @option arguments [Boolean] :include_disk_info Return information about disk usage and shard sizes (default: false)
26
26
  # @option arguments [Hash] :headers Custom HTTP headers
27
- # @option arguments [Hash] :body The index, shard, and primary flag to explain. Empty means 'explain the first unassigned shard'
27
+ # @option arguments [Hash] :body The index, shard, and primary flag to explain. Empty means 'explain a randomly-chosen unassigned shard'
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-allocation-explain.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-allocation-explain.html
30
30
  #
31
31
  def allocation_explain(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -39,7 +39,7 @@ module Elasticsearch
39
39
  Elasticsearch::API::HTTP_GET
40
40
  end
41
41
 
42
- path = "_cluster/allocation/explain"
42
+ path = "_cluster/allocation/explain"
43
43
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
44
44
 
45
45
  body = arguments[:body]
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/indices-component-template.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/indices-component-template.html
30
30
  #
31
31
  def delete_component_template(arguments = {})
32
32
  raise ArgumentError, "Required argument 'name' missing" unless arguments[:name]
@@ -24,7 +24,7 @@ module Elasticsearch
24
24
  # @option arguments [Boolean] :wait_for_removal Specifies whether to wait for all excluded nodes to be removed from the cluster before clearing the voting configuration exclusions list.
25
25
  # @option arguments [Hash] :headers Custom HTTP headers
26
26
  #
27
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/voting-config-exclusions.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/voting-config-exclusions.html
28
28
  #
29
29
  def delete_voting_config_exclusions(arguments = {})
30
30
  headers = arguments.delete(:headers) || {}
@@ -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.11/indices-component-template.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/indices-component-template.html
30
30
  #
31
31
  def exists_component_template(arguments = {})
32
32
  raise ArgumentError, "Required argument 'name' missing" unless arguments[:name]
@@ -46,6 +46,7 @@ module Elasticsearch
46
46
  end
47
47
 
48
48
  alias_method :exists_component_template?, :exists_component_template
49
+
49
50
  # Register this action with its valid params when the module is loaded.
50
51
  #
51
52
  # @since 6.2.0
@@ -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.11/indices-component-template.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/indices-component-template.html
30
30
  #
31
31
  def get_component_template(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Boolean] :include_defaults Whether to return all default clusters setting.
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-update-settings.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-get-settings.html
31
31
  #
32
32
  def get_settings(arguments = {})
33
33
  headers = arguments.delete(:headers) || {}
@@ -35,7 +35,7 @@ module Elasticsearch
35
35
  # @option arguments [String] :wait_for_status Wait until cluster is in a specific state (options: green, yellow, red)
36
36
  # @option arguments [Hash] :headers Custom HTTP headers
37
37
  #
38
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-health.html
38
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-health.html
39
39
  #
40
40
  def health(arguments = {})
41
41
  headers = arguments.delete(:headers) || {}
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-pending.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-pending.html
30
30
  #
31
31
  def pending_tasks(arguments = {})
32
32
  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.11/voting-config-exclusions.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/voting-config-exclusions.html
30
30
  #
31
31
  def post_voting_config_exclusions(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -28,7 +28,7 @@ module Elasticsearch
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  # @option arguments [Hash] :body The template definition (*Required*)
30
30
  #
31
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/indices-component-template.html
31
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/indices-component-template.html
32
32
  #
33
33
  def put_component_template(arguments = {})
34
34
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  # @option arguments [Hash] :body The settings to be updated. Can be either `transient` or `persistent` (survives cluster restart). (*Required*)
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-update-settings.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-update-settings.html
31
31
  #
32
32
  def put_settings(arguments = {})
33
33
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -23,7 +23,7 @@ module Elasticsearch
23
23
  #
24
24
  # @option arguments [Hash] :headers Custom HTTP headers
25
25
  #
26
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-remote-info.html
26
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-remote-info.html
27
27
  #
28
28
  def remote_info(arguments = {})
29
29
  headers = arguments.delete(:headers) || {}
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @option arguments [Hash] :headers Custom HTTP headers
31
31
  # @option arguments [Hash] :body The definition of `commands` to perform (`move`, `cancel`, `allocate`)
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-reroute.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-reroute.html
34
34
  #
35
35
  def reroute(arguments = {})
36
36
  headers = arguments.delete(:headers) || {}
@@ -33,7 +33,7 @@ module Elasticsearch
33
33
  # @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)
34
34
  # @option arguments [Hash] :headers Custom HTTP headers
35
35
  #
36
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/cluster-state.html
36
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-state.html
37
37
  #
38
38
  def state(arguments = {})
39
39
  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.11/cluster-stats.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/cluster-stats.html
30
30
  #
31
31
  def stats(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -44,7 +44,7 @@ module Elasticsearch
44
44
  # Deprecated since version 7.0.0
45
45
  #
46
46
  #
47
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/search-count.html
47
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/search-count.html
48
48
  #
49
49
  def count(arguments = {})
50
50
  headers = arguments.delete(:headers) || {}
@@ -55,7 +55,12 @@ module Elasticsearch
55
55
 
56
56
  _type = arguments.delete(:type)
57
57
 
58
- method = Elasticsearch::API::HTTP_POST
58
+ method = if arguments[:body]
59
+ Elasticsearch::API::HTTP_POST
60
+ else
61
+ Elasticsearch::API::HTTP_GET
62
+ end
63
+
59
64
  path = if _index && _type
60
65
  "#{Utils.__listify(_index)}/#{Utils.__listify(_type)}/_count"
61
66
  elsif _index
@@ -40,7 +40,7 @@ module Elasticsearch
40
40
  # Deprecated since version 7.0.0
41
41
  #
42
42
  #
43
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-index_.html
43
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-index_.html
44
44
  #
45
45
  def create(arguments = {})
46
46
  if arguments[:id]
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-gateway-dangling-indices.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-gateway-dangling-indices.html
31
31
  #
32
32
  def delete_dangling_index(arguments = {})
33
33
  raise ArgumentError, "Required argument 'index_uuid' missing" unless arguments[:index_uuid]
@@ -27,7 +27,7 @@ module Elasticsearch
27
27
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
28
28
  # @option arguments [Hash] :headers Custom HTTP headers
29
29
  #
30
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-gateway-dangling-indices.html
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-gateway-dangling-indices.html
31
31
  #
32
32
  def import_dangling_index(arguments = {})
33
33
  raise ArgumentError, "Required argument 'index_uuid' missing" unless arguments[:index_uuid]
@@ -23,7 +23,7 @@ module Elasticsearch
23
23
  #
24
24
  # @option arguments [Hash] :headers Custom HTTP headers
25
25
  #
26
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-gateway-dangling-indices.html
26
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-gateway-dangling-indices.html
27
27
  #
28
28
  def list_dangling_indices(arguments = {})
29
29
  headers = arguments.delete(:headers) || {}
@@ -38,7 +38,7 @@ module Elasticsearch
38
38
  # Deprecated since version 7.0.0
39
39
  #
40
40
  #
41
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-delete.html
41
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-delete.html
42
42
  #
43
43
  def delete(arguments = {})
44
44
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -41,9 +41,6 @@ module Elasticsearch
41
41
  # @option arguments [Number] :size Deprecated, please use `max_docs` instead
42
42
  # @option arguments [Number] :max_docs Maximum number of documents to process (default: all documents)
43
43
  # @option arguments [List] :sort A comma-separated list of <field>:<direction> pairs
44
- # @option arguments [List] :_source True or false to return the _source field or not, or a list of fields to return
45
- # @option arguments [List] :_source_excludes A list of fields to exclude from the returned _source field
46
- # @option arguments [List] :_source_includes A list of fields to extract and return from the _source field
47
44
  # @option arguments [Number] :terminate_after The maximum number of documents to collect for each shard, upon reaching which the query execution will terminate early.
48
45
  # @option arguments [List] :stats Specific 'tag' of the request for logging and statistical purposes
49
46
  # @option arguments [Boolean] :version Specify whether to return document version as part of a hit
@@ -63,7 +60,7 @@ module Elasticsearch
63
60
  # Deprecated since version 7.0.0
64
61
  #
65
62
  #
66
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-delete-by-query.html
63
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-delete-by-query.html
67
64
  #
68
65
  def delete_by_query(arguments = {})
69
66
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -112,9 +109,6 @@ module Elasticsearch
112
109
  :size,
113
110
  :max_docs,
114
111
  :sort,
115
- :_source,
116
- :_source_excludes,
117
- :_source_includes,
118
112
  :terminate_after,
119
113
  :stats,
120
114
  :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.11/docs-delete-by-query.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-delete-by-query.html
28
28
  #
29
29
  def delete_by_query_rethrottle(arguments = {})
30
30
  raise ArgumentError, "Required argument 'task_id' missing" unless arguments[:task_id]
@@ -25,7 +25,7 @@ module Elasticsearch
25
25
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
26
26
  # @option arguments [Hash] :headers Custom HTTP headers
27
27
  #
28
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-scripting.html
28
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-scripting.html
29
29
  #
30
30
  def delete_script(arguments = {})
31
31
  raise ArgumentError, "Required argument 'id' missing" unless arguments[:id]
@@ -40,7 +40,7 @@ module Elasticsearch
40
40
  # Deprecated since version 7.0.0
41
41
  #
42
42
  #
43
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-get.html
43
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-get.html
44
44
  #
45
45
  def exists(arguments = {})
46
46
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -72,6 +72,7 @@ module Elasticsearch
72
72
  end
73
73
 
74
74
  alias_method :exists?, :exists
75
+
75
76
  # Register this action with its valid params when the module is loaded.
76
77
  #
77
78
  # @since 6.2.0
@@ -39,7 +39,7 @@ module Elasticsearch
39
39
  # Deprecated since version 7.0.0
40
40
  #
41
41
  #
42
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-get.html
42
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-get.html
43
43
  #
44
44
  def exists_source(arguments = {})
45
45
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -68,6 +68,7 @@ module Elasticsearch
68
68
  end
69
69
 
70
70
  alias_method :exists_source?, :exists_source
71
+
71
72
  # Register this action with its valid params when the module is loaded.
72
73
  #
73
74
  # @since 6.2.0
@@ -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.11/search-explain.html
46
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/search-explain.html
47
47
  #
48
48
  def explain(arguments = {})
49
49
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -65,11 +65,11 @@ module Elasticsearch
65
65
  Elasticsearch::API::HTTP_GET
66
66
  end
67
67
 
68
- path = if _index && _type && _id
69
- "#{Utils.__listify(_index)}/#{Utils.__listify(_type)}/#{Utils.__listify(_id)}/_explain"
70
- else
71
- "#{Utils.__listify(_index)}/_explain/#{Utils.__listify(_id)}"
72
- end
68
+ path = if _index && _type && _id
69
+ "#{Utils.__listify(_index)}/#{Utils.__listify(_type)}/#{Utils.__listify(_id)}/_explain"
70
+ else
71
+ "#{Utils.__listify(_index)}/_explain/#{Utils.__listify(_id)}"
72
+ end
73
73
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
74
74
 
75
75
  body = arguments[:body]
@@ -17,38 +17,33 @@
17
17
 
18
18
  module Elasticsearch
19
19
  module API
20
- module Nodes
20
+ module Features
21
21
  module Actions
22
- # Shutdown one or all nodes
22
+ # Gets a list of features which can be included in snapshots using the feature_states field when creating a snapshot
23
23
  #
24
- # @example Shut down node named _Bloke_
24
+ # @option arguments [Time] :master_timeout Explicit operation timeout for connection to master node
25
+ # @option arguments [Hash] :headers Custom HTTP headers
25
26
  #
26
- # client.nodes.shutdown node_id: 'Bloke'
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/get-features-api.html
27
28
  #
28
- # @option arguments [List] :node_id A comma-separated list of node IDs or names to perform the operation on; use
29
- # `_local` to shutdown the node you're connected to, leave empty to
30
- # shutdown all nodes
31
- # @option arguments [Time] :delay Set the delay for the operation (default: 1s)
32
- # @option arguments [Boolean] :exit Exit the JVM as well (default: true)
33
- #
34
- # @see http://elasticsearch.org/guide/reference/api/admin-cluster-nodes-shutdown/
35
- #
36
- def shutdown(arguments = {})
37
- method = HTTP_POST
38
- path = Utils.__pathify '_cluster/nodes', Utils.__listify(arguments[:node_id]), '_shutdown'
29
+ def get_features(arguments = {})
30
+ headers = arguments.delete(:headers) || {}
31
+
32
+ arguments = arguments.clone
39
33
 
34
+ method = Elasticsearch::API::HTTP_GET
35
+ path = "_features"
40
36
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
41
- body = nil
42
37
 
43
- perform_request(method, path, params, body).body
38
+ body = nil
39
+ perform_request(method, path, params, body, headers).body
44
40
  end
45
41
 
46
42
  # Register this action with its valid params when the module is loaded.
47
43
  #
48
- # @since 6.1.1
49
- ParamsRegistry.register(:shutdown, [
50
- :delay,
51
- :exit
44
+ # @since 6.2.0
45
+ ParamsRegistry.register(:get_features, [
46
+ :master_timeout
52
47
  ].freeze)
53
48
  end
54
49
  end
@@ -0,0 +1,60 @@
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 Features
21
+ module Actions
22
+ module ParamsRegistry
23
+ extend self
24
+
25
+ # A Mapping of all the actions to their list of valid params.
26
+ #
27
+ # @since 6.1.1
28
+ PARAMS = {}
29
+
30
+ # Register an action with its list of valid params.
31
+ #
32
+ # @example Register the action.
33
+ # ParamsRegistry.register(:benchmark, [ :verbose ])
34
+ #
35
+ # @param [ Symbol ] action The action to register.
36
+ # @param [ Array[Symbol] ] valid_params The list of valid params.
37
+ #
38
+ # @since 6.1.1
39
+ def register(action, valid_params)
40
+ PARAMS[action.to_sym] = valid_params
41
+ end
42
+
43
+ # Get the list of valid params for a given action.
44
+ #
45
+ # @example Get the list of valid params.
46
+ # ParamsRegistry.get(:benchmark)
47
+ #
48
+ # @param [ Symbol ] action The action.
49
+ #
50
+ # @return [ Array<Symbol> ] The list of valid params for the action.
51
+ #
52
+ # @since 6.1.1
53
+ def get(action)
54
+ PARAMS.fetch(action, [])
55
+ end
56
+ end
57
+ end
58
+ end
59
+ end
60
+ end
@@ -0,0 +1,47 @@
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 Features
21
+ module Actions
22
+ # Resets the internal state of features, usually by deleting system indices
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.
27
+ #
28
+ # @option arguments [Hash] :headers Custom HTTP headers
29
+ #
30
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-snapshots.html
31
+ #
32
+ def reset_features(arguments = {})
33
+ headers = arguments.delete(:headers) || {}
34
+
35
+ arguments = arguments.clone
36
+
37
+ method = Elasticsearch::API::HTTP_POST
38
+ path = "_features/_reset"
39
+ params = {}
40
+
41
+ body = nil
42
+ perform_request(method, path, params, body, headers).body
43
+ end
44
+ end
45
+ end
46
+ end
47
+ end
@@ -29,7 +29,7 @@ module Elasticsearch
29
29
  # @option arguments [Hash] :headers Custom HTTP headers
30
30
  # @option arguments [Hash] :body An index filter specified with the Query DSL
31
31
  #
32
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/search-field-caps.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/search-field-caps.html
33
33
  #
34
34
  def field_caps(arguments = {})
35
35
  headers = arguments.delete(:headers) || {}
@@ -44,11 +44,11 @@ module Elasticsearch
44
44
  Elasticsearch::API::HTTP_GET
45
45
  end
46
46
 
47
- path = if _index
48
- "#{Utils.__listify(_index)}/_field_caps"
49
- else
50
- "_field_caps"
51
- end
47
+ path = if _index
48
+ "#{Utils.__listify(_index)}/_field_caps"
49
+ else
50
+ "_field_caps"
51
+ end
52
52
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
53
53
 
54
54
  body = arguments[:body]
@@ -40,7 +40,7 @@ module Elasticsearch
40
40
  # Deprecated since version 7.0.0
41
41
  #
42
42
  #
43
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-get.html
43
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-get.html
44
44
  #
45
45
  def get(arguments = {})
46
46
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -24,7 +24,7 @@ module Elasticsearch
24
24
  # @option arguments [Time] :master_timeout Specify timeout for connection to master
25
25
  # @option arguments [Hash] :headers Custom HTTP headers
26
26
  #
27
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-scripting.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-scripting.html
28
28
  #
29
29
  def get_script(arguments = {})
30
30
  raise ArgumentError, "Required argument 'id' missing" unless arguments[:id]
@@ -19,14 +19,10 @@ module Elasticsearch
19
19
  module API
20
20
  module Actions
21
21
  # Returns all script contexts.
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 [Hash] :headers Custom HTTP headers
28
24
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.11/painless-contexts.html
25
+ # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.17/painless-contexts.html
30
26
  #
31
27
  def get_script_context(arguments = {})
32
28
  headers = arguments.delete(:headers) || {}
@@ -19,14 +19,10 @@ module Elasticsearch
19
19
  module API
20
20
  module Actions
21
21
  # Returns available script types, languages and contexts
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 [Hash] :headers Custom HTTP headers
28
24
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/modules-scripting.html
25
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/modules-scripting.html
30
26
  #
31
27
  def get_script_languages(arguments = {})
32
28
  headers = arguments.delete(:headers) || {}
@@ -39,7 +39,7 @@ module Elasticsearch
39
39
  # Deprecated since version 7.0.0
40
40
  #
41
41
  #
42
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.11/docs-get.html
42
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-get.html
43
43
  #
44
44
  def get_source(arguments = {})
45
45
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -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.11/docs-index_.html
45
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.17/docs-index_.html
46
46
  #
47
47
  def index(arguments = {})
48
48
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]