elasticsearch-api 7.9.0 → 7.14.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (200) hide show
  1. checksums.yaml +4 -4
  2. data/Gemfile +4 -4
  3. data/README.md +27 -13
  4. data/Rakefile +46 -62
  5. data/elasticsearch-api.gemspec +2 -4
  6. data/lib/elasticsearch/api/actions/bulk.rb +4 -3
  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 -2
  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 +2 -2
  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 -2
  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 +2 -2
  23. data/lib/elasticsearch/api/actions/cat/snapshots.rb +1 -1
  24. data/lib/elasticsearch/api/actions/cat/tasks.rb +5 -5
  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/close_point_in_time.rb +42 -0
  29. data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +1 -1
  30. data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +1 -5
  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 -5
  33. data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +1 -5
  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 -5
  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 +1 -1
  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 -1
  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/features/get_features.rb +51 -0
  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 -1
  63. data/lib/elasticsearch/api/actions/get_script_languages.rb +1 -1
  64. data/lib/elasticsearch/api/actions/get_source.rb +1 -1
  65. data/lib/elasticsearch/api/actions/index.rb +4 -2
  66. data/lib/elasticsearch/api/actions/indices/add_block.rb +1 -1
  67. data/lib/elasticsearch/api/actions/indices/analyze.rb +6 -7
  68. data/lib/elasticsearch/api/actions/indices/clear_cache.rb +1 -2
  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 +1 -1
  73. data/lib/elasticsearch/api/actions/indices/delete_alias.rb +1 -1
  74. data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +1 -5
  75. data/lib/elasticsearch/api/actions/indices/delete_template.rb +1 -1
  76. data/lib/elasticsearch/api/actions/indices/exists.rb +2 -1
  77. data/lib/elasticsearch/api/actions/indices/exists_alias.rb +2 -1
  78. data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +2 -5
  79. data/lib/elasticsearch/api/actions/indices/exists_template.rb +2 -1
  80. data/lib/elasticsearch/api/actions/indices/exists_type.rb +2 -1
  81. data/lib/elasticsearch/api/actions/indices/flush.rb +1 -1
  82. data/lib/elasticsearch/api/actions/indices/flush_synced.rb +6 -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 +1 -5
  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 +7 -2
  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 -5
  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 -1
  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 -5
  106. data/lib/elasticsearch/api/actions/indices/simulate_template.rb +1 -5
  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 +7 -2
  111. data/lib/elasticsearch/api/actions/indices/validate_query.rb +8 -8
  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 +43 -0
  115. data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +3 -1
  116. data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +1 -1
  117. data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +1 -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 +4 -6
  121. data/lib/elasticsearch/api/actions/msearch_template.rb +2 -2
  122. data/lib/elasticsearch/api/actions/mtermvectors.rb +8 -8
  123. data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +1 -1
  124. data/lib/elasticsearch/api/actions/nodes/info.rb +1 -1
  125. data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +1 -1
  126. data/lib/elasticsearch/api/actions/nodes/stats.rb +4 -2
  127. data/lib/elasticsearch/api/actions/nodes/usage.rb +1 -1
  128. data/lib/elasticsearch/api/actions/open_point_in_time.rb +64 -0
  129. data/lib/elasticsearch/api/actions/ping.rb +3 -3
  130. data/lib/elasticsearch/api/actions/put_script.rb +1 -2
  131. data/lib/elasticsearch/api/actions/rank_eval.rb +1 -1
  132. data/lib/elasticsearch/api/actions/reindex.rb +1 -1
  133. data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +1 -1
  134. data/lib/elasticsearch/api/actions/render_search_template.rb +6 -6
  135. data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +2 -2
  136. data/lib/elasticsearch/api/actions/scroll.rb +6 -7
  137. data/lib/elasticsearch/api/actions/search.rb +11 -9
  138. data/lib/elasticsearch/api/actions/search_shards.rb +1 -1
  139. data/lib/elasticsearch/api/actions/search_template.rb +2 -2
  140. data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +52 -0
  141. data/lib/elasticsearch/api/actions/shutdown/get_node.rb +54 -0
  142. data/lib/elasticsearch/api/actions/shutdown/params_registry.rb +60 -0
  143. data/lib/elasticsearch/api/actions/shutdown/put_node.rb +54 -0
  144. data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +1 -1
  145. data/lib/elasticsearch/api/actions/snapshot/clone.rb +66 -0
  146. data/lib/elasticsearch/api/actions/snapshot/create.rb +1 -1
  147. data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +1 -1
  148. data/lib/elasticsearch/api/actions/snapshot/delete.rb +1 -1
  149. data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +1 -1
  150. data/lib/elasticsearch/api/actions/snapshot/get.rb +5 -1
  151. data/lib/elasticsearch/api/actions/snapshot/get_features.rb +51 -0
  152. data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +1 -1
  153. data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +76 -0
  154. data/lib/elasticsearch/api/actions/snapshot/restore.rb +1 -1
  155. data/lib/elasticsearch/api/actions/snapshot/status.rb +1 -1
  156. data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +1 -1
  157. data/lib/elasticsearch/api/actions/tasks/cancel.rb +5 -1
  158. data/lib/elasticsearch/api/actions/tasks/get.rb +5 -1
  159. data/lib/elasticsearch/api/actions/tasks/list.rb +5 -1
  160. data/lib/elasticsearch/api/actions/termvectors.rb +11 -10
  161. data/lib/elasticsearch/api/actions/update.rb +4 -2
  162. data/lib/elasticsearch/api/actions/update_by_query.rb +1 -1
  163. data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +1 -1
  164. data/lib/elasticsearch/api/namespace/features.rb +36 -0
  165. data/lib/elasticsearch/api/namespace/security.rb +36 -0
  166. data/lib/elasticsearch/api/namespace/shutdown.rb +37 -0
  167. data/lib/elasticsearch/api/version.rb +1 -1
  168. data/lib/elasticsearch/api.rb +3 -1
  169. data/spec/elasticsearch/api/actions/close_point_in_time_spec.rb +34 -0
  170. data/spec/elasticsearch/api/actions/features/get_features_spec.rb +34 -0
  171. data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +34 -0
  172. data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +16 -3
  173. data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +34 -0
  174. data/spec/elasticsearch/api/actions/msearch_spec.rb +16 -33
  175. data/spec/elasticsearch/api/actions/open_point_in_time_spec.rb +44 -0
  176. data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +44 -0
  177. data/spec/elasticsearch/api/actions/{indices/freeze_spec.rb → shutdown/get_node_spec.rb} +12 -51
  178. data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +50 -0
  179. data/spec/elasticsearch/api/actions/snapshot/clone_spec.rb +67 -0
  180. data/spec/elasticsearch/api/actions/snapshot/get_features_spec.rb +38 -0
  181. data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +48 -0
  182. data/spec/elasticsearch/api/rest_api_yaml_spec.rb +36 -9
  183. data/spec/rest_yaml_tests_helper.rb +25 -52
  184. data/spec/skipped_tests.yml +29 -0
  185. data/spec/spec_helper.rb +4 -1
  186. data/utils/Gemfile +4 -3
  187. data/utils/README.md +6 -1
  188. data/utils/thor/generate_source.rb +1 -2
  189. data/utils/thor/generator/endpoint_specifics.rb +6 -2
  190. data/utils/thor/generator/files_helper.rb +38 -20
  191. data/utils/thor/templates/_documentation_top.erb +20 -1
  192. data/utils/thor/templates/_method_setup.erb +18 -0
  193. data/utils/thor/templates/_params_registry.erb +19 -0
  194. data/utils/thor/templates/_perform_request.erb +19 -1
  195. data/utils/thor/templates/test.erb +16 -3
  196. data/utils/thor/templates/test_helper.rb +0 -4
  197. metadata +46 -46
  198. data/lib/elasticsearch/api/actions/indices/freeze.rb +0 -56
  199. data/lib/elasticsearch/api/actions/indices/unfreeze.rb +0 -56
  200. data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +0 -85
