opensearch-ruby 2.0.3 → 3.4.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
- checksums.yaml.gz.sig +0 -0
- data/README.md +80 -46
- data/USER_GUIDE.md +149 -0
- data/bin/opensearch_ruby_console +4 -34
- data/lib/opensearch/api/actions/abort_benchmark.rb +49 -0
- data/lib/opensearch/api/actions/benchmark.rb +88 -0
- data/lib/opensearch/api/actions/bulk.rb +91 -0
- data/lib/opensearch/api/actions/cat/aliases.rb +79 -0
- data/lib/opensearch/api/actions/cat/all_pit_segments.rb +45 -0
- data/lib/opensearch/api/actions/cat/allocation.rb +83 -0
- data/lib/opensearch/api/actions/cat/cluster_manager.rb +54 -0
- data/lib/opensearch/api/actions/cat/count.rb +75 -0
- data/lib/opensearch/api/actions/cat/fielddata.rb +77 -0
- data/lib/opensearch/api/actions/cat/health.rb +72 -0
- data/lib/opensearch/api/actions/cat/help.rb +61 -0
- data/lib/opensearch/api/actions/cat/indices.rb +93 -0
- data/lib/opensearch/api/actions/cat/master.rb +73 -0
- data/lib/opensearch/api/actions/cat/nodeattrs.rb +73 -0
- data/lib/opensearch/api/actions/cat/nodes.rb +82 -0
- data/lib/opensearch/api/actions/cat/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/cat/pending_tasks.rb +76 -0
- data/lib/opensearch/api/actions/cat/pit_segments.rb +48 -0
- data/lib/opensearch/api/actions/cat/plugins.rb +75 -0
- data/lib/opensearch/api/actions/cat/recovery.rb +84 -0
- data/lib/opensearch/api/actions/cat/repositories.rb +73 -0
- data/lib/opensearch/api/actions/cat/segments.rb +76 -0
- data/lib/opensearch/api/actions/cat/shards.rb +85 -0
- data/lib/opensearch/api/actions/cat/snapshots.rb +82 -0
- data/lib/opensearch/api/actions/cat/tasks.rb +77 -0
- data/lib/opensearch/api/actions/cat/templates.rb +80 -0
- data/lib/opensearch/api/actions/cat/thread_pool.rb +84 -0
- data/lib/opensearch/api/actions/clear_scroll.rb +62 -0
- data/lib/opensearch/api/actions/cluster/allocation_explain.rb +67 -0
- data/lib/opensearch/api/actions/cluster/delete_component_template.rb +68 -0
- data/lib/opensearch/api/actions/cluster/delete_voting_config_exclusions.rb +59 -0
- data/lib/opensearch/api/actions/cluster/exists_component_template.rb +70 -0
- data/lib/opensearch/api/actions/cluster/get_component_template.rb +70 -0
- data/lib/opensearch/api/actions/cluster/get_settings.rb +67 -0
- data/lib/opensearch/api/actions/cluster/health.rb +88 -0
- data/lib/opensearch/api/actions/cluster/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/cluster/pending_tasks.rb +64 -0
- data/lib/opensearch/api/actions/cluster/post_voting_config_exclusions.rb +63 -0
- data/lib/opensearch/api/actions/cluster/put_component_template.rb +72 -0
- data/lib/opensearch/api/actions/cluster/put_settings.rb +68 -0
- data/{spec/unit/wrapper_gem_spec.rb → lib/opensearch/api/actions/cluster/remote_info.rb} +20 -17
- data/lib/opensearch/api/actions/cluster/reroute.rb +72 -0
- data/lib/opensearch/api/actions/cluster/state.rb +87 -0
- data/lib/opensearch/api/actions/cluster/stats.rb +68 -0
- data/lib/opensearch/api/actions/count.rb +96 -0
- data/lib/opensearch/api/actions/create.rb +60 -0
- data/lib/opensearch/api/actions/create_pit.rb +45 -0
- data/lib/opensearch/api/actions/dangling_indices/delete_dangling_index.rb +70 -0
- data/lib/opensearch/api/actions/dangling_indices/import_dangling_index.rb +69 -0
- data/lib/opensearch/api/actions/dangling_indices/list_dangling_indices.rb +51 -0
- data/lib/opensearch/api/actions/dangling_indices/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/delete.rb +89 -0
- data/lib/opensearch/api/actions/delete_all_pits.rb +26 -0
- data/lib/opensearch/api/actions/delete_by_query.rb +133 -0
- data/lib/opensearch/api/actions/delete_by_query_rethrottle.rb +62 -0
- data/lib/opensearch/api/actions/delete_pit.rb +30 -0
- data/lib/opensearch/api/actions/delete_script.rb +66 -0
- data/lib/opensearch/api/actions/exists.rb +94 -0
- data/lib/opensearch/api/actions/exists_source.rb +89 -0
- data/lib/opensearch/api/actions/explain.rb +99 -0
- data/lib/opensearch/api/actions/features/get_features.rb +61 -0
- data/lib/opensearch/api/actions/features/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/features/reset_features.rb +55 -0
- data/lib/opensearch/api/actions/field_caps.rb +78 -0
- data/lib/opensearch/api/actions/get.rb +93 -0
- data/lib/opensearch/api/actions/get_all_pits.rb +26 -0
- data/lib/opensearch/api/actions/get_script.rb +64 -0
- data/lib/opensearch/api/actions/get_script_context.rb +53 -0
- data/lib/opensearch/api/actions/get_script_languages.rb +53 -0
- data/lib/opensearch/api/actions/get_source.rb +87 -0
- data/lib/opensearch/api/actions/http/connect.rb +28 -0
- data/lib/opensearch/api/actions/http/delete.rb +28 -0
- data/lib/opensearch/api/actions/http/get.rb +28 -0
- data/lib/opensearch/api/actions/http/head.rb +28 -0
- data/lib/opensearch/api/actions/http/options.rb +28 -0
- data/lib/opensearch/api/actions/http/patch.rb +28 -0
- data/lib/opensearch/api/actions/http/post.rb +28 -0
- data/lib/opensearch/api/actions/http/put.rb +28 -0
- data/lib/opensearch/api/actions/http/request.rb +27 -0
- data/lib/opensearch/api/actions/http/trace.rb +28 -0
- data/lib/opensearch/api/actions/index.rb +96 -0
- data/lib/opensearch/api/actions/indices/add_block.rb +78 -0
- data/lib/opensearch/api/actions/indices/analyze.rb +71 -0
- data/lib/opensearch/api/actions/indices/clear_cache.rb +79 -0
- data/lib/opensearch/api/actions/indices/clone.rb +75 -0
- data/lib/opensearch/api/actions/indices/close.rb +76 -0
- data/lib/opensearch/api/actions/indices/create.rb +71 -0
- data/lib/opensearch/api/actions/indices/delete.rb +78 -0
- data/lib/opensearch/api/actions/indices/delete_alias.rb +72 -0
- data/lib/opensearch/api/actions/indices/delete_index_template.rb +68 -0
- data/lib/opensearch/api/actions/indices/delete_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/disk_usage.rb +76 -0
- data/lib/opensearch/api/actions/indices/exists.rb +79 -0
- data/lib/opensearch/api/actions/indices/exists_alias.rb +82 -0
- data/lib/opensearch/api/actions/indices/exists_index_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/exists_template.rb +75 -0
- data/lib/opensearch/api/actions/indices/field_usage_stats.rb +74 -0
- data/lib/opensearch/api/actions/indices/flush.rb +74 -0
- data/lib/opensearch/api/actions/indices/forcemerge.rb +76 -0
- data/lib/opensearch/api/actions/indices/get.rb +78 -0
- data/lib/opensearch/api/actions/indices/get_alias.rb +79 -0
- data/lib/opensearch/api/actions/indices/get_field_mapping.rb +83 -0
- data/lib/opensearch/api/actions/indices/get_index_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/get_mapping.rb +81 -0
- data/lib/opensearch/api/actions/indices/get_settings.rb +87 -0
- data/lib/opensearch/api/actions/indices/get_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/get_upgrade.rb +75 -0
- data/lib/opensearch/api/actions/indices/open.rb +76 -0
- data/lib/opensearch/api/actions/indices/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/indices/put_alias.rb +73 -0
- data/lib/opensearch/api/actions/indices/put_index_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/put_mapping.rb +82 -0
- data/lib/opensearch/api/actions/indices/put_settings.rb +83 -0
- data/lib/opensearch/api/actions/indices/put_template.rb +72 -0
- data/lib/opensearch/api/actions/indices/recovery.rb +68 -0
- data/lib/opensearch/api/actions/indices/refresh.rb +70 -0
- data/lib/opensearch/api/actions/indices/resolve_index.rb +68 -0
- data/lib/opensearch/api/actions/indices/rollover.rb +81 -0
- data/lib/opensearch/api/actions/indices/segments.rb +72 -0
- data/lib/opensearch/api/actions/indices/shard_stores.rb +72 -0
- data/lib/opensearch/api/actions/indices/shrink.rb +77 -0
- data/lib/opensearch/api/actions/indices/simulate_index_template.rb +71 -0
- data/lib/opensearch/api/actions/indices/simulate_template.rb +73 -0
- data/lib/opensearch/api/actions/indices/split.rb +77 -0
- data/lib/opensearch/api/actions/indices/stats.rb +100 -0
- data/lib/opensearch/api/actions/indices/update_aliases.rb +66 -0
- data/lib/opensearch/api/actions/indices/upgrade.rb +79 -0
- data/lib/opensearch/api/actions/indices/validate_query.rb +99 -0
- data/{Gemfile → lib/opensearch/api/actions/info.rb} +19 -8
- data/lib/opensearch/api/actions/ingest/delete_pipeline.rb +68 -0
- data/lib/opensearch/api/actions/ingest/geo_ip_stats.rb +51 -0
- data/lib/opensearch/api/actions/ingest/get_pipeline.rb +70 -0
- data/lib/opensearch/api/actions/ingest/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/ingest/processor_grok.rb +51 -0
- data/lib/opensearch/api/actions/ingest/put_pipeline.rb +70 -0
- data/lib/opensearch/api/actions/ingest/simulate.rb +69 -0
- data/lib/opensearch/api/actions/mget.rb +86 -0
- data/lib/opensearch/api/actions/msearch.rb +105 -0
- data/lib/opensearch/api/actions/msearch_template.rb +89 -0
- data/lib/opensearch/api/actions/mtermvectors.rb +102 -0
- data/lib/opensearch/api/actions/nodes/hot_threads.rb +81 -0
- data/lib/opensearch/api/actions/nodes/info.rb +75 -0
- data/lib/opensearch/api/actions/nodes/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/nodes/reload_secure_settings.rb +67 -0
- data/lib/opensearch/api/actions/nodes/shutdown.rb +65 -0
- data/lib/opensearch/api/actions/nodes/stats.rb +96 -0
- data/lib/opensearch/api/actions/nodes/usage.rb +73 -0
- data/lib/opensearch/api/actions/params_registry.rb +67 -0
- data/lib/opensearch/api/actions/ping.rb +54 -0
- data/lib/opensearch/api/actions/put_script.rb +76 -0
- data/lib/opensearch/api/actions/rank_eval.rb +77 -0
- data/lib/opensearch/api/actions/reindex.rb +76 -0
- data/lib/opensearch/api/actions/reindex_rethrottle.rb +62 -0
- data/{spec/integration/security_disabled/validation_integration_spec.rb → lib/opensearch/api/actions/remote/info.rb} +17 -11
- data/lib/opensearch/api/actions/remote_store/restore.rb +43 -0
- data/lib/opensearch/api/actions/render_search_template.rb +62 -0
- data/lib/opensearch/api/actions/scripts_painless_execute.rb +59 -0
- data/lib/opensearch/api/actions/scroll.rb +78 -0
- data/lib/opensearch/api/actions/search.rb +161 -0
- data/lib/opensearch/api/actions/search_shards.rb +74 -0
- data/lib/opensearch/api/actions/search_template.rb +96 -0
- data/lib/opensearch/api/actions/security/change_password.rb +39 -0
- data/lib/opensearch/api/actions/security/create_action_group.rb +42 -0
- data/lib/opensearch/api/actions/security/create_role.rb +43 -0
- data/lib/opensearch/api/actions/security/create_role_mapping.rb +43 -0
- data/lib/opensearch/api/actions/security/create_tenant.rb +42 -0
- data/lib/opensearch/api/actions/security/create_user.rb +43 -0
- data/lib/opensearch/api/actions/security/delete_action_group.rb +41 -0
- data/lib/opensearch/api/actions/security/delete_distinguished_names.rb +41 -0
- data/lib/opensearch/api/actions/security/delete_role.rb +41 -0
- data/lib/opensearch/api/actions/security/delete_role_mapping.rb +41 -0
- data/lib/opensearch/api/actions/security/delete_tenant.rb +41 -0
- data/lib/opensearch/api/actions/security/delete_user.rb +41 -0
- data/lib/opensearch/api/actions/security/flush_cache.rb +36 -0
- data/lib/opensearch/api/actions/security/get_account_details.rb +36 -0
- data/lib/opensearch/api/actions/security/get_action_group.rb +41 -0
- data/lib/opensearch/api/actions/security/get_action_groups.rb +36 -0
- data/lib/opensearch/api/actions/security/get_audit_configuration.rb +36 -0
- data/lib/opensearch/api/actions/security/get_certificates.rb +36 -0
- data/lib/opensearch/api/actions/security/get_configuration.rb +36 -0
- data/lib/opensearch/api/actions/security/get_distinguished_names.rb +39 -0
- data/lib/opensearch/api/actions/security/get_role.rb +41 -0
- data/lib/opensearch/api/actions/security/get_role_mapping.rb +41 -0
- data/lib/opensearch/api/actions/security/get_role_mappings.rb +36 -0
- data/lib/opensearch/api/actions/security/get_roles.rb +36 -0
- data/lib/opensearch/api/actions/security/get_tenant.rb +41 -0
- data/lib/opensearch/api/actions/security/get_tenants.rb +36 -0
- data/lib/opensearch/api/actions/security/get_user.rb +41 -0
- data/lib/opensearch/api/actions/security/get_users.rb +36 -0
- data/lib/opensearch/api/actions/security/health.rb +36 -0
- data/lib/opensearch/api/actions/security/patch_action_group.rb +42 -0
- data/lib/opensearch/api/actions/security/patch_action_groups.rb +37 -0
- data/lib/opensearch/api/actions/security/patch_audit_configuration.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_configuration.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_distinguished_names.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_role.rb +43 -0
- data/lib/opensearch/api/actions/security/patch_role_mapping.rb +43 -0
- data/lib/opensearch/api/actions/security/patch_role_mappings.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_roles.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_tenant.rb +43 -0
- data/lib/opensearch/api/actions/security/patch_tenants.rb +39 -0
- data/lib/opensearch/api/actions/security/patch_user.rb +43 -0
- data/lib/opensearch/api/actions/security/patch_users.rb +39 -0
- data/lib/opensearch/api/actions/security/reload_http_certificates.rb +36 -0
- data/lib/opensearch/api/actions/security/reload_transport_certificates.rb +36 -0
- data/lib/opensearch/api/actions/security/update_audit_configuration.rb +39 -0
- data/lib/opensearch/api/actions/security/update_configuration.rb +39 -0
- data/lib/opensearch/api/actions/security/update_distinguished_names.rb +42 -0
- data/lib/opensearch/api/actions/shutdown/delete_node.rb +60 -0
- data/lib/opensearch/api/actions/shutdown/get_node.rb +62 -0
- data/lib/opensearch/api/actions/shutdown/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/shutdown/put_node.rb +62 -0
- data/lib/opensearch/api/actions/snapshot/cleanup_repository.rb +68 -0
- data/lib/opensearch/api/actions/snapshot/clone.rb +76 -0
- data/lib/opensearch/api/actions/snapshot/create.rb +73 -0
- data/lib/opensearch/api/actions/snapshot/create_repository.rb +72 -0
- data/lib/opensearch/api/actions/snapshot/delete.rb +74 -0
- data/lib/opensearch/api/actions/snapshot/delete_repository.rb +72 -0
- data/lib/opensearch/api/actions/snapshot/get.rb +82 -0
- data/lib/opensearch/api/actions/snapshot/get_features.rb +61 -0
- data/lib/opensearch/api/actions/snapshot/get_repository.rb +73 -0
- data/lib/opensearch/api/actions/snapshot/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/snapshot/repository_analyze.rb +84 -0
- data/lib/opensearch/api/actions/snapshot/restore.rb +73 -0
- data/lib/opensearch/api/actions/snapshot/status.rb +79 -0
- data/lib/opensearch/api/actions/snapshot/verify_repository.rb +68 -0
- data/lib/opensearch/api/actions/tasks/cancel.rb +76 -0
- data/lib/opensearch/api/actions/tasks/get.rb +68 -0
- data/lib/opensearch/api/actions/tasks/list.rb +75 -0
- data/lib/opensearch/api/actions/tasks/params_registry.rb +69 -0
- data/lib/opensearch/api/actions/termvectors.rb +108 -0
- data/lib/opensearch/api/actions/update.rb +99 -0
- data/lib/opensearch/api/actions/update_by_query.rb +137 -0
- data/lib/opensearch/api/actions/update_by_query_rethrottle.rb +62 -0
- data/{spec/integration/security_enabled/validation_integration_spec.rb → lib/opensearch/api/namespace/cat.rb} +19 -12
- data/lib/opensearch/api/namespace/cluster.rb +47 -0
- data/lib/opensearch/api/namespace/common.rb +72 -0
- data/lib/opensearch/api/namespace/dangling_indices.rb +47 -0
- data/lib/opensearch/api/namespace/features.rb +47 -0
- data/lib/opensearch/api/namespace/http.rb +30 -0
- data/lib/opensearch/api/namespace/indices.rb +47 -0
- data/lib/opensearch/api/namespace/ingest.rb +47 -0
- data/lib/opensearch/api/namespace/nodes.rb +47 -0
- data/lib/opensearch/api/namespace/remote.rb +47 -0
- data/lib/opensearch/api/namespace/remote_store.rb +30 -0
- data/lib/opensearch/api/namespace/security.rb +30 -0
- data/lib/opensearch/api/namespace/shutdown.rb +47 -0
- data/lib/opensearch/api/namespace/snapshot.rb +47 -0
- data/lib/opensearch/api/namespace/tasks.rb +47 -0
- data/lib/opensearch/api/utils.rb +296 -0
- data/lib/opensearch/api.rb +104 -0
- data/lib/opensearch/dsl/search/aggregation.rb +112 -0
- data/lib/opensearch/dsl/search/aggregations/avg.rb +49 -0
- data/lib/opensearch/dsl/search/aggregations/cardinality.rb +56 -0
- data/lib/opensearch/dsl/search/aggregations/children.rb +63 -0
- data/lib/opensearch/dsl/search/aggregations/composite.rb +68 -0
- data/lib/opensearch/dsl/search/aggregations/date_histogram.rb +64 -0
- data/lib/opensearch/dsl/search/aggregations/date_range.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/extended_stats.rb +48 -0
- data/lib/opensearch/dsl/search/aggregations/filter.rb +54 -0
- data/lib/opensearch/dsl/search/aggregations/filters.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/geo_bounds.rb +68 -0
- data/lib/opensearch/dsl/search/aggregations/geo_distance.rb +63 -0
- data/lib/opensearch/dsl/search/aggregations/geohash_grid.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/global.rb +52 -0
- data/{spec/integration/security_disabled/client_integration_spec.rb → lib/opensearch/dsl/search/aggregations/histogram.rb} +29 -29
- data/lib/opensearch/dsl/search/aggregations/ip_range.rb +55 -0
- data/lib/opensearch/dsl/search/aggregations/max.rb +49 -0
- data/lib/opensearch/dsl/search/aggregations/min.rb +49 -0
- data/lib/opensearch/dsl/search/aggregations/missing.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/nested.rb +57 -0
- data/lib/opensearch/dsl/search/aggregations/percentile_ranks.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/percentiles.rb +57 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/avg_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/bucket_script.rb +60 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/bucket_selector.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/bucket_sort.rb +111 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/cumulative_sum.rb +57 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/derivative.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/extended_stats_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/max_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/min_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/moving_avg.rb +66 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/percentiles_bucket.rb +60 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/serial_diff.rb +60 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/stats_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/pipeline/sum_bucket.rb +58 -0
- data/lib/opensearch/dsl/search/aggregations/range.rb +77 -0
- data/lib/opensearch/dsl/search/aggregations/reverse_nested.rb +61 -0
- data/lib/opensearch/dsl/search/aggregations/scripted_metric.rb +63 -0
- data/lib/opensearch/dsl/search/aggregations/significant_terms.rb +69 -0
- data/lib/opensearch/dsl/search/aggregations/stats.rb +61 -0
- data/lib/opensearch/dsl/search/aggregations/sum.rb +49 -0
- data/lib/opensearch/dsl/search/aggregations/terms.rb +66 -0
- data/lib/opensearch/dsl/search/aggregations/top_hits.rb +59 -0
- data/lib/opensearch/dsl/search/aggregations/value_count.rb +49 -0
- data/lib/opensearch/dsl/search/base_aggregation_component.rb +83 -0
- data/lib/opensearch/dsl/search/base_component.rb +191 -0
- data/lib/opensearch/dsl/search/base_compound_filter_component.rb +124 -0
- data/lib/opensearch/dsl/search/filter.rb +82 -0
- data/lib/opensearch/dsl/search/filters/and.rb +70 -0
- data/lib/opensearch/dsl/search/filters/bool.rb +103 -0
- data/lib/opensearch/dsl/search/filters/exists.rb +56 -0
- data/lib/opensearch/dsl/search/filters/geo_bounding_box.rb +69 -0
- data/lib/opensearch/dsl/search/filters/geo_distance.rb +81 -0
- data/lib/opensearch/dsl/search/filters/geo_distance_range.rb +56 -0
- data/lib/opensearch/dsl/search/filters/geo_polygon.rb +65 -0
- data/lib/opensearch/dsl/search/filters/geo_shape.rb +59 -0
- data/lib/opensearch/dsl/search/filters/geohash_cell.rb +71 -0
- data/lib/opensearch/dsl/search/filters/has_child.rb +98 -0
- data/lib/opensearch/dsl/search/filters/has_parent.rb +97 -0
- data/lib/opensearch/dsl/search/filters/ids.rb +56 -0
- data/lib/opensearch/dsl/search/filters/indices.rb +101 -0
- data/lib/opensearch/dsl/search/filters/limit.rb +55 -0
- data/lib/opensearch/dsl/search/filters/match_all.rb +52 -0
- data/lib/opensearch/dsl/search/filters/missing.rb +58 -0
- data/lib/opensearch/dsl/search/filters/nested.rb +91 -0
- data/lib/opensearch/dsl/search/filters/not.rb +98 -0
- data/lib/opensearch/dsl/search/filters/or.rb +70 -0
- data/lib/opensearch/dsl/search/filters/prefix.rb +53 -0
- data/lib/opensearch/dsl/search/filters/query.rb +77 -0
- data/lib/opensearch/dsl/search/filters/range.rb +63 -0
- data/lib/opensearch/dsl/search/filters/regexp.rb +58 -0
- data/lib/opensearch/dsl/search/filters/script.rb +56 -0
- data/lib/opensearch/dsl/search/filters/term.rb +55 -0
- data/lib/opensearch/dsl/search/filters/terms.rb +56 -0
- data/lib/opensearch/dsl/search/filters/type.rb +58 -0
- data/lib/opensearch/dsl/search/highlight.rb +117 -0
- data/lib/opensearch/dsl/search/options.rb +80 -0
- data/lib/opensearch/dsl/search/queries/bool.rb +110 -0
- data/lib/opensearch/dsl/search/queries/boosting.rb +57 -0
- data/lib/opensearch/dsl/search/queries/common.rb +62 -0
- data/lib/opensearch/dsl/search/queries/constant_score.rb +90 -0
- data/lib/opensearch/dsl/search/queries/dis_max.rb +59 -0
- data/lib/opensearch/dsl/search/queries/exists.rb +68 -0
- data/lib/opensearch/dsl/search/queries/filtered.rb +101 -0
- data/lib/opensearch/dsl/search/queries/function_score.rb +122 -0
- data/lib/opensearch/dsl/search/queries/fuzzy.rb +69 -0
- data/lib/opensearch/dsl/search/queries/fuzzy_like_this.rb +61 -0
- data/lib/opensearch/dsl/search/queries/fuzzy_like_this_field.rb +60 -0
- data/lib/opensearch/dsl/search/queries/geo_shape.rb +54 -0
- data/lib/opensearch/dsl/search/queries/has_child.rb +82 -0
- data/lib/opensearch/dsl/search/queries/has_parent.rb +82 -0
- data/lib/opensearch/dsl/search/queries/ids.rb +52 -0
- data/lib/opensearch/dsl/search/queries/indices.rb +58 -0
- data/lib/opensearch/dsl/search/queries/match.rb +66 -0
- data/lib/opensearch/dsl/search/queries/match_all.rb +50 -0
- data/lib/opensearch/dsl/search/queries/match_phrase.rb +56 -0
- data/lib/opensearch/dsl/search/queries/match_phrase_prefix.rb +55 -0
- data/lib/opensearch/dsl/search/queries/more_like_this.rb +88 -0
- data/lib/opensearch/dsl/search/queries/multi_match.rb +69 -0
- data/lib/opensearch/dsl/search/queries/nested.rb +80 -0
- data/lib/opensearch/dsl/search/queries/prefix.rb +54 -0
- data/lib/opensearch/dsl/search/queries/query_string.rb +75 -0
- data/lib/opensearch/dsl/search/queries/range.rb +71 -0
- data/lib/opensearch/dsl/search/queries/regexp.rb +55 -0
- data/lib/opensearch/dsl/search/queries/script_score.rb +62 -0
- data/lib/opensearch/dsl/search/queries/simple_query_string.rb +64 -0
- data/lib/opensearch/dsl/search/queries/span_first.rb +52 -0
- data/lib/opensearch/dsl/search/queries/span_multi.rb +52 -0
- data/lib/opensearch/dsl/search/queries/span_near.rb +56 -0
- data/lib/opensearch/dsl/search/queries/span_not.rb +57 -0
- data/lib/opensearch/dsl/search/queries/span_or.rb +52 -0
- data/lib/opensearch/dsl/search/queries/span_term.rb +50 -0
- data/lib/opensearch/dsl/search/queries/template.rb +55 -0
- data/lib/opensearch/dsl/search/queries/term.rb +50 -0
- data/lib/opensearch/dsl/search/queries/terms.rb +51 -0
- data/lib/opensearch/dsl/search/queries/top_children.rb +82 -0
- data/lib/opensearch/dsl/search/queries/wildcard.rb +54 -0
- data/lib/opensearch/dsl/search/query.rb +82 -0
- data/lib/opensearch/dsl/search/sort.rb +83 -0
- data/lib/opensearch/dsl/search/suggest.rb +52 -0
- data/lib/opensearch/dsl/search.rb +282 -0
- data/lib/opensearch/dsl/utils.rb +49 -0
- data/lib/opensearch/dsl.rb +69 -0
- data/lib/opensearch/transport/client.rb +362 -0
- data/lib/opensearch/transport/redacted.rb +82 -0
- data/lib/opensearch/transport/transport/base.rb +451 -0
- data/lib/opensearch/transport/transport/connections/collection.rb +134 -0
- data/lib/opensearch/transport/transport/connections/connection.rb +168 -0
- data/lib/opensearch/transport/transport/connections/selector.rb +100 -0
- data/lib/opensearch/transport/transport/errors.rb +97 -0
- data/lib/opensearch/transport/transport/http/curb.rb +139 -0
- data/lib/opensearch/transport/transport/http/faraday.rb +101 -0
- data/lib/opensearch/transport/transport/http/manticore.rb +188 -0
- data/lib/opensearch/transport/transport/loggable.rb +92 -0
- data/lib/opensearch/transport/transport/response.rb +47 -0
- data/lib/opensearch/transport/transport/serializer/multi_json.rb +61 -0
- data/lib/opensearch/transport/transport/sniffer.rb +110 -0
- data/lib/opensearch/transport.rb +44 -0
- data/lib/opensearch/version.rb +1 -1
- data/lib/opensearch-dsl.rb +27 -0
- data/lib/opensearch.rb +12 -12
- data/opensearch-ruby.gemspec +69 -0
- data/spec/spec_helper.rb +95 -4
- data/test/dsl/integration/search_aggregation_children_test.rb +91 -0
- data/test/dsl/integration/search_aggregation_geo_test.rb +112 -0
- data/test/dsl/integration/search_aggregation_nested_test.rb +129 -0
- data/test/dsl/integration/search_aggregations_test.rb +288 -0
- data/test/dsl/integration/search_filters_test.rb +290 -0
- data/test/dsl/integration/search_options_test.rb +54 -0
- data/test/dsl/integration/search_query_test.rb +98 -0
- data/test/dsl/integration/search_size_from_test.rb +71 -0
- data/test/dsl/integration/search_sort_test.rb +57 -0
- data/test/dsl/integration/search_suggest_test.rb +107 -0
- data/test/dsl/integration/search_test.rb +81 -0
- data/test/dsl/test_helper.rb +95 -0
- data/test/dsl/unit/dsl_test.rb +44 -0
- data/test/dsl/unit/search_aggregation_test.rb +96 -0
- data/test/dsl/unit/search_base_aggregation_component_test.rb +66 -0
- data/test/dsl/unit/search_base_component_test.rb +210 -0
- data/test/dsl/unit/search_filter_test.rb +84 -0
- data/test/dsl/unit/search_highlight_test.rb +103 -0
- data/test/dsl/unit/search_options_test.rb +114 -0
- data/test/dsl/unit/search_query_test.rb +88 -0
- data/test/dsl/unit/search_size_from_test.rb +68 -0
- data/test/dsl/unit/search_sort_test.rb +91 -0
- data/test/dsl/unit/search_suggest_test.rb +46 -0
- data/test/dsl/unit/search_test.rb +268 -0
- data/test/dsl/unit/utils_test.rb +47 -0
- data/test/transport/integration/transport_test.rb +117 -0
- data/test/transport/profile/client_benchmark_test.rb +141 -0
- data/test/transport/test_helper.rb +97 -0
- data/test/transport/unit/connection_test.rb +145 -0
- data/test/transport/unit/response_test.rb +46 -0
- data/test/transport/unit/serializer_test.rb +42 -0
- data/test/transport/unit/transport_base_test.rb +673 -0
- data/test/transport/unit/transport_curb_test.rb +143 -0
- data/test/transport/unit/transport_faraday_test.rb +237 -0
- data/test/transport/unit/transport_manticore_test.rb +191 -0
- data.tar.gz.sig +0 -0
- metadata +502 -191
- metadata.gz.sig +0 -0
- data/.gitignore +0 -21
- data/Rakefile +0 -69
- data/opensearch.gemspec +0 -81
- data/spec/integration/security_enabled/client_integration_spec.rb +0 -43
- data/spec/unit/opensearch_product_validation_spec.rb +0 -198
- /data/{LICENSE → LICENSE.txt} +0 -0
@@ -0,0 +1,49 @@
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
2
|
+
#
|
3
|
+
# The OpenSearch Contributors require contributions made to
|
4
|
+
# this file be licensed under the Apache-2.0 license or a
|
5
|
+
# compatible open source license.
|
6
|
+
#
|
7
|
+
# Modifications Copyright OpenSearch Contributors. See
|
8
|
+
# GitHub history for details.
|
9
|
+
#
|
10
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
11
|
+
# license agreements. See the NOTICE file distributed with
|
12
|
+
# this work for additional information regarding copyright
|
13
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
14
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
15
|
+
# not use this file except in compliance with the License.
|
16
|
+
# You may obtain a copy of the License at
|
17
|
+
#
|
18
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
19
|
+
#
|
20
|
+
# Unless required by applicable law or agreed to in writing,
|
21
|
+
# software distributed under the License is distributed on an
|
22
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
23
|
+
# KIND, either express or implied. See the License for the
|
24
|
+
# specific language governing permissions and limitations
|
25
|
+
# under the License.
|
26
|
+
|
27
|
+
module OpenSearch
|
28
|
+
module DSL
|
29
|
+
# Generic utility methods
|
30
|
+
#
|
31
|
+
module Utils
|
32
|
+
# Camelize an underscored string
|
33
|
+
#
|
34
|
+
# A lightweight version of ActiveSupport's `camelize`
|
35
|
+
#
|
36
|
+
# @example
|
37
|
+
# __camelize('query_string')
|
38
|
+
# # => 'QueryString'
|
39
|
+
#
|
40
|
+
# @api private
|
41
|
+
#
|
42
|
+
def __camelize(string)
|
43
|
+
string.to_s.split('_').map(&:capitalize).join
|
44
|
+
end
|
45
|
+
|
46
|
+
extend self
|
47
|
+
end
|
48
|
+
end
|
49
|
+
end
|
@@ -0,0 +1,69 @@
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
2
|
+
#
|
3
|
+
# The OpenSearch Contributors require contributions made to
|
4
|
+
# this file be licensed under the Apache-2.0 license or a
|
5
|
+
# compatible open source license.
|
6
|
+
#
|
7
|
+
# Modifications Copyright OpenSearch Contributors. See
|
8
|
+
# GitHub history for details.
|
9
|
+
#
|
10
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
11
|
+
# license agreements. See the NOTICE file distributed with
|
12
|
+
# this work for additional information regarding copyright
|
13
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
14
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
15
|
+
# not use this file except in compliance with the License.
|
16
|
+
# You may obtain a copy of the License at
|
17
|
+
#
|
18
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
19
|
+
#
|
20
|
+
# Unless required by applicable law or agreed to in writing,
|
21
|
+
# software distributed under the License is distributed on an
|
22
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
23
|
+
# KIND, either express or implied. See the License for the
|
24
|
+
# specific language governing permissions and limitations
|
25
|
+
# under the License.
|
26
|
+
|
27
|
+
require 'opensearch/dsl/utils'
|
28
|
+
require 'opensearch/dsl/search/base_component'
|
29
|
+
require 'opensearch/dsl/search/base_compound_filter_component'
|
30
|
+
require 'opensearch/dsl/search/base_aggregation_component'
|
31
|
+
require 'opensearch/dsl/search/query'
|
32
|
+
require 'opensearch/dsl/search/filter'
|
33
|
+
require 'opensearch/dsl/search/aggregation'
|
34
|
+
require 'opensearch/dsl/search/highlight'
|
35
|
+
require 'opensearch/dsl/search/sort'
|
36
|
+
require 'opensearch/dsl/search/options'
|
37
|
+
require 'opensearch/dsl/search/suggest'
|
38
|
+
|
39
|
+
Dir[File.expand_path('dsl/search/queries/**/*.rb', __dir__)].sort.each { |f| require f }
|
40
|
+
Dir[File.expand_path('dsl/search/filters/**/*.rb', __dir__)].sort.each { |f| require f }
|
41
|
+
Dir[File.expand_path('dsl/search/aggregations/**/*.rb', __dir__)].sort.each { |f| require f }
|
42
|
+
|
43
|
+
require 'opensearch/dsl/search'
|
44
|
+
|
45
|
+
module OpenSearch
|
46
|
+
# The main module, which can be included into your own class or namespace,
|
47
|
+
# to provide the DSL methods.
|
48
|
+
#
|
49
|
+
# @example
|
50
|
+
#
|
51
|
+
# include OpenSearch::DSL
|
52
|
+
#
|
53
|
+
# definition = search do
|
54
|
+
# query do
|
55
|
+
# match title: 'test'
|
56
|
+
# end
|
57
|
+
# end
|
58
|
+
#
|
59
|
+
# definition.to_hash
|
60
|
+
# # => { query: { match: { title: "test"} } }
|
61
|
+
#
|
62
|
+
# @see Search
|
63
|
+
#
|
64
|
+
module DSL
|
65
|
+
def self.included(base)
|
66
|
+
base.__send__ :include, OpenSearch::DSL::Search
|
67
|
+
end
|
68
|
+
end
|
69
|
+
end
|
@@ -0,0 +1,362 @@
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
2
|
+
#
|
3
|
+
# The OpenSearch Contributors require contributions made to
|
4
|
+
# this file be licensed under the Apache-2.0 license or a
|
5
|
+
# compatible open source license.
|
6
|
+
#
|
7
|
+
# Modifications Copyright OpenSearch Contributors. See
|
8
|
+
# GitHub history for details.
|
9
|
+
#
|
10
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
11
|
+
# license agreements. See the NOTICE file distributed with
|
12
|
+
# this work for additional information regarding copyright
|
13
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
14
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
15
|
+
# not use this file except in compliance with the License.
|
16
|
+
# You may obtain a copy of the License at
|
17
|
+
#
|
18
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
19
|
+
#
|
20
|
+
# Unless required by applicable law or agreed to in writing,
|
21
|
+
# software distributed under the License is distributed on an
|
22
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
23
|
+
# KIND, either express or implied. See the License for the
|
24
|
+
# specific language governing permissions and limitations
|
25
|
+
# under the License.
|
26
|
+
|
27
|
+
module OpenSearch
|
28
|
+
module Transport
|
29
|
+
# Handles communication with an OpenSearch cluster.
|
30
|
+
#
|
31
|
+
# See {file:README.md README} for usage and code examples.
|
32
|
+
#
|
33
|
+
class Client
|
34
|
+
DEFAULT_TRANSPORT_CLASS = Transport::HTTP::Faraday
|
35
|
+
|
36
|
+
DEFAULT_LOGGER = lambda do
|
37
|
+
require 'logger'
|
38
|
+
logger = Logger.new($stderr)
|
39
|
+
logger.progname = 'opensearch'
|
40
|
+
logger.formatter = proc { |_severity, datetime, _progname, msg| "#{datetime}: #{msg}\n" }
|
41
|
+
logger
|
42
|
+
end
|
43
|
+
|
44
|
+
DEFAULT_TRACER = lambda do
|
45
|
+
require 'logger'
|
46
|
+
logger = Logger.new($stderr)
|
47
|
+
logger.progname = 'opensearch.tracer'
|
48
|
+
logger.formatter = proc { |_severity, _datetime, _progname, msg| "#{msg}\n" }
|
49
|
+
logger
|
50
|
+
end
|
51
|
+
|
52
|
+
# The default host and port to use if not otherwise specified.
|
53
|
+
#
|
54
|
+
# @since 7.0.0
|
55
|
+
DEFAULT_HOST = 'localhost:9200'.freeze
|
56
|
+
|
57
|
+
# The default port to use if connecting using a Cloud ID.
|
58
|
+
# Updated from 9243 to 443 in client version 7.10.1
|
59
|
+
#
|
60
|
+
# @since 7.2.0
|
61
|
+
DEFAULT_CLOUD_PORT = 443
|
62
|
+
|
63
|
+
# The default port to use if not otherwise specified.
|
64
|
+
#
|
65
|
+
# @since 7.2.0
|
66
|
+
DEFAULT_PORT = 9200
|
67
|
+
|
68
|
+
# Returns the transport object.
|
69
|
+
#
|
70
|
+
# @see OpenSearch::Transport::Transport::Base
|
71
|
+
# @see OpenSearch::Transport::Transport::HTTP::Faraday
|
72
|
+
#
|
73
|
+
attr_accessor :transport
|
74
|
+
|
75
|
+
# Create a client connected to an OpenSearch cluster.
|
76
|
+
#
|
77
|
+
# Specify the URL via arguments or set the `OPENSEARCH_URL` environment variable.
|
78
|
+
#
|
79
|
+
# @option arguments [String,Array] :hosts Single host passed as a String or Hash, or multiple hosts
|
80
|
+
# passed as an Array; `host` or `url` keys are also valid
|
81
|
+
#
|
82
|
+
# @option arguments [Boolean] :log Use the default logger (disabled by default)
|
83
|
+
#
|
84
|
+
# @option arguments [Boolean] :trace Use the default tracer (disabled by default)
|
85
|
+
#
|
86
|
+
# @option arguments [Object] :logger An instance of a Logger-compatible object
|
87
|
+
#
|
88
|
+
# @option arguments [Object] :tracer An instance of a Logger-compatible object
|
89
|
+
#
|
90
|
+
# @option arguments [Number] :resurrect_after After how many seconds a dead connection should be tried again
|
91
|
+
#
|
92
|
+
# @option arguments [Boolean,Number] :reload_connections Reload connections after X requests (false by default)
|
93
|
+
#
|
94
|
+
# @option arguments [Boolean] :randomize_hosts Shuffle connections on initialization and reload (false by default)
|
95
|
+
#
|
96
|
+
# @option arguments [Integer] :sniffer_timeout Timeout for reloading connections in seconds (1 by default)
|
97
|
+
#
|
98
|
+
# @option arguments [Boolean,Number] :retry_on_failure Retry X times when request fails before raising and
|
99
|
+
# exception (false by default)
|
100
|
+
# @option arguments Array<Number> :retry_on_status Retry when specific status codes are returned
|
101
|
+
#
|
102
|
+
# @option arguments [Boolean] :reload_on_failure Reload connections after failure (false by default)
|
103
|
+
#
|
104
|
+
# @option arguments [Integer] :request_timeout The request timeout to be passed to transport in options
|
105
|
+
#
|
106
|
+
# @option arguments [Symbol] :adapter A specific adapter for Faraday (e.g. `:patron`)
|
107
|
+
#
|
108
|
+
# @option arguments [Hash] :transport_options Options to be passed to the `Faraday::Connection` constructor
|
109
|
+
#
|
110
|
+
# @option arguments [Constant] :transport_class A specific transport class to use, will be initialized by
|
111
|
+
# the client and passed hosts and all arguments
|
112
|
+
#
|
113
|
+
# @option arguments [Object] :transport A specific transport instance
|
114
|
+
#
|
115
|
+
# @option arguments [Constant] :serializer_class A specific serializer class to use, will be initialized by
|
116
|
+
# the transport and passed the transport instance
|
117
|
+
#
|
118
|
+
# @option arguments [Constant] :selector An instance of selector strategy implemented with
|
119
|
+
# {OpenSearch::Transport::Transport::Connections::Selector::Base}.
|
120
|
+
#
|
121
|
+
# @option arguments [String] :send_get_body_as Specify the HTTP method to use for GET requests with a body.
|
122
|
+
# (Default: GET)
|
123
|
+
# @option arguments [true, false] :compression Whether to compress requests. Gzip compression will be used.
|
124
|
+
# The default is false. Responses will automatically be inflated if they are compressed.
|
125
|
+
# If a custom transport object is used, it must handle the request compression and response inflation.
|
126
|
+
#
|
127
|
+
# @option api_key [String, Hash] :api_key Use API Key Authentication, either the base64 encoding of `id` and `api_key`
|
128
|
+
# joined by a colon as a String, or a hash with the `id` and `api_key` values.
|
129
|
+
# @option opaque_id_prefix [String] :opaque_id_prefix set a prefix for X-Opaque-Id when initializing the client.
|
130
|
+
# This will be prepended to the id you set before each request
|
131
|
+
# if you're using X-Opaque-Id
|
132
|
+
#
|
133
|
+
# @yield [faraday] Access and configure the `Faraday::Connection` instance directly with a block
|
134
|
+
#
|
135
|
+
def initialize(arguments = {}, &block)
|
136
|
+
@options = arguments.transform_keys(&:to_sym)
|
137
|
+
@arguments = @options
|
138
|
+
@arguments[:logger] ||= @arguments[:log] ? DEFAULT_LOGGER.call : nil
|
139
|
+
@arguments[:tracer] ||= @arguments[:trace] ? DEFAULT_TRACER.call : nil
|
140
|
+
@arguments[:reload_connections] ||= false
|
141
|
+
@arguments[:retry_on_failure] ||= false
|
142
|
+
@arguments[:reload_on_failure] ||= false
|
143
|
+
@arguments[:randomize_hosts] ||= false
|
144
|
+
@arguments[:transport_options] ||= {}
|
145
|
+
@arguments[:http] ||= {}
|
146
|
+
@options[:http] ||= {}
|
147
|
+
|
148
|
+
set_api_key if (@api_key = @arguments[:api_key])
|
149
|
+
set_compatibility_header if ENV['ELASTIC_CLIENT_APIVERSIONING']
|
150
|
+
|
151
|
+
@seeds = extract_cloud_creds(@arguments)
|
152
|
+
@seeds ||= __extract_hosts(@arguments[:hosts] ||
|
153
|
+
@arguments[:host] ||
|
154
|
+
@arguments[:url] ||
|
155
|
+
@arguments[:urls] ||
|
156
|
+
ENV.fetch('OPENSEARCH_URL', nil) ||
|
157
|
+
DEFAULT_HOST)
|
158
|
+
|
159
|
+
@send_get_body_as = @arguments[:send_get_body_as] || 'GET'
|
160
|
+
@opaque_id_prefix = @arguments[:opaque_id_prefix] || nil
|
161
|
+
|
162
|
+
if @arguments[:request_timeout]
|
163
|
+
@arguments[:transport_options][:request] = { timeout: @arguments[:request_timeout] }
|
164
|
+
end
|
165
|
+
|
166
|
+
if @arguments[:transport]
|
167
|
+
@transport = @arguments[:transport]
|
168
|
+
else
|
169
|
+
@transport_class = @arguments[:transport_class] || DEFAULT_TRANSPORT_CLASS
|
170
|
+
@transport = if @transport_class == Transport::HTTP::Faraday
|
171
|
+
@arguments[:adapter] ||= __auto_detect_adapter
|
172
|
+
@transport_class.new(hosts: @seeds, options: @arguments) do |faraday|
|
173
|
+
faraday.adapter(@arguments[:adapter])
|
174
|
+
block&.call faraday
|
175
|
+
end
|
176
|
+
else
|
177
|
+
@transport_class.new(hosts: @seeds, options: @arguments)
|
178
|
+
end
|
179
|
+
end
|
180
|
+
end
|
181
|
+
|
182
|
+
# Performs a request through delegation to {#transport}.
|
183
|
+
#
|
184
|
+
def perform_request(method, path, params = {}, body = nil, headers = nil)
|
185
|
+
method = @send_get_body_as if method == 'GET' && body
|
186
|
+
if (opaque_id = params.delete(:opaque_id))
|
187
|
+
headers = {} if headers.nil?
|
188
|
+
opaque_id = @opaque_id_prefix ? "#{@opaque_id_prefix}#{opaque_id}" : opaque_id
|
189
|
+
headers.merge!('X-Opaque-Id' => opaque_id)
|
190
|
+
end
|
191
|
+
transport.perform_request(method, path, params, body, headers)
|
192
|
+
end
|
193
|
+
|
194
|
+
private
|
195
|
+
|
196
|
+
def set_api_key
|
197
|
+
@api_key = __encode(@api_key) if @api_key.is_a? Hash
|
198
|
+
add_header('Authorization' => "ApiKey #{@api_key}")
|
199
|
+
@arguments.delete(:user)
|
200
|
+
@arguments.delete(:password)
|
201
|
+
end
|
202
|
+
|
203
|
+
def set_compatibility_header
|
204
|
+
return unless %w[1 true].include?(ENV.fetch('ELASTIC_CLIENT_APIVERSIONING', nil))
|
205
|
+
|
206
|
+
add_header(
|
207
|
+
{
|
208
|
+
'Accept' => 'application/vnd.opensearch+json;compatible-with=7',
|
209
|
+
'Content-Type' => 'application/vnd.opensearch+json; compatible-with=7'
|
210
|
+
}
|
211
|
+
)
|
212
|
+
end
|
213
|
+
|
214
|
+
def add_header(header)
|
215
|
+
headers = @arguments[:transport_options]&.[](:headers) || {}
|
216
|
+
headers.merge!(header)
|
217
|
+
@arguments[:transport_options].merge!(
|
218
|
+
headers: headers
|
219
|
+
)
|
220
|
+
end
|
221
|
+
|
222
|
+
def extract_cloud_creds(arguments)
|
223
|
+
return unless arguments[:cloud_id] && !arguments[:cloud_id].empty?
|
224
|
+
|
225
|
+
name = arguments[:cloud_id].split(':')[0]
|
226
|
+
base64_decoded = arguments[:cloud_id].gsub("#{name}:", '').unpack1('m')
|
227
|
+
cloud_url, opensearch_instance = base64_decoded.split('$')
|
228
|
+
|
229
|
+
if cloud_url.include?(':')
|
230
|
+
url, port = cloud_url.split(':')
|
231
|
+
host = "#{opensearch_instance}.#{url}"
|
232
|
+
else
|
233
|
+
host = "#{opensearch_instance}.#{cloud_url}"
|
234
|
+
port = arguments[:port] || DEFAULT_CLOUD_PORT
|
235
|
+
end
|
236
|
+
[
|
237
|
+
{
|
238
|
+
scheme: 'https',
|
239
|
+
user: arguments[:user],
|
240
|
+
password: arguments[:password],
|
241
|
+
host: host,
|
242
|
+
port: port.to_i
|
243
|
+
}
|
244
|
+
]
|
245
|
+
end
|
246
|
+
|
247
|
+
# Normalizes and returns hosts configuration.
|
248
|
+
#
|
249
|
+
# Arrayifies the `hosts_config` argument and extracts `host` and `port` info from strings.
|
250
|
+
# Performs shuffling when the `randomize_hosts` option is set.
|
251
|
+
#
|
252
|
+
# TODO: Refactor, so it's available in OpenSearch::Transport::Base as well
|
253
|
+
#
|
254
|
+
# @return [Array<Hash>]
|
255
|
+
# @raise [ArgumentError]
|
256
|
+
#
|
257
|
+
# @api private
|
258
|
+
#
|
259
|
+
def __extract_hosts(hosts_config)
|
260
|
+
hosts = case hosts_config
|
261
|
+
when String
|
262
|
+
hosts_config.split(',').map { |h| h.strip! || h }
|
263
|
+
when Array
|
264
|
+
hosts_config
|
265
|
+
when Hash, URI
|
266
|
+
[hosts_config]
|
267
|
+
else
|
268
|
+
Array(hosts_config)
|
269
|
+
end
|
270
|
+
|
271
|
+
host_list = hosts.map { |host| __parse_host(host) }
|
272
|
+
@options[:randomize_hosts] ? host_list.shuffle! : host_list
|
273
|
+
end
|
274
|
+
|
275
|
+
def __parse_host(host)
|
276
|
+
host_parts = case host
|
277
|
+
when String
|
278
|
+
if host =~ %r{^[a-z]+://}
|
279
|
+
# Construct a new `URI::Generic` directly from the array returned by URI::split.
|
280
|
+
# This avoids `URI::HTTP` and `URI::HTTPS`, which supply default ports.
|
281
|
+
uri = URI::Generic.new(*URI.split(host))
|
282
|
+
default_port = uri.scheme == 'https' ? 443 : DEFAULT_PORT
|
283
|
+
{
|
284
|
+
scheme: uri.scheme,
|
285
|
+
user: uri.user,
|
286
|
+
password: uri.password,
|
287
|
+
host: uri.host,
|
288
|
+
path: uri.path,
|
289
|
+
port: uri.port || default_port
|
290
|
+
}
|
291
|
+
else
|
292
|
+
host, port = host.split(':')
|
293
|
+
{ host: host, port: port }
|
294
|
+
end
|
295
|
+
when URI
|
296
|
+
{
|
297
|
+
scheme: host.scheme,
|
298
|
+
user: host.user,
|
299
|
+
password: host.password,
|
300
|
+
host: host.host,
|
301
|
+
path: host.path,
|
302
|
+
port: host.port
|
303
|
+
}
|
304
|
+
when Hash
|
305
|
+
host
|
306
|
+
else
|
307
|
+
raise ArgumentError, "Please pass host as a String, URI or Hash -- #{host.class} given."
|
308
|
+
end
|
309
|
+
if @api_key
|
310
|
+
# Remove Basic Auth if using API KEY
|
311
|
+
host_parts.delete(:user)
|
312
|
+
host_parts.delete(:password)
|
313
|
+
else
|
314
|
+
@options[:http][:user] ||= host_parts[:user]
|
315
|
+
@options[:http][:password] ||= host_parts[:password]
|
316
|
+
end
|
317
|
+
|
318
|
+
host_parts[:port] = host_parts[:port].to_i if host_parts[:port]
|
319
|
+
host_parts[:path]&.chomp!('/')
|
320
|
+
host_parts
|
321
|
+
end
|
322
|
+
|
323
|
+
# Auto-detect the best adapter (HTTP "driver") available, based on libraries
|
324
|
+
# loaded by the user, preferring those with persistent connections
|
325
|
+
# ("keep-alive") by default
|
326
|
+
#
|
327
|
+
# @return [Symbol]
|
328
|
+
#
|
329
|
+
# @api private
|
330
|
+
#
|
331
|
+
def __auto_detect_adapter
|
332
|
+
# Get the Faraday adapter list without initializing it.
|
333
|
+
adapter = if Faraday::Adapter.respond_to?(:registered_middleware) # Faraday 2.x
|
334
|
+
->(name) { Faraday::Adapter.registered_middleware[name] }
|
335
|
+
elsif Faraday::Adapter.respond_to?(:fetch_middleware) # Faraday 1.x
|
336
|
+
->(name) { Faraday::Adapter.fetch_middleware(name) }
|
337
|
+
else
|
338
|
+
{} # fallback behavior that should never happen
|
339
|
+
end
|
340
|
+
# Pick an adapter that has both the client and adapter defined.
|
341
|
+
if defined?(::Patron) && adapter[:patron]
|
342
|
+
:patron
|
343
|
+
elsif defined?(::Typhoeus) && adapter[:typhoeus]
|
344
|
+
:typhoeus
|
345
|
+
elsif defined?(::HTTPClient) && adapter[:httpclient]
|
346
|
+
:httpclient
|
347
|
+
elsif defined?(::Net::HTTP::Persistent) && adapter[:net_http_persistent]
|
348
|
+
:net_http_persistent
|
349
|
+
else
|
350
|
+
::Faraday.default_adapter
|
351
|
+
end
|
352
|
+
end
|
353
|
+
|
354
|
+
# Encode credentials for the Authorization Header
|
355
|
+
# Credentials is the base64 encoding of id and api_key joined by a colon
|
356
|
+
def __encode(api_key)
|
357
|
+
joined = [api_key[:id], api_key[:api_key]].join(':')
|
358
|
+
[joined].pack('m0')
|
359
|
+
end
|
360
|
+
end
|
361
|
+
end
|
362
|
+
end
|
@@ -0,0 +1,82 @@
|
|
1
|
+
# SPDX-License-Identifier: Apache-2.0
|
2
|
+
#
|
3
|
+
# The OpenSearch Contributors require contributions made to
|
4
|
+
# this file be licensed under the Apache-2.0 license or a
|
5
|
+
# compatible open source license.
|
6
|
+
#
|
7
|
+
# Modifications Copyright OpenSearch Contributors. See
|
8
|
+
# GitHub history for details.
|
9
|
+
#
|
10
|
+
# Licensed to Elasticsearch B.V. under one or more contributor
|
11
|
+
# license agreements. See the NOTICE file distributed with
|
12
|
+
# this work for additional information regarding copyright
|
13
|
+
# ownership. Elasticsearch B.V. licenses this file to you under
|
14
|
+
# the Apache License, Version 2.0 (the "License"); you may
|
15
|
+
# not use this file except in compliance with the License.
|
16
|
+
# You may obtain a copy of the License at
|
17
|
+
#
|
18
|
+
# http://www.apache.org/licenses/LICENSE-2.0
|
19
|
+
#
|
20
|
+
# Unless required by applicable law or agreed to in writing,
|
21
|
+
# software distributed under the License is distributed on an
|
22
|
+
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
|
23
|
+
# KIND, either express or implied. See the License for the
|
24
|
+
# specific language governing permissions and limitations
|
25
|
+
# under the License.
|
26
|
+
|
27
|
+
module OpenSearch
|
28
|
+
module Transport
|
29
|
+
# Class for wrapping a hash that could have sensitive data.
|
30
|
+
# When printed, the sensitive values will be redacted.
|
31
|
+
#
|
32
|
+
# @since 6.1.1
|
33
|
+
class Redacted < ::Hash
|
34
|
+
def initialize(elements = nil)
|
35
|
+
super()
|
36
|
+
(elements || {}).each_pair { |key, value| self[key] = value }
|
37
|
+
end
|
38
|
+
|
39
|
+
# The keys whose values will be redacted.
|
40
|
+
#
|
41
|
+
# @since 6.1.1
|
42
|
+
SENSITIVE_KEYS = %i[password
|
43
|
+
pwd].freeze
|
44
|
+
|
45
|
+
# The replacement string used in place of the value for sensitive keys.
|
46
|
+
#
|
47
|
+
# @since 6.1.1
|
48
|
+
STRING_REPLACEMENT = '<REDACTED>'.freeze
|
49
|
+
|
50
|
+
# Get a string representation of the hash.
|
51
|
+
#
|
52
|
+
# @return [ String ] The string representation of the hash.
|
53
|
+
#
|
54
|
+
# @since 6.1.1
|
55
|
+
def inspect
|
56
|
+
redacted_string(:inspect)
|
57
|
+
end
|
58
|
+
|
59
|
+
# Get a string representation of the hash.
|
60
|
+
#
|
61
|
+
# @return [ String ] The string representation of the hash.
|
62
|
+
#
|
63
|
+
# @since 6.1.1
|
64
|
+
def to_s
|
65
|
+
redacted_string(:to_s)
|
66
|
+
end
|
67
|
+
|
68
|
+
private
|
69
|
+
|
70
|
+
def redacted_string(method)
|
71
|
+
content = map { |k, v| "#{k.send(method)}=>#{redact(k, v, method)}" }
|
72
|
+
"{#{content.join(', ')}}"
|
73
|
+
end
|
74
|
+
|
75
|
+
def redact(key, val, method)
|
76
|
+
return STRING_REPLACEMENT if SENSITIVE_KEYS.include?(key.to_sym)
|
77
|
+
|
78
|
+
val.send(method)
|
79
|
+
end
|
80
|
+
end
|
81
|
+
end
|
82
|
+
end
|