elasticsearch-api 7.13.3 → 8.14.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/Gemfile +2 -10
- data/README.md +15 -186
- data/Rakefile +29 -74
- data/api-spec-testing/README.md +118 -0
- data/api-spec-testing/custom_cleanup.rb +32 -0
- data/api-spec-testing/logging.rb +28 -0
- data/api-spec-testing/rspec_matchers.rb +338 -0
- data/api-spec-testing/test_file/action.rb +251 -0
- data/api-spec-testing/test_file/task_group.rb +346 -0
- data/api-spec-testing/test_file/test.rb +296 -0
- data/api-spec-testing/test_file.rb +184 -0
- data/api-spec-testing/wipe_cluster.rb +423 -0
- data/elasticsearch-api.gemspec +22 -17
- data/lib/elasticsearch/api/actions/async_search/delete.rb +60 -0
- data/lib/elasticsearch/api/actions/async_search/get.rb +63 -0
- data/lib/elasticsearch/api/actions/async_search/status.rb +61 -0
- data/lib/elasticsearch/api/actions/async_search/submit.rb +104 -0
- data/lib/elasticsearch/api/actions/autoscaling/delete_autoscaling_policy.rb +60 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_capacity.rb +50 -0
- data/lib/elasticsearch/api/actions/autoscaling/get_autoscaling_policy.rb +60 -0
- data/lib/elasticsearch/api/actions/autoscaling/put_autoscaling_policy.rb +62 -0
- data/lib/elasticsearch/api/actions/bulk.rb +29 -35
- data/lib/elasticsearch/api/actions/cat/aliases.rb +19 -20
- data/lib/elasticsearch/api/actions/cat/allocation.rb +19 -21
- data/lib/elasticsearch/api/actions/cat/component_templates.rb +69 -0
- data/lib/elasticsearch/api/actions/cat/count.rb +19 -18
- data/lib/elasticsearch/api/actions/cat/fielddata.rb +19 -20
- data/lib/elasticsearch/api/actions/cat/health.rb +14 -20
- data/lib/elasticsearch/api/actions/cat/help.rb +14 -15
- data/lib/elasticsearch/api/actions/cat/indices.rb +19 -27
- data/lib/elasticsearch/api/actions/cat/master.rb +14 -20
- data/lib/elasticsearch/api/actions/cat/ml_data_frame_analytics.rb +70 -0
- data/lib/elasticsearch/api/actions/cat/ml_datafeeds.rb +69 -0
- data/lib/elasticsearch/api/actions/cat/ml_jobs.rb +70 -0
- data/lib/elasticsearch/api/actions/cat/ml_trained_models.rb +72 -0
- data/lib/elasticsearch/api/actions/cat/nodeattrs.rb +14 -20
- data/lib/elasticsearch/api/actions/cat/nodes.rb +14 -25
- data/lib/elasticsearch/api/actions/cat/pending_tasks.rb +14 -21
- data/lib/elasticsearch/api/actions/cat/plugins.rb +14 -21
- data/lib/elasticsearch/api/actions/cat/recovery.rb +19 -23
- data/lib/elasticsearch/api/actions/cat/repositories.rb +14 -20
- data/lib/elasticsearch/api/actions/cat/segments.rb +19 -19
- data/lib/elasticsearch/api/actions/cat/shards.rb +19 -23
- data/lib/elasticsearch/api/actions/cat/snapshots.rb +19 -21
- data/lib/elasticsearch/api/actions/cat/tasks.rb +18 -23
- data/lib/elasticsearch/api/actions/cat/templates.rb +19 -20
- data/lib/elasticsearch/api/actions/cat/thread_pool.rb +20 -22
- data/lib/elasticsearch/api/actions/cat/transforms.rb +71 -0
- data/lib/elasticsearch/api/actions/clear_scroll.rb +27 -7
- data/lib/elasticsearch/api/actions/close_point_in_time.rb +13 -6
- data/lib/elasticsearch/api/actions/cluster/allocation_explain.rb +16 -17
- data/lib/elasticsearch/api/actions/cluster/delete_component_template.rb +18 -14
- data/lib/elasticsearch/api/actions/cluster/delete_voting_config_exclusions.rb +15 -14
- data/lib/elasticsearch/api/actions/cluster/exists_component_template.rb +19 -14
- data/lib/elasticsearch/api/actions/cluster/get_component_template.rb +20 -15
- data/lib/elasticsearch/api/actions/cluster/get_settings.rb +14 -17
- data/lib/elasticsearch/api/actions/cluster/health.rb +19 -24
- data/lib/elasticsearch/api/actions/cluster/info.rb +60 -0
- data/lib/elasticsearch/api/actions/cluster/pending_tasks.rb +14 -15
- data/lib/elasticsearch/api/actions/cluster/post_voting_config_exclusions.rb +15 -16
- data/lib/elasticsearch/api/actions/cluster/put_component_template.rb +18 -15
- data/lib/elasticsearch/api/actions/cluster/put_settings.rb +14 -16
- data/lib/elasticsearch/api/actions/cluster/remote_info.rb +13 -6
- data/lib/elasticsearch/api/actions/cluster/reroute.rb +15 -20
- data/lib/elasticsearch/api/actions/cluster/state.rb +19 -21
- data/lib/elasticsearch/api/actions/cluster/stats.rb +19 -15
- data/lib/elasticsearch/api/actions/connector/check_in.rb +64 -0
- data/lib/elasticsearch/api/actions/connector/delete.rb +65 -0
- data/lib/elasticsearch/api/actions/connector/get.rb +64 -0
- data/lib/elasticsearch/api/actions/connector/last_sync.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/list.rb +60 -0
- data/lib/elasticsearch/api/actions/connector/post.rb +57 -0
- data/lib/elasticsearch/api/actions/connector/put.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/secret_delete.rb +64 -0
- data/lib/elasticsearch/api/actions/connector/secret_get.rb +64 -0
- data/lib/elasticsearch/api/actions/connector/secret_post.rb +57 -0
- data/lib/elasticsearch/api/actions/connector/secret_put.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_cancel.rb +67 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_check_in.rb +67 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_delete.rb +67 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_error.rb +70 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_get.rb +67 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_list.rb +59 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_post.rb +57 -0
- data/lib/elasticsearch/api/actions/connector/sync_job_update_stats.rb +70 -0
- data/lib/elasticsearch/api/actions/connector/update_active_filtering.rb +64 -0
- data/lib/elasticsearch/api/actions/connector/update_api_key_id.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_configuration.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_error.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_filtering.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_filtering_validation.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_index_name.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_name.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_native.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_pipeline.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_scheduling.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_service_type.rb +66 -0
- data/lib/elasticsearch/api/actions/connector/update_status.rb +66 -0
- data/lib/elasticsearch/api/actions/count.rb +27 -40
- data/lib/elasticsearch/api/actions/create.rb +12 -8
- data/lib/elasticsearch/api/actions/cross_cluster_replication/delete_auto_follow_pattern.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow.rb +64 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_info.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/follow_stats.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/forget_follower.rb +63 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/get_auto_follow_pattern.rb +63 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/pause_auto_follow_pattern.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/pause_follow.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/put_auto_follow_pattern.rb +63 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_auto_follow_pattern.rb +61 -0
- data/lib/elasticsearch/api/actions/cross_cluster_replication/resume_follow.rb +62 -0
- data/lib/elasticsearch/api/actions/{snapshot/get_features.rb → cross_cluster_replication/stats.rb} +18 -17
- data/lib/elasticsearch/api/actions/cross_cluster_replication/unfollow.rb +61 -0
- data/lib/elasticsearch/api/actions/dangling_indices/delete_dangling_index.rb +18 -15
- data/lib/elasticsearch/api/actions/dangling_indices/import_dangling_index.rb +18 -15
- data/lib/elasticsearch/api/actions/dangling_indices/list_dangling_indices.rb +13 -6
- data/lib/elasticsearch/api/actions/delete.rb +25 -35
- data/lib/elasticsearch/api/actions/delete_by_query.rb +21 -64
- data/lib/elasticsearch/api/actions/delete_by_query_rethrottle.rb +18 -13
- data/lib/elasticsearch/api/actions/delete_script.rb +18 -14
- data/lib/elasticsearch/api/actions/enrich/delete_policy.rb +60 -0
- data/lib/elasticsearch/api/actions/enrich/execute_policy.rb +61 -0
- data/lib/elasticsearch/api/actions/enrich/get_policy.rb +62 -0
- data/lib/elasticsearch/api/actions/enrich/put_policy.rb +62 -0
- data/lib/elasticsearch/api/actions/enrich/stats.rb +50 -0
- data/lib/elasticsearch/api/actions/eql/delete.rb +60 -0
- data/lib/elasticsearch/api/actions/eql/get.rb +62 -0
- data/lib/elasticsearch/api/actions/eql/get_status.rb +60 -0
- data/lib/elasticsearch/api/actions/eql/search.rb +65 -0
- data/lib/elasticsearch/api/actions/esql/async_query.rb +56 -0
- data/lib/elasticsearch/api/actions/esql/async_query_get.rb +63 -0
- data/lib/elasticsearch/api/actions/esql/query.rb +56 -0
- data/lib/elasticsearch/api/actions/exists.rb +19 -37
- data/lib/elasticsearch/api/actions/exists_source.rb +21 -35
- data/lib/elasticsearch/api/actions/explain.rb +20 -38
- data/lib/elasticsearch/api/actions/features/get_features.rb +14 -14
- data/lib/elasticsearch/api/actions/features/reset_features.rb +13 -6
- data/lib/elasticsearch/api/actions/field_caps.rb +23 -19
- data/lib/elasticsearch/api/actions/fleet/delete_secret.rb +64 -0
- data/lib/elasticsearch/api/actions/fleet/get_secret.rb +64 -0
- data/lib/elasticsearch/api/actions/fleet/global_checkpoints.rb +64 -0
- data/lib/elasticsearch/api/actions/fleet/msearch.rb +90 -0
- data/lib/elasticsearch/api/actions/fleet/post_secret.rb +57 -0
- data/lib/elasticsearch/api/actions/fleet/search.rb +73 -0
- data/lib/elasticsearch/api/actions/get.rb +26 -37
- data/lib/elasticsearch/api/actions/get_script.rb +18 -13
- data/lib/elasticsearch/api/actions/get_script_context.rb +13 -10
- data/lib/elasticsearch/api/actions/get_script_languages.rb +13 -10
- data/lib/elasticsearch/api/actions/get_source.rb +20 -35
- data/lib/elasticsearch/api/actions/graph/explore.rb +68 -0
- data/lib/elasticsearch/api/actions/health_report.rb +63 -0
- data/lib/elasticsearch/api/actions/index.rb +20 -36
- data/lib/elasticsearch/api/actions/index_lifecycle_management/delete_lifecycle.rb +60 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/explain_lifecycle.rb +62 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_lifecycle.rb +62 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/get_status.rb +50 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/migrate_to_data_tiers.rb +52 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/move_to_step.rb +61 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/put_lifecycle.rb +61 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/remove_policy.rb +60 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/retry.rb +60 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/start.rb +50 -0
- data/lib/elasticsearch/api/actions/index_lifecycle_management/stop.rb +50 -0
- data/lib/elasticsearch/api/actions/indices/add_block.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/analyze.rb +20 -15
- data/lib/elasticsearch/api/actions/indices/clear_cache.rb +19 -21
- data/lib/elasticsearch/api/actions/indices/clone.rb +18 -15
- data/lib/elasticsearch/api/actions/indices/close.rb +19 -19
- data/lib/elasticsearch/api/actions/indices/create.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/create_data_stream.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/data_streams_stats.rb +62 -0
- data/lib/elasticsearch/api/actions/indices/delete.rb +24 -19
- data/lib/elasticsearch/api/actions/indices/delete_alias.rb +19 -17
- data/lib/elasticsearch/api/actions/indices/delete_data_lifecycle.rb +67 -0
- data/lib/elasticsearch/api/actions/indices/delete_data_stream.rb +61 -0
- data/lib/elasticsearch/api/actions/indices/delete_index_template.rb +18 -14
- data/lib/elasticsearch/api/actions/indices/delete_template.rb +23 -15
- data/lib/elasticsearch/api/actions/indices/disk_usage.rb +69 -0
- data/lib/elasticsearch/api/actions/indices/downsample.rb +70 -0
- data/lib/elasticsearch/api/actions/indices/exists.rb +17 -19
- data/lib/elasticsearch/api/actions/indices/exists_alias.rb +17 -17
- data/lib/elasticsearch/api/actions/indices/exists_index_template.rb +19 -15
- data/lib/elasticsearch/api/actions/indices/exists_template.rb +17 -16
- data/lib/elasticsearch/api/actions/indices/explain_data_lifecycle.rb +66 -0
- data/lib/elasticsearch/api/actions/indices/{exists_type.rb → field_usage_stats.rb} +28 -30
- data/lib/elasticsearch/api/actions/indices/flush.rb +19 -18
- data/lib/elasticsearch/api/actions/indices/forcemerge.rb +20 -19
- data/lib/elasticsearch/api/actions/indices/get.rb +19 -21
- data/lib/elasticsearch/api/actions/indices/get_alias.rb +19 -17
- data/lib/elasticsearch/api/actions/indices/get_data_lifecycle.rb +66 -0
- data/lib/elasticsearch/api/actions/indices/get_data_stream.rb +64 -0
- data/lib/elasticsearch/api/actions/indices/get_field_mapping.rb +19 -32
- data/lib/elasticsearch/api/actions/indices/get_index_template.rb +21 -17
- data/lib/elasticsearch/api/actions/indices/get_mapping.rb +20 -33
- data/lib/elasticsearch/api/actions/indices/get_settings.rb +19 -20
- data/lib/elasticsearch/api/actions/indices/get_template.rb +19 -18
- data/lib/elasticsearch/api/actions/indices/migrate_to_data_stream.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/modify_data_stream.rb +53 -0
- data/lib/elasticsearch/api/actions/indices/open.rb +18 -18
- data/lib/elasticsearch/api/actions/indices/promote_data_stream.rb +60 -0
- data/lib/elasticsearch/api/actions/indices/put_alias.rb +19 -17
- data/lib/elasticsearch/api/actions/indices/put_data_lifecycle.rb +68 -0
- data/lib/elasticsearch/api/actions/indices/put_index_template.rb +18 -15
- data/lib/elasticsearch/api/actions/indices/put_mapping.rb +20 -35
- data/lib/elasticsearch/api/actions/indices/put_settings.rb +20 -20
- data/lib/elasticsearch/api/actions/indices/put_template.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/recovery.rb +19 -15
- data/lib/elasticsearch/api/actions/indices/refresh.rb +19 -16
- data/lib/elasticsearch/api/actions/indices/{get_upgrade.rb → reload_search_analyzers.rb} +25 -28
- data/lib/elasticsearch/api/actions/indices/resolve_cluster.rb +64 -0
- data/lib/elasticsearch/api/actions/indices/resolve_index.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/rollover.rb +20 -18
- data/lib/elasticsearch/api/actions/indices/segments.rb +20 -18
- data/lib/elasticsearch/api/actions/indices/shard_stores.rb +19 -17
- data/lib/elasticsearch/api/actions/indices/shrink.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/simulate_index_template.rb +19 -15
- data/lib/elasticsearch/api/actions/indices/simulate_template.rb +20 -16
- data/lib/elasticsearch/api/actions/indices/split.rb +18 -17
- data/lib/elasticsearch/api/actions/indices/stats.rb +35 -49
- data/lib/elasticsearch/api/actions/indices/{upgrade.rb → unfreeze.rb} +30 -30
- data/lib/elasticsearch/api/actions/indices/update_aliases.rb +14 -15
- data/lib/elasticsearch/api/actions/indices/validate_query.rb +21 -37
- data/lib/elasticsearch/api/actions/inference/delete_model.rb +71 -0
- data/lib/elasticsearch/api/actions/inference/get_model.rb +71 -0
- data/lib/elasticsearch/api/actions/inference/inference.rb +72 -0
- data/lib/elasticsearch/api/actions/inference/put_model.rb +72 -0
- data/lib/elasticsearch/api/actions/info.rb +13 -6
- data/lib/elasticsearch/api/actions/ingest/delete_pipeline.rb +18 -14
- data/lib/elasticsearch/api/actions/ingest/geo_ip_stats.rb +13 -6
- data/lib/elasticsearch/api/actions/ingest/get_pipeline.rb +19 -15
- data/lib/elasticsearch/api/actions/ingest/processor_grok.rb +13 -6
- data/lib/elasticsearch/api/actions/ingest/put_pipeline.rb +19 -14
- data/lib/elasticsearch/api/actions/ingest/simulate.rb +19 -14
- data/lib/elasticsearch/api/actions/knn_search.rb +69 -0
- data/lib/elasticsearch/api/actions/license/delete.rb +50 -0
- data/lib/elasticsearch/api/actions/license/get.rb +52 -0
- data/lib/elasticsearch/api/actions/license/get_basic_status.rb +50 -0
- data/lib/elasticsearch/api/actions/license/get_trial_status.rb +50 -0
- data/lib/elasticsearch/api/actions/license/post.rb +52 -0
- data/lib/elasticsearch/api/actions/license/post_start_basic.rb +51 -0
- data/lib/elasticsearch/api/actions/license/post_start_trial.rb +52 -0
- data/lib/elasticsearch/api/actions/logstash/delete_pipeline.rb +60 -0
- data/lib/elasticsearch/api/actions/logstash/get_pipeline.rb +62 -0
- data/lib/elasticsearch/api/actions/logstash/put_pipeline.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/clear_trained_model_deployment_cache.rb +60 -0
- data/lib/elasticsearch/api/actions/machine_learning/close_job.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar.rb +60 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_event.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_calendar_job.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_data_frame_analytics.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_datafeed.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_expired_data.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_filter.rb +60 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_forecast.rb +69 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_job.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_model_snapshot.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/delete_trained_model_alias.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/estimate_model_memory.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/evaluate_data_frame.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/explain_data_frame_analytics.rb +68 -0
- data/lib/elasticsearch/api/actions/machine_learning/flush_job.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/forecast.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_buckets.rb +82 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendar_events.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_calendars.rb +70 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_categories.rb +76 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_data_frame_analytics_stats.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeed_stats.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_datafeeds.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_filters.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_influencers.rb +74 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_job_stats.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_jobs.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_memory_stats.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_model_snapshots.rb +79 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_overall_buckets.rb +73 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_records.rb +74 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models.rb +70 -0
- data/lib/elasticsearch/api/actions/machine_learning/get_trained_models_stats.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/infer_trained_model.rb +68 -0
- data/lib/elasticsearch/api/actions/machine_learning/info.rb +50 -0
- data/lib/elasticsearch/api/actions/machine_learning/open_job.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_calendar_events.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/post_data.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_data_frame_analytics.rb +68 -0
- data/lib/elasticsearch/api/actions/machine_learning/preview_datafeed.rb +70 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar.rb +61 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_calendar_job.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_data_frame_analytics.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_datafeed.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_filter.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_job.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_alias.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_definition_part.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/put_trained_model_vocabulary.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/reset_job.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/revert_model_snapshot.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/set_upgrade_mode.rb +52 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_data_frame_analytics.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_datafeed.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/start_trained_model_deployment.rb +68 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_data_frame_analytics.rb +64 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_datafeed.rb +65 -0
- data/lib/elasticsearch/api/actions/machine_learning/stop_trained_model_deployment.rb +63 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_data_frame_analytics.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_datafeed.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_filter.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_job.rb +62 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_model_snapshot.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/update_trained_model_deployment.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/upgrade_job_snapshot.rb +66 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate.rb +53 -0
- data/lib/elasticsearch/api/actions/machine_learning/validate_detector.rb +53 -0
- data/lib/elasticsearch/api/actions/mget.rb +22 -33
- data/lib/elasticsearch/api/actions/migration/deprecations.rb +62 -0
- data/lib/elasticsearch/api/actions/migration/get_feature_upgrade_status.rb +50 -0
- data/lib/elasticsearch/api/actions/migration/post_feature_upgrade.rb +50 -0
- data/lib/elasticsearch/api/actions/monitoring/bulk.rb +81 -0
- data/lib/elasticsearch/api/actions/msearch.rb +27 -40
- data/lib/elasticsearch/api/actions/msearch_template.rb +25 -36
- data/lib/elasticsearch/api/actions/mtermvectors.rb +26 -43
- data/lib/elasticsearch/api/actions/nodes/clear_repositories_metering_archive.rb +68 -0
- data/lib/elasticsearch/api/actions/nodes/get_repositories_metering_info.rb +64 -0
- data/lib/elasticsearch/api/actions/nodes/hot_threads.rb +22 -26
- data/lib/elasticsearch/api/actions/nodes/info.rb +20 -16
- data/lib/elasticsearch/api/actions/nodes/reload_secure_settings.rb +19 -14
- data/lib/elasticsearch/api/actions/nodes/stats.rb +22 -25
- data/lib/elasticsearch/api/actions/nodes/usage.rb +19 -14
- data/lib/elasticsearch/api/actions/open_point_in_time.rb +23 -23
- data/lib/elasticsearch/api/actions/ping.rb +15 -12
- data/lib/elasticsearch/api/actions/profiling/flamegraph.rb +53 -0
- data/lib/elasticsearch/api/actions/profiling/stacktraces.rb +53 -0
- data/lib/elasticsearch/api/actions/profiling/status.rb +53 -0
- data/lib/elasticsearch/api/actions/profiling/topn_functions.rb +53 -0
- data/lib/elasticsearch/api/actions/put_script.rb +18 -15
- data/lib/elasticsearch/api/actions/query_ruleset/delete.rb +64 -0
- data/lib/elasticsearch/api/actions/query_ruleset/get.rb +64 -0
- data/lib/elasticsearch/api/actions/query_ruleset/list.rb +56 -0
- data/lib/elasticsearch/api/actions/query_ruleset/put.rb +66 -0
- data/lib/elasticsearch/api/actions/rank_eval.rb +19 -21
- data/lib/elasticsearch/api/actions/reindex.rb +14 -21
- data/lib/elasticsearch/api/actions/reindex_rethrottle.rb +18 -13
- data/lib/elasticsearch/api/actions/render_search_template.rb +19 -7
- data/lib/elasticsearch/api/actions/rollup/delete_job.rb +64 -0
- data/lib/elasticsearch/api/actions/rollup/get_jobs.rb +66 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_caps.rb +66 -0
- data/lib/elasticsearch/api/actions/rollup/get_rollup_index_caps.rb +64 -0
- data/lib/elasticsearch/api/actions/rollup/put_job.rb +66 -0
- data/lib/elasticsearch/api/actions/rollup/rollup_search.rb +68 -0
- data/lib/elasticsearch/api/actions/rollup/start_job.rb +64 -0
- data/lib/elasticsearch/api/actions/rollup/stop_job.rb +66 -0
- data/lib/elasticsearch/api/actions/scripts_painless_execute.rb +14 -7
- data/lib/elasticsearch/api/actions/scroll.rb +20 -17
- data/lib/elasticsearch/api/actions/search.rb +24 -70
- data/lib/elasticsearch/api/actions/search_application/delete.rb +64 -0
- data/lib/elasticsearch/api/actions/search_application/delete_behavioral_analytics.rb +64 -0
- data/lib/elasticsearch/api/actions/search_application/get.rb +64 -0
- data/lib/elasticsearch/api/actions/search_application/get_behavioral_analytics.rb +66 -0
- data/lib/elasticsearch/api/actions/search_application/list.rb +57 -0
- data/lib/elasticsearch/api/actions/search_application/post_behavioral_analytics_event.rb +71 -0
- data/lib/elasticsearch/api/actions/search_application/put.rb +67 -0
- data/lib/elasticsearch/api/actions/search_application/put_behavioral_analytics.rb +64 -0
- data/lib/elasticsearch/api/actions/search_application/render_query.rb +65 -0
- data/lib/elasticsearch/api/actions/search_application/search.rb +71 -0
- data/lib/elasticsearch/api/actions/search_mvt.rb +86 -0
- data/lib/elasticsearch/api/actions/search_shards.rb +19 -19
- data/lib/elasticsearch/api/actions/search_template.rb +21 -38
- data/lib/elasticsearch/api/actions/searchable_snapshots/cache_stats.rb +66 -0
- data/lib/elasticsearch/api/actions/{indices/flush_synced.rb → searchable_snapshots/clear_cache.rb} +28 -30
- data/lib/elasticsearch/api/actions/searchable_snapshots/mount.rb +69 -0
- data/lib/elasticsearch/api/actions/searchable_snapshots/stats.rb +63 -0
- data/lib/elasticsearch/api/actions/security/activate_user_profile.rb +53 -0
- data/lib/elasticsearch/api/actions/security/authenticate.rb +50 -0
- data/lib/elasticsearch/api/actions/security/bulk_update_api_keys.rb +53 -0
- data/lib/elasticsearch/api/actions/security/change_password.rb +66 -0
- data/lib/elasticsearch/api/actions/security/clear_api_key_cache.rb +60 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_privileges.rb +60 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_realms.rb +61 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_roles.rb +60 -0
- data/lib/elasticsearch/api/actions/security/clear_cached_service_tokens.rb +68 -0
- data/lib/elasticsearch/api/actions/security/create_api_key.rb +54 -0
- data/lib/elasticsearch/api/actions/security/create_cross_cluster_api_key.rb +57 -0
- data/lib/elasticsearch/api/actions/security/create_service_token.rb +72 -0
- data/lib/elasticsearch/api/actions/security/delete_privileges.rb +65 -0
- data/lib/elasticsearch/api/actions/security/delete_role.rb +61 -0
- data/lib/elasticsearch/api/actions/security/delete_role_mapping.rb +61 -0
- data/lib/elasticsearch/api/actions/security/delete_service_token.rb +69 -0
- data/lib/elasticsearch/api/actions/security/delete_user.rb +61 -0
- data/lib/elasticsearch/api/actions/security/disable_user.rb +61 -0
- data/lib/elasticsearch/api/actions/security/disable_user_profile.rb +61 -0
- data/lib/elasticsearch/api/actions/security/enable_user.rb +61 -0
- data/lib/elasticsearch/api/actions/security/enable_user_profile.rb +61 -0
- data/lib/elasticsearch/api/actions/security/enroll_kibana.rb +50 -0
- data/lib/elasticsearch/api/actions/security/enroll_node.rb +50 -0
- data/lib/elasticsearch/api/actions/security/get_api_key.rb +58 -0
- data/lib/elasticsearch/api/actions/security/get_builtin_privileges.rb +50 -0
- data/lib/elasticsearch/api/actions/security/get_privileges.rb +67 -0
- data/lib/elasticsearch/api/actions/security/get_role.rb +70 -0
- data/lib/elasticsearch/api/actions/security/get_role_mapping.rb +62 -0
- data/lib/elasticsearch/api/actions/security/get_service_accounts.rb +67 -0
- data/lib/elasticsearch/api/actions/security/get_service_credentials.rb +64 -0
- data/lib/elasticsearch/api/actions/security/get_settings.rb +50 -0
- data/lib/elasticsearch/api/actions/security/get_token.rb +53 -0
- data/lib/elasticsearch/api/actions/security/get_user.rb +71 -0
- data/lib/elasticsearch/api/actions/security/get_user_privileges.rb +50 -0
- data/lib/elasticsearch/api/actions/security/get_user_profile.rb +61 -0
- data/lib/elasticsearch/api/actions/security/grant_api_key.rb +54 -0
- data/lib/elasticsearch/api/actions/security/has_privileges.rb +65 -0
- data/lib/elasticsearch/api/actions/security/has_privileges_user_profile.rb +53 -0
- data/lib/elasticsearch/api/actions/security/invalidate_api_key.rb +53 -0
- data/lib/elasticsearch/api/actions/security/invalidate_token.rb +53 -0
- data/lib/elasticsearch/api/actions/security/oidc_authenticate.rb +53 -0
- data/lib/elasticsearch/api/actions/security/oidc_logout.rb +53 -0
- data/lib/elasticsearch/api/actions/security/oidc_prepare_authentication.rb +53 -0
- data/lib/elasticsearch/api/actions/security/put_privileges.rb +54 -0
- data/lib/elasticsearch/api/actions/security/put_role.rb +63 -0
- data/lib/elasticsearch/api/actions/security/put_role_mapping.rb +63 -0
- data/lib/elasticsearch/api/actions/security/put_user.rb +63 -0
- data/lib/elasticsearch/api/actions/security/query_api_keys.rb +59 -0
- data/lib/elasticsearch/api/actions/security/query_user.rb +57 -0
- data/lib/elasticsearch/api/actions/security/saml_authenticate.rb +53 -0
- data/lib/elasticsearch/api/actions/security/saml_complete_logout.rb +53 -0
- data/lib/elasticsearch/api/actions/security/saml_invalidate.rb +53 -0
- data/lib/elasticsearch/api/actions/security/saml_logout.rb +53 -0
- data/lib/elasticsearch/api/actions/security/saml_prepare_authentication.rb +53 -0
- data/lib/elasticsearch/api/actions/security/saml_service_provider_metadata.rb +60 -0
- data/lib/elasticsearch/api/actions/security/suggest_user_profiles.rb +57 -0
- data/lib/elasticsearch/api/actions/security/update_api_key.rb +61 -0
- data/lib/elasticsearch/api/actions/security/update_cross_cluster_api_key.rb +66 -0
- data/lib/elasticsearch/api/actions/security/update_settings.rb +53 -0
- data/lib/elasticsearch/api/actions/security/update_user_profile_data.rb +65 -0
- data/lib/elasticsearch/api/actions/shutdown/delete_node.rb +17 -9
- data/lib/elasticsearch/api/actions/shutdown/get_node.rb +18 -10
- data/lib/elasticsearch/api/actions/shutdown/put_node.rb +17 -9
- data/lib/elasticsearch/api/actions/simulate/ingest.rb +70 -0
- data/lib/elasticsearch/api/actions/snapshot/cleanup_repository.rb +18 -14
- data/lib/elasticsearch/api/actions/snapshot/clone.rb +18 -13
- data/lib/elasticsearch/api/actions/snapshot/create.rb +18 -14
- data/lib/elasticsearch/api/actions/snapshot/create_repository.rb +18 -15
- data/lib/elasticsearch/api/actions/snapshot/delete.rb +25 -16
- data/lib/elasticsearch/api/actions/snapshot/delete_repository.rb +23 -15
- data/lib/elasticsearch/api/actions/snapshot/get.rb +32 -17
- data/lib/elasticsearch/api/actions/snapshot/get_repository.rb +24 -16
- data/lib/elasticsearch/api/actions/snapshot/repository_analyze.rb +71 -0
- data/lib/elasticsearch/api/actions/snapshot/restore.rb +18 -14
- data/lib/elasticsearch/api/actions/snapshot/status.rb +24 -16
- data/lib/elasticsearch/api/actions/snapshot/verify_repository.rb +18 -14
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/delete_lifecycle.rb +60 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_lifecycle.rb +60 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/execute_retention.rb +50 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_lifecycle.rb +62 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_stats.rb +50 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/get_status.rb +50 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/put_lifecycle.rb +61 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/start.rb +50 -0
- data/lib/elasticsearch/api/actions/snapshot_lifecycle_management/stop.rb +50 -0
- data/lib/elasticsearch/api/actions/sql/clear_cursor.rb +53 -0
- data/lib/elasticsearch/api/actions/sql/delete_async.rb +60 -0
- data/lib/elasticsearch/api/actions/sql/get_async.rb +64 -0
- data/lib/elasticsearch/api/actions/sql/get_async_status.rb +60 -0
- data/lib/elasticsearch/api/actions/sql/query.rb +54 -0
- data/lib/elasticsearch/api/actions/sql/translate.rb +53 -0
- data/lib/elasticsearch/api/actions/ssl/certificates.rb +50 -0
- data/lib/elasticsearch/api/actions/synonyms/delete_synonym.rb +60 -0
- data/lib/elasticsearch/api/actions/synonyms/delete_synonym_rule.rb +64 -0
- data/lib/elasticsearch/api/actions/synonyms/get_synonym.rb +62 -0
- data/lib/elasticsearch/api/actions/synonyms/get_synonym_rule.rb +64 -0
- data/lib/elasticsearch/api/actions/synonyms/get_synonyms_sets.rb +52 -0
- data/lib/elasticsearch/api/actions/synonyms/put_synonym.rb +62 -0
- data/lib/elasticsearch/api/actions/synonyms/put_synonym_rule.rb +66 -0
- data/lib/elasticsearch/api/actions/tasks/cancel.rb +19 -17
- data/lib/elasticsearch/api/actions/tasks/get.rb +18 -14
- data/lib/elasticsearch/api/actions/tasks/list.rb +14 -20
- data/lib/elasticsearch/api/actions/terms_enum.rb +64 -0
- data/lib/elasticsearch/api/actions/termvectors.rb +27 -43
- data/lib/elasticsearch/api/actions/text_structure/find_field_structure.rb +64 -0
- data/lib/elasticsearch/api/actions/text_structure/find_message_structure.rb +64 -0
- data/lib/elasticsearch/api/actions/text_structure/find_structure.rb +75 -0
- data/lib/elasticsearch/api/actions/text_structure/test_grok_pattern.rb +54 -0
- data/lib/elasticsearch/api/actions/transform/delete_transform.rb +63 -0
- data/lib/elasticsearch/api/actions/transform/get_transform.rb +66 -0
- data/lib/elasticsearch/api/actions/transform/get_transform_stats.rb +64 -0
- data/lib/elasticsearch/api/actions/transform/preview_transform.rb +69 -0
- data/lib/elasticsearch/api/actions/transform/put_transform.rb +64 -0
- data/lib/elasticsearch/api/actions/transform/reset_transform.rb +62 -0
- data/lib/elasticsearch/api/actions/transform/schedule_now_transform.rb +61 -0
- data/lib/elasticsearch/api/actions/transform/start_transform.rb +62 -0
- data/lib/elasticsearch/api/actions/transform/stop_transform.rb +65 -0
- data/lib/elasticsearch/api/actions/transform/update_transform.rb +64 -0
- data/lib/elasticsearch/api/actions/transform/upgrade_transforms.rb +52 -0
- data/lib/elasticsearch/api/actions/update.rb +24 -38
- data/lib/elasticsearch/api/actions/update_by_query.rb +20 -65
- data/lib/elasticsearch/api/actions/update_by_query_rethrottle.rb +18 -13
- data/lib/elasticsearch/api/actions/watcher/ack_watch.rb +67 -0
- data/lib/elasticsearch/api/actions/watcher/activate_watch.rb +60 -0
- data/lib/elasticsearch/api/actions/watcher/deactivate_watch.rb +60 -0
- data/lib/elasticsearch/api/actions/watcher/delete_watch.rb +68 -0
- data/lib/elasticsearch/api/actions/watcher/execute_watch.rb +64 -0
- data/lib/elasticsearch/api/actions/watcher/get_settings.rb +50 -0
- data/lib/elasticsearch/api/actions/watcher/get_watch.rb +60 -0
- data/lib/elasticsearch/api/actions/watcher/put_watch.rb +65 -0
- data/lib/elasticsearch/api/actions/watcher/query_watches.rb +56 -0
- data/lib/elasticsearch/api/actions/watcher/start.rb +50 -0
- data/lib/elasticsearch/api/actions/watcher/stats.rb +63 -0
- data/lib/elasticsearch/api/actions/watcher/stop.rb +50 -0
- data/lib/elasticsearch/api/actions/watcher/update_settings.rb +53 -0
- data/lib/elasticsearch/api/actions/xpack/info.rb +52 -0
- data/lib/elasticsearch/api/actions/xpack/usage.rb +51 -0
- data/lib/elasticsearch/api/namespace/async_search.rb +36 -0
- data/lib/elasticsearch/api/{actions/remote/info.rb → namespace/autoscaling.rb} +12 -13
- data/lib/elasticsearch/api/namespace/common.rb +2 -2
- data/lib/elasticsearch/api/namespace/connector.rb +36 -0
- data/lib/elasticsearch/api/namespace/cross_cluster_replication.rb +38 -0
- data/lib/elasticsearch/api/namespace/data_frame_transform_deprecated.rb +36 -0
- data/lib/elasticsearch/api/namespace/enrich.rb +36 -0
- data/lib/elasticsearch/api/namespace/eql.rb +36 -0
- data/lib/elasticsearch/api/namespace/esql.rb +36 -0
- data/lib/elasticsearch/api/namespace/fleet.rb +36 -0
- data/lib/elasticsearch/api/namespace/graph.rb +36 -0
- data/lib/elasticsearch/api/namespace/index_lifecycle_management.rb +38 -0
- data/lib/elasticsearch/api/namespace/inference.rb +36 -0
- data/lib/elasticsearch/api/namespace/ingest.rb +0 -1
- data/lib/elasticsearch/api/namespace/license.rb +36 -0
- data/lib/elasticsearch/api/namespace/logstash.rb +36 -0
- data/lib/elasticsearch/api/{actions/abort_benchmark.rb → namespace/machine_learning.rb} +13 -16
- data/lib/elasticsearch/api/namespace/migration.rb +36 -0
- data/lib/elasticsearch/api/namespace/monitoring.rb +36 -0
- data/lib/elasticsearch/api/namespace/profiling.rb +36 -0
- data/lib/elasticsearch/api/namespace/query_ruleset.rb +36 -0
- data/lib/elasticsearch/api/namespace/rollup.rb +36 -0
- data/lib/elasticsearch/api/namespace/search_application.rb +36 -0
- data/lib/elasticsearch/api/namespace/searchable_snapshots.rb +36 -0
- data/lib/elasticsearch/api/namespace/security.rb +36 -0
- data/lib/elasticsearch/api/namespace/simulate.rb +36 -0
- data/lib/elasticsearch/api/namespace/snapshot_lifecycle_management.rb +38 -0
- data/lib/elasticsearch/api/namespace/sql.rb +36 -0
- data/lib/elasticsearch/api/namespace/ssl.rb +36 -0
- data/lib/elasticsearch/api/namespace/synonyms.rb +36 -0
- data/lib/elasticsearch/api/namespace/text_structure.rb +36 -0
- data/lib/elasticsearch/api/namespace/transform.rb +36 -0
- data/lib/elasticsearch/api/namespace/watcher.rb +36 -0
- data/lib/elasticsearch/api/namespace/xpack.rb +36 -0
- data/lib/elasticsearch/api/response.rb +48 -0
- data/lib/elasticsearch/api/utils.rb +6 -56
- data/lib/elasticsearch/api/version.rb +1 -1
- data/lib/elasticsearch/api.rb +34 -21
- data/spec/elasticsearch/api/actions/bulk_spec.rb +39 -35
- data/spec/elasticsearch/api/actions/cat/aliases_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/allocation_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/component_templates_spec.rb +58 -0
- data/spec/elasticsearch/api/actions/cat/count_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/fielddata_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/cat/health_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/help_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/indices_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/master_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/nodeattrs_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/nodes_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/pending_tasks_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/plugins_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/recovery_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/repositories_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/segments_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/cat/shards_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/snapshot_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/tasks_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/templates_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cat/thread_pool_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/clear_scroll_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/close_point_in_time_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/allocation_explain_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/get_settings_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/health_spec.rb +9 -6
- data/spec/elasticsearch/api/actions/cluster/info_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/cluster/pending_tasks_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/put_settings_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/remote_info_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/cluster/reroute_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/cluster/state_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/cluster/stats_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/connector/check_in_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/delete_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/get_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/last_sync_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/{benchmark_spec.rb → connector/list_spec.rb} +7 -6
- data/spec/elasticsearch/api/actions/connector/post_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector/put_spec.rb +43 -0
- data/spec/elasticsearch/api/actions/connector/update_active_filtering_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_api_key_id_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_configuration_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_error_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_filtering_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_filtering_validation_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_index_name_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_name_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_native_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_pipeline_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_scheduling_spec.rb +42 -0
- data/spec/elasticsearch/api/actions/connector/update_service_type_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector/update_status_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_secret/delete_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_secret/get_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_secret/post_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_secret/put_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/cancel_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/check_in_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/delete_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/error_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/get_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/list_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/post_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/connector_sync_job/update_stats_spec.rb +38 -0
- data/spec/elasticsearch/api/actions/count_spec.rb +12 -12
- data/spec/elasticsearch/api/actions/create_document_spec.rb +43 -9
- data/spec/elasticsearch/api/actions/dangling_indices/delete_dangling_indices_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/dangling_indices/import_dangling_indices_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/dangling_indices/list_dangling_indices_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/data_frame/update_data_frame_transform_spec.rb +82 -0
- data/spec/elasticsearch/api/actions/delete_by_query_spec.rb +6 -21
- data/spec/elasticsearch/api/actions/delete_document_spec.rb +13 -24
- data/spec/elasticsearch/api/actions/delete_script_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/esql/async_query_get._spec.rb +35 -0
- data/spec/elasticsearch/api/actions/esql/async_query_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/{abort_benchmark_spec.rb → esql/query_spec.rb} +6 -5
- data/spec/elasticsearch/api/actions/exists_document_spec.rb +12 -22
- data/spec/elasticsearch/api/actions/explain_document_spec.rb +44 -10
- data/spec/elasticsearch/api/actions/features/get_features_spec.rb +12 -7
- data/spec/elasticsearch/api/actions/features/reset_features_spec.rb +12 -7
- data/spec/elasticsearch/api/actions/field_caps_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/fleet/global_checkpoints_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/fleet/msearch_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/fleet/search_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/get_document_source_spec.rb +19 -19
- data/spec/elasticsearch/api/actions/get_document_spec.rb +19 -32
- data/spec/elasticsearch/api/actions/get_script_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/health_report_spec.rb +52 -0
- data/spec/elasticsearch/api/actions/index_document_spec.rb +34 -29
- data/spec/elasticsearch/api/actions/index_lifecycle_management/migrate_to_data_tiers_spec.rb +37 -0
- data/spec/elasticsearch/api/actions/indices/add_block_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/indices/analyze_spec.rb +16 -4
- data/spec/elasticsearch/api/actions/indices/clear_cache_spec.rb +44 -8
- data/spec/elasticsearch/api/actions/indices/clone_spec.rb +9 -7
- data/spec/elasticsearch/api/actions/indices/close_spec.rb +16 -4
- data/spec/elasticsearch/api/actions/indices/create_spec.rb +16 -4
- data/spec/elasticsearch/api/actions/{nodes/shutdown_spec.rb → indices/data_streams_stats_spec.rb} +26 -32
- data/spec/elasticsearch/api/actions/indices/delete_alias_spec.rb +17 -3
- data/spec/elasticsearch/api/actions/indices/delete_data_lifecycle_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/indices/delete_spec.rb +28 -5
- data/spec/elasticsearch/api/actions/indices/delete_template_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/indices/disk_usage_spec.rb +49 -0
- data/spec/elasticsearch/api/actions/indices/exists_alias_spec.rb +26 -1
- data/spec/elasticsearch/api/actions/indices/exists_spec.rb +24 -1
- data/spec/elasticsearch/api/actions/indices/exists_template_spec.rb +13 -1
- data/spec/elasticsearch/api/actions/indices/explain_data_lifecycle_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/indices/field_usage_stats_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/indices/flush_spec.rb +51 -6
- data/spec/elasticsearch/api/actions/indices/forcemerge_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/indices/get_alias_spec.rb +28 -4
- data/spec/elasticsearch/api/actions/indices/get_data_lifecycle_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/indices/get_field_mapping_spec.rb +13 -12
- data/spec/elasticsearch/api/actions/indices/get_mapping_spec.rb +40 -21
- data/spec/elasticsearch/api/actions/indices/get_settings_spec.rb +39 -5
- data/spec/elasticsearch/api/actions/indices/get_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/indices/open_spec.rb +16 -4
- data/spec/elasticsearch/api/actions/indices/put_alias_spec.rb +31 -5
- data/spec/elasticsearch/api/actions/indices/put_data_lifecycle_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/indices/put_mapping_spec.rb +32 -15
- data/spec/elasticsearch/api/actions/indices/put_settings_spec.rb +51 -6
- data/spec/elasticsearch/api/actions/indices/put_template_spec.rb +16 -4
- data/spec/elasticsearch/api/actions/indices/recovery_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/indices/refresh_spec.rb +51 -6
- data/spec/elasticsearch/api/actions/indices/resolve_cluster_spec.rb +51 -0
- data/spec/elasticsearch/api/actions/indices/rollover_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/indices/segments_spec.rb +51 -6
- data/spec/elasticsearch/api/actions/indices/shard_stores_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/indices/shrink_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/indices/split_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/indices/stats_spec.rb +75 -13
- data/spec/elasticsearch/api/actions/indices/unfreeze_spec.rb +97 -0
- data/spec/elasticsearch/api/actions/indices/update_aliases_spec.rb +4 -3
- data/spec/elasticsearch/api/actions/indices/validate_query_spec.rb +74 -16
- data/spec/elasticsearch/api/actions/inference/delete_model_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/inference/get_model_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/inference/inference_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/inference/put_model_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/info_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/ingest/delete_pipeline_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/ingest/geo_ip_stats_spec.rb +7 -2
- data/spec/elasticsearch/api/actions/ingest/get_pipeline_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/ingest/put_pipeline_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/ingest/simulate_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/json_builders_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/machine_learning/get_memory_stats_spec.rb +59 -0
- data/spec/elasticsearch/api/actions/machine_learning/get_model_snapshot_upgrade_stats_spec.rb +60 -0
- data/spec/elasticsearch/api/actions/machine_learning/infer_trained_model_deployment_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/machine_learning/put_trained_model_definition_part_spec.rb +64 -0
- data/spec/elasticsearch/api/actions/machine_learning/put_trained_model_vocabulary_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/machine_learning/reset_job_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/machine_learning/set_upgrade_mode_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/machine_learning/start_trained_model_deployment_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/machine_learning/stop_trained_model_deployment_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/machine_learning/update_trained_model_deployment_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/mget_spec.rb +27 -19
- data/spec/elasticsearch/api/actions/migration/get_feature_upgrade_status_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/migration/post_feature_upgrade_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/msearch_spec.rb +51 -15
- data/spec/elasticsearch/api/actions/msearch_template_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/mtermvectors_spec.rb +6 -7
- data/spec/elasticsearch/api/actions/nodes/clear_repositories_metering_archive_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/nodes/get_repositories_metering_info_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/nodes/hot_threads_spec.rb +30 -7
- data/spec/elasticsearch/api/actions/nodes/info_spec.rb +52 -7
- data/spec/elasticsearch/api/actions/nodes/reload_secure_settings_spec.rb +40 -6
- data/spec/elasticsearch/api/actions/nodes/stats_spec.rb +39 -5
- data/spec/elasticsearch/api/actions/open_point_in_time_spec.rb +4 -13
- data/spec/elasticsearch/api/actions/ping_spec.rb +2 -1
- data/spec/elasticsearch/api/actions/profiling/flamegraph_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/profiling/stacktraces_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/{snapshot/get_features_spec.rb → profiling/status_spec.rb} +6 -8
- data/spec/elasticsearch/api/actions/profiling/topn_functions_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/put_script_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/query_ruleset/delete_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/query_ruleset/get_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/query_ruleset/put_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/rank_eval_spec.rb +139 -0
- data/spec/elasticsearch/api/actions/reindex_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/render_search_template_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/scroll_spec.rb +6 -4
- data/spec/elasticsearch/api/actions/search_application/delete_behavioral_analytics_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/search_application/delete_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_application/get_behavioral_analytics_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_application/get_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_application/list_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_application/post_behavioral_analytics_event_spec.rb +40 -0
- data/spec/elasticsearch/api/actions/search_application/put_behavioral_analytics_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/search_application/put_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_application/render_query_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/search_application/search_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/search_mvt_spec.rb +55 -0
- data/spec/elasticsearch/api/actions/search_shards_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/search_spec.rb +24 -39
- data/spec/elasticsearch/api/actions/search_template_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/searchable_snapshots/cache_stats_spec.rb +56 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/clear_cache_spec.rb +57 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/mount_spec.rb +58 -0
- data/spec/elasticsearch/api/actions/searchable_snapshots/stats_spec.rb +57 -0
- data/spec/elasticsearch/api/actions/security/clear_cached_service_tokens_spec.rb +60 -0
- data/spec/elasticsearch/api/actions/security/create_api_key_spec.rb +81 -0
- data/spec/elasticsearch/api/actions/security/create_cross_cluster_api_key_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/security/create_service_token_spec.rb +83 -0
- data/spec/elasticsearch/api/actions/security/delete_service_token_spec.rb +62 -0
- data/spec/elasticsearch/api/actions/security/disable_user_profile_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/security/enable_user_profile_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/security/enroll_kibana_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/security/get_api_key_spec.rb +57 -0
- data/spec/elasticsearch/api/actions/{indices/upgrade_spec.rb → security/get_builtin_privileges_spec.rb} +6 -5
- data/spec/elasticsearch/api/actions/security/get_service_accounts_spec.rb +83 -0
- data/spec/elasticsearch/api/actions/security/get_service_credentials_spec.rb +55 -0
- data/spec/elasticsearch/api/actions/security/has_privileges_user_profile_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/security/invalidate_api_key_spec.rb +39 -0
- data/spec/elasticsearch/api/actions/security/query_api_keys_spec.rb +49 -0
- data/spec/elasticsearch/api/actions/security/query_user_spec.rb +49 -0
- data/spec/elasticsearch/api/actions/security/saml_authenticate_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/saml_complete_logout_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/saml_invalidate_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/saml_logout_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/saml_prepare_authentication_spec.rb +45 -0
- data/spec/elasticsearch/api/actions/security/saml_service_provider_metadata_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/security/suggest_user_profiles_spec.rb +46 -0
- data/spec/elasticsearch/api/actions/security/update_api_key_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/security/update_cross_cluster_api_key_spec.rb +37 -0
- data/spec/elasticsearch/api/actions/shutdown/delete_node_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/shutdown/get_node_spec.rb +15 -3
- data/spec/elasticsearch/api/actions/shutdown/put_node_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/simulate/ingest_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/snapshot/clone_spec.rb +5 -2
- data/spec/elasticsearch/api/actions/snapshot/create_repository_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/snapshot/create_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/snapshot/delete_repository_spec.rb +17 -3
- data/spec/elasticsearch/api/actions/snapshot/delete_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/snapshot/get_repository_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/snapshot/get_spec.rb +4 -2
- data/spec/elasticsearch/api/actions/snapshot/repository_analize_spec.rb +48 -0
- data/spec/elasticsearch/api/actions/snapshot/restore_spec.rb +9 -10
- data/spec/elasticsearch/api/actions/snapshot/status_spec.rb +15 -4
- data/spec/elasticsearch/api/actions/snapshot/verify_repository_spec.rb +8 -7
- data/spec/elasticsearch/api/actions/sql/delete_async_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/sql/get_async_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/sql/get_async_stats_spec.rb +47 -0
- data/spec/elasticsearch/api/actions/tasks/cancel_spec.rb +19 -8
- data/spec/elasticsearch/api/actions/tasks/get_spec.rb +3 -2
- data/spec/elasticsearch/api/actions/tasks/list_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/terms_enum_spec.rb +53 -0
- data/spec/elasticsearch/api/actions/termvectors_spec.rb +18 -6
- data/spec/elasticsearch/api/actions/text_structure/find_field_structure_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/text_structure/find_message_structure_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/text_structure/find_structure_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/text_structure/test_grok_pattern_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/transform/schedule_now_transform_spec.rb +36 -0
- data/spec/elasticsearch/api/actions/update_by_query_spec.rb +7 -7
- data/spec/elasticsearch/api/actions/update_document_spec.rb +27 -29
- data/spec/elasticsearch/api/actions/watcher/get_settings_spec.rb +35 -0
- data/spec/elasticsearch/api/actions/watcher/update_settings_spec.rb +47 -0
- data/spec/elasticsearch/api/api_response_spec.rb +65 -0
- data/spec/elasticsearch/api/api_spec.rb +0 -3
- data/spec/elasticsearch/api/client_spec.rb +0 -4
- data/spec/elasticsearch/api/perform_request_spec.rb +86 -0
- data/spec/elasticsearch/api/utils_spec.rb +14 -89
- data/spec/free/integration/health_spec.rb +28 -0
- data/spec/free/integration/spec_helper.rb +28 -0
- data/spec/platinum/integration/analytics/usage_spec.rb +56 -0
- data/spec/platinum/integration/api_key/admin_user_query_api_keys_spec.rb +111 -0
- data/spec/platinum/integration/api_key/api_key_admin_user_spec.rb +127 -0
- data/spec/platinum/integration/api_key/api_key_cross_cluster_spec.rb +113 -0
- data/spec/platinum/integration/api_key/api_key_invalidation_spec.rb +105 -0
- data/spec/platinum/integration/api_key/api_key_query_spec.rb +149 -0
- data/spec/platinum/integration/api_key/api_key_query_with_aggs_spec.rb +120 -0
- data/spec/platinum/integration/api_key/api_key_spec.rb +156 -0
- data/spec/platinum/integration/api_key/api_key_update_spec.rb +134 -0
- data/spec/platinum/integration/eql/eql_async_spec.rb +72 -0
- data/spec/platinum/integration/health/health_spec.rb +49 -0
- data/spec/platinum/integration/ml/get_memory_stats_spec.rb +47 -0
- data/spec/platinum/integration/platinum_helper.rb +42 -0
- data/spec/platinum/integration/security/users_query_spec.rb +49 -0
- data/spec/platinum/integration/service_accounts/service_accounts_spec.rb +65 -0
- data/spec/platinum/integration/snapshots/snapshots_spec.rb +84 -0
- data/spec/platinum/integration/spatial/script_doc_values_spec.rb +147 -0
- data/spec/platinum/integration/token/token_spec.rb +94 -0
- data/spec/platinum/unit/async_search/delete_test.rb +39 -0
- data/spec/platinum/unit/async_search/get_test.rb +39 -0
- data/spec/platinum/unit/async_search/status_test.rb +39 -0
- data/spec/platinum/unit/async_search/submit_test.rb +50 -0
- data/spec/platinum/unit/autoscaling/delete_autoscaling_policy_test.rb +46 -0
- data/spec/platinum/unit/autoscaling/get_autoscaling_capacity_test.rb +40 -0
- data/spec/platinum/unit/autoscaling/get_autoscaling_policy_test.rb +46 -0
- data/spec/platinum/unit/autoscaling/put_autoscaling_policy_test.rb +52 -0
- data/spec/platinum/unit/enrich/delete_policy_test.rb +43 -0
- data/spec/platinum/unit/eql/delete_test.rb +46 -0
- data/spec/platinum/unit/eql/get_status_test.rb +46 -0
- data/spec/platinum/unit/eql/get_test.rb +46 -0
- data/spec/platinum/unit/eql/search_test.rb +52 -0
- data/spec/platinum/unit/graph/explore_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/explain_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/get_status_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/move_to_step.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/remove_policy_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/retry_policy_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/start_test.rb +43 -0
- data/spec/platinum/unit/index_lifecycle_management/stop_test.rb +43 -0
- data/spec/platinum/unit/indices/create_data_stream_test.rb +46 -0
- data/spec/platinum/unit/indices/data_stream_stats_test.rb +54 -0
- data/spec/platinum/unit/indices/delete_data_stream_test.rb +46 -0
- data/spec/platinum/unit/indices/downsample_test.rb +58 -0
- data/spec/platinum/unit/indices/get_data_stream_test.rb +50 -0
- data/spec/platinum/unit/indices/migrate_to_data_stream_test.rb +46 -0
- data/spec/platinum/unit/indices/modify_data_stream_test.rb +46 -0
- data/spec/platinum/unit/indices/promote_data_stream_test.rb +46 -0
- data/spec/platinum/unit/info_test.rb +40 -0
- data/spec/platinum/unit/knn_search_test.rb +40 -0
- data/spec/platinum/unit/license/delete_test.rb +43 -0
- data/spec/platinum/unit/license/get_test.rb +43 -0
- data/spec/platinum/unit/license/post_test.rb +43 -0
- data/spec/platinum/unit/logstash/delete_pipeline_test.rb +46 -0
- data/spec/platinum/unit/logstash/get_pipeline_test.rb +46 -0
- data/spec/platinum/unit/logstash/put_pipeline_test.rb +46 -0
- data/spec/platinum/unit/machine_learning/clear_trained_model_deployment_cache_test.rb +40 -0
- data/spec/platinum/unit/machine_learning/close_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_expired_data_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_filter_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_forecast_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/delete_model_alias_test.rb +40 -0
- data/spec/platinum/unit/machine_learning/delete_model_snapshot_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/flush_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/forecast_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_buckets_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_categories_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_datafeed_stats_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_datafeeds_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_filters_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_influencers_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_job_stats_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_jobs_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_model_snapshots_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_overall_buckets_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/get_records_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/open_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/post_data_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/preview_data_frame_analytics_test.rb +64 -0
- data/spec/platinum/unit/machine_learning/preview_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/put_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/put_filter_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/put_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/put_trained_model_alias_test.rb +40 -0
- data/spec/platinum/unit/machine_learning/revert_model_snapshot_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/start_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/stop_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/update_data_frame_analytics_test.rb +40 -0
- data/spec/platinum/unit/machine_learning/update_datafeed_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/update_filter_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/update_job_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/update_model_snapshot_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/upgrade_job_snapshot_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/validate_detector_test.rb +43 -0
- data/spec/platinum/unit/machine_learning/validate_test.rb +43 -0
- data/spec/platinum/unit/migration/deprecations_test.rb +42 -0
- data/spec/platinum/unit/monitoring/bulk_test.rb +43 -0
- data/spec/platinum/unit/rollup/get_rollup_index_caps_test.rb +40 -0
- data/spec/platinum/unit/security/activate_user_profile_test.rb +40 -0
- data/spec/platinum/unit/security/authenticate_test.rb +43 -0
- data/spec/platinum/unit/security/bulk_update_api_key_test.rb +40 -0
- data/spec/platinum/unit/security/change_password_test.rb +55 -0
- data/spec/platinum/unit/security/clear_api_key_cache_test.rb +40 -0
- data/spec/platinum/unit/security/clear_cached_privileges_test.rb +40 -0
- data/spec/platinum/unit/security/clear_cached_realms_test.rb +43 -0
- data/spec/platinum/unit/security/clear_cached_roles_test.rb +43 -0
- data/spec/platinum/unit/security/delete_privileges_test.rb +43 -0
- data/spec/platinum/unit/security/delete_role_mapping_test.rb +43 -0
- data/spec/platinum/unit/security/delete_role_test.rb +43 -0
- data/spec/platinum/unit/security/delete_user_test.rb +43 -0
- data/spec/platinum/unit/security/disable_user_test.rb +43 -0
- data/spec/platinum/unit/security/enable_user_test.rb +43 -0
- data/spec/platinum/unit/security/get_privileges_test.rb +78 -0
- data/spec/platinum/unit/security/get_role_mapping_test.rb +54 -0
- data/spec/platinum/unit/security/get_role_test.rb +62 -0
- data/spec/platinum/unit/security/get_token_test.rb +43 -0
- data/spec/platinum/unit/security/get_user_privileges_test.rb +43 -0
- data/spec/platinum/unit/security/get_user_profile_test.rb +40 -0
- data/spec/platinum/unit/security/get_user_test.rb +61 -0
- data/spec/platinum/unit/security/grant_api_key_test.rb +41 -0
- data/spec/platinum/unit/security/has_privileges_test.rb +55 -0
- data/spec/platinum/unit/security/invalidate_token_test.rb +43 -0
- data/spec/platinum/unit/security/oidc_authenticate_test.rb +40 -0
- data/spec/platinum/unit/security/oidc_logout_test.rb +40 -0
- data/spec/platinum/unit/security/oidc_prepare_authentication_test.rb +40 -0
- data/spec/platinum/unit/security/put_privileges_test.rb +43 -0
- data/spec/platinum/unit/security/put_role_mapping_test.rb +43 -0
- data/spec/platinum/unit/security/put_role_test.rb +43 -0
- data/spec/platinum/unit/security/put_user_test.rb +43 -0
- data/spec/platinum/unit/security/update_user_profile_data_test.rb +40 -0
- data/spec/platinum/unit/ssl/certificates_test.rb +43 -0
- data/spec/platinum/unit/test_helper.rb +72 -0
- data/spec/platinum/unit/transform/reset_transform_spec.rb +34 -0
- data/spec/{elasticsearch/api/actions/remote/info_spec.rb → platinum/unit/transform/upgrade_transforms_spec.rb} +7 -8
- data/spec/platinum/unit/usage_test.rb +40 -0
- data/spec/platinum/unit/watcher/ack_watch_test.rb +55 -0
- data/spec/platinum/unit/watcher/activate_watch_test.rb +43 -0
- data/spec/platinum/unit/watcher/deactivate_watch_test.rb +43 -0
- data/spec/platinum/unit/watcher/delete_watch_test.rb +43 -0
- data/spec/platinum/unit/watcher/execute_watch_test.rb +55 -0
- data/spec/platinum/unit/watcher/get_watch_test.rb +43 -0
- data/spec/platinum/unit/watcher/put_watch_test.rb +43 -0
- data/spec/platinum/unit/watcher/query_watches_test.rb +52 -0
- data/spec/platinum/unit/watcher/start_test.rb +41 -0
- data/spec/platinum/unit/watcher/stats_test.rb +43 -0
- data/spec/platinum/unit/watcher/stop_test.rb +43 -0
- data/spec/rest_api/rest_api_tests_helper.rb +100 -0
- data/spec/rest_api/rest_api_yaml_spec.rb +82 -0
- data/spec/rest_api/run_rspec_matchers.rb +111 -0
- data/spec/rest_api/skipped_tests_free.yml +84 -0
- data/spec/rest_api/skipped_tests_platinum.yml +120 -0
- data/spec/rspec_formatter.rb +31 -0
- data/spec/spec_helper.rb +23 -20
- data/utils/Gemfile +1 -3
- data/utils/README.md +15 -8
- data/utils/thor/endpoint_spec.rb +193 -0
- data/utils/thor/{generator/endpoint_specifics.rb → endpoint_specifics.rb} +16 -42
- data/utils/thor/generate_source.rb +29 -203
- data/utils/thor/generator/build_hash_helper.rb +64 -0
- data/utils/thor/generator/docs_helper.rb +62 -0
- data/utils/thor/generator/files_helper.rb +32 -42
- data/utils/thor/templates/_body.erb +34 -0
- data/utils/thor/templates/_documentation_top.erb +40 -23
- data/utils/thor/templates/_method_setup.erb +34 -32
- data/utils/thor/templates/_perform_request.erb +40 -28
- data/utils/thor/templates/method.erb +36 -30
- data/utils/thor/templates/test.erb +16 -3
- data/utils/thor/templates/test_helper.rb +0 -4
- metadata +1003 -110
- data/lib/elasticsearch/api/actions/benchmark.rb +0 -81
- data/lib/elasticsearch/api/actions/cat/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/cluster/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/dangling_indices/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/delete_by_rethrottle.rb +0 -47
- data/lib/elasticsearch/api/actions/features/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/indices/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/ingest/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/nodes/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/nodes/shutdown.rb +0 -56
- data/lib/elasticsearch/api/actions/params_registry.rb +0 -58
- data/lib/elasticsearch/api/actions/shutdown/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/snapshot/params_registry.rb +0 -60
- data/lib/elasticsearch/api/actions/tasks/params_registry.rb +0 -60
- data/spec/elasticsearch/api/actions/indices/exists_type_spec.rb +0 -108
- data/spec/elasticsearch/api/actions/indices/flush_synced_spec.rb +0 -90
- data/spec/elasticsearch/api/rest_api_yaml_spec.rb +0 -147
- data/spec/rest_yaml_tests_helper.rb +0 -81
- data/spec/skipped_tests.yml +0 -29
- data/utils/thor/templates/_params_registry.erb +0 -12
- /data/{LICENSE → LICENSE.txt} +0 -0
@@ -0,0 +1,105 @@
|
|
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 'base64'
|
19
|
+
require_relative '../platinum_helper'
|
20
|
+
|
21
|
+
describe 'API keys API invalidation' do
|
22
|
+
before do
|
23
|
+
ADMIN_CLIENT.security.put_role(
|
24
|
+
name: 'admin_role',
|
25
|
+
body: {
|
26
|
+
cluster: ['manage_api_key']
|
27
|
+
}
|
28
|
+
)
|
29
|
+
ADMIN_CLIENT.security.put_role(
|
30
|
+
name: 'user_role',
|
31
|
+
body: {
|
32
|
+
cluster: ['manage_own_api_key']
|
33
|
+
}
|
34
|
+
)
|
35
|
+
ADMIN_CLIENT.security.put_user(
|
36
|
+
username: 'api_key_manager',
|
37
|
+
body: {
|
38
|
+
password: 'changeme',
|
39
|
+
roles: [ 'admin_role' ],
|
40
|
+
full_name: 'API key manager'
|
41
|
+
}
|
42
|
+
)
|
43
|
+
ADMIN_CLIENT.security.put_user(
|
44
|
+
username: 'api_key_test_user1',
|
45
|
+
body: {
|
46
|
+
password: 'x-pack-test-password',
|
47
|
+
roles: [ 'user_role' ],
|
48
|
+
full_name: 'API key user'
|
49
|
+
}
|
50
|
+
)
|
51
|
+
end
|
52
|
+
|
53
|
+
after do
|
54
|
+
ADMIN_CLIENT.security.delete_role(name: "admin_role", ignore: 404)
|
55
|
+
ADMIN_CLIENT.security.delete_role(name: "user_role", ignore: 404)
|
56
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user1", ignore: 404)
|
57
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_manager", ignore: 404)
|
58
|
+
end
|
59
|
+
|
60
|
+
let(:credentials) { Base64.strict_encode64("api_key_manager:changeme") }
|
61
|
+
|
62
|
+
let(:client) do
|
63
|
+
Elasticsearch::Client.new(
|
64
|
+
host: HOST,
|
65
|
+
transport_options: TRANSPORT_OPTIONS.merge(headers: { Authorization: "Basic #{credentials}" })
|
66
|
+
)
|
67
|
+
end
|
68
|
+
|
69
|
+
it 'invalidates by realm name' do
|
70
|
+
response = client.security.create_api_key(
|
71
|
+
body: {
|
72
|
+
name: "manager-api-key",
|
73
|
+
expiration: "1d",
|
74
|
+
role_descriptors: {}
|
75
|
+
}
|
76
|
+
)
|
77
|
+
expect(response['name']).to eq 'manager-api-key'
|
78
|
+
id = response['id']
|
79
|
+
expect(id).not_to be nil
|
80
|
+
expect(response['api_key']).not_to be nil
|
81
|
+
expect(response['expiration']).not_to be nil
|
82
|
+
|
83
|
+
user_credentials = Base64.strict_encode64('api_key_test_user1:x-pack-test-password')
|
84
|
+
user_client = Elasticsearch::Client.new(
|
85
|
+
host: HOST,
|
86
|
+
transport_options: TRANSPORT_OPTIONS.merge(headers: { Authentication: "Basic #{user_credentials}" })
|
87
|
+
)
|
88
|
+
response = user_client.security.create_api_key(
|
89
|
+
body: {
|
90
|
+
name: "user1-api-key",
|
91
|
+
expiration: "1d",
|
92
|
+
role_descriptors: {}
|
93
|
+
}
|
94
|
+
)
|
95
|
+
expect(response['name']).to eq 'user1-api-key'
|
96
|
+
id = response['id']
|
97
|
+
expect(id).not_to be nil
|
98
|
+
expect(response['api_key']).not_to be nil
|
99
|
+
expect(response['expiration']).not_to be nil
|
100
|
+
|
101
|
+
response = client.security.invalidate_api_key(body: { realm_name: 'default_native'})
|
102
|
+
expect(response['invalidated_api_keys'].count).to be >= 2
|
103
|
+
expect(response['error_count']).to eq 0
|
104
|
+
end
|
105
|
+
end
|
@@ -0,0 +1,149 @@
|
|
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_relative '../platinum_helper'
|
19
|
+
|
20
|
+
describe 'API keys' do
|
21
|
+
before do
|
22
|
+
ADMIN_CLIENT.security.put_role(
|
23
|
+
name: 'admin_role',
|
24
|
+
body: { cluster: ['manage_api_key'] }
|
25
|
+
)
|
26
|
+
ADMIN_CLIENT.security.put_role(
|
27
|
+
name: 'user_role',
|
28
|
+
body: {
|
29
|
+
cluster: ['manage_own_api_key'],
|
30
|
+
}
|
31
|
+
)
|
32
|
+
ADMIN_CLIENT.security.put_user(
|
33
|
+
username: 'api_key_manager',
|
34
|
+
body: {
|
35
|
+
password: 'x-pack-test-password',
|
36
|
+
roles: [ 'admin_role' ],
|
37
|
+
full_name: 'API key manager'
|
38
|
+
}
|
39
|
+
)
|
40
|
+
ADMIN_CLIENT.security.put_user(
|
41
|
+
username: 'api_key_user_1',
|
42
|
+
body: {
|
43
|
+
password: 'x-pack-test-password',
|
44
|
+
roles: [ 'user_role' ],
|
45
|
+
full_name: 'API key user 1'
|
46
|
+
}
|
47
|
+
)
|
48
|
+
ADMIN_CLIENT.security.put_user(
|
49
|
+
username: 'api_key_user_2',
|
50
|
+
body: {
|
51
|
+
password: 'x-pack-test-password',
|
52
|
+
roles: [ 'user_role' ],
|
53
|
+
full_name: 'API key user 2'
|
54
|
+
}
|
55
|
+
)
|
56
|
+
end
|
57
|
+
|
58
|
+
after do
|
59
|
+
ADMIN_CLIENT.security.delete_role(name: "admin_role", ignore: 404)
|
60
|
+
ADMIN_CLIENT.security.delete_role(name: "user_role", ignore: 404)
|
61
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user_1", ignore: 404)
|
62
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user_2", ignore: 404)
|
63
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_manager", ignore: 404)
|
64
|
+
end
|
65
|
+
|
66
|
+
def client(headers)
|
67
|
+
Elasticsearch::Client.new(
|
68
|
+
host: "https://#{HOST_URI.host}:#{HOST_URI.port}",
|
69
|
+
transport_options: TRANSPORT_OPTIONS.merge(headers: headers)
|
70
|
+
)
|
71
|
+
end
|
72
|
+
|
73
|
+
let(:manager_auth) do
|
74
|
+
{ Authorization: "Basic YXBpX2tleV9tYW5hZ2VyOngtcGFjay10ZXN0LXBhc3N3b3Jk" }
|
75
|
+
end
|
76
|
+
let(:user1_auth) do
|
77
|
+
{ Authorization: "Basic YXBpX2tleV91c2VyXzE6eC1wYWNrLXRlc3QtcGFzc3dvcmQ=" }
|
78
|
+
end
|
79
|
+
let(:user2_auth) do
|
80
|
+
{ Authorization: "Basic YXBpX2tleV91c2VyXzI6eC1wYWNrLXRlc3QtcGFzc3dvcmQ=" }
|
81
|
+
end
|
82
|
+
|
83
|
+
it 'queries api key' do
|
84
|
+
# api_key_manager authorization:
|
85
|
+
client = client(manager_auth)
|
86
|
+
response = client.security.create_api_key(
|
87
|
+
body: {
|
88
|
+
name: 'manager-api-key',
|
89
|
+
expiration: '10d',
|
90
|
+
metadata: {
|
91
|
+
letter: 'a',
|
92
|
+
number: 42
|
93
|
+
}
|
94
|
+
}
|
95
|
+
)
|
96
|
+
expect(response.status).to eq 200
|
97
|
+
manager_key_id = response['id']
|
98
|
+
|
99
|
+
# api_key_user1 authorization:
|
100
|
+
client = client(user1_auth)
|
101
|
+
response = client.security.create_api_key(
|
102
|
+
body: {
|
103
|
+
name: 'user1-api-key',
|
104
|
+
expiration: '1d',
|
105
|
+
metadata: {
|
106
|
+
letter: 'a',
|
107
|
+
number: 1
|
108
|
+
}
|
109
|
+
}
|
110
|
+
)
|
111
|
+
expect(response.status).to eq 200
|
112
|
+
user1_key_id = response['id']
|
113
|
+
|
114
|
+
# api_key_user2 authorization
|
115
|
+
client = client(user2_auth)
|
116
|
+
response = client.security.create_api_key(
|
117
|
+
body: {
|
118
|
+
name: 'user2-api-key',
|
119
|
+
expiration: '1d',
|
120
|
+
metadata: {
|
121
|
+
letter: 'b',
|
122
|
+
number: 42
|
123
|
+
}
|
124
|
+
}
|
125
|
+
)
|
126
|
+
expect(response.status).to eq 200
|
127
|
+
user1_key_id = response['id']
|
128
|
+
|
129
|
+
client = client(manager_auth)
|
130
|
+
response = client.security.query_api_keys
|
131
|
+
expect(response.status).to eq 200
|
132
|
+
manager_total = response['total']
|
133
|
+
expect(manager_total).to be >= 3
|
134
|
+
|
135
|
+
client = client(user1_auth)
|
136
|
+
response = client.security.query_api_keys
|
137
|
+
expect(response.status).to eq 200
|
138
|
+
user_1_total = response['total']
|
139
|
+
expect(user_1_total).to be >= 1
|
140
|
+
expect(user_1_total).to be < manager_total
|
141
|
+
|
142
|
+
client = client(user2_auth)
|
143
|
+
response = client.security.query_api_keys
|
144
|
+
expect(response.status).to eq 200
|
145
|
+
user_2_total = response['total']
|
146
|
+
expect(user_2_total).to be >= 1
|
147
|
+
expect(user_2_total).to be < manager_total
|
148
|
+
end
|
149
|
+
end
|
@@ -0,0 +1,120 @@
|
|
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_relative '../platinum_helper'
|
19
|
+
|
20
|
+
describe 'API keys' do
|
21
|
+
before do
|
22
|
+
ADMIN_CLIENT.security.put_role(
|
23
|
+
name: 'admin_role',
|
24
|
+
body: { cluster: ['manage_api_key'] }
|
25
|
+
)
|
26
|
+
ADMIN_CLIENT.security.put_role(
|
27
|
+
name: 'user_role',
|
28
|
+
body: {
|
29
|
+
cluster: ['manage_own_api_key'],
|
30
|
+
}
|
31
|
+
)
|
32
|
+
ADMIN_CLIENT.security.put_user(
|
33
|
+
username: 'api_key_manager',
|
34
|
+
body: {
|
35
|
+
password: 'x-pack-test-password',
|
36
|
+
roles: [ 'admin_role' ],
|
37
|
+
full_name: 'API key manager'
|
38
|
+
}
|
39
|
+
)
|
40
|
+
|
41
|
+
ADMIN_CLIENT.security.put_user(
|
42
|
+
username: 'api_key_user',
|
43
|
+
body: {
|
44
|
+
password: 'x-pack-test-password',
|
45
|
+
roles: [ 'user_role' ],
|
46
|
+
full_name: 'API key user'
|
47
|
+
}
|
48
|
+
)
|
49
|
+
end
|
50
|
+
after do
|
51
|
+
ADMIN_CLIENT.security.delete_role(name: "admin_role", ignore: 404)
|
52
|
+
ADMIN_CLIENT.security.delete_role(name: "user_role", ignore: 404)
|
53
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user", ignore: 404)
|
54
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_manager", ignore: 404)
|
55
|
+
end
|
56
|
+
|
57
|
+
def client(headers)
|
58
|
+
Elasticsearch::Client.new(
|
59
|
+
host: "https://#{HOST_URI.host}:#{HOST_URI.port}",
|
60
|
+
transport_options: TRANSPORT_OPTIONS.merge(headers: headers)
|
61
|
+
)
|
62
|
+
end
|
63
|
+
|
64
|
+
let(:manager_auth) do
|
65
|
+
{ Authorization: "Basic YXBpX2tleV9tYW5hZ2VyOngtcGFjay10ZXN0LXBhc3N3b3Jk" }
|
66
|
+
end
|
67
|
+
let(:user_auth) do
|
68
|
+
{ Authorization: "Basic YXBpX2tleV9tYW5hZ2VyOngtcGFjay10ZXN0LXBhc3N3b3Jk" }
|
69
|
+
end
|
70
|
+
|
71
|
+
it 'queries api key with args' do
|
72
|
+
# api_key_manager authorization:
|
73
|
+
client = client(manager_auth)
|
74
|
+
response = client.security.create_api_key(
|
75
|
+
body: {
|
76
|
+
name: 'manager-api-key',
|
77
|
+
expiration: '10d',
|
78
|
+
metadata: {
|
79
|
+
letter: 'a',
|
80
|
+
number: 42
|
81
|
+
}
|
82
|
+
}
|
83
|
+
)
|
84
|
+
expect(response.status).to eq 200
|
85
|
+
id = response['id']
|
86
|
+
api_key = response['api_key']
|
87
|
+
expect(response['encoded']).to eq Base64.strict_encode64("#{id}:#{api_key}")
|
88
|
+
|
89
|
+
client = client(user_auth)
|
90
|
+
response = client.security.create_api_key(
|
91
|
+
body: {
|
92
|
+
name: 'user-api-key',
|
93
|
+
expiration: '1d',
|
94
|
+
metadata: {
|
95
|
+
letter: 'a',
|
96
|
+
number: 1
|
97
|
+
}
|
98
|
+
}
|
99
|
+
)
|
100
|
+
expect(response.status).to eq 200
|
101
|
+
id = response['id']
|
102
|
+
api_key = response['api_key']
|
103
|
+
expect(response['encoded']).to eq Base64.strict_encode64("#{id}:#{api_key}")
|
104
|
+
|
105
|
+
response = client.security.query_api_keys(
|
106
|
+
body: {
|
107
|
+
size: 0,
|
108
|
+
aggs: {
|
109
|
+
my_buckets: {
|
110
|
+
composite: {
|
111
|
+
sources: [{ key_name: { terms: { field: "name" } } } ]
|
112
|
+
}
|
113
|
+
}
|
114
|
+
}
|
115
|
+
}
|
116
|
+
)
|
117
|
+
expect(response.dig('aggregations', 'my_buckets', 'buckets').find { |a| a.dig('key', 'key_name') == 'manager-api-key'})
|
118
|
+
expect(response.dig('aggregations', 'my_buckets', 'buckets').find { |a| a.dig('key', 'key_name') == 'user-api-key'})
|
119
|
+
end
|
120
|
+
end
|
@@ -0,0 +1,156 @@
|
|
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 'base64'
|
19
|
+
require_relative '../platinum_helper'
|
20
|
+
|
21
|
+
describe 'API keys' do
|
22
|
+
before do
|
23
|
+
ADMIN_CLIENT.security.put_role(
|
24
|
+
name: 'admin_role',
|
25
|
+
body: {
|
26
|
+
cluster: ['manage_api_key'],
|
27
|
+
indices: [
|
28
|
+
{
|
29
|
+
names: '*',
|
30
|
+
privileges: ['all']
|
31
|
+
}
|
32
|
+
],
|
33
|
+
applications: [
|
34
|
+
{
|
35
|
+
application: 'myapp',
|
36
|
+
privileges: ['*'],
|
37
|
+
resources: ['*']
|
38
|
+
}
|
39
|
+
]
|
40
|
+
}
|
41
|
+
)
|
42
|
+
ADMIN_CLIENT.security.put_user(
|
43
|
+
username: 'api_key_user',
|
44
|
+
body: {
|
45
|
+
password: 'test-password',
|
46
|
+
roles: [ 'admin_role' ],
|
47
|
+
full_name: 'API key user'
|
48
|
+
}
|
49
|
+
)
|
50
|
+
ADMIN_CLIENT.security.put_privileges(
|
51
|
+
body:
|
52
|
+
{
|
53
|
+
myapp: {
|
54
|
+
read: {
|
55
|
+
application: 'myapp',
|
56
|
+
name: 'read',
|
57
|
+
actions: [ 'data:read/*' ]
|
58
|
+
},
|
59
|
+
write: {
|
60
|
+
application: 'myapp',
|
61
|
+
name: 'write',
|
62
|
+
actions: [ 'data:write/*' ]
|
63
|
+
}
|
64
|
+
}
|
65
|
+
}
|
66
|
+
)
|
67
|
+
end
|
68
|
+
|
69
|
+
after do
|
70
|
+
ADMIN_CLIENT.security.delete_role(name: "admin_role", ignore: 404)
|
71
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user", ignore: 404)
|
72
|
+
ADMIN_CLIENT.security.delete_privileges(application: 'myapp', name: "read,write", ignore: 404)
|
73
|
+
end
|
74
|
+
|
75
|
+
let(:credentials) { Base64.strict_encode64("api_key_user:test-password") }
|
76
|
+
let(:client) do
|
77
|
+
Elasticsearch::Client.new(
|
78
|
+
host: HOST,
|
79
|
+
transport_options: TRANSPORT_OPTIONS.merge(headers: { Authorization: "Basic #{credentials}" })
|
80
|
+
)
|
81
|
+
end
|
82
|
+
|
83
|
+
it 'creates api key' do
|
84
|
+
response = client.security.create_api_key(
|
85
|
+
body: {
|
86
|
+
name: "my-api-key",
|
87
|
+
expiration: "1d",
|
88
|
+
role_descriptors: {
|
89
|
+
'role-a' => {
|
90
|
+
cluster: ["all"],
|
91
|
+
index: [
|
92
|
+
{
|
93
|
+
names: ["index-a"],
|
94
|
+
privileges: ["read"]
|
95
|
+
}
|
96
|
+
]
|
97
|
+
},
|
98
|
+
'role-b' => {
|
99
|
+
cluster: ["manage"],
|
100
|
+
index: [
|
101
|
+
{
|
102
|
+
names: ["index-b"],
|
103
|
+
privileges: ["all"]
|
104
|
+
}
|
105
|
+
]
|
106
|
+
}
|
107
|
+
}
|
108
|
+
}
|
109
|
+
)
|
110
|
+
expect(response['name']).to eq 'my-api-key'
|
111
|
+
id = response['id']
|
112
|
+
expect(id).not_to be nil
|
113
|
+
expect(response['api_key']).not_to be nil
|
114
|
+
expect(response['expiration']).not_to be nil
|
115
|
+
credentials = Base64.strict_encode64("#{response['id']}:#{response['api_key']}")
|
116
|
+
expect(credentials).to eq response['encoded']
|
117
|
+
new_client = Elasticsearch::Client.new(
|
118
|
+
host: "https://#{HOST_URI.host}:#{HOST_URI.port}",
|
119
|
+
transport_options: TRANSPORT_OPTIONS,
|
120
|
+
api_key: credentials
|
121
|
+
)
|
122
|
+
response = new_client.security.authenticate
|
123
|
+
expect(response['username']).to eq 'api_key_user'
|
124
|
+
expect(response['roles'].length).to eq 0
|
125
|
+
expect(response['authentication_realm']['name']).to eq '_es_api_key'
|
126
|
+
expect(response['authentication_realm']['type']).to eq '_es_api_key'
|
127
|
+
expect(response['api_key']['id']).to eq id
|
128
|
+
expect(response['api_key']['name']).to eq 'my-api-key'
|
129
|
+
response = ADMIN_CLIENT.security.clear_api_key_cache(ids: id)
|
130
|
+
expect(response['_nodes']['failed']).to eq 0
|
131
|
+
end
|
132
|
+
|
133
|
+
context 'Test get api key' do
|
134
|
+
let(:name) { 'my-api-key-2'}
|
135
|
+
|
136
|
+
it 'gets api key' do
|
137
|
+
response = ADMIN_CLIENT.security.create_api_key(
|
138
|
+
body: { name: name, expiration: '1d' }
|
139
|
+
)
|
140
|
+
expect(response['name']).to eq name
|
141
|
+
id = response['id']
|
142
|
+
expect(id).not_to be nil
|
143
|
+
expect(response['api_key']).not_to be nil
|
144
|
+
expect(response['expiration']).not_to be nil
|
145
|
+
|
146
|
+
response = ADMIN_CLIENT.security.get_api_key(id: id)
|
147
|
+
expect(response['api_keys'].first['id']).to eq id
|
148
|
+
expect(response['api_keys'].first['name']).to eq name
|
149
|
+
expect(response['api_keys'].first['username']).to eq 'elastic'
|
150
|
+
expect(response['api_keys'].first['invalidated']).to eq false
|
151
|
+
expect(response['api_keys'].first['creation']).not_to be nil
|
152
|
+
response = ADMIN_CLIENT.security.get_api_key(owner: true)
|
153
|
+
expect(response['api_keys'].length).to be > 0
|
154
|
+
end
|
155
|
+
end
|
156
|
+
end
|
@@ -0,0 +1,134 @@
|
|
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 'base64'
|
19
|
+
require_relative '../platinum_helper'
|
20
|
+
|
21
|
+
describe 'API keys API' do
|
22
|
+
before do
|
23
|
+
ADMIN_CLIENT.security.put_role(
|
24
|
+
name: 'user_role',
|
25
|
+
body: {
|
26
|
+
cluster: ['manage_own_api_key'],
|
27
|
+
indices: [
|
28
|
+
{
|
29
|
+
names: '*',
|
30
|
+
privileges: ['all']
|
31
|
+
}
|
32
|
+
]
|
33
|
+
}
|
34
|
+
)
|
35
|
+
ADMIN_CLIENT.security.put_user(
|
36
|
+
username: 'api_key_user_1',
|
37
|
+
body: {
|
38
|
+
password: 'x-pack-test-password',
|
39
|
+
roles: [ 'user_role' ],
|
40
|
+
full_name: 'API key user 1'
|
41
|
+
}
|
42
|
+
)
|
43
|
+
end
|
44
|
+
|
45
|
+
after do
|
46
|
+
ADMIN_CLIENT.security.delete_role(name: "user_role", ignore: 404)
|
47
|
+
ADMIN_CLIENT.security.delete_user(username: "api_key_user_1", ignore: 404)
|
48
|
+
end
|
49
|
+
|
50
|
+
let(:client) do
|
51
|
+
Elasticsearch::Client.new(
|
52
|
+
host: "https://#{HOST_URI.host}:#{HOST_URI.port}",
|
53
|
+
transport_options: TRANSPORT_OPTIONS.merge(
|
54
|
+
headers: { Authorization: "Basic YXBpX2tleV91c2VyXzE6eC1wYWNrLXRlc3QtcGFzc3dvcmQ=" }
|
55
|
+
)
|
56
|
+
)
|
57
|
+
end
|
58
|
+
|
59
|
+
it 'updates api key' do
|
60
|
+
response = client.security.create_api_key(
|
61
|
+
body: {
|
62
|
+
name: 'user1-api-key',
|
63
|
+
role_descriptors: {
|
64
|
+
"role-a" => {
|
65
|
+
cluster: ["none"],
|
66
|
+
index: [
|
67
|
+
{
|
68
|
+
names: ["index-a"],
|
69
|
+
privileges: ["read"]
|
70
|
+
}
|
71
|
+
]
|
72
|
+
}
|
73
|
+
}
|
74
|
+
}
|
75
|
+
)
|
76
|
+
expect(response.status).to eq 200
|
77
|
+
expect(response['name']).to eq 'user1-api-key'
|
78
|
+
id = response['id']
|
79
|
+
expect(id).not_to be nil
|
80
|
+
expect(response['api_key']).not_to be nil
|
81
|
+
credentials = Base64.strict_encode64("#{response['id']}:#{response['api_key']}")
|
82
|
+
expect(credentials).to eq response['encoded']
|
83
|
+
|
84
|
+
new_client = Elasticsearch::Client.new(
|
85
|
+
host: "https://#{HOST_URI.host}:#{HOST_URI.port}",
|
86
|
+
transport_options: TRANSPORT_OPTIONS,
|
87
|
+
api_key: credentials
|
88
|
+
)
|
89
|
+
privileges_body = {
|
90
|
+
cluster: ['manage_own_api_key'],
|
91
|
+
index: [
|
92
|
+
{
|
93
|
+
names: ['index-a'],
|
94
|
+
privileges: ['write']
|
95
|
+
},
|
96
|
+
{
|
97
|
+
names: ['index-b'],
|
98
|
+
privileges: ['read']
|
99
|
+
}
|
100
|
+
]
|
101
|
+
}
|
102
|
+
response = new_client.security.has_privileges(body: privileges_body)
|
103
|
+
expect(response['has_all_requested']).to eq false
|
104
|
+
|
105
|
+
response = client.security.update_api_key(
|
106
|
+
id: id,
|
107
|
+
body: {
|
108
|
+
role_descriptors: {
|
109
|
+
"role-a" => {
|
110
|
+
cluster: ["all"],
|
111
|
+
index: [
|
112
|
+
{
|
113
|
+
names: ["index-a"],
|
114
|
+
privileges: ["write"]
|
115
|
+
},
|
116
|
+
{
|
117
|
+
names: ["index-b"],
|
118
|
+
privileges: ["read"]
|
119
|
+
}
|
120
|
+
]
|
121
|
+
}
|
122
|
+
},
|
123
|
+
metadata: {
|
124
|
+
letter: "a",
|
125
|
+
number: 42
|
126
|
+
}
|
127
|
+
}
|
128
|
+
)
|
129
|
+
expect(response['updated']).to eq true
|
130
|
+
|
131
|
+
response = new_client.security.has_privileges(user: nil, body: privileges_body)
|
132
|
+
expect(response['has_all_requested']).to eq true
|
133
|
+
end
|
134
|
+
end
|