elasticsearch-api 7.11.2 → 7.16.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +4 -4
- data/README.md +22 -45
- data/Rakefile +46 -62
- data/elasticsearch-api.gemspec +6 -7
- data/lib/elasticsearch/api/actions/bulk.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/aliases.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/allocation.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/count.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/health.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/help.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/indices.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/master.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/nodes.rb +4 -2
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/plugins.rb +3 -1
- data/lib/elasticsearch/api/actions/cat/recovery.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/repositories.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/segments.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/shards.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/tasks.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/templates.rb +1 -1
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +1 -1
- data/lib/elasticsearch/api/actions/clear_scroll.rb +1 -1
- data/lib/elasticsearch/api/actions/{abort_benchmark.rb → close_point_in_time.rb} +13 -12
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +3 -3
- data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +2 -1
- data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/health.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/remote_info.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/state.rb +1 -1
- data/lib/elasticsearch/api/actions/cluster/stats.rb +1 -1
- data/lib/elasticsearch/api/actions/count.rb +7 -2
- data/lib/elasticsearch/api/actions/create.rb +1 -1
- data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +1 -1
- data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +1 -1
- data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +1 -1
- data/lib/elasticsearch/api/actions/delete.rb +1 -1
- data/lib/elasticsearch/api/actions/delete_by_query.rb +1 -1
- data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +1 -1
- data/lib/elasticsearch/api/actions/delete_script.rb +1 -1
- data/lib/elasticsearch/api/actions/exists.rb +2 -1
- data/lib/elasticsearch/api/actions/exists_source.rb +2 -1
- data/lib/elasticsearch/api/actions/explain.rb +6 -6
- data/lib/elasticsearch/api/actions/{nodes/shutdown.rb → features/get_features.rb} +16 -21
- data/lib/elasticsearch/api/actions/features/params_registry.rb +60 -0
- data/lib/elasticsearch/api/actions/features/reset_features.rb +47 -0
- data/lib/elasticsearch/api/actions/field_caps.rb +6 -6
- data/lib/elasticsearch/api/actions/get.rb +1 -1
- data/lib/elasticsearch/api/actions/get_script.rb +1 -1
- data/lib/elasticsearch/api/actions/get_script_context.rb +1 -5
- data/lib/elasticsearch/api/actions/get_script_languages.rb +1 -5
- data/lib/elasticsearch/api/actions/get_source.rb +1 -1
- data/lib/elasticsearch/api/actions/index.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/add_block.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/analyze.rb +6 -6
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/clone.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/close.rb +2 -2
- data/lib/elasticsearch/api/actions/indices/create.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/delete.rb +2 -2
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +6 -2
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/disk_usage.rb +68 -0
- data/lib/elasticsearch/api/actions/indices/exists.rb +2 -1
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +2 -1
- data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +7 -2
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +2 -1
- data/lib/elasticsearch/api/actions/indices/exists_type.rb +2 -1
- data/lib/elasticsearch/api/actions/indices/field_usage_stats.rb +66 -0
- data/lib/elasticsearch/api/actions/indices/flush.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/flush_synced.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_index_template.rb +2 -2
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/get_upgrade.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/open.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/put_index_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/put_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/recovery.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/refresh.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/resolve_index.rb +1 -5
- data/lib/elasticsearch/api/actions/indices/rollover.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/segments.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/shrink.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/simulate_template.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/split.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/stats.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/upgrade.rb +1 -1
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +8 -8
- data/lib/elasticsearch/api/actions/info.rb +1 -1
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +1 -1
- data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +43 -0
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +3 -1
- data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +1 -1
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +3 -1
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +1 -1
- data/lib/elasticsearch/api/actions/mget.rb +1 -1
- data/lib/elasticsearch/api/actions/msearch.rb +2 -2
- data/lib/elasticsearch/api/actions/msearch_template.rb +2 -2
- data/lib/elasticsearch/api/actions/mtermvectors.rb +8 -8
- data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +56 -0
- data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +52 -0
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +4 -2
- data/lib/elasticsearch/api/actions/nodes/info.rb +2 -2
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +1 -1
- data/lib/elasticsearch/api/actions/nodes/stats.rb +5 -3
- data/lib/elasticsearch/api/actions/nodes/usage.rb +1 -1
- data/lib/elasticsearch/api/actions/open_point_in_time.rb +62 -0
- data/lib/elasticsearch/api/actions/ping.rb +3 -3
- data/lib/elasticsearch/api/actions/put_script.rb +1 -1
- data/lib/elasticsearch/api/actions/rank_eval.rb +1 -5
- data/lib/elasticsearch/api/actions/reindex.rb +1 -1
- data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +1 -1
- data/lib/elasticsearch/api/actions/render_search_template.rb +6 -6
- data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +2 -2
- data/lib/elasticsearch/api/actions/scroll.rb +6 -6
- data/lib/elasticsearch/api/actions/search.rb +11 -9
- data/lib/elasticsearch/api/actions/search_mvt.rb +85 -0
- data/lib/elasticsearch/api/actions/search_shards.rb +1 -1
- data/lib/elasticsearch/api/actions/search_template.rb +2 -2
- data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +48 -0
- data/lib/elasticsearch/api/actions/shutdown/get_node.rb +50 -0
- data/lib/elasticsearch/api/actions/shutdown/params_registry.rb +60 -0
- data/lib/elasticsearch/api/actions/shutdown/put_node.rb +50 -0
- data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/clone.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/create.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/get.rb +5 -1
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +76 -0
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/status.rb +1 -1
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +1 -1
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +1 -1
- data/lib/elasticsearch/api/actions/tasks/get.rb +1 -1
- data/lib/elasticsearch/api/actions/tasks/list.rb +1 -1
- data/lib/elasticsearch/api/actions/termvectors.rb +11 -10
- data/lib/elasticsearch/api/actions/update.rb +1 -1
- data/lib/elasticsearch/api/actions/update_by_query.rb +1 -1
- data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +1 -1
- data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/features.rb} +12 -13
- data/lib/elasticsearch/api/namespace/security.rb +36 -0
- data/lib/elasticsearch/api/namespace/shutdown.rb +37 -0
- data/lib/elasticsearch/api/version.rb +1 -1
- data/lib/elasticsearch/api.rb +3 -1
- data/spec/elasticsearch/api/actions/{benchmark_spec.rb → close_point_in_time_spec.rb} +6 -6
- data/spec/elasticsearch/api/actions/count_spec.rb +2 -5
- data/spec/elasticsearch/api/actions/{remote/info_spec.rb → features/get_features_spec.rb} +7 -8
- data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +16 -3
- data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +34 -0
- data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +51 -0
- data/spec/elasticsearch/api/actions/nodes/get_repositories_metering_info_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → open_point_in_time_spec.rb} +5 -5
- data/spec/elasticsearch/api/actions/search_mvt_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +44 -0
- data/spec/elasticsearch/api/actions/shutdown/get_node_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +50 -0
- data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +48 -0
- data/spec/elasticsearch/api/rest_api_yaml_spec.rb +23 -3
- data/spec/rest_yaml_tests_helper.rb +17 -53
- data/spec/skipped_tests.yml +29 -0
- data/spec/spec_helper.rb +4 -1
- data/utils/Gemfile +4 -3
- data/utils/README.md +6 -1
- data/utils/thor/.rubocop.yml +2 -0
- data/utils/thor/generate_source.rb +18 -13
- data/utils/thor/generator/endpoint_specifics.rb +7 -1
- data/utils/thor/generator/files_helper.rb +38 -20
- data/utils/thor/templates/_documentation_top.erb +19 -0
- data/utils/thor/templates/_method_setup.erb +18 -0
- data/utils/thor/templates/_params_registry.erb +19 -0
- data/utils/thor/templates/_perform_request.erb +19 -1
- data/utils/thor/templates/test.erb +16 -3
- data/utils/thor/templates/test_helper.rb +0 -4
- metadata +58 -48
- data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
- data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
- data/lib/elasticsearch/api/actions/indices/freeze.rb +0 -56
- data/lib/elasticsearch/api/actions/indices/unfreeze.rb +0 -56
- data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +0 -85
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +0 -85
- data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +0 -76
@@ -1,81 +0,0 @@
|
|
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
|
-
# Run a single query, or a set of queries, and return statistics on their performance
|
22
|
-
#
|
23
|
-
# @example Return statistics for a single query
|
24
|
-
#
|
25
|
-
# client.benchmark body: {
|
26
|
-
# name: 'my_benchmark',
|
27
|
-
# competitors: [
|
28
|
-
# {
|
29
|
-
# name: 'query_1',
|
30
|
-
# requests: [
|
31
|
-
# { query: { match: { _all: 'a*' } } }
|
32
|
-
# ]
|
33
|
-
# }
|
34
|
-
# ]
|
35
|
-
# }
|
36
|
-
#
|
37
|
-
# @example Return statistics for a set of "competing" queries
|
38
|
-
#
|
39
|
-
# client.benchmark body: {
|
40
|
-
# name: 'my_benchmark',
|
41
|
-
# competitors: [
|
42
|
-
# {
|
43
|
-
# name: 'query_a',
|
44
|
-
# requests: [
|
45
|
-
# { query: { match: { _all: 'a*' } } }
|
46
|
-
# ]
|
47
|
-
# },
|
48
|
-
# {
|
49
|
-
# name: 'query_b',
|
50
|
-
# requests: [
|
51
|
-
# { query: { match: { _all: 'b*' } } }
|
52
|
-
# ]
|
53
|
-
# }
|
54
|
-
# ]
|
55
|
-
# }
|
56
|
-
#
|
57
|
-
# @option arguments [List] :index A comma-separated list of index names; use `_all` or empty string
|
58
|
-
# to perform the operation on all indices
|
59
|
-
# @option arguments [String] :type The name of the document type
|
60
|
-
# @option arguments [Hash] :body The search definition using the Query DSL
|
61
|
-
# @option arguments [Boolean] :verbose Specify whether to return verbose statistics about each iteration
|
62
|
-
# (default: false)
|
63
|
-
#
|
64
|
-
# @see https://www.elastic.co/guide/en/elasticsearch/reference/master/search-benchmark.html
|
65
|
-
#
|
66
|
-
def benchmark(arguments = {})
|
67
|
-
method = HTTP_PUT
|
68
|
-
path = "_bench"
|
69
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
70
|
-
body = arguments[:body]
|
71
|
-
|
72
|
-
perform_request(method, path, params, body).body
|
73
|
-
end
|
74
|
-
|
75
|
-
# Register this action with its valid params when the module is loaded.
|
76
|
-
#
|
77
|
-
# @since 6.1.1
|
78
|
-
ParamsRegistry.register(:benchmark, [:verbose].freeze)
|
79
|
-
end
|
80
|
-
end
|
81
|
-
end
|
@@ -1,47 +0,0 @@
|
|
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
|
-
# The value of requests_per_second can be changed on a running delete by query using the _rethrottle API
|
22
|
-
#
|
23
|
-
# @option arguments [String] :task_id The task id to rethrottle (*Required*)
|
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.
|
25
|
-
#
|
26
|
-
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/docs-delete-by-query.html
|
27
|
-
#
|
28
|
-
def delete_by_query_rethrottle(arguments = {})
|
29
|
-
raise ArgumentError, "Required argument 'task_id' missing" unless arguments[:task_id]
|
30
|
-
|
31
|
-
method = Elasticsearch::API::HTTP_POST
|
32
|
-
path = "_delete_by_query/#{arguments[:task_id]}/_rethrottle"
|
33
|
-
params = Elasticsearch::API::Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
34
|
-
body = nil
|
35
|
-
|
36
|
-
perform_request(method, path, params, body).body
|
37
|
-
end
|
38
|
-
|
39
|
-
# Register this action with its valid params when the module is loaded.
|
40
|
-
#
|
41
|
-
# @since 6.2.0
|
42
|
-
ParamsRegistry.register(:delete_by_query_rethrottle, [
|
43
|
-
:requests_per_second
|
44
|
-
].freeze)
|
45
|
-
end
|
46
|
-
end
|
47
|
-
end
|
@@ -1,56 +0,0 @@
|
|
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 Indices
|
21
|
-
module Actions
|
22
|
-
# In order to keep indices available and queryable for a longer period but at the same time reduce their
|
23
|
-
# hardware requirements they can be transitioned into a frozen state. Once an index is frozen, all of its
|
24
|
-
# transient shard memory (aside from mappings and analyzers) is moved to persistent storage.
|
25
|
-
#
|
26
|
-
# @option arguments [List] :index A comma separated list of indices to freeze. (*Required*)
|
27
|
-
#
|
28
|
-
# @note This feature is available in the Platinum distribution of Elasticsearch.
|
29
|
-
#
|
30
|
-
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/frozen-indices.html
|
31
|
-
#
|
32
|
-
def freeze(arguments = {})
|
33
|
-
raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
|
34
|
-
|
35
|
-
valid_params = [
|
36
|
-
:timeout,
|
37
|
-
:master_timeout,
|
38
|
-
:ignore_unavailable,
|
39
|
-
:allow_no_indices,
|
40
|
-
:expand_wildcards,
|
41
|
-
:wait_for_active_shards
|
42
|
-
]
|
43
|
-
|
44
|
-
arguments = arguments.clone
|
45
|
-
index = arguments.delete(:index)
|
46
|
-
|
47
|
-
method = Elasticsearch::API::HTTP_POST
|
48
|
-
path = Elasticsearch::API::Utils.__pathify Elasticsearch::API::Utils.__listify(index), '_freeze'
|
49
|
-
params = Elasticsearch::API::Utils.__validate_and_extract_params arguments, valid_params
|
50
|
-
|
51
|
-
perform_request(method, path, params).body
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
@@ -1,56 +0,0 @@
|
|
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 Indices
|
21
|
-
module Actions
|
22
|
-
# In order to keep indices available and queryable for a longer period but at the same time reduce their
|
23
|
-
# hardware requirements they can be transitioned into a frozen state. Once an index is frozen, all of its
|
24
|
-
# transient shard memory (aside from mappings and analyzers) is moved to persistent storage.
|
25
|
-
#
|
26
|
-
# @option arguments [List] :index A comma separated list of indices to unfreeze. (*Required*)
|
27
|
-
#
|
28
|
-
# @note This feature is available in the Platinum distribution of Elasticsearch.
|
29
|
-
#
|
30
|
-
# @see https://www.elastic.co/guide/en/elasticsearch/reference/current/frozen-indices.html
|
31
|
-
#
|
32
|
-
def unfreeze(arguments = {})
|
33
|
-
raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
|
34
|
-
|
35
|
-
valid_params = [
|
36
|
-
:timeout,
|
37
|
-
:master_timeout,
|
38
|
-
:ignore_unavailable,
|
39
|
-
:allow_no_indices,
|
40
|
-
:expand_wildcards,
|
41
|
-
:wait_for_active_shards
|
42
|
-
]
|
43
|
-
|
44
|
-
arguments = arguments.clone
|
45
|
-
index = arguments.delete(:index)
|
46
|
-
|
47
|
-
method = Elasticsearch::API::HTTP_POST
|
48
|
-
path = Elasticsearch::API::Utils.__pathify Elasticsearch::API::Utils.__listify(index), '_unfreeze'
|
49
|
-
params = Elasticsearch::API::Utils.__validate_and_extract_params arguments, valid_params
|
50
|
-
|
51
|
-
perform_request(method, path, params).body
|
52
|
-
end
|
53
|
-
end
|
54
|
-
end
|
55
|
-
end
|
56
|
-
end
|
@@ -1,85 +0,0 @@
|
|
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
|
-
require 'spec_helper'
|
19
|
-
|
20
|
-
describe 'client.indices#freeze' do
|
21
|
-
|
22
|
-
let(:expected_args) do
|
23
|
-
[
|
24
|
-
'POST',
|
25
|
-
url,
|
26
|
-
params,
|
27
|
-
nil,
|
28
|
-
nil
|
29
|
-
]
|
30
|
-
end
|
31
|
-
|
32
|
-
let(:params) do
|
33
|
-
{}
|
34
|
-
end
|
35
|
-
|
36
|
-
context 'when there is no index specified' do
|
37
|
-
|
38
|
-
let(:client) do
|
39
|
-
Class.new { include Elasticsearch::API }.new
|
40
|
-
end
|
41
|
-
|
42
|
-
it 'raises an exception' do
|
43
|
-
expect {
|
44
|
-
client.indices.freeze
|
45
|
-
}.to raise_exception(ArgumentError)
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
context 'when an index is specified' do
|
50
|
-
|
51
|
-
let(:url) do
|
52
|
-
'foo/_freeze'
|
53
|
-
end
|
54
|
-
|
55
|
-
it 'performs the request' do
|
56
|
-
expect(client_double.indices.freeze(index: 'foo')).to eq({})
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
context 'when params are specified' do
|
61
|
-
|
62
|
-
let(:params) do
|
63
|
-
{ timeout: '1s' }
|
64
|
-
end
|
65
|
-
|
66
|
-
let(:url) do
|
67
|
-
'foo/_freeze'
|
68
|
-
end
|
69
|
-
|
70
|
-
it 'performs the request' do
|
71
|
-
expect(client_double.indices.freeze(index: 'foo', timeout: '1s')).to eq({})
|
72
|
-
end
|
73
|
-
end
|
74
|
-
|
75
|
-
context 'when the path must be URL-escaped' do
|
76
|
-
|
77
|
-
let(:url) do
|
78
|
-
'foo%5Ebar/_freeze'
|
79
|
-
end
|
80
|
-
|
81
|
-
it 'performs the request' do
|
82
|
-
expect(client_double.indices.freeze(index: 'foo^bar')).to eq({})
|
83
|
-
end
|
84
|
-
end
|
85
|
-
end
|
@@ -1,85 +0,0 @@
|
|
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
|
-
require 'spec_helper'
|
19
|
-
|
20
|
-
describe 'client.indices#unfreeze' do
|
21
|
-
|
22
|
-
let(:expected_args) do
|
23
|
-
[
|
24
|
-
'POST',
|
25
|
-
url,
|
26
|
-
params,
|
27
|
-
nil,
|
28
|
-
nil
|
29
|
-
]
|
30
|
-
end
|
31
|
-
|
32
|
-
let(:params) do
|
33
|
-
{}
|
34
|
-
end
|
35
|
-
|
36
|
-
context 'when there is no index specified' do
|
37
|
-
|
38
|
-
let(:client) do
|
39
|
-
Class.new { include Elasticsearch::API }.new
|
40
|
-
end
|
41
|
-
|
42
|
-
it 'raises an exception' do
|
43
|
-
expect {
|
44
|
-
client.indices.unfreeze
|
45
|
-
}.to raise_exception(ArgumentError)
|
46
|
-
end
|
47
|
-
end
|
48
|
-
|
49
|
-
context 'when an index is specified' do
|
50
|
-
|
51
|
-
let(:url) do
|
52
|
-
'foo/_unfreeze'
|
53
|
-
end
|
54
|
-
|
55
|
-
it 'performs the request' do
|
56
|
-
expect(client_double.indices.unfreeze(index: 'foo')).to eq({})
|
57
|
-
end
|
58
|
-
end
|
59
|
-
|
60
|
-
context 'when params are specified' do
|
61
|
-
|
62
|
-
let(:params) do
|
63
|
-
{ timeout: '1s' }
|
64
|
-
end
|
65
|
-
|
66
|
-
let(:url) do
|
67
|
-
'foo/_unfreeze'
|
68
|
-
end
|
69
|
-
|
70
|
-
it 'performs the request' do
|
71
|
-
expect(client_double.indices.unfreeze(index: 'foo', timeout: '1s')).to eq({})
|
72
|
-
end
|
73
|
-
end
|
74
|
-
|
75
|
-
context 'when the path must be URL-escaped' do
|
76
|
-
|
77
|
-
let(:url) do
|
78
|
-
'foo%5Ebar/_unfreeze'
|
79
|
-
end
|
80
|
-
|
81
|
-
it 'performs the request' do
|
82
|
-
expect(client_double.indices.unfreeze(index: 'foo^bar')).to eq({})
|
83
|
-
end
|
84
|
-
end
|
85
|
-
end
|
@@ -1,76 +0,0 @@
|
|
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
|
-
require 'spec_helper'
|
19
|
-
|
20
|
-
describe 'client.nodes#shutdown' do
|
21
|
-
|
22
|
-
let(:expected_args) do
|
23
|
-
[
|
24
|
-
'POST',
|
25
|
-
url,
|
26
|
-
params,
|
27
|
-
nil,
|
28
|
-
nil
|
29
|
-
]
|
30
|
-
end
|
31
|
-
|
32
|
-
let(:url) do
|
33
|
-
'_cluster/nodes/_shutdown'
|
34
|
-
end
|
35
|
-
|
36
|
-
it 'performs the request' do
|
37
|
-
expect(client_double.nodes.shutdown).to eq({})
|
38
|
-
end
|
39
|
-
|
40
|
-
let(:params) do
|
41
|
-
{}
|
42
|
-
end
|
43
|
-
|
44
|
-
context 'when the node id is specified' do
|
45
|
-
|
46
|
-
let(:url) do
|
47
|
-
'_cluster/nodes/foo/_shutdown'
|
48
|
-
end
|
49
|
-
|
50
|
-
it 'performs the request' do
|
51
|
-
expect(client_double.nodes.shutdown(node_id: 'foo')).to eq({})
|
52
|
-
end
|
53
|
-
end
|
54
|
-
|
55
|
-
context 'when multiple node ids are specified as a list' do
|
56
|
-
|
57
|
-
let(:url) do
|
58
|
-
'_cluster/nodes/A,B,C/_shutdown'
|
59
|
-
end
|
60
|
-
|
61
|
-
it 'performs the request' do
|
62
|
-
expect(client_double.nodes.shutdown(node_id: ['A', 'B', 'C'])).to eq({})
|
63
|
-
end
|
64
|
-
end
|
65
|
-
|
66
|
-
context 'when multiple node ids are specified as a String' do
|
67
|
-
|
68
|
-
let(:url) do
|
69
|
-
'_cluster/nodes/A,B,C/_shutdown'
|
70
|
-
end
|
71
|
-
|
72
|
-
it 'performs the request' do
|
73
|
-
expect(client_double.nodes.shutdown(node_id: 'A,B,C')).to eq({})
|
74
|
-
end
|
75
|
-
end
|
76
|
-
end
|