@@ -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.9/docs-delete.html
41
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-delete.html
42
42
  #
43
43
  def delete(arguments = {})
44
44
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -63,7 +63,7 @@ module Elasticsearch
63
63
  # Deprecated since version 7.0.0
64
64
  #
65
65
  #
66
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/docs-delete-by-query.html
66
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-delete-by-query.html
67
67
  #
68
68
  def delete_by_query(arguments = {})
69
69
  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.9/docs-delete-by-query.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/modules-scripting.html
28
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/docs-get.html
43
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/docs-get.html
42
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/search-explain.html
46
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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]
@@ -0,0 +1,51 @@
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
+ # Gets a list of features which can be included in snapshots using the feature_states field when creating a snapshot
23
+ #
24
+ # @option arguments [Time] :master_timeout Explicit operation timeout for connection to master node
25
+ # @option arguments [Hash] :headers Custom HTTP headers
26
+ #
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/get-features-api.html
28
+ #
29
+ def get_features(arguments = {})
30
+ headers = arguments.delete(:headers) || {}
31
+
32
+ arguments = arguments.clone
33
+
34
+ method = Elasticsearch::API::HTTP_GET
35
+ path = "_features"
36
+ params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
37
+
38
+ body = nil
39
+ perform_request(method, path, params, body, headers).body
40
+ end
41
+
42
+ # Register this action with its valid params when the module is loaded.
43
+ #
44
+ # @since 6.2.0
45
+ ParamsRegistry.register(:get_features, [
46
+ :master_timeout
47
+ ].freeze)
48
+ end
49
+ end
50
+ end
51
+ 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.14/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.9/search-field-caps.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/docs-get.html
43
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/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.9/modules-scripting.html
27
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-scripting.html
28
28
  #
29
29
  def get_script(arguments = {})
30
30
  raise ArgumentError, "Required argument 'id' missing" unless arguments[:id]
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  #
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.9/painless-contexts.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/painless/7.14/painless-contexts.html
30
30
  #
