elasticsearch-api 6.8.0 → 7.10.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/Gemfile +26 -5
- data/LICENSE +202 -0
- data/README.md +24 -21
- data/Rakefile +43 -45
- data/elasticsearch-api.gemspec +56 -55
- data/lib/elasticsearch/api/actions/abort_benchmark.rb +19 -3
- data/lib/elasticsearch/api/actions/benchmark.rb +21 -5
- data/lib/elasticsearch/api/actions/bulk.rb +54 -69
- data/lib/elasticsearch/api/actions/cat/aliases.rb +45 -45
- data/lib/elasticsearch/api/actions/cat/allocation.rb +45 -41
- data/lib/elasticsearch/api/actions/cat/count.rb +38 -39
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +42 -29
- data/lib/elasticsearch/api/actions/cat/health.rb +37 -29
- data/lib/elasticsearch/api/actions/cat/help.rb +31 -9
- data/lib/elasticsearch/api/actions/cat/indices.rb +51 -51
- data/lib/elasticsearch/api/actions/cat/master.rb +36 -26
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +36 -14
- data/lib/elasticsearch/api/actions/cat/nodes.rb +43 -39
- data/lib/elasticsearch/api/actions/cat/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +38 -26
- data/lib/elasticsearch/api/actions/cat/plugins.rb +36 -14
- data/lib/elasticsearch/api/actions/cat/recovery.rb +47 -47
- data/lib/elasticsearch/api/actions/cat/repositories.rb +36 -22
- data/lib/elasticsearch/api/actions/cat/segments.rb +42 -19
- data/lib/elasticsearch/api/actions/cat/shards.rb +45 -50
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +44 -25
- data/lib/elasticsearch/api/actions/cat/tasks.rb +40 -16
- data/lib/elasticsearch/api/actions/cat/templates.rb +43 -16
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +46 -35
- data/lib/elasticsearch/api/actions/clear_scroll.rb +40 -17
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +38 -11
- data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +62 -0
- data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +51 -0
- data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +63 -0
- data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +64 -0
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +33 -15
- data/lib/elasticsearch/api/actions/cluster/health.rb +46 -27
- data/lib/elasticsearch/api/actions/cluster/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +32 -14
- data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +55 -0
- data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +66 -0
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +35 -15
- data/lib/elasticsearch/api/actions/cluster/remote_info.rb +27 -12
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +38 -33
- data/lib/elasticsearch/api/actions/cluster/state.rb +53 -44
- data/lib/elasticsearch/api/actions/cluster/stats.rb +38 -19
- data/lib/elasticsearch/api/actions/count.rb +60 -36
- data/lib/elasticsearch/api/actions/create.rb +37 -25
- data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +60 -0
- data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +60 -0
- data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +43 -0
- data/lib/elasticsearch/api/actions/dangling_indices/params_registry.rb +60 -0
- data/lib/elasticsearch/api/actions/delete.rb +62 -47
- data/lib/elasticsearch/api/actions/delete_by_query.rb +82 -57
- data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +36 -11
- data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +47 -0
- data/lib/elasticsearch/api/actions/delete_script.rb +37 -12
- data/lib/elasticsearch/api/actions/exists.rb +61 -34
- data/lib/elasticsearch/api/actions/exists_source.rb +60 -24
- data/lib/elasticsearch/api/actions/explain.rb +68 -44
- data/lib/elasticsearch/api/actions/field_caps.rb +49 -19
- data/lib/elasticsearch/api/actions/get.rb +60 -40
- data/lib/elasticsearch/api/actions/get_script.rb +37 -13
- data/lib/elasticsearch/api/actions/get_script_context.rb +45 -0
- data/lib/elasticsearch/api/actions/get_script_languages.rb +45 -0
- data/lib/elasticsearch/api/actions/get_source.rb +57 -38
- data/lib/elasticsearch/api/actions/index.rb +67 -74
- data/lib/elasticsearch/api/actions/indices/add_block.rb +68 -0
- data/lib/elasticsearch/api/actions/indices/analyze.rb +41 -34
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +44 -41
- data/lib/elasticsearch/api/actions/indices/clone.rb +65 -0
- data/lib/elasticsearch/api/actions/indices/close.rb +41 -21
- data/lib/elasticsearch/api/actions/indices/create.rb +39 -69
- data/lib/elasticsearch/api/actions/indices/delete.rb +41 -34
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +41 -19
- data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +62 -0
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +36 -20
- data/lib/elasticsearch/api/actions/indices/exists.rb +43 -21
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +46 -18
- data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +65 -0
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +37 -14
- data/lib/elasticsearch/api/actions/indices/exists_type.rb +42 -17
- data/lib/elasticsearch/api/actions/indices/flush.rb +41 -19
- data/lib/elasticsearch/api/actions/indices/flush_synced.rb +45 -11
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +42 -40
- data/lib/elasticsearch/api/actions/indices/freeze.rb +24 -7
- data/lib/elasticsearch/api/actions/indices/get.rb +42 -18
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +47 -22
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +59 -37
- data/lib/elasticsearch/api/actions/indices/get_index_template.rb +66 -0
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +57 -32
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +50 -36
- data/lib/elasticsearch/api/actions/indices/get_template.rb +40 -22
- data/lib/elasticsearch/api/actions/indices/get_upgrade.rb +62 -0
- data/lib/elasticsearch/api/actions/indices/open.rb +40 -20
- data/lib/elasticsearch/api/actions/indices/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +43 -26
- data/lib/elasticsearch/api/actions/indices/put_index_template.rb +66 -0
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +58 -40
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +46 -36
- data/lib/elasticsearch/api/actions/indices/put_template.rb +40 -24
- data/lib/elasticsearch/api/actions/indices/recovery.rb +38 -22
- data/lib/elasticsearch/api/actions/indices/refresh.rb +39 -25
- data/lib/elasticsearch/api/actions/indices/resolve_index.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/rollover.rb +47 -18
- data/lib/elasticsearch/api/actions/indices/segments.rb +40 -16
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +41 -13
- data/lib/elasticsearch/api/actions/indices/shrink.rb +40 -17
- data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +65 -0
- data/lib/elasticsearch/api/actions/indices/simulate_template.rb +67 -0
- data/lib/elasticsearch/api/actions/indices/split.rb +40 -18
- data/lib/elasticsearch/api/actions/indices/stats.rb +68 -104
- data/lib/elasticsearch/api/actions/indices/unfreeze.rb +24 -7
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +33 -31
- data/lib/elasticsearch/api/actions/indices/upgrade.rb +42 -14
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +64 -57
- data/lib/elasticsearch/api/actions/info.rb +29 -13
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +36 -11
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +37 -9
- data/lib/elasticsearch/api/actions/ingest/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +27 -13
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +37 -13
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +39 -10
- data/lib/elasticsearch/api/actions/mget.rb +55 -43
- data/lib/elasticsearch/api/actions/msearch.rb +67 -50
- data/lib/elasticsearch/api/actions/msearch_template.rb +62 -29
- data/lib/elasticsearch/api/actions/mtermvectors.rb +59 -32
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +46 -22
- data/lib/elasticsearch/api/actions/nodes/info.rb +43 -40
- data/lib/elasticsearch/api/actions/nodes/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +37 -21
- data/lib/elasticsearch/api/actions/nodes/shutdown.rb +22 -5
- data/lib/elasticsearch/api/actions/nodes/stats.rb +53 -33
- data/lib/elasticsearch/api/actions/nodes/usage.rb +46 -12
- data/lib/elasticsearch/api/actions/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/ping.rb +30 -18
- data/lib/elasticsearch/api/actions/put_script.rb +44 -31
- data/lib/elasticsearch/api/actions/rank_eval.rb +49 -16
- data/lib/elasticsearch/api/actions/reindex.rb +45 -48
- data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +36 -11
- data/lib/elasticsearch/api/actions/remote/info.rb +18 -2
- data/lib/elasticsearch/api/actions/render_search_template.rb +41 -15
- data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +38 -14
- data/lib/elasticsearch/api/actions/scroll.rb +51 -51
- data/lib/elasticsearch/api/actions/search.rb +96 -121
- data/lib/elasticsearch/api/actions/search_shards.rb +43 -15
- data/lib/elasticsearch/api/actions/search_template.rb +64 -37
- data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +58 -0
- data/lib/elasticsearch/api/actions/snapshot/clone.rb +66 -0
- data/lib/elasticsearch/api/actions/snapshot/create.rb +39 -26
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +37 -23
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +38 -21
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +35 -17
- data/lib/elasticsearch/api/actions/snapshot/get.rb +40 -29
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +38 -20
- data/lib/elasticsearch/api/actions/snapshot/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +39 -31
- data/lib/elasticsearch/api/actions/snapshot/status.rb +41 -21
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +36 -12
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +39 -12
- data/lib/elasticsearch/api/actions/tasks/get.rb +34 -12
- data/lib/elasticsearch/api/actions/tasks/list.rb +35 -16
- data/lib/elasticsearch/api/actions/tasks/params_registry.rb +20 -4
- data/lib/elasticsearch/api/actions/termvectors.rb +71 -65
- data/lib/elasticsearch/api/actions/update.rb +68 -72
- data/lib/elasticsearch/api/actions/update_by_query.rb +84 -62
- data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +36 -11
- data/lib/elasticsearch/api/namespace/cat.rb +17 -1
- data/lib/elasticsearch/api/namespace/cluster.rb +17 -0
- data/lib/elasticsearch/api/namespace/common.rb +17 -0
- data/lib/elasticsearch/api/namespace/dangling_indices.rb +35 -0
- data/lib/elasticsearch/api/namespace/indices.rb +17 -0
- data/lib/elasticsearch/api/namespace/ingest.rb +17 -0
- data/lib/elasticsearch/api/namespace/nodes.rb +17 -0
- data/lib/elasticsearch/api/namespace/remote.rb +17 -0
- data/lib/elasticsearch/api/namespace/snapshot.rb +17 -0
- data/lib/elasticsearch/api/namespace/tasks.rb +17 -0
- data/lib/elasticsearch/api/utils.rb +17 -0
- data/lib/elasticsearch/api/version.rb +18 -1
- data/lib/elasticsearch/api.rb +22 -2
- data/lib/elasticsearch-api.rb +17 -0
- data/spec/elasticsearch/api/actions/abort_benchmark_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/benchmark_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/bulk_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/cat/aliases_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/allocation_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/count_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/fielddata_spec.rb +19 -2
- data/spec/elasticsearch/api/actions/cat/health_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/help_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/indices_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/master_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/nodeattrs_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/nodes_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/pending_tasks_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/plugins_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/recovery_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/repositories_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/segments_spec.rb +36 -5
- data/spec/elasticsearch/api/actions/cat/shards_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/snapshot_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/tasks_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/templates_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cat/thread_pool_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/clear_scroll_spec.rb +21 -2
- data/spec/elasticsearch/api/actions/cluster/allocation_explain_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cluster/get_settings_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cluster/health_spec.rb +20 -3
- data/spec/elasticsearch/api/actions/cluster/pending_tasks_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cluster/put_settings_spec.rb +19 -2
- data/spec/elasticsearch/api/actions/cluster/remote_info_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/cluster/reroute_spec.rb +19 -2
- data/spec/elasticsearch/api/actions/cluster/state_spec.rb +19 -2
- data/spec/elasticsearch/api/actions/cluster/stats_spec.rb +18 -18
- data/spec/elasticsearch/api/actions/count_spec.rb +30 -10
- data/spec/elasticsearch/api/actions/create_document_spec.rb +25 -4
- data/spec/elasticsearch/api/actions/dangling_indices/delete_dangling_indices_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/dangling_indices/import_dangling_indices_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/dangling_indices/list_dangling_indices_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/delete_by_query_spec.rb +33 -8
- data/spec/elasticsearch/api/actions/delete_document_spec.rb +21 -8
- data/spec/elasticsearch/api/actions/delete_script_spec.rb +19 -15
- data/spec/elasticsearch/api/actions/exists_document_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/explain_document_spec.rb +26 -15
- data/spec/elasticsearch/api/actions/field_caps_spec.rb +19 -1
- data/spec/elasticsearch/api/actions/get_document_source_spec.rb +24 -4
- data/spec/elasticsearch/api/actions/get_document_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/get_script_spec.rb +25 -14
- data/spec/elasticsearch/api/actions/hashie_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/index_document_spec.rb +25 -22
- data/spec/elasticsearch/api/actions/indices/add_block_spec.rb +63 -0
- data/spec/elasticsearch/api/actions/indices/analyze_spec.rb +24 -12
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +8 -8
- data/spec/elasticsearch/api/actions/indices/clone_spec.rb +122 -0
- data/spec/elasticsearch/api/actions/indices/close_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/create_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/delete_alias_spec.rb +20 -3
- data/spec/elasticsearch/api/actions/indices/delete_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/delete_template_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/exists_alias_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/exists_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/exists_template_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/exists_type_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/flush_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/flush_synced_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/forcemerge_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/freeze_spec.rb +85 -0
- data/spec/elasticsearch/api/actions/indices/get_alias_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/get_field_mapping_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/get_mapping_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/get_settings_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/get_spec.rb +18 -12
- data/spec/elasticsearch/api/actions/indices/open_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/put_alias_spec.rb +21 -4
- data/spec/elasticsearch/api/actions/indices/put_mapping_spec.rb +21 -4
- data/spec/elasticsearch/api/actions/indices/put_settings_spec.rb +33 -1
- data/spec/elasticsearch/api/actions/indices/put_template_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/recovery_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/refresh_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/rollover_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/segments_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/shard_stores_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/shrink_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/split_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/stats_spec.rb +124 -0
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +85 -0
- data/spec/elasticsearch/api/actions/indices/update_aliases_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/upgrade_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/indices/validate_query_spec.rb +24 -13
- data/spec/elasticsearch/api/actions/info_spec.rb +19 -1
- data/spec/elasticsearch/api/actions/ingest/delete_pipeline_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/ingest/get_pipeline_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/ingest/put_pipeline_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/ingest/simulate_spec.rb +23 -7
- data/spec/elasticsearch/api/actions/json_builders_spec.rb +27 -11
- data/spec/elasticsearch/api/actions/mget_spec.rb +22 -5
- data/spec/elasticsearch/api/actions/msearch_spec.rb +38 -39
- data/spec/elasticsearch/api/actions/msearch_template_spec.rb +22 -6
- data/spec/elasticsearch/api/actions/mtermvectors_spec.rb +24 -6
- data/spec/elasticsearch/api/actions/nodes/hot_threads_spec.rb +21 -4
- data/spec/elasticsearch/api/actions/nodes/info_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/nodes/reload_secure_settings_spec.rb +24 -10
- data/spec/elasticsearch/api/actions/nodes/shutdown_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/nodes/stats_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/ping_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/put_script_spec.rb +39 -15
- data/spec/elasticsearch/api/actions/reindex_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/remote/info_spec.rb +17 -0
- data/spec/elasticsearch/api/actions/render_search_template_spec.rb +44 -9
- data/spec/elasticsearch/api/actions/scroll_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/search_shards_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/search_spec.rb +24 -6
- data/spec/elasticsearch/api/actions/search_template_spec.rb +22 -5
- data/spec/elasticsearch/api/actions/snapshot/clone_spec.rb +67 -0
- data/spec/elasticsearch/api/actions/snapshot/create_repository_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/create_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/delete_repository_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/delete_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/get_repository_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/get_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/restore_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/status_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/snapshot/verify_repository_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/tasks/cancel_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/tasks/get_spec.rb +18 -1
- data/spec/elasticsearch/api/actions/tasks/list_spec.rb +18 -12
- data/spec/elasticsearch/api/actions/termvectors_spec.rb +22 -12
- data/spec/elasticsearch/api/actions/update_by_query_spec.rb +20 -2
- data/spec/elasticsearch/api/actions/update_document_spec.rb +22 -14
- data/spec/elasticsearch/api/api_spec.rb +17 -0
- data/spec/elasticsearch/api/client_spec.rb +17 -0
- data/spec/elasticsearch/api/rest_api_yaml_spec.rb +138 -0
- data/spec/elasticsearch/api/utils_spec.rb +18 -1
- data/spec/rest_yaml_tests_helper.rb +107 -0
- data/spec/spec_helper.rb +33 -34
- data/utils/Gemfile +18 -0
- data/utils/README.md +41 -0
- data/utils/Thorfile +4 -1
- data/utils/thor/.rubocop.yml +2 -0
- data/utils/thor/generate_source.rb +248 -81
- data/utils/thor/generator/endpoint_specifics.rb +181 -0
- data/utils/thor/generator/files_helper.rb +60 -0
- data/utils/thor/lister.rb +20 -4
- data/utils/thor/templates/_documentation_top.erb +39 -0
- data/utils/thor/templates/_method_setup.erb +35 -0
- data/utils/thor/templates/_params_registry.erb +12 -0
- data/utils/thor/templates/_perform_request.erb +38 -0
- data/utils/thor/templates/method.erb +73 -0
- data/utils/thor/templates/{ruby/test.erb → test.erb} +4 -0
- data/utils/thor/templates/{ruby/test_helper.rb → test_helper.rb} +17 -1
- metadata +123 -124
- data/LICENSE.txt +0 -13
- data/lib/elasticsearch/api/actions/count_percolate.rb +0 -82
- data/lib/elasticsearch/api/actions/delete_template.rb +0 -21
- data/lib/elasticsearch/api/actions/field_stats.rb +0 -36
- data/lib/elasticsearch/api/actions/get_template.rb +0 -27
- data/lib/elasticsearch/api/actions/indices/delete_mapping.rb +0 -26
- data/lib/elasticsearch/api/actions/indices/delete_warmer.rb +0 -32
- data/lib/elasticsearch/api/actions/indices/get_aliases.rb +0 -37
- data/lib/elasticsearch/api/actions/indices/get_warmer.rb +0 -62
- data/lib/elasticsearch/api/actions/indices/optimize.rb +0 -77
- data/lib/elasticsearch/api/actions/indices/put_warmer.rb +0 -65
- data/lib/elasticsearch/api/actions/indices/seal.rb +0 -24
- data/lib/elasticsearch/api/actions/indices/snapshot_index.rb +0 -44
- data/lib/elasticsearch/api/actions/indices/status.rb +0 -63
- data/lib/elasticsearch/api/actions/list_benchmarks.rb +0 -27
- data/lib/elasticsearch/api/actions/mlt.rb +0 -130
- data/lib/elasticsearch/api/actions/mpercolate.rb +0 -62
- data/lib/elasticsearch/api/actions/percolate.rb +0 -73
- data/lib/elasticsearch/api/actions/put_template.rb +0 -25
- data/lib/elasticsearch/api/actions/search_exists.rb +0 -63
- data/lib/elasticsearch/api/actions/suggest.rb +0 -49
- data/spec/elasticsearch/api/actions/count_percolate_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/delete_template_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/field_stats_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/get_template_spec.rb +0 -52
- data/spec/elasticsearch/api/actions/indices/delete_mapping_spec.rb +0 -77
- data/spec/elasticsearch/api/actions/indices/delete_warmer_spec.rb +0 -86
- data/spec/elasticsearch/api/actions/indices/get_aliases_spec.rb +0 -55
- data/spec/elasticsearch/api/actions/indices/get_template_spec.rb +0 -59
- data/spec/elasticsearch/api/actions/indices/get_warmer_spec.rb +0 -48
- data/spec/elasticsearch/api/actions/indices/optimize_spec.rb +0 -63
- data/spec/elasticsearch/api/actions/indices/put_warmer_spec.rb +0 -101
- data/spec/elasticsearch/api/actions/indices/seal_spec.rb +0 -18
- data/spec/elasticsearch/api/actions/indices/snapshot_index_spec.rb +0 -89
- data/spec/elasticsearch/api/actions/indices/status_spec.rb +0 -92
- data/spec/elasticsearch/api/actions/list_benchmarks_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/mlt_spec.rb +0 -130
- data/spec/elasticsearch/api/actions/mpercolate_spec.rb +0 -49
- data/spec/elasticsearch/api/actions/percolate_spec.rb +0 -67
- data/spec/elasticsearch/api/actions/put_template_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/scoll_spec.rb +0 -17
- data/spec/elasticsearch/api/actions/search_exists_spec.rb +0 -63
- data/spec/elasticsearch/api/actions/suggest_spec.rb +0 -77
- data/test/integration/yaml_test_runner.rb +0 -546
- data/test/test_helper.rb +0 -42
- data/utils/thor/generate_api.rb +0 -189
- data/utils/thor/templates/ruby/method.erb +0 -60
@@ -1,130 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Return documents similar to the specified one.
|
6
|
-
#
|
7
|
-
# Performs a `more_like_this` query with the specified document as the input.
|
8
|
-
#
|
9
|
-
# @example Search for similar documents using the `title` property of document `myindex/mytype/1`
|
10
|
-
#
|
11
|
-
# # First, let's setup a synonym-aware analyzer ("quick" <=> "fast")
|
12
|
-
# client.indices.create index: 'myindex', body: {
|
13
|
-
# settings: {
|
14
|
-
# analysis: {
|
15
|
-
# filter: {
|
16
|
-
# synonyms: {
|
17
|
-
# type: 'synonym',
|
18
|
-
# synonyms: [ "quick,fast" ]
|
19
|
-
# }
|
20
|
-
# },
|
21
|
-
# analyzer: {
|
22
|
-
# title_synonym: {
|
23
|
-
# type: 'custom',
|
24
|
-
# tokenizer: 'whitespace',
|
25
|
-
# filter: ['lowercase', 'stop', 'snowball', 'synonyms']
|
26
|
-
# }
|
27
|
-
# }
|
28
|
-
# }
|
29
|
-
# },
|
30
|
-
# mappings: {
|
31
|
-
# mytype: {
|
32
|
-
# properties: {
|
33
|
-
# title: {
|
34
|
-
# type: 'string',
|
35
|
-
# analyzer: 'title_synonym'
|
36
|
-
# }
|
37
|
-
# }
|
38
|
-
# }
|
39
|
-
# }
|
40
|
-
# }
|
41
|
-
#
|
42
|
-
# # Index three documents
|
43
|
-
# client.index index: 'myindex', type: 'mytype', id: 1, body: { title: 'Quick Brown Fox' }
|
44
|
-
# client.index index: 'myindex', type: 'mytype', id: 2, body: { title: 'Slow Black Dog' }
|
45
|
-
# client.index index: 'myindex', type: 'mytype', id: 3, body: { title: 'Fast White Rabbit' }
|
46
|
-
# client.indices.refresh index: 'myindex'
|
47
|
-
#
|
48
|
-
# client.mlt index: 'myindex', type: 'mytype', id: 1, mlt_fields: 'title', min_doc_freq: 1, min_term_freq: 1
|
49
|
-
# # => { ... {"title"=>"Fast White Rabbit"}}]}}
|
50
|
-
#
|
51
|
-
# @option arguments [String] :id The document ID (*Required*)
|
52
|
-
# @option arguments [String] :index The name of the index (*Required*)
|
53
|
-
# @option arguments [String] :type The type of the document (use `_all` to fetch
|
54
|
-
# the first document matching the ID across all types) (*Required*)
|
55
|
-
# @option arguments [Hash] :body A specific search request definition
|
56
|
-
# @option arguments [Number] :boost_terms The boost factor
|
57
|
-
# @option arguments [Number] :max_doc_freq The word occurrence frequency as count: words with higher occurrence
|
58
|
-
# in the corpus will be ignored
|
59
|
-
# @option arguments [Number] :max_query_terms The maximum query terms to be included in the generated query
|
60
|
-
# @option arguments [Number] :max_word_len The minimum length of the word: longer words will be ignored
|
61
|
-
# @option arguments [Number] :min_doc_freq The word occurrence frequency as count: words with lower occurrence
|
62
|
-
# in the corpus will be ignored
|
63
|
-
# @option arguments [Number] :min_term_freq The term frequency as percent: terms with lower occurence
|
64
|
-
# in the source document will be ignored
|
65
|
-
# @option arguments [Number] :min_word_len The minimum length of the word: shorter words will be ignored
|
66
|
-
# @option arguments [List] :mlt_fields Specific fields to perform the query against
|
67
|
-
# @option arguments [Number] :percent_terms_to_match How many terms have to match in order to consider
|
68
|
-
# the document a match (default: 0.3)
|
69
|
-
# @option arguments [String] :routing Specific routing value
|
70
|
-
# @option arguments [Number] :search_from The offset from which to return results
|
71
|
-
# @option arguments [List] :search_indices A comma-separated list of indices to perform the query against
|
72
|
-
# (default: the index containing the document)
|
73
|
-
# @option arguments [String] :search_query_hint The search query hint
|
74
|
-
# @option arguments [String] :search_scroll A scroll search request definition
|
75
|
-
# @option arguments [Number] :search_size The number of documents to return (default: 10)
|
76
|
-
# @option arguments [String] :search_source A specific search request definition (instead of using the request body)
|
77
|
-
# @option arguments [String] :search_type Specific search type (eg. `dfs_then_fetch`, `count`, etc)
|
78
|
-
# @option arguments [List] :search_types A comma-separated list of types to perform the query against
|
79
|
-
# (default: the same type as the document)
|
80
|
-
# @option arguments [List] :stop_words A list of stop words to be ignored
|
81
|
-
#
|
82
|
-
# @see http://elasticsearch.org/guide/reference/api/more-like-this/
|
83
|
-
#
|
84
|
-
def mlt(arguments={})
|
85
|
-
raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
|
86
|
-
raise ArgumentError, "Required argument 'type' missing" unless arguments[:type]
|
87
|
-
raise ArgumentError, "Required argument 'id' missing" unless arguments[:id]
|
88
|
-
method = HTTP_GET
|
89
|
-
path = Utils.__pathify Utils.__escape(arguments[:index]),
|
90
|
-
Utils.__escape(arguments[:type]),
|
91
|
-
Utils.__escape(arguments[:id]),
|
92
|
-
'_mlt'
|
93
|
-
|
94
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
95
|
-
|
96
|
-
[:mlt_fields, :search_indices, :search_types, :stop_words].each do |name|
|
97
|
-
params[name] = Utils.__listify(params[name]) if params[name]
|
98
|
-
end
|
99
|
-
|
100
|
-
body = arguments[:body]
|
101
|
-
|
102
|
-
perform_request(method, path, params, body).body
|
103
|
-
end
|
104
|
-
|
105
|
-
# Register this action with its valid params when the module is loaded.
|
106
|
-
#
|
107
|
-
# @since 6.2.0
|
108
|
-
ParamsRegistry.register(:mlt, [
|
109
|
-
:boost_terms,
|
110
|
-
:max_doc_freq,
|
111
|
-
:max_query_terms,
|
112
|
-
:max_word_len,
|
113
|
-
:min_doc_freq,
|
114
|
-
:min_term_freq,
|
115
|
-
:min_word_len,
|
116
|
-
:mlt_fields,
|
117
|
-
:percent_terms_to_match,
|
118
|
-
:routing,
|
119
|
-
:search_from,
|
120
|
-
:search_indices,
|
121
|
-
:search_query_hint,
|
122
|
-
:search_scroll,
|
123
|
-
:search_size,
|
124
|
-
:search_source,
|
125
|
-
:search_type,
|
126
|
-
:search_types,
|
127
|
-
:stop_words ].freeze)
|
128
|
-
end
|
129
|
-
end
|
130
|
-
end
|
@@ -1,62 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Perform multiple percolate operations in a single request, similar to the {#msearch} API
|
6
|
-
#
|
7
|
-
# Pass the percolate definitions as header-body pairs in the `:body` argument, as an Array of Hashes.
|
8
|
-
#
|
9
|
-
# @example Perform two different percolations in a single request
|
10
|
-
#
|
11
|
-
# client.mpercolate \
|
12
|
-
# body: [
|
13
|
-
# { percolate: { index: "my-index", type: "my-type" } },
|
14
|
-
# { doc: { message: "foo bar" } },
|
15
|
-
# { percolate: { index: "my-other-index", type: "my-other-type", id: "1" } },
|
16
|
-
# { }
|
17
|
-
# ]
|
18
|
-
#
|
19
|
-
# @option arguments [String] :index The index of the document being count percolated to use as default
|
20
|
-
# @option arguments [String] :type The type of the document being percolated to use as default.
|
21
|
-
# @option arguments [Array<Hash>] The percolate request definitions (header & body pairs) (*Required*)
|
22
|
-
# @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when
|
23
|
-
# unavailable (missing or closed)
|
24
|
-
# @option arguments [Boolean] :allow_no_indices Whether to ignore if a wildcard indices expression resolves into
|
25
|
-
# no concrete indices. (This includes `_all` string or when no
|
26
|
-
# indices have been specified)
|
27
|
-
# @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are
|
28
|
-
# open, closed or both. (options: open, closed)
|
29
|
-
#
|
30
|
-
# @see http://www.elasticsearch.org/guide/en/elasticsearch/reference/master/search-percolate.html
|
31
|
-
#
|
32
|
-
def mpercolate(arguments={})
|
33
|
-
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
|
34
|
-
method = HTTP_GET
|
35
|
-
path = "_mpercolate"
|
36
|
-
|
37
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
38
|
-
body = arguments[:body]
|
39
|
-
|
40
|
-
case
|
41
|
-
when body.is_a?(Array)
|
42
|
-
payload = body.map { |d| d.is_a?(String) ? d : Elasticsearch::API.serializer.dump(d) }
|
43
|
-
payload << "" unless payload.empty?
|
44
|
-
payload = payload.join("\n")
|
45
|
-
else
|
46
|
-
payload = body
|
47
|
-
end
|
48
|
-
|
49
|
-
perform_request(method, path, params, payload).body
|
50
|
-
end
|
51
|
-
|
52
|
-
# Register this action with its valid params when the module is loaded.
|
53
|
-
#
|
54
|
-
# @since 6.2.0
|
55
|
-
ParamsRegistry.register(:mpercolate, [
|
56
|
-
:ignore_unavailable,
|
57
|
-
:allow_no_indices,
|
58
|
-
:expand_wildcards,
|
59
|
-
:percolate_format ].freeze)
|
60
|
-
end
|
61
|
-
end
|
62
|
-
end
|
@@ -1,73 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Return names of queries matching a document.
|
6
|
-
#
|
7
|
-
# Percolator allows you to register queries and then evaluate a document against them:
|
8
|
-
# the IDs of matching queries are returned in the response.
|
9
|
-
#
|
10
|
-
# @deprecated The `_percolate` API has been deprecated in favour of a special field mapping and the
|
11
|
-
# `percolate` query;
|
12
|
-
# see https://www.elastic.co/guide/en/elasticsearch/reference/5.5/breaking_50_percolator.html
|
13
|
-
#
|
14
|
-
# See full example for Elasticsearch 5.x and higher in <https://github.com/elastic/elasticsearch-ruby/blob/master/examples/percolator/percolator_alerts.rb>
|
15
|
-
#
|
16
|
-
# @option arguments [String] :index The index of the document being percolated. (*Required*)
|
17
|
-
# @option arguments [String] :type The type of the document being percolated. (*Required*)
|
18
|
-
# @option arguments [String] :id Fetch the document specified by index/type/id and
|
19
|
-
# use it instead of the passed `doc`
|
20
|
-
# @option arguments [Hash] :body The percolator request definition using the percolate DSL
|
21
|
-
# @option arguments [List] :routing A comma-separated list of specific routing values
|
22
|
-
# @option arguments [String] :preference Specify the node or shard the operation should be performed on
|
23
|
-
# (default: random)
|
24
|
-
# @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when
|
25
|
-
# unavailable (missing or closed)
|
26
|
-
# @option arguments [Boolean] :allow_no_indices Whether to ignore if a wildcard indices expression resolves into
|
27
|
-
# no concrete indices. (This includes `_all` string or when no
|
28
|
-
# indices have been specified)
|
29
|
-
# @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices that are
|
30
|
-
# open, closed or both. (options: open, closed)
|
31
|
-
# @option arguments [String] :percolate_index The index to percolate the document into. Defaults to passed `index`.
|
32
|
-
# @option arguments [String] :percolate_format Return an array of matching query IDs instead of objects.
|
33
|
-
# (options: ids)
|
34
|
-
# @option arguments [String] :percolate_type The type to percolate document into. Defaults to passed `type`.
|
35
|
-
# @option arguments [Number] :version Explicit version number for concurrency control
|
36
|
-
# @option arguments [String] :version_type Specific version type (options: internal, external, external_gte, force)
|
37
|
-
#
|
38
|
-
# @see http://www.elasticsearch.org/guide/en/elasticsearch/reference/master/search-percolate.html
|
39
|
-
#
|
40
|
-
def percolate(arguments={})
|
41
|
-
Utils.__report_unsupported_method :percolate
|
42
|
-
|
43
|
-
raise ArgumentError, "Required argument 'index' missing" unless arguments[:index]
|
44
|
-
raise ArgumentError, "Required argument 'type' missing" unless arguments[:type]
|
45
|
-
method = HTTP_GET
|
46
|
-
path = Utils.__pathify Utils.__escape(arguments[:index]),
|
47
|
-
Utils.__escape(arguments[:type]),
|
48
|
-
Utils.__escape(arguments[:id]),
|
49
|
-
'_percolate'
|
50
|
-
|
51
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
52
|
-
body = arguments[:body]
|
53
|
-
|
54
|
-
perform_request(method, path, params, body).body
|
55
|
-
end
|
56
|
-
|
57
|
-
# Register this action with its valid params when the module is loaded.
|
58
|
-
#
|
59
|
-
# @since 6.2.0
|
60
|
-
ParamsRegistry.register(:percolate, [
|
61
|
-
:routing,
|
62
|
-
:preference,
|
63
|
-
:ignore_unavailable,
|
64
|
-
:allow_no_indices,
|
65
|
-
:expand_wildcards,
|
66
|
-
:percolate_index,
|
67
|
-
:percolate_type,
|
68
|
-
:percolate_format,
|
69
|
-
:version,
|
70
|
-
:version_type ].freeze)
|
71
|
-
end
|
72
|
-
end
|
73
|
-
end
|
@@ -1,25 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Store a template for the search definition in Elasticsearch,
|
6
|
-
# to be later used with the `search_template` method
|
7
|
-
#
|
8
|
-
# @option arguments [String] :id Template ID (*Required*)
|
9
|
-
# @option arguments [Hash] :body The document (*Required*)
|
10
|
-
#
|
11
|
-
# @see http://www.elasticsearch.org/guide/en/elasticsearch/reference/master/search-template.html
|
12
|
-
#
|
13
|
-
def put_template(arguments={})
|
14
|
-
raise ArgumentError, "Required argument 'id' missing" unless arguments[:id]
|
15
|
-
raise ArgumentError, "Required argument 'body' missing" unless arguments[:body]
|
16
|
-
method = HTTP_POST
|
17
|
-
path = "_scripts/#{arguments[:id]}"
|
18
|
-
params = {}
|
19
|
-
body = arguments[:body]
|
20
|
-
|
21
|
-
perform_request(method, path, params, body).body
|
22
|
-
end
|
23
|
-
end
|
24
|
-
end
|
25
|
-
end
|
@@ -1,63 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Return whether documents exists for a particular query
|
6
|
-
#
|
7
|
-
# @option arguments [List] :index A comma-separated list of indices to restrict the results
|
8
|
-
# @option arguments [List] :type A comma-separated list of types to restrict the results
|
9
|
-
# @option arguments [Hash] :body A query to restrict the results specified with the Query DSL (optional)
|
10
|
-
# @option arguments [Boolean] :ignore_unavailable Whether specified concrete indices should be ignored when
|
11
|
-
# unavailable (missing or closed)
|
12
|
-
# @option arguments [Boolean] :allow_no_indices Whether to ignore if a wildcard indices expression resolves
|
13
|
-
# into no concrete indices.
|
14
|
-
# @option arguments [String] :expand_wildcards Whether to expand wildcard expression to concrete indices
|
15
|
-
# that are open, closed or both.
|
16
|
-
# (options: open, closed, none, all)
|
17
|
-
# @option arguments [Number] :min_score Include only documents with a specific `_score` value in the result
|
18
|
-
# @option arguments [String] :preference Specify the node or shard the operation should be performed on
|
19
|
-
# (default: random)
|
20
|
-
# @option arguments [String] :routing Specific routing value
|
21
|
-
# @option arguments [String] :q Query in the Lucene query string syntax
|
22
|
-
# @option arguments [String] :analyzer The analyzer to use for the query string
|
23
|
-
# @option arguments [Boolean] :analyze_wildcard Specify whether wildcard and prefix queries should be
|
24
|
-
# analyzed (default: false)
|
25
|
-
# @option arguments [String] :default_operator The default operator for query string query (AND or OR)
|
26
|
-
# (options: AND, OR)
|
27
|
-
# @option arguments [String] :df The field to use as default where no field prefix is given
|
28
|
-
# in the query string
|
29
|
-
# @option arguments [Boolean] :lenient Specify whether format-based query failures
|
30
|
-
# (such as providing text to a numeric field) should be ignored
|
31
|
-
# @option arguments [Boolean] :lowercase_expanded_terms Specify whether query terms should be lowercased
|
32
|
-
#
|
33
|
-
# @see http://www.elastic.co/guide/en/elasticsearch/reference/master/search-exists.html
|
34
|
-
#
|
35
|
-
def search_exists(arguments={})
|
36
|
-
method = 'POST'
|
37
|
-
path = "_search/exists"
|
38
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
39
|
-
body = arguments[:body]
|
40
|
-
|
41
|
-
perform_request(method, path, params, body).body
|
42
|
-
end
|
43
|
-
|
44
|
-
# Register this action with its valid params when the module is loaded.
|
45
|
-
#
|
46
|
-
# @since 6.2.0
|
47
|
-
ParamsRegistry.register(:search_exists, [
|
48
|
-
:ignore_unavailable,
|
49
|
-
:allow_no_indices,
|
50
|
-
:expand_wildcards,
|
51
|
-
:min_score,
|
52
|
-
:preference,
|
53
|
-
:routing,
|
54
|
-
:q,
|
55
|
-
:analyzer,
|
56
|
-
:analyze_wildcard,
|
57
|
-
:default_operator,
|
58
|
-
:df,
|
59
|
-
:lenient,
|
60
|
-
:lowercase_expanded_terms ].freeze)
|
61
|
-
end
|
62
|
-
end
|
63
|
-
end
|
@@ -1,49 +0,0 @@
|
|
1
|
-
module Elasticsearch
|
2
|
-
module API
|
3
|
-
module Actions
|
4
|
-
|
5
|
-
# Return query terms suggestions based on provided text and configuration.
|
6
|
-
#
|
7
|
-
# Pass the request definition in the `:body` argument.
|
8
|
-
#
|
9
|
-
# @example Return query terms suggestions ("auto-correction")
|
10
|
-
#
|
11
|
-
# client.suggest index: 'myindex',
|
12
|
-
# body: { my_suggest: { text: 'tset', term: { field: 'title' } } }
|
13
|
-
# # => { ... "my_suggest"=>[ {"text"=>"tset", ... "options"=>[{"text"=>"test", "score"=>0.75, "freq"=>5}] }]}
|
14
|
-
#
|
15
|
-
# @option arguments [List] :index A comma-separated list of index names to restrict the operation;
|
16
|
-
# use `_all` or empty string to perform the operation on all indices
|
17
|
-
# @option arguments [Hash] :body The request definition
|
18
|
-
# @option arguments [String] :ignore_indices When performed on multiple indices, allows to ignore `missing` ones
|
19
|
-
# (options: none, missing)
|
20
|
-
# @option arguments [String] :preference Specify the node or shard the operation should be performed on
|
21
|
-
# (default: random)
|
22
|
-
# @option arguments [String] :routing Specific routing value
|
23
|
-
# @option arguments [String] :source The URL-encoded request definition (instead of using request body)
|
24
|
-
#
|
25
|
-
# @since 0.90
|
26
|
-
#
|
27
|
-
# @see http://elasticsearch.org/guide/reference/api/search/suggest/
|
28
|
-
#
|
29
|
-
def suggest(arguments={})
|
30
|
-
method = HTTP_POST
|
31
|
-
path = Utils.__pathify( Utils.__listify(arguments[:index]), '_suggest' )
|
32
|
-
|
33
|
-
params = Utils.__validate_and_extract_params arguments, ParamsRegistry.get(__method__)
|
34
|
-
body = arguments[:body]
|
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(:suggest, [
|
43
|
-
:ignore_indices,
|
44
|
-
:preference,
|
45
|
-
:routing,
|
46
|
-
:source ].freeze)
|
47
|
-
end
|
48
|
-
end
|
49
|
-
end
|
@@ -1,17 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe 'client#count_percolate' do
|
4
|
-
|
5
|
-
let(:expected_args) do
|
6
|
-
[
|
7
|
-
'GET',
|
8
|
-
'foo/bar/_percolate/count',
|
9
|
-
{},
|
10
|
-
{ doc: { foo: 'bar' } }
|
11
|
-
]
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'performs the request' do
|
15
|
-
expect(client_double.count_percolate(index: 'foo', type: 'bar', body: { doc: { foo: 'bar' } })).to eq({})
|
16
|
-
end
|
17
|
-
end
|
@@ -1,17 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe 'client#delete_template' do
|
4
|
-
|
5
|
-
let(:expected_args) do
|
6
|
-
[
|
7
|
-
'DELETE',
|
8
|
-
'_search/template/foo',
|
9
|
-
{},
|
10
|
-
nil
|
11
|
-
]
|
12
|
-
end
|
13
|
-
|
14
|
-
it 'performs the request' do
|
15
|
-
expect(client_double.delete_template(id: 'foo')).to eq({})
|
16
|
-
end
|
17
|
-
end
|
@@ -1,52 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe 'client#get_template' do
|
4
|
-
|
5
|
-
let(:expected_args) do
|
6
|
-
[
|
7
|
-
'GET',
|
8
|
-
url,
|
9
|
-
params,
|
10
|
-
nil
|
11
|
-
]
|
12
|
-
end
|
13
|
-
|
14
|
-
let(:params) do
|
15
|
-
{ }
|
16
|
-
end
|
17
|
-
|
18
|
-
let(:client) do
|
19
|
-
Class.new { include Elasticsearch::API }.new
|
20
|
-
end
|
21
|
-
|
22
|
-
context 'when the `lang` parameter is specified' do
|
23
|
-
|
24
|
-
let(:url) do
|
25
|
-
'_scripts/foo'
|
26
|
-
end
|
27
|
-
|
28
|
-
it 'performs the request' do
|
29
|
-
expect(client_double.get_template(id: 'foo')).to eq({})
|
30
|
-
end
|
31
|
-
end
|
32
|
-
|
33
|
-
context 'when the request raises a NotFound exception' do
|
34
|
-
|
35
|
-
before do
|
36
|
-
expect(client).to receive(:perform_request).and_raise(NotFound)
|
37
|
-
end
|
38
|
-
|
39
|
-
it 'raises the exception' do
|
40
|
-
expect {
|
41
|
-
client.get_template(id: 'foo')
|
42
|
-
}.to raise_exception(NotFound)
|
43
|
-
end
|
44
|
-
|
45
|
-
context 'when the ignore parameter is specified' do
|
46
|
-
|
47
|
-
it 'returns false' do
|
48
|
-
expect(client.get_template(id: 'foo', ignore: 404)).to eq(false)
|
49
|
-
end
|
50
|
-
end
|
51
|
-
end
|
52
|
-
end
|
@@ -1,77 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe 'client.indices#delete_mapping' do
|
4
|
-
|
5
|
-
let(:expected_args) do
|
6
|
-
[
|
7
|
-
'DELETE',
|
8
|
-
url,
|
9
|
-
params,
|
10
|
-
nil,
|
11
|
-
nil
|
12
|
-
]
|
13
|
-
end
|
14
|
-
|
15
|
-
let(:params) do
|
16
|
-
{}
|
17
|
-
end
|
18
|
-
|
19
|
-
context 'when there is no index specified' do
|
20
|
-
|
21
|
-
let(:client) do
|
22
|
-
Class.new { include Elasticsearch::API }.new
|
23
|
-
end
|
24
|
-
|
25
|
-
it 'raises an exception' do
|
26
|
-
expect {
|
27
|
-
client.indices.delete_mapping(type: 'foo')
|
28
|
-
}.to raise_exception(ArgumentError)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
context 'when there is no type specified' do
|
33
|
-
|
34
|
-
let(:client) do
|
35
|
-
Class.new { include Elasticsearch::API }.new
|
36
|
-
end
|
37
|
-
|
38
|
-
it 'raises an exception' do
|
39
|
-
expect {
|
40
|
-
client.indices.delete_mapping(index: 'foo')
|
41
|
-
}.to raise_exception(ArgumentError)
|
42
|
-
end
|
43
|
-
end
|
44
|
-
|
45
|
-
context 'when an index and type are specified' do
|
46
|
-
|
47
|
-
let(:url) do
|
48
|
-
'foo/bar'
|
49
|
-
end
|
50
|
-
|
51
|
-
it 'performs the request' do
|
52
|
-
expect(client_double.indices.delete_mapping(index: 'foo', type: 'bar')).to eq({})
|
53
|
-
end
|
54
|
-
end
|
55
|
-
|
56
|
-
context 'when multiple indices are specified' do
|
57
|
-
|
58
|
-
let(:url) do
|
59
|
-
'foo,bar/baz'
|
60
|
-
end
|
61
|
-
|
62
|
-
it 'performs the request' do
|
63
|
-
expect(client_double.indices.delete_mapping(index: ['foo','bar'], type: 'baz')).to eq({})
|
64
|
-
end
|
65
|
-
end
|
66
|
-
|
67
|
-
context 'when the path must be URL-escaped' do
|
68
|
-
|
69
|
-
let(:url) do
|
70
|
-
'foo%5Ebar/bar%2Fbam'
|
71
|
-
end
|
72
|
-
|
73
|
-
it 'performs the request' do
|
74
|
-
expect(client_double.indices.delete_mapping(index: 'foo^bar', type: 'bar/bam')).to eq({})
|
75
|
-
end
|
76
|
-
end
|
77
|
-
end
|
@@ -1,86 +0,0 @@
|
|
1
|
-
require 'spec_helper'
|
2
|
-
|
3
|
-
describe 'client.indices#delete_warmer' do
|
4
|
-
|
5
|
-
let(:expected_args) do
|
6
|
-
[
|
7
|
-
'DELETE',
|
8
|
-
url,
|
9
|
-
params,
|
10
|
-
nil,
|
11
|
-
nil
|
12
|
-
]
|
13
|
-
end
|
14
|
-
|
15
|
-
let(:params) do
|
16
|
-
{}
|
17
|
-
end
|
18
|
-
|
19
|
-
context 'when an index is not specified' do
|
20
|
-
|
21
|
-
let(:client) do
|
22
|
-
Class.new { include Elasticsearch::API }.new
|
23
|
-
end
|
24
|
-
|
25
|
-
it 'raises an exception' do
|
26
|
-
expect {
|
27
|
-
client.indices.delete_warmer
|
28
|
-
}.to raise_exception(ArgumentError)
|
29
|
-
end
|
30
|
-
end
|
31
|
-
|
32
|
-
context 'when an index is specified' do
|
33
|
-
|
34
|
-
let(:url) do
|
35
|
-
'foo/_warmer'
|
36
|
-
end
|
37
|
-
|
38
|
-
it 'performs the request' do
|
39
|
-
expect(client_double.indices.delete_warmer(index: 'foo')).to eq({})
|
40
|
-
end
|
41
|
-
end
|
42
|
-
|
43
|
-
context 'when multiple indices are specified' do
|
44
|
-
|
45
|
-
let(:url) do
|
46
|
-
'foo,bar/_warmer'
|
47
|
-
end
|
48
|
-
|
49
|
-
it 'performs the request' do
|
50
|
-
expect(client_double.indices.delete_warmer(index: ['foo', 'bar'])).to eq({})
|
51
|
-
end
|
52
|
-
end
|
53
|
-
|
54
|
-
context 'when a single warmer is specified' do
|
55
|
-
|
56
|
-
let(:url) do
|
57
|
-
'foo/_warmer/bar'
|
58
|
-
end
|
59
|
-
|
60
|
-
it 'performs the request' do
|
61
|
-
expect(client_double.indices.delete_warmer(index: 'foo', name: 'bar')).to eq({})
|
62
|
-
end
|
63
|
-
end
|
64
|
-
|
65
|
-
context 'when a multiple warmers are specified' do
|
66
|
-
|
67
|
-
let(:url) do
|
68
|
-
'foo/_warmer/bar,baz'
|
69
|
-
end
|
70
|
-
|
71
|
-
it 'performs the request' do
|
72
|
-
expect(client_double.indices.delete_warmer(index: 'foo', name: ['bar', 'baz'])).to eq({})
|
73
|
-
end
|
74
|
-
end
|
75
|
-
|
76
|
-
context 'when the path needs to be URL-escaped' do
|
77
|
-
|
78
|
-
let(:url) do
|
79
|
-
'foo%5Ebar/_warmer/bar%2Fbam'
|
80
|
-
end
|
81
|
-
|
82
|
-
it 'performs the request' do
|
83
|
-
expect(client_double.indices.delete_warmer(index: 'foo^bar', name: 'bar/bam')).to eq({})
|
84
|
-
end
|
85
|
-
end
|
86
|
-
end
|