algolia 3.0.0.beta.7 → 3.0.0.beta.9
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.github/workflows/release.yml +2 -0
- data/CHANGELOG.md +12 -0
- data/Gemfile.lock +3 -30
- data/Rakefile +0 -2
- data/algolia.gemspec +1 -1
- data/lib/algolia/api/abtesting_client.rb +52 -37
- data/lib/algolia/api/analytics_client.rb +415 -116
- data/lib/algolia/api/ingestion_client.rb +462 -182
- data/lib/algolia/api/insights_client.rb +45 -28
- data/lib/algolia/api/monitoring_client.rb +50 -44
- data/lib/algolia/api/personalization_client.rb +57 -32
- data/lib/algolia/api/query_suggestions_client.rb +59 -40
- data/lib/algolia/api/recommend_client.rb +70 -43
- data/lib/algolia/api/search_client.rb +461 -264
- data/lib/algolia/api/usage_client.rb +48 -28
- data/lib/algolia/api_client.rb +25 -24
- data/lib/algolia/api_error.rb +8 -8
- data/lib/algolia/configuration.rb +17 -6
- data/lib/algolia/error.rb +2 -2
- data/lib/algolia/logger_helper.rb +4 -4
- data/lib/algolia/models/abtesting/ab_test.rb +62 -37
- data/lib/algolia/models/abtesting/ab_test_configuration.rb +35 -20
- data/lib/algolia/models/abtesting/ab_test_response.rb +35 -20
- data/lib/algolia/models/abtesting/ab_tests_variant.rb +38 -23
- data/lib/algolia/models/abtesting/ab_tests_variant_search_params.rb +41 -26
- data/lib/algolia/models/abtesting/add_ab_tests_request.rb +38 -23
- data/lib/algolia/models/abtesting/add_ab_tests_variant.rb +33 -24
- data/lib/algolia/models/abtesting/currency.rb +32 -20
- data/lib/algolia/models/abtesting/custom_search_params.rb +33 -18
- data/lib/algolia/models/abtesting/effect.rb +2 -3
- data/lib/algolia/models/abtesting/empty_search.rb +33 -18
- data/lib/algolia/models/abtesting/error_base.rb +24 -13
- data/lib/algolia/models/abtesting/filter_effects.rb +34 -19
- data/lib/algolia/models/abtesting/filter_effects_empty_search.rb +34 -19
- data/lib/algolia/models/abtesting/filter_effects_outliers.rb +34 -19
- data/lib/algolia/models/abtesting/list_ab_tests_response.rb +37 -22
- data/lib/algolia/models/abtesting/minimum_detectable_effect.rb +37 -22
- data/lib/algolia/models/abtesting/outliers.rb +29 -17
- data/lib/algolia/models/abtesting/status.rb +2 -3
- data/lib/algolia/models/abtesting/variant.rb +83 -51
- data/lib/algolia/models/analytics/click_positions_inner.rb +39 -24
- data/lib/algolia/models/analytics/currencies_value.rb +34 -19
- data/lib/algolia/models/analytics/daily_add_to_cart_rates.rb +42 -27
- data/lib/algolia/models/analytics/daily_average_clicks.rb +40 -25
- data/lib/algolia/models/analytics/daily_click_through_rates.rb +42 -27
- data/lib/algolia/models/analytics/daily_conversion_rates.rb +42 -27
- data/lib/algolia/models/analytics/daily_no_click_rates.rb +41 -26
- data/lib/algolia/models/analytics/daily_no_results_rates.rb +39 -24
- data/lib/algolia/models/analytics/daily_purchase_rates.rb +40 -25
- data/lib/algolia/models/analytics/daily_revenue.rb +34 -19
- data/lib/algolia/models/analytics/daily_searches.rb +34 -19
- data/lib/algolia/models/analytics/daily_searches_no_clicks.rb +37 -22
- data/lib/algolia/models/analytics/daily_searches_no_results.rb +37 -22
- data/lib/algolia/models/analytics/daily_users.rb +34 -19
- data/lib/algolia/models/analytics/direction.rb +2 -3
- data/lib/algolia/models/analytics/error_base.rb +24 -13
- data/lib/algolia/models/analytics/get_add_to_cart_rate_response.rb +42 -27
- data/lib/algolia/models/analytics/get_average_click_position_response.rb +40 -25
- data/lib/algolia/models/analytics/get_click_positions_response.rb +36 -21
- data/lib/algolia/models/analytics/get_click_through_rate_response.rb +42 -27
- data/lib/algolia/models/analytics/get_conversion_rate_response.rb +42 -27
- data/lib/algolia/models/analytics/get_no_click_rate_response.rb +41 -26
- data/lib/algolia/models/analytics/get_no_results_rate_response.rb +39 -24
- data/lib/algolia/models/analytics/get_purchase_rate_response.rb +40 -25
- data/lib/algolia/models/analytics/get_revenue.rb +34 -19
- data/lib/algolia/models/analytics/get_searches_count_response.rb +34 -19
- data/lib/algolia/models/analytics/get_searches_no_clicks_response.rb +33 -18
- data/lib/algolia/models/analytics/get_searches_no_results_response.rb +33 -18
- data/lib/algolia/models/analytics/get_status_response.rb +35 -20
- data/lib/algolia/models/analytics/get_top_countries_response.rb +33 -18
- data/lib/algolia/models/analytics/get_top_filter_attribute.rb +34 -19
- data/lib/algolia/models/analytics/get_top_filter_attributes_response.rb +33 -18
- data/lib/algolia/models/analytics/get_top_filter_for_attribute.rb +36 -21
- data/lib/algolia/models/analytics/get_top_filter_for_attribute_response.rb +33 -18
- data/lib/algolia/models/analytics/get_top_filters_no_results_response.rb +35 -20
- data/lib/algolia/models/analytics/get_top_filters_no_results_value.rb +35 -20
- data/lib/algolia/models/analytics/get_top_filters_no_results_values.rb +34 -19
- data/lib/algolia/models/analytics/get_top_hits_response.rb +34 -25
- data/lib/algolia/models/analytics/get_top_searches_response.rb +34 -25
- data/lib/algolia/models/analytics/get_users_count_response.rb +34 -19
- data/lib/algolia/models/analytics/operator.rb +2 -3
- data/lib/algolia/models/analytics/order_by.rb +2 -3
- data/lib/algolia/models/analytics/top_country.rb +34 -19
- data/lib/algolia/models/analytics/top_hit.rb +30 -18
- data/lib/algolia/models/analytics/top_hit_with_analytics.rb +50 -35
- data/lib/algolia/models/analytics/top_hit_with_revenue_analytics.rb +77 -50
- data/lib/algolia/models/analytics/top_hits_response.rb +33 -18
- data/lib/algolia/models/analytics/top_hits_response_with_analytics.rb +33 -18
- data/lib/algolia/models/analytics/top_hits_response_with_revenue_analytics.rb +33 -18
- data/lib/algolia/models/analytics/top_search.rb +35 -20
- data/lib/algolia/models/analytics/top_search_with_analytics.rb +76 -44
- data/lib/algolia/models/analytics/top_search_with_revenue_analytics.rb +94 -58
- data/lib/algolia/models/analytics/top_searches_response.rb +33 -18
- data/lib/algolia/models/analytics/top_searches_response_with_analytics.rb +33 -18
- data/lib/algolia/models/analytics/top_searches_response_with_revenue_analytics.rb +33 -18
- data/lib/algolia/models/ingestion/action_type.rb +2 -3
- data/lib/algolia/models/ingestion/auth_algolia.rb +34 -19
- data/lib/algolia/models/ingestion/auth_algolia_insights.rb +34 -19
- data/lib/algolia/models/ingestion/auth_algolia_insights_partial.rb +34 -19
- data/lib/algolia/models/ingestion/auth_algolia_partial.rb +34 -19
- data/lib/algolia/models/ingestion/auth_api_key.rb +33 -18
- data/lib/algolia/models/ingestion/auth_api_key_partial.rb +33 -18
- data/lib/algolia/models/ingestion/auth_basic.rb +34 -19
- data/lib/algolia/models/ingestion/auth_basic_partial.rb +34 -19
- data/lib/algolia/models/ingestion/auth_google_service_account.rb +34 -19
- data/lib/algolia/models/ingestion/auth_google_service_account_partial.rb +34 -19
- data/lib/algolia/models/ingestion/auth_input.rb +37 -28
- data/lib/algolia/models/ingestion/auth_input_partial.rb +37 -28
- data/lib/algolia/models/ingestion/auth_o_auth.rb +36 -21
- data/lib/algolia/models/ingestion/auth_o_auth_partial.rb +36 -21
- data/lib/algolia/models/ingestion/authentication.rb +41 -26
- data/lib/algolia/models/ingestion/authentication_create.rb +38 -23
- data/lib/algolia/models/ingestion/authentication_create_response.rb +35 -20
- data/lib/algolia/models/ingestion/authentication_search.rb +33 -18
- data/lib/algolia/models/ingestion/authentication_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/authentication_type.rb +2 -3
- data/lib/algolia/models/ingestion/authentication_update.rb +38 -23
- data/lib/algolia/models/ingestion/authentication_update_response.rb +35 -20
- data/lib/algolia/models/ingestion/big_commerce_channel.rb +34 -19
- data/lib/algolia/models/ingestion/big_commerce_metafield.rb +34 -19
- data/lib/algolia/models/ingestion/big_query_data_type.rb +2 -3
- data/lib/algolia/models/ingestion/commercetools_custom_fields.rb +39 -24
- data/lib/algolia/models/ingestion/delete_response.rb +33 -18
- data/lib/algolia/models/ingestion/destination.rb +39 -24
- data/lib/algolia/models/ingestion/destination_create.rb +36 -21
- data/lib/algolia/models/ingestion/destination_create_response.rb +35 -20
- data/lib/algolia/models/ingestion/destination_index_name.rb +35 -20
- data/lib/algolia/models/ingestion/destination_index_prefix.rb +33 -18
- data/lib/algolia/models/ingestion/destination_input.rb +33 -24
- data/lib/algolia/models/ingestion/destination_search.rb +33 -18
- data/lib/algolia/models/ingestion/destination_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/destination_type.rb +2 -3
- data/lib/algolia/models/ingestion/destination_update.rb +36 -21
- data/lib/algolia/models/ingestion/destination_update_response.rb +35 -20
- data/lib/algolia/models/ingestion/docker_image_type.rb +2 -3
- data/lib/algolia/models/ingestion/docker_registry.rb +2 -3
- data/lib/algolia/models/ingestion/{on_demand_date_utils_input.rb → docker_streams_input.rb} +41 -49
- data/lib/algolia/models/ingestion/error_base.rb +24 -13
- data/lib/algolia/models/ingestion/event.rb +38 -26
- data/lib/algolia/models/ingestion/event_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/event_status.rb +2 -3
- data/lib/algolia/models/ingestion/event_type.rb +2 -3
- data/lib/algolia/models/ingestion/list_authentications_response.rb +34 -19
- data/lib/algolia/models/ingestion/list_destinations_response.rb +34 -19
- data/lib/algolia/models/ingestion/list_events_response.rb +35 -20
- data/lib/algolia/models/ingestion/list_sources_response.rb +34 -19
- data/lib/algolia/models/ingestion/list_tasks_response.rb +34 -19
- data/lib/algolia/models/ingestion/list_transformations_response.rb +34 -19
- data/lib/algolia/models/ingestion/mapping_field_directive.rb +34 -19
- data/lib/algolia/models/ingestion/mapping_format_schema.rb +2 -3
- data/lib/algolia/models/ingestion/mapping_input.rb +34 -19
- data/lib/algolia/models/ingestion/mapping_kit_action.rb +36 -21
- data/lib/algolia/models/ingestion/mapping_type_csv.rb +2 -3
- data/lib/algolia/models/ingestion/method_type.rb +2 -3
- data/lib/algolia/models/ingestion/on_demand_trigger.rb +34 -19
- data/lib/algolia/models/ingestion/on_demand_trigger_input.rb +33 -18
- data/lib/algolia/models/ingestion/on_demand_trigger_type.rb +2 -3
- data/lib/algolia/models/ingestion/order_keys.rb +2 -3
- data/lib/algolia/models/ingestion/pagination.rb +45 -30
- data/lib/algolia/models/ingestion/platform.rb +2 -3
- data/lib/algolia/models/ingestion/platform_none.rb +2 -3
- data/lib/algolia/models/ingestion/platform_with_none.rb +33 -24
- data/lib/algolia/models/ingestion/record_type.rb +2 -3
- data/lib/algolia/models/ingestion/run.rb +59 -33
- data/lib/algolia/models/ingestion/run_list_response.rb +35 -20
- data/lib/algolia/models/ingestion/run_outcome.rb +2 -3
- data/lib/algolia/models/ingestion/run_progress.rb +34 -19
- data/lib/algolia/models/ingestion/run_reason_code.rb +2 -3
- data/lib/algolia/models/ingestion/run_response.rb +34 -19
- data/lib/algolia/models/ingestion/run_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/run_status.rb +2 -3
- data/lib/algolia/models/ingestion/run_type.rb +2 -3
- data/lib/algolia/models/ingestion/schedule_trigger.rb +36 -21
- data/lib/algolia/models/ingestion/schedule_trigger_input.rb +34 -19
- data/lib/algolia/models/ingestion/schedule_trigger_type.rb +2 -3
- data/lib/algolia/models/ingestion/shopify_input.rb +34 -19
- data/lib/algolia/models/ingestion/shopify_market.rb +35 -20
- data/lib/algolia/models/ingestion/shopify_metafield.rb +35 -20
- data/lib/algolia/models/ingestion/sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/source.rb +35 -23
- data/lib/algolia/models/ingestion/source_big_commerce.rb +37 -22
- data/lib/algolia/models/ingestion/source_big_query.rb +39 -24
- data/lib/algolia/models/ingestion/source_commercetools.rb +38 -23
- data/lib/algolia/models/ingestion/source_create.rb +36 -21
- data/lib/algolia/models/ingestion/source_create_response.rb +35 -20
- data/lib/algolia/models/ingestion/source_csv.rb +43 -25
- data/lib/algolia/models/ingestion/source_docker.rb +37 -22
- data/lib/algolia/models/ingestion/source_ga4_big_query_export.rb +35 -20
- data/lib/algolia/models/ingestion/source_input.rb +39 -30
- data/lib/algolia/models/ingestion/source_json.rb +35 -20
- data/lib/algolia/models/ingestion/source_search.rb +33 -18
- data/lib/algolia/models/ingestion/source_shopify.rb +52 -29
- data/lib/algolia/models/ingestion/source_shopify_base.rb +33 -18
- data/lib/algolia/models/ingestion/source_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/source_type.rb +2 -3
- data/lib/algolia/models/ingestion/source_update.rb +35 -20
- data/lib/algolia/models/ingestion/source_update_commercetools.rb +37 -22
- data/lib/algolia/models/ingestion/source_update_docker.rb +36 -21
- data/lib/algolia/models/ingestion/source_update_input.rb +38 -29
- data/lib/algolia/models/ingestion/source_update_response.rb +35 -20
- data/lib/algolia/models/ingestion/source_update_shopify.rb +48 -26
- data/lib/algolia/models/ingestion/source_watch_response.rb +36 -21
- data/lib/algolia/models/ingestion/{streaming_utils_input.rb → streaming_input.rb} +34 -19
- data/lib/algolia/models/ingestion/streaming_trigger.rb +33 -18
- data/lib/algolia/models/ingestion/streaming_trigger_type.rb +2 -3
- data/lib/algolia/models/ingestion/subscription_trigger.rb +33 -18
- data/lib/algolia/models/ingestion/subscription_trigger_type.rb +2 -3
- data/lib/algolia/models/ingestion/task.rb +55 -31
- data/lib/algolia/models/ingestion/task_create.rb +43 -28
- data/lib/algolia/models/ingestion/task_create_response.rb +34 -19
- data/lib/algolia/models/ingestion/task_create_trigger.rb +35 -26
- data/lib/algolia/models/ingestion/task_input.rb +34 -26
- data/lib/algolia/models/ingestion/task_search.rb +33 -18
- data/lib/algolia/models/ingestion/task_sort_keys.rb +2 -3
- data/lib/algolia/models/ingestion/task_update.rb +40 -25
- data/lib/algolia/models/ingestion/task_update_response.rb +34 -19
- data/lib/algolia/models/ingestion/transformation.rb +38 -25
- data/lib/algolia/models/ingestion/transformation_create.rb +35 -22
- data/lib/algolia/models/ingestion/transformation_create_response.rb +34 -19
- data/lib/algolia/models/ingestion/transformation_search.rb +33 -18
- data/lib/algolia/models/ingestion/transformation_try.rb +34 -19
- data/lib/algolia/models/ingestion/transformation_try_response.rb +34 -19
- data/lib/algolia/models/ingestion/transformation_try_response_error.rb +34 -19
- data/lib/algolia/models/ingestion/transformation_update_response.rb +34 -19
- data/lib/algolia/models/ingestion/trigger.rb +35 -26
- data/lib/algolia/models/ingestion/trigger_type.rb +2 -3
- data/lib/algolia/models/ingestion/trigger_update_input.rb +33 -18
- data/lib/algolia/models/ingestion/window.rb +30 -18
- data/lib/algolia/models/insights/add_to_cart_event.rb +2 -3
- data/lib/algolia/models/insights/added_to_cart_object_ids.rb +91 -46
- data/lib/algolia/models/insights/added_to_cart_object_ids_after_search.rb +99 -50
- data/lib/algolia/models/insights/click_event.rb +2 -3
- data/lib/algolia/models/insights/clicked_filters.rb +71 -38
- data/lib/algolia/models/insights/clicked_object_ids.rb +71 -38
- data/lib/algolia/models/insights/clicked_object_ids_after_search.rb +93 -47
- data/lib/algolia/models/insights/conversion_event.rb +2 -3
- data/lib/algolia/models/insights/converted_filters.rb +71 -38
- data/lib/algolia/models/insights/converted_object_ids.rb +71 -38
- data/lib/algolia/models/insights/converted_object_ids_after_search.rb +78 -42
- data/lib/algolia/models/insights/discount.rb +33 -24
- data/lib/algolia/models/insights/error_base.rb +24 -13
- data/lib/algolia/models/insights/events_items.rb +43 -34
- data/lib/algolia/models/insights/events_response.rb +34 -19
- data/lib/algolia/models/insights/insights_events.rb +36 -21
- data/lib/algolia/models/insights/object_data.rb +35 -20
- data/lib/algolia/models/insights/object_data_after_search.rb +42 -24
- data/lib/algolia/models/insights/price.rb +33 -24
- data/lib/algolia/models/insights/purchase_event.rb +2 -3
- data/lib/algolia/models/insights/purchased_object_ids.rb +91 -46
- data/lib/algolia/models/insights/purchased_object_ids_after_search.rb +91 -46
- data/lib/algolia/models/insights/value.rb +33 -24
- data/lib/algolia/models/insights/view_event.rb +2 -3
- data/lib/algolia/models/insights/viewed_filters.rb +71 -38
- data/lib/algolia/models/insights/viewed_object_ids.rb +71 -38
- data/lib/algolia/models/monitoring/error_base.rb +24 -13
- data/lib/algolia/models/monitoring/get_servers403_response.rb +33 -18
- data/lib/algolia/models/monitoring/incident.rb +30 -18
- data/lib/algolia/models/monitoring/incidents_inner.rb +34 -19
- data/lib/algolia/models/monitoring/incidents_response.rb +33 -18
- data/lib/algolia/models/monitoring/indexing_time_response.rb +33 -18
- data/lib/algolia/models/monitoring/indexing_time_response_metrics.rb +33 -18
- data/lib/algolia/models/monitoring/infrastructure_response.rb +33 -18
- data/lib/algolia/models/monitoring/infrastructure_response_metrics.rb +37 -22
- data/lib/algolia/models/monitoring/inventory_response.rb +33 -18
- data/lib/algolia/models/monitoring/latency_response.rb +33 -18
- data/lib/algolia/models/monitoring/latency_response_metrics.rb +33 -18
- data/lib/algolia/models/monitoring/metric.rb +2 -3
- data/lib/algolia/models/monitoring/period.rb +2 -3
- data/lib/algolia/models/monitoring/probes_metric.rb +34 -19
- data/lib/algolia/models/monitoring/region.rb +2 -3
- data/lib/algolia/models/monitoring/server.rb +35 -23
- data/lib/algolia/models/monitoring/server_status.rb +2 -3
- data/lib/algolia/models/monitoring/status.rb +2 -3
- data/lib/algolia/models/monitoring/status_response.rb +33 -18
- data/lib/algolia/models/monitoring/time_inner.rb +34 -19
- data/lib/algolia/models/monitoring/type.rb +2 -3
- data/lib/algolia/models/personalization/delete_user_profile_response.rb +34 -19
- data/lib/algolia/models/personalization/error_base.rb +24 -13
- data/lib/algolia/models/personalization/event_scoring.rb +35 -20
- data/lib/algolia/models/personalization/event_type.rb +2 -3
- data/lib/algolia/models/personalization/facet_scoring.rb +34 -19
- data/lib/algolia/models/personalization/get_user_token_response.rb +35 -20
- data/lib/algolia/models/personalization/personalization_strategy_params.rb +38 -23
- data/lib/algolia/models/personalization/set_personalization_strategy_response.rb +33 -18
- data/lib/algolia/models/query-suggestions/app_id.rb +29 -17
- data/lib/algolia/models/query-suggestions/base_query_suggestions_configuration_response.rb +22 -9
- data/lib/algolia/models/query-suggestions/base_query_suggestions_configuration_with_index.rb +22 -9
- data/lib/algolia/models/query-suggestions/base_response.rb +34 -19
- data/lib/algolia/models/query-suggestions/configuration.rb +44 -26
- data/lib/algolia/models/query-suggestions/configuration_response.rb +48 -30
- data/lib/algolia/models/query-suggestions/configuration_with_index.rb +46 -28
- data/lib/algolia/models/query-suggestions/error_base.rb +24 -13
- data/lib/algolia/models/query-suggestions/facet.rb +30 -18
- data/lib/algolia/models/query-suggestions/get_config_status200_response.rb +37 -22
- data/lib/algolia/models/query-suggestions/get_log_file200_response.rb +36 -21
- data/lib/algolia/models/query-suggestions/languages.rb +33 -24
- data/lib/algolia/models/query-suggestions/log_level.rb +2 -3
- data/lib/algolia/models/query-suggestions/query_suggestions_configuration.rb +34 -16
- data/lib/algolia/models/query-suggestions/query_suggestions_configuration_response.rb +34 -16
- data/lib/algolia/models/query-suggestions/query_suggestions_configuration_with_index.rb +34 -16
- data/lib/algolia/models/query-suggestions/source_index.rb +49 -34
- data/lib/algolia/models/recommend/advanced_syntax_features.rb +2 -3
- data/lib/algolia/models/recommend/alternatives_as_exact.rb +2 -3
- data/lib/algolia/models/recommend/around_precision.rb +33 -24
- data/lib/algolia/models/recommend/around_precision_from_value_inner.rb +34 -19
- data/lib/algolia/models/recommend/around_radius.rb +33 -24
- data/lib/algolia/models/recommend/around_radius_all.rb +2 -3
- data/lib/algolia/models/recommend/auto_facet_filter.rb +34 -19
- data/lib/algolia/models/recommend/base_recommend_request.rb +42 -27
- data/lib/algolia/models/recommend/base_search_params.rb +110 -63
- data/lib/algolia/models/recommend/base_search_params_without_query.rb +106 -60
- data/lib/algolia/models/recommend/base_search_response.rb +76 -121
- data/lib/algolia/models/recommend/bought_together_query.rb +46 -31
- data/lib/algolia/models/recommend/condition.rb +35 -20
- data/lib/algolia/models/recommend/consequence.rb +39 -24
- data/lib/algolia/models/recommend/deleted_at_response.rb +34 -19
- data/lib/algolia/models/recommend/distinct.rb +33 -24
- data/lib/algolia/models/recommend/error_base.rb +24 -13
- data/lib/algolia/models/recommend/exact_on_single_word_query.rb +2 -3
- data/lib/algolia/models/recommend/exhaustive.rb +37 -22
- data/lib/algolia/models/recommend/facet_filters.rb +33 -24
- data/lib/algolia/models/recommend/facet_ordering.rb +34 -19
- data/lib/algolia/models/recommend/facets.rb +29 -17
- data/lib/algolia/models/recommend/facets_stats.rb +36 -21
- data/lib/algolia/models/recommend/fallback_params.rb +207 -118
- data/lib/algolia/models/recommend/fbt_model.rb +2 -3
- data/lib/algolia/models/recommend/frequently_bought_together.rb +34 -19
- data/lib/algolia/models/recommend/get_recommend_task_response.rb +33 -18
- data/lib/algolia/models/recommend/get_recommendations_params.rb +33 -18
- data/lib/algolia/models/recommend/get_recommendations_response.rb +33 -18
- data/lib/algolia/models/recommend/hide_consequence_object.rb +33 -18
- data/lib/algolia/models/recommend/highlight_result.rb +34 -25
- data/lib/algolia/models/recommend/highlight_result_option.rb +36 -21
- data/lib/algolia/models/recommend/ignore_plurals.rb +33 -24
- data/lib/algolia/models/recommend/index_settings_as_search_params.rb +134 -75
- data/lib/algolia/models/recommend/looking_similar.rb +35 -20
- data/lib/algolia/models/recommend/looking_similar_model.rb +2 -3
- data/lib/algolia/models/recommend/looking_similar_query.rb +47 -32
- data/lib/algolia/models/recommend/match_level.rb +2 -3
- data/lib/algolia/models/recommend/matched_geo_location.rb +35 -20
- data/lib/algolia/models/recommend/mode.rb +2 -3
- data/lib/algolia/models/recommend/numeric_filters.rb +33 -24
- data/lib/algolia/models/recommend/optional_filters.rb +33 -24
- data/lib/algolia/models/recommend/params_consequence.rb +35 -20
- data/lib/algolia/models/recommend/personalization.rb +35 -20
- data/lib/algolia/models/recommend/promote_consequence_object.rb +36 -21
- data/lib/algolia/models/recommend/query_type.rb +2 -3
- data/lib/algolia/models/recommend/ranking_info.rb +76 -48
- data/lib/algolia/models/recommend/re_ranking_apply_filter.rb +33 -24
- data/lib/algolia/models/recommend/recommend_hit.rb +32 -21
- data/lib/algolia/models/recommend/recommend_models.rb +2 -3
- data/lib/algolia/models/recommend/recommend_rule.rb +38 -23
- data/lib/algolia/models/recommend/recommend_rule_metadata.rb +33 -18
- data/lib/algolia/models/recommend/recommendations_hit.rb +33 -24
- data/lib/algolia/models/recommend/recommendations_hits.rb +33 -18
- data/lib/algolia/models/recommend/recommendations_request.rb +37 -28
- data/lib/algolia/models/recommend/recommendations_results.rb +159 -114
- data/lib/algolia/models/recommend/recommended_for_you.rb +34 -19
- data/lib/algolia/models/recommend/recommended_for_you_model.rb +2 -3
- data/lib/algolia/models/recommend/recommended_for_you_query.rb +46 -31
- data/lib/algolia/models/recommend/redirect.rb +30 -18
- data/lib/algolia/models/recommend/redirect_rule_index_metadata.rb +37 -22
- data/lib/algolia/models/recommend/redirect_rule_index_metadata_data.rb +33 -18
- data/lib/algolia/models/{ingestion/schedule_date_utils_input.rb → recommend/redirect_url.rb} +43 -58
- data/lib/algolia/models/recommend/related_model.rb +2 -3
- data/lib/algolia/models/recommend/related_products.rb +35 -20
- data/lib/algolia/models/recommend/related_query.rb +47 -32
- data/lib/algolia/models/recommend/remove_stop_words.rb +33 -24
- data/lib/algolia/models/recommend/remove_words_if_no_results.rb +2 -3
- data/lib/algolia/models/recommend/rendering_content.rb +45 -21
- data/lib/algolia/models/recommend/search_pagination.rb +282 -0
- data/lib/algolia/models/recommend/search_params.rb +207 -118
- data/lib/algolia/models/recommend/search_params_object.rb +208 -119
- data/lib/algolia/models/recommend/search_params_query.rb +33 -18
- data/lib/algolia/models/recommend/search_recommend_rules_params.rb +48 -33
- data/lib/algolia/models/recommend/search_recommend_rules_response.rb +38 -23
- data/lib/algolia/models/recommend/semantic_search.rb +35 -20
- data/lib/algolia/models/recommend/snippet_result.rb +34 -25
- data/lib/algolia/models/recommend/snippet_result_option.rb +34 -19
- data/lib/algolia/models/recommend/sort_remaining_by.rb +2 -3
- data/lib/algolia/models/recommend/supported_language.rb +72 -5
- data/lib/algolia/models/recommend/tag_filters.rb +33 -24
- data/lib/algolia/models/recommend/task_status.rb +2 -3
- data/lib/algolia/models/recommend/trending_facet_hit.rb +38 -23
- data/lib/algolia/models/recommend/trending_facets.rb +37 -22
- data/lib/algolia/models/recommend/trending_facets_model.rb +2 -3
- data/lib/algolia/models/recommend/trending_facets_query.rb +49 -34
- data/lib/algolia/models/recommend/trending_items.rb +36 -21
- data/lib/algolia/models/recommend/trending_items_model.rb +2 -3
- data/lib/algolia/models/recommend/trending_items_query.rb +58 -34
- data/lib/algolia/models/recommend/typo_tolerance.rb +33 -24
- data/lib/algolia/models/recommend/typo_tolerance_enum.rb +2 -3
- data/lib/algolia/models/recommend/value.rb +31 -19
- data/lib/algolia/models/search/acl.rb +19 -5
- data/lib/algolia/models/search/action.rb +11 -4
- data/lib/algolia/models/search/add_api_key_response.rb +34 -19
- data/lib/algolia/models/search/advanced_syntax_features.rb +2 -3
- data/lib/algolia/models/search/alternatives_as_exact.rb +2 -3
- data/lib/algolia/models/search/anchoring.rb +2 -3
- data/lib/algolia/models/search/api_key.rb +46 -25
- data/lib/algolia/models/search/api_key_operation.rb +2 -3
- data/lib/algolia/models/search/around_precision.rb +33 -24
- data/lib/algolia/models/search/around_precision_from_value_inner.rb +34 -19
- data/lib/algolia/models/search/around_radius.rb +33 -24
- data/lib/algolia/models/search/around_radius_all.rb +2 -3
- data/lib/algolia/models/search/assign_user_id_params.rb +33 -18
- data/lib/algolia/models/search/attribute_to_update.rb +33 -24
- data/lib/algolia/models/search/automatic_facet_filter.rb +35 -20
- data/lib/algolia/models/search/automatic_facet_filters.rb +33 -24
- data/lib/algolia/models/search/base_get_api_key_response.rb +34 -19
- data/lib/algolia/models/search/base_index_settings.rb +71 -39
- data/lib/algolia/models/search/base_search_params.rb +110 -63
- data/lib/algolia/models/search/base_search_params_without_query.rb +106 -60
- data/lib/algolia/models/search/base_search_response.rb +76 -121
- data/lib/algolia/models/search/batch_assign_user_ids_params.rb +34 -19
- data/lib/algolia/models/search/batch_dictionary_entries_params.rb +34 -19
- data/lib/algolia/models/search/batch_dictionary_entries_request.rb +34 -19
- data/lib/algolia/models/search/batch_params.rb +33 -18
- data/lib/algolia/models/search/batch_request.rb +34 -19
- data/lib/algolia/models/search/batch_response.rb +34 -19
- data/lib/algolia/models/search/batch_write_params.rb +33 -18
- data/lib/algolia/models/search/browse_pagination.rb +274 -0
- data/lib/algolia/models/search/browse_params.rb +33 -24
- data/lib/algolia/models/search/browse_params_object.rb +210 -120
- data/lib/algolia/models/search/browse_response.rb +158 -118
- data/lib/algolia/models/search/built_in_operation.rb +34 -19
- data/lib/algolia/models/search/built_in_operation_type.rb +2 -3
- data/lib/algolia/models/search/condition.rb +38 -23
- data/lib/algolia/models/search/consequence.rb +43 -28
- data/lib/algolia/models/search/consequence_hide.rb +33 -18
- data/lib/algolia/models/search/consequence_params.rb +213 -122
- data/lib/algolia/models/search/consequence_query.rb +33 -24
- data/lib/algolia/models/search/consequence_query_object.rb +34 -19
- data/lib/algolia/models/search/created_at_response.rb +33 -18
- data/lib/algolia/models/search/cursor.rb +29 -17
- data/lib/algolia/models/search/delete_api_key_response.rb +33 -18
- data/lib/algolia/models/search/delete_by_params.rb +50 -26
- data/lib/algolia/models/search/delete_source_response.rb +33 -18
- data/lib/algolia/models/search/deleted_at_response.rb +34 -19
- data/lib/algolia/models/search/dictionary_action.rb +2 -3
- data/lib/algolia/models/search/dictionary_entry.rb +29 -18
- data/lib/algolia/models/search/dictionary_entry_state.rb +2 -3
- data/lib/algolia/models/search/dictionary_language.rb +33 -18
- data/lib/algolia/models/search/dictionary_settings_params.rb +33 -18
- data/lib/algolia/models/search/dictionary_type.rb +2 -3
- data/lib/algolia/models/search/distinct.rb +33 -24
- data/lib/algolia/models/search/edit.rb +31 -19
- data/lib/algolia/models/search/edit_type.rb +2 -3
- data/lib/algolia/models/search/error_base.rb +24 -13
- data/lib/algolia/models/search/exact_on_single_word_query.rb +2 -3
- data/lib/algolia/models/search/exhaustive.rb +37 -22
- data/lib/algolia/models/search/facet_filters.rb +33 -24
- data/lib/algolia/models/search/facet_hits.rb +35 -20
- data/lib/algolia/models/search/facet_ordering.rb +34 -19
- data/lib/algolia/models/search/facets.rb +29 -17
- data/lib/algolia/models/search/facets_stats.rb +36 -21
- data/lib/algolia/models/search/fetched_index.rb +58 -30
- data/lib/algolia/models/search/get_api_key_response.rb +56 -30
- data/lib/algolia/models/search/get_dictionary_settings_response.rb +33 -18
- data/lib/algolia/models/search/get_logs_response.rb +33 -18
- data/lib/algolia/models/search/get_objects_params.rb +33 -18
- data/lib/algolia/models/search/get_objects_request.rb +35 -20
- data/lib/algolia/models/search/get_objects_response.rb +33 -18
- data/lib/algolia/models/search/get_task_response.rb +33 -18
- data/lib/algolia/models/search/get_top_user_ids_response.rb +33 -18
- data/lib/algolia/models/search/has_pending_mappings_response.rb +34 -19
- data/lib/algolia/models/search/highlight_result.rb +34 -25
- data/lib/algolia/models/search/highlight_result_option.rb +36 -21
- data/lib/algolia/models/search/hit.rb +24 -16
- data/lib/algolia/models/search/ignore_plurals.rb +33 -24
- data/lib/algolia/models/search/index_settings.rb +171 -97
- data/lib/algolia/models/search/index_settings_as_search_params.rb +134 -75
- data/lib/algolia/models/search/languages.rb +39 -24
- data/lib/algolia/models/search/list_api_keys_response.rb +33 -18
- data/lib/algolia/models/search/list_clusters_response.rb +33 -18
- data/lib/algolia/models/search/list_indices_response.rb +34 -19
- data/lib/algolia/models/search/list_user_ids_response.rb +33 -18
- data/lib/algolia/models/search/log.rb +70 -37
- data/lib/algolia/models/search/log_query.rb +31 -19
- data/lib/algolia/models/search/log_type.rb +2 -3
- data/lib/algolia/models/search/match_level.rb +2 -3
- data/lib/algolia/models/search/matched_geo_location.rb +35 -20
- data/lib/algolia/models/search/mode.rb +2 -3
- data/lib/algolia/models/search/multiple_batch_request.rb +35 -20
- data/lib/algolia/models/search/multiple_batch_response.rb +34 -19
- data/lib/algolia/models/search/numeric_filters.rb +33 -24
- data/lib/algolia/models/search/operation_index_params.rb +35 -20
- data/lib/algolia/models/search/operation_type.rb +2 -3
- data/lib/algolia/models/search/optional_filters.rb +33 -24
- data/lib/algolia/models/search/params.rb +32 -20
- data/lib/algolia/models/search/personalization.rb +35 -20
- data/lib/algolia/models/search/promote.rb +33 -24
- data/lib/algolia/models/search/promote_object_id.rb +34 -19
- data/lib/algolia/models/search/promote_object_ids.rb +36 -21
- data/lib/algolia/models/search/query_type.rb +2 -3
- data/lib/algolia/models/search/ranking_info.rb +76 -48
- data/lib/algolia/models/search/re_ranking_apply_filter.rb +33 -24
- data/lib/algolia/models/search/redirect.rb +30 -18
- data/lib/algolia/models/search/redirect_rule_index_metadata.rb +37 -22
- data/lib/algolia/models/search/redirect_rule_index_metadata_data.rb +33 -18
- data/lib/algolia/models/search/redirect_url.rb +212 -0
- data/lib/algolia/models/search/remove_stop_words.rb +33 -24
- data/lib/algolia/models/search/remove_user_id_response.rb +33 -18
- data/lib/algolia/models/search/remove_words_if_no_results.rb +2 -3
- data/lib/algolia/models/search/rendering_content.rb +45 -21
- data/lib/algolia/models/search/replace_all_objects_response.rb +35 -20
- data/lib/algolia/models/search/replace_source_response.rb +33 -18
- data/lib/algolia/models/search/rule.rb +37 -25
- data/lib/algolia/models/search/save_object_response.rb +35 -20
- data/lib/algolia/models/search/save_synonym_response.rb +35 -20
- data/lib/algolia/models/search/scope_type.rb +2 -3
- data/lib/algolia/models/search/search_dictionary_entries_params.rb +41 -26
- data/lib/algolia/models/search/search_dictionary_entries_response.rb +38 -23
- data/lib/algolia/models/search/search_for_facet_values_request.rb +37 -22
- data/lib/algolia/models/search/search_for_facet_values_response.rb +35 -20
- data/lib/algolia/models/search/search_for_facets.rb +218 -124
- data/lib/algolia/models/search/search_for_facets_options.rb +39 -24
- data/lib/algolia/models/search/search_for_hits.rb +214 -122
- data/lib/algolia/models/search/search_for_hits_options.rb +34 -19
- data/lib/algolia/models/search/search_hits.rb +26 -15
- data/lib/algolia/models/search/search_method_params.rb +34 -19
- data/lib/algolia/models/search/search_pagination.rb +282 -0
- data/lib/algolia/models/search/search_params.rb +33 -24
- data/lib/algolia/models/search/search_params_object.rb +208 -119
- data/lib/algolia/models/search/search_params_query.rb +33 -18
- data/lib/algolia/models/search/search_params_string.rb +33 -18
- data/lib/algolia/models/search/search_query.rb +33 -24
- data/lib/algolia/models/search/search_response.rb +154 -111
- data/lib/algolia/models/search/search_responses.rb +33 -18
- data/lib/algolia/models/search/search_result.rb +33 -24
- data/lib/algolia/models/search/search_rules_params.rb +45 -30
- data/lib/algolia/models/search/search_rules_response.rb +36 -21
- data/lib/algolia/models/search/search_strategy.rb +2 -3
- data/lib/algolia/models/search/search_synonyms_params.rb +41 -26
- data/lib/algolia/models/search/search_synonyms_response.rb +25 -14
- data/lib/algolia/models/search/search_type_default.rb +2 -3
- data/lib/algolia/models/search/search_type_facet.rb +2 -3
- data/lib/algolia/models/search/search_user_ids_params.rb +41 -26
- data/lib/algolia/models/search/search_user_ids_response.rb +42 -27
- data/lib/algolia/models/search/secured_api_key_restrictions.rb +38 -23
- data/lib/algolia/models/search/semantic_search.rb +35 -20
- data/lib/algolia/models/search/snippet_result.rb +34 -25
- data/lib/algolia/models/search/snippet_result_option.rb +34 -19
- data/lib/algolia/models/search/sort_remaining_by.rb +2 -3
- data/lib/algolia/models/search/source.rb +30 -18
- data/lib/algolia/models/search/standard_entries.rb +39 -24
- data/lib/algolia/models/search/supported_language.rb +72 -5
- data/lib/algolia/models/search/synonym_hit.rb +40 -25
- data/lib/algolia/models/search/synonym_type.rb +2 -3
- data/lib/algolia/models/search/tag_filters.rb +33 -24
- data/lib/algolia/models/search/task_status.rb +2 -3
- data/lib/algolia/models/search/time_range.rb +34 -19
- data/lib/algolia/models/search/typo_tolerance.rb +33 -24
- data/lib/algolia/models/search/typo_tolerance_enum.rb +2 -3
- data/lib/algolia/models/search/update_api_key_response.rb +34 -19
- data/lib/algolia/models/search/updated_at_response.rb +34 -19
- data/lib/algolia/models/search/updated_at_with_object_id_response.rb +35 -20
- data/lib/algolia/models/search/updated_rule_response.rb +35 -20
- data/lib/algolia/models/search/user_highlight_result.rb +34 -19
- data/lib/algolia/models/search/user_hit.rb +35 -23
- data/lib/algolia/models/search/user_id.rb +33 -21
- data/lib/algolia/models/search/value.rb +31 -19
- data/lib/algolia/models/usage/error_base.rb +24 -13
- data/lib/algolia/models/usage/get_usage200_response.rb +33 -18
- data/lib/algolia/models/usage/get_usage200_response_statistics_inner.rb +34 -19
- data/lib/algolia/models/usage/get_usage400_response.rb +33 -18
- data/lib/algolia/models/usage/get_usage400_response_error.rb +35 -20
- data/lib/algolia/models/usage/get_usage400_response_error_errors_inner.rb +36 -21
- data/lib/algolia/models/usage/granularity.rb +2 -3
- data/lib/algolia/models/usage/statistic.rb +88 -5
- data/lib/algolia/models/usage/statistic_value.rb +33 -24
- data/lib/algolia/transport/call_type.rb +1 -1
- data/lib/algolia/transport/echo_requester.rb +11 -2
- data/lib/algolia/transport/http/http_requester.rb +23 -15
- data/lib/algolia/transport/http/response.rb +8 -8
- data/lib/algolia/transport/request_options.rb +6 -4
- data/lib/algolia/transport/retry_outcome_type.rb +3 -3
- data/lib/algolia/transport/retry_strategy.rb +8 -7
- data/lib/algolia/transport/stateful_host.rb +6 -6
- data/lib/algolia/transport/transport.rb +27 -20
- data/lib/algolia/user_agent.rb +1 -1
- data/lib/algolia/version.rb +1 -1
- data/lib/algolia.rb +16 -16
- metadata +22 -13
- data/.rubocop.yml +0 -99
@@ -5,9 +5,9 @@ module Algolia
|
|
5
5
|
attr_accessor :api_client
|
6
6
|
|
7
7
|
def initialize(config = nil)
|
8
|
-
raise
|
9
|
-
raise
|
10
|
-
raise
|
8
|
+
raise "`config` is missing." if config.nil?
|
9
|
+
raise "`app_id` is missing." if config.app_id.nil? || config.app_id == ""
|
10
|
+
raise "`api_key` is missing." if config.api_key.nil? || config.api_key == ""
|
11
11
|
|
12
12
|
@api_client = Algolia::ApiClient.new(config)
|
13
13
|
end
|
@@ -17,11 +17,14 @@ module Algolia
|
|
17
17
|
hosts << Transport::StatefulHost.new("#{app_id}-dsn.algolia.net", accept: CallType::READ)
|
18
18
|
hosts << Transport::StatefulHost.new("#{app_id}.algolia.net", accept: CallType::WRITE)
|
19
19
|
|
20
|
-
hosts += 1
|
21
|
-
|
22
|
-
|
20
|
+
hosts += 1
|
21
|
+
.upto(3)
|
22
|
+
.map do |i|
|
23
|
+
Transport::StatefulHost.new("#{app_id}-#{i}.algolianet.com", accept: CallType::READ | CallType::WRITE)
|
24
|
+
end
|
25
|
+
.shuffle
|
23
26
|
|
24
|
-
config = Algolia::Configuration.new(app_id, api_key, hosts,
|
27
|
+
config = Algolia::Configuration.new(app_id, api_key, hosts, "Usage", opts)
|
25
28
|
create_with_config(config)
|
26
29
|
end
|
27
30
|
|
@@ -41,7 +44,7 @@ module Algolia
|
|
41
44
|
raise ArgumentError, "Parameter `path` is required when calling `custom_delete`."
|
42
45
|
end
|
43
46
|
|
44
|
-
path =
|
47
|
+
path = "/{path}".sub("{" + "path" + "}", path.to_s)
|
45
48
|
query_params = {}
|
46
49
|
query_params = query_params.merge(parameters) unless parameters.nil?
|
47
50
|
query_params = query_params.merge(request_options[:query_params]) unless request_options[:query_params].nil?
|
@@ -51,7 +54,7 @@ module Algolia
|
|
51
54
|
post_body = request_options[:debug_body]
|
52
55
|
|
53
56
|
new_options = request_options.merge(
|
54
|
-
:operation => :
|
57
|
+
:operation => :"UsageClient.custom_delete",
|
55
58
|
:header_params => header_params,
|
56
59
|
:query_params => query_params,
|
57
60
|
:body => post_body,
|
@@ -69,7 +72,7 @@ module Algolia
|
|
69
72
|
# @return [Object]
|
70
73
|
def custom_delete(path, parameters = nil, request_options = {})
|
71
74
|
response = custom_delete_with_http_info(path, parameters, request_options)
|
72
|
-
@api_client.deserialize(response.body, request_options[:debug_return_type] ||
|
75
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Object")
|
73
76
|
end
|
74
77
|
|
75
78
|
# This method allow you to send requests to the Algolia REST API.
|
@@ -84,7 +87,7 @@ module Algolia
|
|
84
87
|
raise ArgumentError, "Parameter `path` is required when calling `custom_get`."
|
85
88
|
end
|
86
89
|
|
87
|
-
path =
|
90
|
+
path = "/{path}".sub("{" + "path" + "}", path.to_s)
|
88
91
|
query_params = {}
|
89
92
|
query_params = query_params.merge(parameters) unless parameters.nil?
|
90
93
|
query_params = query_params.merge(request_options[:query_params]) unless request_options[:query_params].nil?
|
@@ -94,7 +97,7 @@ module Algolia
|
|
94
97
|
post_body = request_options[:debug_body]
|
95
98
|
|
96
99
|
new_options = request_options.merge(
|
97
|
-
:operation => :
|
100
|
+
:operation => :"UsageClient.custom_get",
|
98
101
|
:header_params => header_params,
|
99
102
|
:query_params => query_params,
|
100
103
|
:body => post_body,
|
@@ -112,7 +115,7 @@ module Algolia
|
|
112
115
|
# @return [Object]
|
113
116
|
def custom_get(path, parameters = nil, request_options = {})
|
114
117
|
response = custom_get_with_http_info(path, parameters, request_options)
|
115
|
-
@api_client.deserialize(response.body, request_options[:debug_return_type] ||
|
118
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Object")
|
116
119
|
end
|
117
120
|
|
118
121
|
# This method allow you to send requests to the Algolia REST API.
|
@@ -128,7 +131,7 @@ module Algolia
|
|
128
131
|
raise ArgumentError, "Parameter `path` is required when calling `custom_post`."
|
129
132
|
end
|
130
133
|
|
131
|
-
path =
|
134
|
+
path = "/{path}".sub("{" + "path" + "}", path.to_s)
|
132
135
|
query_params = {}
|
133
136
|
query_params = query_params.merge(parameters) unless parameters.nil?
|
134
137
|
query_params = query_params.merge(request_options[:query_params]) unless request_options[:query_params].nil?
|
@@ -138,7 +141,7 @@ module Algolia
|
|
138
141
|
post_body = request_options[:debug_body] || @api_client.object_to_http_body(body)
|
139
142
|
|
140
143
|
new_options = request_options.merge(
|
141
|
-
:operation => :
|
144
|
+
:operation => :"UsageClient.custom_post",
|
142
145
|
:header_params => header_params,
|
143
146
|
:query_params => query_params,
|
144
147
|
:body => post_body,
|
@@ -157,7 +160,7 @@ module Algolia
|
|
157
160
|
# @return [Object]
|
158
161
|
def custom_post(path, parameters = nil, body = nil, request_options = {})
|
159
162
|
response = custom_post_with_http_info(path, parameters, body, request_options)
|
160
|
-
@api_client.deserialize(response.body, request_options[:debug_return_type] ||
|
163
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Object")
|
161
164
|
end
|
162
165
|
|
163
166
|
# This method allow you to send requests to the Algolia REST API.
|
@@ -173,7 +176,7 @@ module Algolia
|
|
173
176
|
raise ArgumentError, "Parameter `path` is required when calling `custom_put`."
|
174
177
|
end
|
175
178
|
|
176
|
-
path =
|
179
|
+
path = "/{path}".sub("{" + "path" + "}", path.to_s)
|
177
180
|
query_params = {}
|
178
181
|
query_params = query_params.merge(parameters) unless parameters.nil?
|
179
182
|
query_params = query_params.merge(request_options[:query_params]) unless request_options[:query_params].nil?
|
@@ -183,7 +186,7 @@ module Algolia
|
|
183
186
|
post_body = request_options[:debug_body] || @api_client.object_to_http_body(body)
|
184
187
|
|
185
188
|
new_options = request_options.merge(
|
186
|
-
:operation => :
|
189
|
+
:operation => :"UsageClient.custom_put",
|
187
190
|
:header_params => header_params,
|
188
191
|
:query_params => query_params,
|
189
192
|
:body => post_body,
|
@@ -202,7 +205,7 @@ module Algolia
|
|
202
205
|
# @return [Object]
|
203
206
|
def custom_put(path, parameters = nil, body = nil, request_options = {})
|
204
207
|
response = custom_put_with_http_info(path, parameters, body, request_options)
|
205
|
-
@api_client.deserialize(response.body, request_options[:debug_return_type] ||
|
208
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Object")
|
206
209
|
end
|
207
210
|
|
208
211
|
# Retrieves the selected usage statistics for one index.
|
@@ -214,7 +217,14 @@ module Algolia
|
|
214
217
|
# @param granularity [Granularity] Granularity of the aggregated metrics. - `hourly`: the maximum time range for hourly metrics is 7 days. - `daily`: the maximum time range for daily metrics is 365 days. (default to 'daily')
|
215
218
|
# @param request_options: The request options to send along with the query, they will be merged with the transporter base parameters (headers, query params, timeouts, etc.). (optional)
|
216
219
|
# @return [Http::Response] the response
|
217
|
-
def get_index_usage_with_http_info(
|
220
|
+
def get_index_usage_with_http_info(
|
221
|
+
statistic,
|
222
|
+
index_name,
|
223
|
+
start_date,
|
224
|
+
end_date,
|
225
|
+
granularity = nil,
|
226
|
+
request_options = {}
|
227
|
+
)
|
218
228
|
# verify the required parameter 'statistic' is set
|
219
229
|
if @api_client.config.client_side_validation && statistic.nil?
|
220
230
|
raise ArgumentError, "Parameter `statistic` is required when calling `get_index_usage`."
|
@@ -232,8 +242,10 @@ module Algolia
|
|
232
242
|
raise ArgumentError, "Parameter `end_date` is required when calling `get_index_usage`."
|
233
243
|
end
|
234
244
|
|
235
|
-
path =
|
236
|
-
|
245
|
+
path = "/1/usage/{statistic}/{indexName}".sub("{" + "statistic" + "}", Transport.encode_uri(statistic.to_s)).sub(
|
246
|
+
"{" + "indexName" + "}",
|
247
|
+
Transport.encode_uri(index_name.to_s)
|
248
|
+
)
|
237
249
|
query_params = {}
|
238
250
|
query_params[:startDate] = start_date
|
239
251
|
query_params[:endDate] = end_date
|
@@ -245,7 +257,7 @@ module Algolia
|
|
245
257
|
post_body = request_options[:debug_body]
|
246
258
|
|
247
259
|
new_options = request_options.merge(
|
248
|
-
:operation => :
|
260
|
+
:operation => :"UsageClient.get_index_usage",
|
249
261
|
:header_params => header_params,
|
250
262
|
:query_params => query_params,
|
251
263
|
:body => post_body,
|
@@ -265,8 +277,15 @@ module Algolia
|
|
265
277
|
# @param request_options: The request options to send along with the query, they will be merged with the transporter base parameters (headers, query params, timeouts, etc.). (optional)
|
266
278
|
# @return [GetUsage200Response]
|
267
279
|
def get_index_usage(statistic, index_name, start_date, end_date, granularity = nil, request_options = {})
|
268
|
-
response = get_index_usage_with_http_info(
|
269
|
-
|
280
|
+
response = get_index_usage_with_http_info(
|
281
|
+
statistic,
|
282
|
+
index_name,
|
283
|
+
start_date,
|
284
|
+
end_date,
|
285
|
+
granularity,
|
286
|
+
request_options
|
287
|
+
)
|
288
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Usage::GetUsage200Response")
|
270
289
|
end
|
271
290
|
|
272
291
|
# Retrieves usage statistics evaluated over a specified period.
|
@@ -291,7 +310,7 @@ module Algolia
|
|
291
310
|
raise ArgumentError, "Parameter `end_date` is required when calling `get_usage`."
|
292
311
|
end
|
293
312
|
|
294
|
-
path =
|
313
|
+
path = "/1/usage/{statistic}".sub("{" + "statistic" + "}", Transport.encode_uri(statistic.to_s))
|
295
314
|
query_params = {}
|
296
315
|
query_params[:startDate] = start_date
|
297
316
|
query_params[:endDate] = end_date
|
@@ -303,7 +322,7 @@ module Algolia
|
|
303
322
|
post_body = request_options[:debug_body]
|
304
323
|
|
305
324
|
new_options = request_options.merge(
|
306
|
-
:operation => :
|
325
|
+
:operation => :"UsageClient.get_usage",
|
307
326
|
:header_params => header_params,
|
308
327
|
:query_params => query_params,
|
309
328
|
:body => post_body,
|
@@ -323,7 +342,8 @@ module Algolia
|
|
323
342
|
# @return [GetUsage200Response]
|
324
343
|
def get_usage(statistic, start_date, end_date, granularity = nil, request_options = {})
|
325
344
|
response = get_usage_with_http_info(statistic, start_date, end_date, granularity, request_options)
|
326
|
-
@api_client.deserialize(response.body, request_options[:debug_return_type] ||
|
345
|
+
@api_client.deserialize(response.body, request_options[:debug_return_type] || "Usage::GetUsage200Response")
|
327
346
|
end
|
347
|
+
|
328
348
|
end
|
329
349
|
end
|
data/lib/algolia/api_client.rb
CHANGED
@@ -1,5 +1,5 @@
|
|
1
|
-
require
|
2
|
-
require
|
1
|
+
require "cgi"
|
2
|
+
require "json"
|
3
3
|
|
4
4
|
module Algolia
|
5
5
|
class ApiClient
|
@@ -12,7 +12,7 @@ module Algolia
|
|
12
12
|
# @option config [Configuration] Configuration for initializing the object, default to Configuration.default
|
13
13
|
def initialize(config = Configuration.default)
|
14
14
|
@config = config
|
15
|
-
@requester = config.requester || Http::HttpRequester.new(
|
15
|
+
@requester = config.requester || Http::HttpRequester.new("net_http_persistent", LoggerHelper.create)
|
16
16
|
@transporter = Transport::Transport.new(config, @requester)
|
17
17
|
end
|
18
18
|
|
@@ -28,9 +28,9 @@ module Algolia
|
|
28
28
|
call_type = opts[:use_read_transporter] || http_method == :GET ? CallType::READ : CallType::WRITE
|
29
29
|
response = transporter.request(call_type, http_method, path, opts[:body], opts)
|
30
30
|
rescue Faraday::TimeoutError
|
31
|
-
raise ApiError,
|
31
|
+
raise ApiError, "Connection timed out"
|
32
32
|
rescue Faraday::ConnectionFailed
|
33
|
-
raise ApiError,
|
33
|
+
raise ApiError, "Connection failed"
|
34
34
|
end
|
35
35
|
|
36
36
|
response
|
@@ -44,7 +44,7 @@ module Algolia
|
|
44
44
|
return nil if body.nil? || body.empty?
|
45
45
|
|
46
46
|
# return response body directly for String return type
|
47
|
-
return body.to_s if return_type ==
|
47
|
+
return body.to_s if return_type == "String"
|
48
48
|
|
49
49
|
begin
|
50
50
|
data = JSON.parse("[#{body}]", :symbolize_names => true)[0]
|
@@ -54,7 +54,7 @@ module Algolia
|
|
54
54
|
data = body
|
55
55
|
end
|
56
56
|
|
57
|
-
convert_to_type
|
57
|
+
convert_to_type(data, return_type)
|
58
58
|
end
|
59
59
|
|
60
60
|
# Convert data to the given return type.
|
@@ -65,21 +65,21 @@ module Algolia
|
|
65
65
|
return nil if data.nil?
|
66
66
|
|
67
67
|
case return_type
|
68
|
-
when
|
68
|
+
when "String"
|
69
69
|
data.to_s
|
70
|
-
when
|
70
|
+
when "Integer"
|
71
71
|
data.to_i
|
72
|
-
when
|
72
|
+
when "Float"
|
73
73
|
data.to_f
|
74
|
-
when
|
74
|
+
when "Boolean"
|
75
75
|
data == true
|
76
|
-
when
|
76
|
+
when "Time"
|
77
77
|
# parse date time (expecting ISO 8601 format)
|
78
|
-
Time.parse
|
79
|
-
when
|
78
|
+
Time.parse(data)
|
79
|
+
when "Date"
|
80
80
|
# parse date time (expecting ISO 8601 format)
|
81
|
-
Date.parse
|
82
|
-
when
|
81
|
+
Date.parse(data)
|
82
|
+
when "Object"
|
83
83
|
# generic object (usually a Hash), return directly
|
84
84
|
data
|
85
85
|
when /\AArray<(.+)>\z/
|
@@ -103,14 +103,15 @@ module Algolia
|
|
103
103
|
# @param [Object] model object to be converted into JSON string
|
104
104
|
# @return [String] JSON string representation of the object
|
105
105
|
def object_to_http_body(model)
|
106
|
-
return
|
106
|
+
return "{}" if model.nil?
|
107
107
|
return model if model.is_a?(String)
|
108
108
|
|
109
109
|
body = if model.is_a?(Array)
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
110
|
+
model.map { |m| object_to_hash(m) }
|
111
|
+
else
|
112
|
+
object_to_hash(model)
|
113
|
+
end
|
114
|
+
|
114
115
|
body.to_json
|
115
116
|
end
|
116
117
|
|
@@ -132,13 +133,13 @@ module Algolia
|
|
132
133
|
def build_collection_param(param, collection_format)
|
133
134
|
case collection_format
|
134
135
|
when :csv
|
135
|
-
param.join(
|
136
|
+
param.join(",")
|
136
137
|
when :ssv
|
137
|
-
param.join(
|
138
|
+
param.join(" ")
|
138
139
|
when :tsv
|
139
140
|
param.join("\t")
|
140
141
|
when :pipes
|
141
|
-
param.join(
|
142
|
+
param.join("|")
|
142
143
|
when :multi
|
143
144
|
# return the array directly as typhoeus will handle it as expected
|
144
145
|
param
|
data/lib/algolia/api_error.rb
CHANGED
@@ -10,15 +10,15 @@ module Algolia
|
|
10
10
|
# ApiError.new(:code => 500, :response_headers => {}, :response_body => "")
|
11
11
|
# ApiError.new(:code => 404, :message => "Not Found")
|
12
12
|
def initialize(arg = nil)
|
13
|
-
if arg.is_a?
|
14
|
-
if arg.key?(:message) || arg.key?(
|
15
|
-
super(arg[:message] || arg[
|
13
|
+
if arg.is_a?(Hash)
|
14
|
+
if arg.key?(:message) || arg.key?("message")
|
15
|
+
super(arg[:message] || arg["message"])
|
16
16
|
else
|
17
17
|
super
|
18
18
|
end
|
19
19
|
|
20
20
|
arg.each do |k, v|
|
21
|
-
instance_variable_set
|
21
|
+
instance_variable_set("@#{k}", v)
|
22
22
|
end
|
23
23
|
else
|
24
24
|
super
|
@@ -33,10 +33,10 @@ module Algolia
|
|
33
33
|
|
34
34
|
def message
|
35
35
|
msg = if @message.nil?
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
36
|
+
"Error message: the server returns an error"
|
37
|
+
else
|
38
|
+
@message
|
39
|
+
end
|
40
40
|
|
41
41
|
msg += "\nHTTP status code: #{code}" if code
|
42
42
|
msg += "\nResponse headers: #{response_headers}" if response_headers
|
@@ -2,7 +2,18 @@
|
|
2
2
|
|
3
3
|
module Algolia
|
4
4
|
class Configuration
|
5
|
-
attr_accessor
|
5
|
+
attr_accessor(
|
6
|
+
:hosts,
|
7
|
+
:app_id,
|
8
|
+
:api_key,
|
9
|
+
:user_agent,
|
10
|
+
:header_params,
|
11
|
+
:read_timeout,
|
12
|
+
:write_timeout,
|
13
|
+
:connect_timeout,
|
14
|
+
:compression_type,
|
15
|
+
:requester
|
16
|
+
)
|
6
17
|
|
7
18
|
# Set this to false to skip client side validation in the operation.
|
8
19
|
# Default to true.
|
@@ -17,16 +28,16 @@ module Algolia
|
|
17
28
|
@write_timeout = opts[:write_timeout] || 30_000
|
18
29
|
@read_timeout = opts[:read_timeout] || 5_000
|
19
30
|
@connect_timeout = opts[:connect_timeout] || 2_000
|
20
|
-
@compression_type = opts[:compression_type] ||
|
31
|
+
@compression_type = opts[:compression_type] || "none"
|
21
32
|
@requester = opts[:requester]
|
22
33
|
|
23
34
|
@user_agent = UserAgent.new.add(client_name, VERSION)
|
24
35
|
|
25
36
|
@header_params = {
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
37
|
+
"X-Algolia-Application-Id" => app_id,
|
38
|
+
"X-Algolia-API-Key" => api_key,
|
39
|
+
"Content-Type" => "application/json",
|
40
|
+
"User-Agent" => @user_agent
|
30
41
|
}
|
31
42
|
@header_params.transform_keys!(&:downcase)
|
32
43
|
|
data/lib/algolia/error.rb
CHANGED
@@ -20,9 +20,9 @@ module Algolia
|
|
20
20
|
attr_accessor :code, :message
|
21
21
|
|
22
22
|
def initialize(code, message)
|
23
|
-
self.code
|
23
|
+
self.code = code
|
24
24
|
self.message = message
|
25
|
-
super("#{self.code}: #{self.message}")
|
25
|
+
super("#{self.code()}: #{self.message()}")
|
26
26
|
end
|
27
27
|
end
|
28
28
|
end
|
@@ -1,13 +1,13 @@
|
|
1
|
-
require
|
1
|
+
require "logger"
|
2
2
|
|
3
3
|
module Algolia
|
4
4
|
class LoggerHelper
|
5
5
|
# @param debug_file [nil|String] file used to output the logs
|
6
6
|
#
|
7
7
|
def self.create(debug_file = nil)
|
8
|
-
file
|
9
|
-
instance
|
10
|
-
instance.progname =
|
8
|
+
file = debug_file || (ENV["ALGOLIA_DEBUG"] ? File.new("debug.log", "a+") : $stderr)
|
9
|
+
instance = ::Logger.new(file)
|
10
|
+
instance.progname = "algolia"
|
11
11
|
instance
|
12
12
|
end
|
13
13
|
end
|
@@ -1,7 +1,7 @@
|
|
1
1
|
# Code generated by OpenAPI Generator (https://openapi-generator.tech), manual changes will be lost - read more on https://github.com/algolia/api-clients-automation. DO NOT EDIT.
|
2
2
|
|
3
|
-
require
|
4
|
-
require
|
3
|
+
require "date"
|
4
|
+
require "time"
|
5
5
|
|
6
6
|
module Algolia
|
7
7
|
module Abtesting
|
@@ -87,49 +87,54 @@ module Algolia
|
|
87
87
|
# Attribute type mapping.
|
88
88
|
def self.types_mapping
|
89
89
|
{
|
90
|
-
:ab_test_id => :Integer,
|
91
|
-
:click_significance => :Float,
|
92
|
-
:conversion_significance => :Float,
|
93
|
-
:add_to_cart_significance => :Float,
|
94
|
-
:purchase_significance => :Float,
|
95
|
-
:revenue_significance => :
|
96
|
-
:updated_at => :String,
|
97
|
-
:created_at => :String,
|
98
|
-
:end_at => :String,
|
99
|
-
:name => :String,
|
100
|
-
:status => :Status,
|
101
|
-
:variants => :
|
102
|
-
:configuration => :ABTestConfiguration
|
90
|
+
:ab_test_id => :"Integer",
|
91
|
+
:click_significance => :"Float",
|
92
|
+
:conversion_significance => :"Float",
|
93
|
+
:add_to_cart_significance => :"Float",
|
94
|
+
:purchase_significance => :"Float",
|
95
|
+
:revenue_significance => :"Hash<String, Float>",
|
96
|
+
:updated_at => :"String",
|
97
|
+
:created_at => :"String",
|
98
|
+
:end_at => :"String",
|
99
|
+
:name => :"String",
|
100
|
+
:status => :"Status",
|
101
|
+
:variants => :"Array<Variant>",
|
102
|
+
:configuration => :"ABTestConfiguration"
|
103
103
|
}
|
104
104
|
end
|
105
105
|
|
106
106
|
# List of attributes with nullable: true
|
107
107
|
def self.openapi_nullable
|
108
|
-
Set.new(
|
109
|
-
|
110
|
-
|
111
|
-
|
112
|
-
|
113
|
-
|
114
|
-
|
108
|
+
Set.new(
|
109
|
+
[
|
110
|
+
:click_significance,
|
111
|
+
:conversion_significance,
|
112
|
+
:add_to_cart_significance,
|
113
|
+
:purchase_significance,
|
114
|
+
:revenue_significance
|
115
|
+
]
|
116
|
+
)
|
115
117
|
end
|
116
118
|
|
117
119
|
# Initializes the object
|
118
120
|
# @param [Hash] attributes Model attributes in the form of hash
|
119
121
|
def initialize(attributes = {})
|
120
|
-
|
122
|
+
if (!attributes.is_a?(Hash))
|
121
123
|
raise ArgumentError, "The input argument (attributes) must be a hash in `Algolia::ABTest` initialize method"
|
122
124
|
end
|
123
125
|
|
124
126
|
# check to see if the attribute exists and convert string to symbol for hash key
|
125
|
-
attributes = attributes.each_with_object({})
|
126
|
-
|
127
|
-
raise
|
128
|
-
|
127
|
+
attributes = attributes.each_with_object({}) { |(k, v), h|
|
128
|
+
if (!self.class.attribute_map.key?(k.to_sym))
|
129
|
+
raise(
|
130
|
+
ArgumentError,
|
131
|
+
"`#{k}` is not a valid attribute in `Algolia::ABTest`. Please check the name to make sure it's valid. List of attributes: " +
|
132
|
+
self.class.attribute_map.keys.inspect
|
133
|
+
)
|
129
134
|
end
|
130
135
|
|
131
136
|
h[k.to_sym] = v
|
132
|
-
|
137
|
+
}
|
133
138
|
|
134
139
|
if attributes.key?(:ab_test_id)
|
135
140
|
self.ab_test_id = attributes[:ab_test_id]
|
@@ -215,8 +220,7 @@ module Algolia
|
|
215
220
|
# Checks equality by comparing each attribute.
|
216
221
|
# @param [Object] Object to be compared
|
217
222
|
def ==(other)
|
218
|
-
return true if equal?(other)
|
219
|
-
|
223
|
+
return true if self.equal?(other)
|
220
224
|
self.class == other.class &&
|
221
225
|
ab_test_id == other.ab_test_id &&
|
222
226
|
click_significance == other.click_significance &&
|
@@ -242,8 +246,21 @@ module Algolia
|
|
242
246
|
# Calculates hash code according to all attributes.
|
243
247
|
# @return [Integer] Hash code
|
244
248
|
def hash
|
245
|
-
[
|
246
|
-
|
249
|
+
[
|
250
|
+
ab_test_id,
|
251
|
+
click_significance,
|
252
|
+
conversion_significance,
|
253
|
+
add_to_cart_significance,
|
254
|
+
purchase_significance,
|
255
|
+
revenue_significance,
|
256
|
+
updated_at,
|
257
|
+
created_at,
|
258
|
+
end_at,
|
259
|
+
name,
|
260
|
+
status,
|
261
|
+
variants,
|
262
|
+
configuration
|
263
|
+
].hash
|
247
264
|
end
|
248
265
|
|
249
266
|
# Builds the object from hash
|
@@ -251,7 +268,6 @@ module Algolia
|
|
251
268
|
# @return [Object] Returns the model itself
|
252
269
|
def self.build_from_hash(attributes)
|
253
270
|
return nil unless attributes.is_a?(Hash)
|
254
|
-
|
255
271
|
attributes = attributes.transform_keys(&:to_sym)
|
256
272
|
transformed_hash = {}
|
257
273
|
types_mapping.each_pair do |key, type|
|
@@ -261,12 +277,15 @@ module Algolia
|
|
261
277
|
# check to ensure the input is an array given that the attribute
|
262
278
|
# is documented as an array but the input is not
|
263
279
|
if attributes[attribute_map[key]].is_a?(Array)
|
264
|
-
transformed_hash[key.to_sym] = attributes[attribute_map[key]].map { |v|
|
280
|
+
transformed_hash[key.to_sym] = attributes[attribute_map[key]].map { |v|
|
281
|
+
_deserialize(::Regexp.last_match(1), v)
|
282
|
+
}
|
265
283
|
end
|
266
284
|
elsif !attributes[attribute_map[key]].nil?
|
267
285
|
transformed_hash[key.to_sym] = _deserialize(type, attributes[attribute_map[key]])
|
268
286
|
end
|
269
287
|
end
|
288
|
+
|
270
289
|
new(transformed_hash)
|
271
290
|
end
|
272
291
|
|
@@ -292,6 +311,7 @@ module Algolia
|
|
292
311
|
else
|
293
312
|
false
|
294
313
|
end
|
314
|
+
|
295
315
|
when :Object
|
296
316
|
# generic object (usually a Hash), return directly
|
297
317
|
value
|
@@ -306,10 +326,12 @@ module Algolia
|
|
306
326
|
hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
|
307
327
|
end
|
308
328
|
end
|
309
|
-
|
329
|
+
# model
|
330
|
+
else
|
310
331
|
# models (e.g. Pet) or oneOf
|
311
332
|
klass = Algolia::Abtesting.const_get(type)
|
312
|
-
klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass
|
333
|
+
klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass
|
334
|
+
.build_from_hash(value)
|
313
335
|
end
|
314
336
|
end
|
315
337
|
|
@@ -342,6 +364,7 @@ module Algolia
|
|
342
364
|
|
343
365
|
hash[param] = _to_hash(value)
|
344
366
|
end
|
367
|
+
|
345
368
|
hash
|
346
369
|
end
|
347
370
|
|
@@ -356,12 +379,14 @@ module Algolia
|
|
356
379
|
{}.tap do |hash|
|
357
380
|
value.each { |k, v| hash[k] = _to_hash(v) }
|
358
381
|
end
|
359
|
-
elsif value.respond_to?
|
382
|
+
elsif value.respond_to?(:to_hash)
|
360
383
|
value.to_hash
|
361
384
|
else
|
362
385
|
value
|
363
386
|
end
|
364
387
|
end
|
388
|
+
|
365
389
|
end
|
390
|
+
|
366
391
|
end
|
367
392
|
end
|