31
31
  def get_script_context(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
@@ -26,7 +26,7 @@ module Elasticsearch
26
26
  #
27
27
  # @option arguments [Hash] :headers Custom HTTP headers
28
28
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/modules-scripting.html
29
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/modules-scripting.html
30
30
  #
31
31
  def get_script_languages(arguments = {})
32
32
  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.9/docs-get.html
42
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-get.html
43
43
  #
44
44
  def get_source(arguments = {})
45
45
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -33,6 +33,7 @@ module Elasticsearch
33
33
  # @option arguments [Number] :if_seq_no only perform the index operation if the last operation that has changed the document has the specified sequence number
34
34
  # @option arguments [Number] :if_primary_term only perform the index operation if the last operation that has changed the document has the specified primary term
35
35
  # @option arguments [String] :pipeline The pipeline id to preprocess incoming documents with
36
+ # @option arguments [Boolean] :require_alias When true, requires destination to be an alias. Default is false
36
37
  # @option arguments [Hash] :headers Custom HTTP headers
37
38
  # @option arguments [Hash] :body The document (*Required*)
38
39
  #
@@ -41,7 +42,7 @@ module Elasticsearch
41
42
  # Deprecated since version 7.0.0
42
43
  #
43
44
  #
44
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/docs-index_.html
45
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/docs-index_.html
45
46
  #
46
47
  def index(arguments = {})
47
48
  raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
@@ -86,7 +87,8 @@ module Elasticsearch
86
87
  :version_type,
87
88
  :if_seq_no,
88
89
  :if_primary_term,
89
- :pipeline
90
+ :pipeline,
91
+ :require_alias
90
92
  ].freeze)
91
93
  end
92
94
  end
@@ -30,7 +30,7 @@ module Elasticsearch
30
30
  # @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)
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/index-modules-blocks.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/index-modules-blocks.html
34
34
  #
35
35
  def add_block(arguments = {})
36
36
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -22,11 +22,10 @@ module Elasticsearch
22
22
  # Performs the analysis process on a text and return the tokens breakdown of the text.
23
23
  #
24
24
  # @option arguments [String] :index The name of the index to scope the operation
25
- # @option arguments [String] :index The name of the index to scope the operation
26
25
  # @option arguments [Hash] :headers Custom HTTP headers
27
26
  # @option arguments [Hash] :body Define analyzer/tokenizer parameters and the text on which the analysis should be performed
28
27
  #
29
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/indices-analyze.html
28
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/indices-analyze.html
30
29
  #
31
30
  def analyze(arguments = {})
32
31
  headers = arguments.delete(:headers) || {}
@@ -41,11 +40,11 @@ module Elasticsearch
41
40
  Elasticsearch::API::HTTP_GET
42
41
  end
43
42
 
44
- path = if _index
45
- "#{Utils.__listify(_index)}/_analyze"
46
- else
47
- "_analyze"
48
- end
43
+ path = if _index
44
+ "#{Utils.__listify(_index)}/_analyze"
45
+ else
46
+ "_analyze"
47
+ end
49
48
  params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
50
49
 
51
50
  body = arguments[:body]
@@ -28,11 +28,10 @@ module Elasticsearch
28
28
  # @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when unavailable (missing or closed)
29
29
  # @option arguments [Boolean] :allow_no_indices Whether to ignore if a wildcard indices expression resolves into no concrete indices. (This includes `_all` string or when no indices have been specified)
30
30
  # @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)
31
- # @option arguments [List] :index A comma-separated list of index name to limit the operation
32
31
  # @option arguments [Boolean] :request Clear request cache
33
32
  # @option arguments [Hash] :headers Custom HTTP headers
34
33
  #
35
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/indices-clearcache.html
34
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/indices-clearcache.html
36
35
  #
37
36
  def clear_cache(arguments = {})
38
37
  headers = arguments.delete(:headers) || {}
@@ -29,7 +29,7 @@ module Elasticsearch
29
29
  # @option arguments [Hash] :headers Custom HTTP headers
30
30
  # @option arguments [Hash] :body The configuration for the target index (`settings` and `aliases`)
31
31
  #
32
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/indices-clone-index.html
32
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/indices-clone-index.html
33
33
  #
34
34
  def clone(arguments = {})
35
35
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
@@ -27,10 +27,10 @@ module Elasticsearch
27
27
  # @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when unavailable (missing or closed)
28
28
  # @option arguments [Boolean] :allow_no_indices Whether to ignore if a wildcard indices expression resolves into no concrete indices. (This includes `_all` string or when no indices have been specified)
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
- # @option arguments [String] :wait_for_active_shards Sets the number of active shards to wait for before the operation returns.
30
+ # @option arguments [String] :wait_for_active_shards Sets the number of active shards to wait for before the operation returns. Set to `index-setting` to wait according to the index setting `index.write.wait_for_active_shards`, or `all` to wait for all shards, or an integer. Defaults to `0`.
31
31
  # @option arguments [Hash] :headers Custom HTTP headers
32
32
  #
33
- # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.9/indices-open-close.html
33
+ # @see https://www.elastic.co/guide/en/elasticsearch/reference/7.14/indices-open-close.html
34
34
  #
35
35
  def close(arguments = {})
36
36
  raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]