elastic-enterprise-search 7.17.0 → 8.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (158) hide show
  1. checksums.yaml +4 -4
  2. data/.ci/jobs/elastic+enterprise-search-ruby+7.15.yml +12 -0
  3. data/.ci/jobs/elastic+enterprise-search-ruby+7.16.yml +12 -0
  4. data/.ci/test-matrix.yml +1 -2
  5. data/.github/workflows/testing.yml +3 -4
  6. data/.rubocop.yml +1 -1
  7. data/CHANGELOG +1 -0
  8. data/CODE_OF_CONDUCT +1 -0
  9. data/CONTRIBUTING.md +37 -0
  10. data/NOTICE +2 -0
  11. data/README.md +25 -29
  12. data/docs/guide/app-search-api.asciidoc +52 -18
  13. data/docs/guide/overview.asciidoc +11 -3
  14. data/docs/guide/release_notes/712.asciidoc +10 -0
  15. data/docs/guide/release_notes/80.asciidoc +117 -0
  16. data/docs/guide/release_notes/81.asciidoc +8 -0
  17. data/docs/guide/release_notes/index.asciidoc +6 -0
  18. data/docs/guide/workplace-search-api.asciidoc +14 -7
  19. data/elastic-enterprise-search.gemspec +3 -3
  20. data/lib/elastic/api/response.rb +52 -0
  21. data/lib/elastic/{workplace-search/api/user_permissions.rb → app-search/api/adaptive_relevance_settings.rb} +10 -15
  22. data/lib/elastic/{workplace-search/api/add_user_permissions.rb → app-search/api/adaptive_relevance_suggestions.rb} +19 -14
  23. data/lib/elastic/app-search/api/add_meta_engine_source.rb +3 -5
  24. data/lib/elastic/app-search/api/api_key.rb +3 -6
  25. data/lib/elastic/app-search/api/api_logs.rb +7 -15
  26. data/lib/elastic/app-search/api/count_analytics.rb +4 -5
  27. data/lib/elastic/app-search/api/crawler_active_crawl_request.rb +4 -7
  28. data/lib/elastic/app-search/api/crawler_crawl_request.rb +5 -8
  29. data/lib/elastic/app-search/api/crawler_crawl_schedule.rb +4 -7
  30. data/lib/elastic/app-search/api/crawler_domain.rb +5 -8
  31. data/lib/elastic/app-search/api/crawler_domain_validation_result.rb +5 -5
  32. data/lib/elastic/app-search/api/crawler_metrics.rb +3 -6
  33. data/lib/elastic/app-search/api/crawler_overview.rb +4 -7
  34. data/lib/elastic/app-search/api/crawler_process_crawl.rb +5 -8
  35. data/lib/elastic/app-search/api/crawler_process_crawl_denied_urls.rb +5 -8
  36. data/lib/elastic/app-search/api/crawler_url_extraction_result.rb +6 -7
  37. data/lib/elastic/app-search/api/crawler_url_tracing_result.rb +6 -7
  38. data/lib/elastic/app-search/api/crawler_url_validation_result.rb +6 -7
  39. data/lib/elastic/app-search/api/crawler_user_agent.rb +3 -6
  40. data/lib/elastic/app-search/api/create_api_key.rb +9 -10
  41. data/lib/elastic/app-search/api/create_crawler_crawl_request.rb +9 -5
  42. data/lib/elastic/app-search/api/create_crawler_crawl_rule.rb +12 -11
  43. data/lib/elastic/app-search/api/create_crawler_domain.rb +7 -8
  44. data/lib/elastic/app-search/api/create_crawler_entry_point.rb +9 -8
  45. data/lib/elastic/app-search/api/create_crawler_process_crawl.rb +5 -6
  46. data/lib/elastic/app-search/api/create_crawler_sitemap.rb +9 -8
  47. data/lib/elastic/app-search/api/create_curation.rb +9 -8
  48. data/lib/elastic/app-search/api/create_engine.rb +7 -7
  49. data/lib/elastic/app-search/api/create_synonym_set.rb +5 -6
  50. data/lib/elastic/app-search/api/curation.rb +4 -7
  51. data/lib/elastic/app-search/api/delete_api_key.rb +3 -6
  52. data/lib/elastic/app-search/api/delete_crawler_active_crawl_request.rb +4 -7
  53. data/lib/elastic/app-search/api/delete_crawler_crawl_rule.rb +6 -9
  54. data/lib/elastic/app-search/api/delete_crawler_crawl_schedule.rb +4 -7
  55. data/lib/elastic/app-search/api/delete_crawler_domain.rb +5 -8
  56. data/lib/elastic/app-search/api/delete_crawler_entry_point.rb +6 -9
  57. data/lib/elastic/app-search/api/delete_crawler_sitemap.rb +6 -9
  58. data/lib/elastic/app-search/api/delete_curation.rb +4 -7
  59. data/lib/elastic/app-search/api/delete_documents.rb +3 -5
  60. data/lib/elastic/app-search/api/delete_engine.rb +3 -6
  61. data/lib/elastic/app-search/api/delete_meta_engine_source.rb +3 -4
  62. data/lib/elastic/app-search/api/delete_synonym_set.rb +4 -7
  63. data/lib/elastic/app-search/api/documents.rb +4 -5
  64. data/lib/elastic/app-search/api/engine.rb +3 -6
  65. data/lib/elastic/app-search/api/index_documents.rb +3 -5
  66. data/lib/elastic/{workplace-search/api/remove_user_permissions.rb → app-search/api/list_adaptive_relevance_suggestions.rb} +12 -14
  67. data/lib/elastic/app-search/api/list_api_keys.rb +2 -5
  68. data/lib/elastic/app-search/api/list_crawler_crawl_requests.rb +6 -8
  69. data/lib/elastic/{workplace-search/api/list_permissions.rb → app-search/api/list_crawler_domains.rb} +12 -13
  70. data/lib/elastic/app-search/api/list_crawler_process_crawls.rb +6 -7
  71. data/lib/elastic/app-search/api/list_curations.rb +3 -6
  72. data/lib/elastic/app-search/api/list_documents.rb +3 -6
  73. data/lib/elastic/app-search/api/list_engines.rb +2 -5
  74. data/lib/elastic/app-search/api/list_synonym_sets.rb +3 -6
  75. data/lib/elastic/app-search/api/log_clickthrough.rb +8 -8
  76. data/lib/elastic/{workplace-search/api/put_user_permissions.rb → app-search/api/put_adaptive_relevance_settings.rb} +12 -14
  77. data/lib/elastic/app-search/api/put_adaptive_relevance_suggestions.rb +50 -0
  78. data/lib/elastic/app-search/api/put_api_key.rb +10 -10
  79. data/lib/elastic/app-search/api/put_crawler_crawl_rule.rb +13 -12
  80. data/lib/elastic/app-search/api/put_crawler_crawl_schedule.rb +7 -7
  81. data/lib/elastic/app-search/api/put_crawler_domain.rb +8 -9
  82. data/lib/elastic/app-search/api/put_crawler_entry_point.rb +10 -9
  83. data/lib/elastic/app-search/api/put_crawler_sitemap.rb +10 -9
  84. data/lib/elastic/app-search/api/put_curation.rb +10 -9
  85. data/lib/elastic/app-search/api/put_documents.rb +3 -4
  86. data/lib/elastic/app-search/api/put_schema.rb +3 -4
  87. data/lib/elastic/app-search/api/put_search_settings.rb +5 -6
  88. data/lib/elastic/app-search/api/put_synonym_set.rb +7 -8
  89. data/lib/elastic/app-search/api/query_suggestion.rb +4 -5
  90. data/lib/elastic/app-search/api/refresh_adaptive_relevance_update_process.rb +55 -0
  91. data/lib/elastic/app-search/api/reset_search_settings.rb +3 -6
  92. data/lib/elastic/app-search/api/schema.rb +3 -6
  93. data/lib/elastic/app-search/api/search.rb +5 -5
  94. data/lib/elastic/app-search/api/search_settings.rb +3 -6
  95. data/lib/elastic/app-search/api/synonym_set.rb +4 -7
  96. data/lib/elastic/app-search/api/top_clicks_analytics.rb +4 -5
  97. data/lib/elastic/app-search/api/top_queries_analytics.rb +3 -4
  98. data/lib/elastic/enterprise-search/api/health.rb +2 -3
  99. data/lib/elastic/enterprise-search/api/put_read_only.rb +5 -4
  100. data/lib/elastic/enterprise-search/api/read_only.rb +2 -3
  101. data/lib/elastic/enterprise-search/api/stats.rb +2 -3
  102. data/lib/elastic/enterprise-search/api/version.rb +2 -3
  103. data/lib/elastic/enterprise-search/client.rb +8 -13
  104. data/lib/elastic/enterprise-search/request.rb +5 -3
  105. data/lib/elastic/enterprise-search/version.rb +1 -1
  106. data/lib/elastic/workplace-search/api/auto_query_refinement_details.rb +3 -4
  107. data/lib/elastic/workplace-search/api/command_sync_jobs.rb +4 -5
  108. data/lib/elastic/workplace-search/api/content_source.rb +3 -4
  109. data/lib/elastic/workplace-search/api/create_analytics_event.rb +16 -12
  110. data/lib/elastic/workplace-search/api/create_batch_synonym_sets.rb +4 -3
  111. data/lib/elastic/workplace-search/api/create_content_source.rb +6 -5
  112. data/lib/elastic/workplace-search/api/create_external_identity.rb +11 -6
  113. data/lib/elastic/workplace-search/api/current_user.rb +3 -5
  114. data/lib/elastic/workplace-search/api/delete_content_source.rb +3 -4
  115. data/lib/elastic/workplace-search/api/delete_documents.rb +4 -4
  116. data/lib/elastic/workplace-search/api/delete_documents_by_query.rb +4 -3
  117. data/lib/elastic/workplace-search/api/delete_external_identity.rb +7 -9
  118. data/lib/elastic/workplace-search/api/delete_synonym_set.rb +3 -5
  119. data/lib/elastic/workplace-search/api/document.rb +4 -6
  120. data/lib/elastic/workplace-search/api/external_identity.rb +7 -9
  121. data/lib/elastic/workplace-search/api/index_documents.rb +3 -4
  122. data/lib/elastic/workplace-search/api/list_content_sources.rb +2 -3
  123. data/lib/elastic/workplace-search/api/list_documents.rb +4 -5
  124. data/lib/elastic/workplace-search/api/list_external_identities.rb +3 -4
  125. data/lib/elastic/workplace-search/api/list_synonym_sets.rb +1 -2
  126. data/lib/elastic/workplace-search/api/put_content_source.rb +6 -6
  127. data/lib/elastic/workplace-search/api/put_content_source_icons.rb +6 -6
  128. data/lib/elastic/workplace-search/api/put_external_identity.rb +11 -10
  129. data/lib/elastic/workplace-search/api/put_synonym_set.rb +4 -4
  130. data/lib/elastic/workplace-search/api/put_triggers_blocklist.rb +3 -5
  131. data/lib/elastic/workplace-search/api/search.rb +13 -13
  132. data/lib/elastic/workplace-search/api/synonym_set.rb +3 -5
  133. data/lib/elastic/workplace-search/api/triggers_blocklist.rb +3 -3
  134. data/spec/app-search/client_spec.rb +29 -0
  135. data/spec/enterprise-search/client_spec.rb +29 -0
  136. data/spec/enterprise-search/request_spec.rb +1 -1
  137. data/spec/integration/app-search/adaptive_relevance_settings_spec.rb +60 -0
  138. data/spec/integration/app-search/adaptive_relevance_suggestions_spec.rb +54 -0
  139. data/spec/integration/app-search/api_logs_spec.rb +11 -3
  140. data/spec/integration/app-search/app_search_helper.rb +2 -2
  141. data/spec/integration/app-search/count_analytics_spec.rb +3 -2
  142. data/spec/integration/app-search/crawler_domain_spec.rb +16 -0
  143. data/spec/integration/app-search/curations_spec.rb +15 -9
  144. data/spec/integration/app-search/engines_spec.rb +24 -26
  145. data/spec/integration/app-search/log_clickthrough_spec.rb +1 -1
  146. data/spec/integration/app-search/meta_engines_spec.rb +5 -5
  147. data/spec/integration/app-search/search_and_multiple_search_spec.rb +1 -1
  148. data/spec/integration/workplace-search/content_sources_spec.rb +6 -6
  149. data/spec/integration/workplace-search/documents_spec.rb +20 -10
  150. data/spec/integration/workplace-search/external_identities_spec.rb +26 -16
  151. data/spec/integration/workplace-search/triggers_spec.rb +2 -2
  152. data/spec/integration/workplace-search/users_spec.rb +0 -6
  153. data/spec/workplace-search/client_spec.rb +29 -0
  154. metadata +27 -19
  155. data/.ci/jobs/elastic+enterprise-search-ruby+7.10.0.beta.1.yml +0 -12
  156. data/.github/compatibility/Gemfile +0 -23
  157. data/.github/workflows/compatibility.yml +0 -20
  158. data/spec/integration/workplace-search/permissions_spec.rb +0 -77
@@ -24,27 +24,27 @@ module Elastic
24
24
  # Credentials - Update an API key
25
25
  # Updates an API key
26
26
  #
27
- # @param arguments [Hash] endpoint arguments
27
+ # @param [Hash] arguments endpoint arguments
28
28
  # @option arguments [String] :api_key_name Name of an API key (*Required*)
29
- # @option arguments [Hash] :body Details of an API key (Required: name, type)
30
- # @option body [String] :id
31
- # @option body [String] :name (*Required)
32
- # @option body [String] :type (*Required)
33
- # @option body [Boolean] :access_all_engines
29
+ # @option arguments [Hash] :body (Required: name, type)
30
+ # @option body [string] :id
31
+ # @option body [string] :name
32
+ # @option body [string] :type
33
+ # @option body [boolean] :access_all_engines
34
34
  # @option body :engines
35
- # @option body [Boolean] :write
36
- # @option body [Boolean] :read
35
+ # @option body [boolean] :write
36
+ # @option body [boolean] :read
37
37
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
38
38
  #
39
39
  # @see https://www.elastic.co/guide/en/app-search/current/credentials.html#credentials-update
40
40
  #
41
41
  def put_api_key(arguments = {})
42
42
  raise ArgumentError, "Required parameter 'api_key_name' missing" unless arguments[:api_key_name]
43
+ raise ArgumentError, "Required parameter 'body (name,type)' missing" unless arguments[:body]
43
44
 
44
- api_key_name = arguments[:api_key_name]
45
+ api_key_name = arguments.delete(:api_key_name)
45
46
  body = arguments.delete(:body) || {}
46
47
  headers = arguments.delete(:headers) || {}
47
-
48
48
  request(
49
49
  :put,
50
50
  "api/as/v1/credentials/#{api_key_name}/",
@@ -24,16 +24,17 @@ module Elastic
24
24
  # Crawler - Update a crawl rule
25
25
  # Updates crawl rule configuration
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :domain_id Crawler Domain ID (*Required*)
30
30
  # @option arguments [String] :crawl_rule_id Crawl Rule ID (*Required*)
31
- # @option arguments [Hash] :body (Required: order, policy, rule, pattern)
32
- # @option body [String] :id
33
- # @option body [Integer] :order (*Required)
34
- # @option body [String] :policy (*Required)
35
- # @option body [String] :rule (*Required)
36
- # @option body [String] :pattern (*Required)
31
+ # @option arguments [Hash] :body (Required: order, policy, rule, pattern)
32
+ # @option body [string] :id
33
+ # @option body [integer] :order
34
+ # @option body [string] :policy
35
+ # @option body [string] :rule
36
+ # @option body [string] :pattern
37
+ # @option body [string] :created_at
37
38
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
38
39
  #
39
40
  # @see https://www.elastic.co/guide/en/app-search/current/web-crawler-api-reference.html#web-crawler-apis-put-crawl-rule
@@ -42,15 +43,15 @@ module Elastic
42
43
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
43
44
  raise ArgumentError, "Required parameter 'domain_id' missing" unless arguments[:domain_id]
44
45
  raise ArgumentError, "Required parameter 'crawl_rule_id' missing" unless arguments[:crawl_rule_id]
46
+ raise ArgumentError, "Required parameter 'body (order,policy,rule,pattern)' missing" unless arguments[:body]
45
47
 
46
- domain_id = arguments[:domain_id]
47
- crawl_rule_id = arguments[:crawl_rule_id]
48
+ domain_id = arguments.delete(:domain_id)
49
+ crawl_rule_id = arguments.delete(:crawl_rule_id)
48
50
  body = arguments.delete(:body) || {}
49
51
  headers = arguments.delete(:headers) || {}
50
-
51
52
  request(
52
53
  :put,
53
- "api/as/v0/engines/#{engine_name}/crawler/domains/#{domain_id}/crawl_rules/#{crawl_rule_id}/",
54
+ "api/as/v1/engines/#{engine_name}/crawler/domains/#{domain_id}/crawl_rules/#{crawl_rule_id}/",
54
55
  arguments,
55
56
  body,
56
57
  headers
@@ -24,24 +24,24 @@ module Elastic
24
24
  # Crawler - Set crawl schedule
25
25
  # Sets up a crawl schedule for a given engine
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body (Required: frequency, unit)
30
- # @option body [Integer] :frequency (*Required)
31
- # @option body [String] :unit (*Required)
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
+ # @option arguments [Hash] :body (Required: frequency, unit)
30
+ # @option body [integer] :frequency
31
+ # @option body [string] :unit
32
32
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
33
33
  #
34
34
  # @see https://www.elastic.co/guide/en/app-search/current/web-crawler-api-reference.html#web-crawler-apis-put-crawler-crawl-schedule
35
35
  #
36
36
  def put_crawler_crawl_schedule(engine_name, arguments = {})
37
37
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
38
+ raise ArgumentError, "Required parameter 'body (frequency,unit)' missing" unless arguments[:body]
38
39
 
39
40
  body = arguments.delete(:body) || {}
40
41
  headers = arguments.delete(:headers) || {}
41
-
42
42
  request(
43
43
  :put,
44
- "api/as/v0/engines/#{engine_name}/crawler/crawl_schedule/",
44
+ "api/as/v1/engines/#{engine_name}/crawler/crawl_schedule/",
45
45
  arguments,
46
46
  body,
47
47
  headers
@@ -24,14 +24,14 @@ module Elastic
24
24
  # Crawler - Update domain configuration
25
25
  # Updates crawler domain configuration for a given domain
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :domain_id Crawler Domain ID (*Required*)
30
30
  # @option arguments [Hash] :body
31
- # @option body [String] :name
32
- # @option body [Array] :entry_points
33
- # @option body [Array] :crawl_rules
34
- # @option body [Array] :sitemaps
31
+ # @option body [string] :name
32
+ # @option body [Array<object>] :entry_points
33
+ # @option body [Array<object>] :crawl_rules
34
+ # @option body [Array<object>] :sitemaps
35
35
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
36
36
  #
37
37
  # @see https://www.elastic.co/guide/en/app-search/current/web-crawler-api-reference.html#web-crawler-apis-put-crawler-domain
@@ -40,13 +40,12 @@ module Elastic
40
40
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
41
41
  raise ArgumentError, "Required parameter 'domain_id' missing" unless arguments[:domain_id]
42
42
 
43
- domain_id = arguments[:domain_id]
43
+ domain_id = arguments.delete(:domain_id)
44
44
  body = arguments.delete(:body) || {}
45
45
  headers = arguments.delete(:headers) || {}
46
-
47
46
  request(
48
47
  :put,
49
- "api/as/v0/engines/#{engine_name}/crawler/domains/#{domain_id}/",
48
+ "api/as/v1/engines/#{engine_name}/crawler/domains/#{domain_id}/",
50
49
  arguments,
51
50
  body,
52
51
  headers
@@ -24,13 +24,14 @@ module Elastic
24
24
  # Crawler - Update a crawler entry point
25
25
  # Updates a crawler entry point with a new value
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :domain_id Crawler Domain ID (*Required*)
30
30
  # @option arguments [String] :entry_point_id Crawler Entry Point identifier (*Required*)
31
- # @option arguments [Hash] :body (Required: value)
32
- # @option body [String] :id
33
- # @option body [String] :value (*Required)
31
+ # @option arguments [Hash] :body (Required: value)
32
+ # @option body [string] :id
33
+ # @option body [string] :value
34
+ # @option body [string] :created_at
34
35
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
35
36
  #
36
37
  # @see https://www.elastic.co/guide/en/app-search/current/web-crawler-api-reference.html#web-crawler-apis-put-entry-point
@@ -39,15 +40,15 @@ module Elastic
39
40
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
40
41
  raise ArgumentError, "Required parameter 'domain_id' missing" unless arguments[:domain_id]
41
42
  raise ArgumentError, "Required parameter 'entry_point_id' missing" unless arguments[:entry_point_id]
43
+ raise ArgumentError, "Required parameter 'body (value)' missing" unless arguments[:body]
42
44
 
43
- domain_id = arguments[:domain_id]
44
- entry_point_id = arguments[:entry_point_id]
45
+ domain_id = arguments.delete(:domain_id)
46
+ entry_point_id = arguments.delete(:entry_point_id)
45
47
  body = arguments.delete(:body) || {}
46
48
  headers = arguments.delete(:headers) || {}
47
-
48
49
  request(
49
50
  :put,
50
- "api/as/v0/engines/#{engine_name}/crawler/domains/#{domain_id}/entry_points/#{entry_point_id}/",
51
+ "api/as/v1/engines/#{engine_name}/crawler/domains/#{domain_id}/entry_points/#{entry_point_id}/",
51
52
  arguments,
52
53
  body,
53
54
  headers
@@ -24,13 +24,14 @@ module Elastic
24
24
  # Crawler - Update a sitemap
25
25
  # Updates sitemap configuration
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :domain_id Crawler Domain ID (*Required*)
30
30
  # @option arguments [String] :sitemap_id Sitemap ID (*Required*)
31
- # @option arguments [Hash] :body (Required: url)
32
- # @option body [String] :id
33
- # @option body [String] :url (*Required)
31
+ # @option arguments [Hash] :body (Required: url)
32
+ # @option body [string] :id
33
+ # @option body :url
34
+ # @option body [string] :created_at
34
35
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
35
36
  #
36
37
  # @see https://www.elastic.co/guide/en/app-search/current/web-crawler-api-reference.html#web-crawler-apis-put-sitemap
@@ -39,15 +40,15 @@ module Elastic
39
40
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
40
41
  raise ArgumentError, "Required parameter 'domain_id' missing" unless arguments[:domain_id]
41
42
  raise ArgumentError, "Required parameter 'sitemap_id' missing" unless arguments[:sitemap_id]
43
+ raise ArgumentError, "Required parameter 'body (url)' missing" unless arguments[:body]
42
44
 
43
- domain_id = arguments[:domain_id]
44
- sitemap_id = arguments[:sitemap_id]
45
+ domain_id = arguments.delete(:domain_id)
46
+ sitemap_id = arguments.delete(:sitemap_id)
45
47
  body = arguments.delete(:body) || {}
46
48
  headers = arguments.delete(:headers) || {}
47
-
48
49
  request(
49
50
  :put,
50
- "api/as/v0/engines/#{engine_name}/crawler/domains/#{domain_id}/sitemaps/#{sitemap_id}/",
51
+ "api/as/v1/engines/#{engine_name}/crawler/domains/#{domain_id}/sitemaps/#{sitemap_id}/",
51
52
  arguments,
52
53
  body,
53
54
  headers
@@ -24,14 +24,15 @@ module Elastic
24
24
  # Curations - Update a curation
25
25
  # Updates an existing curation
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :curation_id Curation ID (*Required*)
30
- # @option arguments [Hash] :body (Required: queries)
31
- # @option body [String] :id
32
- # @option body [Array] :queries List of affected search queries (*Required)
33
- # @option body [Array] :promoted List of promoted document IDs
34
- # @option body [Array] :hidden List of hidden document IDs
30
+ # @option arguments [Hash] :body (Required: queries)
31
+ # @option body [string] :id
32
+ # @option body [Array<string>] :queries List of affected search queries
33
+ # @option body [Array<string>] :promoted List of promoted document IDs
34
+ # @option body [Array<string>] :hidden List of hidden document IDs
35
+ # @option body [Hash] :suggestion
35
36
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
36
37
  #
37
38
  # @see https://www.elastic.co/guide/en/app-search/current/curations.html#curations-update
@@ -39,11 +40,11 @@ module Elastic
39
40
  def put_curation(engine_name, arguments = {})
40
41
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
41
42
  raise ArgumentError, "Required parameter 'curation_id' missing" unless arguments[:curation_id]
43
+ raise ArgumentError, "Required parameter 'body (queries)' missing" unless arguments[:body]
42
44
 
43
- curation_id = arguments[:curation_id]
45
+ curation_id = arguments.delete(:curation_id)
44
46
  body = arguments.delete(:body) || {}
45
47
  headers = arguments.delete(:headers) || {}
46
-
47
48
  request(
48
49
  :put,
49
50
  "api/as/v1/engines/#{engine_name}/curations/#{curation_id}/",
@@ -24,9 +24,9 @@ module Elastic
24
24
  # Documents - Partial update of documents
25
25
  # Update specific document fields by id and field
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Array] :documents
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
+ # @option arguments [Array<Hash> { id: [string] }] :documents
30
30
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
31
  #
32
32
  # @see https://www.elastic.co/guide/en/app-search/current/documents.html#documents-partial
@@ -36,7 +36,6 @@ module Elastic
36
36
 
37
37
  documents = arguments.delete(:documents) || {}
38
38
  headers = arguments.delete(:headers) || {}
39
-
40
39
  request(
41
40
  :patch,
42
41
  "api/as/v1/engines/#{engine_name}/documents/",
@@ -24,9 +24,9 @@ module Elastic
24
24
  # Schema - Update engine schema
25
25
  # Update schema for the current engine
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Object] :schema
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
+ # @option arguments [Hash] :schema
30
30
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
31
  #
32
32
  # @see https://www.elastic.co/guide/en/app-search/current/schema.html#schema-patch
@@ -36,7 +36,6 @@ module Elastic
36
36
 
37
37
  schema = arguments.delete(:schema) || {}
38
38
  headers = arguments.delete(:headers) || {}
39
-
40
39
  request(
41
40
  :post,
42
41
  "api/as/v1/engines/#{engine_name}/schema/",
@@ -21,26 +21,25 @@ module Elastic
21
21
  module EnterpriseSearch
22
22
  module AppSearch
23
23
  module Actions
24
- # Searchsettings - Update search settings for the engine
24
+ # Synonyms - Update search settings
25
+ # Updates search settings for the engine
25
26
  #
26
- # @param engine_name [String] Name of the engine (*Required*)
27
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
28
29
  # @option arguments [Hash] :body
29
30
  # @option body :boosts
30
31
  # @option body :search_fields
31
32
  # @option body :result_fields
32
- # @option body [Integer] :precision
33
+ # @option body [integer] :precision
33
34
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
34
35
  #
35
36
  # @see https://www.elastic.co/guide/en/app-search/current/search-settings.html#search-settings-update
36
37
  #
37
38
  def put_search_settings(engine_name, arguments = {})
38
39
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
39
- raise ArgumentError, "Required parameter 'body' missing" unless arguments[:body]
40
40
 
41
41
  body = arguments.delete(:body) || {}
42
42
  headers = arguments.delete(:headers) || {}
43
-
44
43
  request(
45
44
  :put,
46
45
  "api/as/v1/engines/#{engine_name}/search_settings/",
@@ -24,12 +24,12 @@ module Elastic
24
24
  # Synonyms - Update a synonym set
25
25
  # Updates a synonym set by ID
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :synonym_set_id Synonym Set ID (*Required*)
30
- # @option arguments [Hash] :body (Required: synonyms)
31
- # @option body [String] :id
32
- # @option body :synonyms (*Required)
30
+ # @option arguments [Hash] :body (Required: synonyms)
31
+ # @option body [string] :id
32
+ # @option body :synonyms
33
33
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
34
34
  #
35
35
  # @see https://www.elastic.co/guide/en/app-search/current/synonyms.html#synonyms-update
@@ -37,12 +37,11 @@ module Elastic
37
37
  def put_synonym_set(engine_name, arguments = {})
38
38
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
39
39
  raise ArgumentError, "Required parameter 'synonym_set_id' missing" unless arguments[:synonym_set_id]
40
- raise ArgumentError, "Required parameter 'body (synonyms)' missing" unless arguments[:body] || arguments[:synonyms]
40
+ raise ArgumentError, "Required parameter 'body (synonyms)' missing" unless arguments[:body]
41
41
 
42
- synonym_set_id = arguments[:synonym_set_id]
42
+ synonym_set_id = arguments.delete(:synonym_set_id)
43
43
  body = arguments.delete(:body) || {}
44
44
  headers = arguments.delete(:headers) || {}
45
-
46
45
  request(
47
46
  :put,
48
47
  "api/as/v1/engines/#{engine_name}/synonyms/#{synonym_set_id}/",
@@ -24,12 +24,12 @@ module Elastic
24
24
  # QuerySuggestion - Retrieve query suggestions
25
25
  # Provide relevant query suggestions for incomplete queries
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [Hash] :body
30
- # @option body [String] :query
30
+ # @option body [string] :query
31
31
  # @option body :types
32
- # @option body [Integer] :size
32
+ # @option body [integer] :size
33
33
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
34
34
  #
35
35
  # @see https://www.elastic.co/guide/en/app-search/current/query-suggestion.html
@@ -39,7 +39,6 @@ module Elastic
39
39
 
40
40
  body = arguments.delete(:body) || {}
41
41
  headers = arguments.delete(:headers) || {}
42
-
43
42
  request(
44
43
  :post,
45
44
  "api/as/v1/engines/#{engine_name}/query_suggestion/",
@@ -0,0 +1,55 @@
1
+ # frozen_string_literal: true
2
+
3
+ # Licensed to Elasticsearch B.V. under one or more contributor
4
+ # license agreements. See the NOTICE file distributed with
5
+ # this work for additional information regarding copyright
6
+ # ownership. Elasticsearch B.V. licenses this file to you under
7
+ # the Apache License, Version 2.0 (the "License"); you may
8
+ # not use this file except in compliance with the License.
9
+ # You may obtain a copy of the License at
10
+ #
11
+ # http://www.apache.org/licenses/LICENSE-2.0
12
+ #
13
+ # Unless required by applicable law or agreed to in writing,
14
+ # software distributed under the License is distributed on an
15
+ # "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
16
+ # KIND, either express or implied. See the License for the
17
+ # specific language governing permissions and limitations
18
+ # under the License.
19
+
20
+ module Elastic
21
+ module EnterpriseSearch
22
+ module AppSearch
23
+ module Actions
24
+ # AdaptiveRelevanceSettings - Retrieve adaptive relevance settings
25
+ # Update suggestions process refresh
26
+ #
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
+ # @option arguments [String] :adaptive_relevance_suggestion_type Adaptive relevance suggestion type (*Required*)
30
+ # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
+ #
32
+ # @see https://www.elastic.co/guide/en/app-search/current/adaptive-relevance-api-reference.html#adaptive-relevance-api-post-engine-adaptive-relevance-suggestions-update-process-refresh
33
+ #
34
+ def refresh_adaptive_relevance_update_process(engine_name, arguments = {})
35
+ raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
36
+
37
+ unless arguments[:adaptive_relevance_suggestion_type]
38
+ raise ArgumentError,
39
+ "Required parameter 'adaptive_relevance_suggestion_type' missing"
40
+ end
41
+
42
+ adaptive_relevance_suggestion_type = arguments.delete(:adaptive_relevance_suggestion_type)
43
+ headers = arguments.delete(:headers) || {}
44
+ request(
45
+ :post,
46
+ "api/as/v0/engines/#{engine_name}/adaptive_relevance/update_process/#{adaptive_relevance_suggestion_type}/refresh/",
47
+ arguments,
48
+ nil,
49
+ headers
50
+ )
51
+ end
52
+ end
53
+ end
54
+ end
55
+ end
@@ -24,9 +24,8 @@ module Elastic
24
24
  # Synonyms - Reset search settings
25
25
  # Resets search settings for the engine
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body The request body
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
30
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
30
  #
32
31
  # @see https://www.elastic.co/guide/en/app-search/current/search-settings.html#search-settings-reset
@@ -34,14 +33,12 @@ module Elastic
34
33
  def reset_search_settings(engine_name, arguments = {})
35
34
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
36
35
 
37
- body = arguments.delete(:body) || {}
38
36
  headers = arguments.delete(:headers) || {}
39
-
40
37
  request(
41
38
  :post,
42
39
  "api/as/v1/engines/#{engine_name}/search_settings/reset/",
43
40
  arguments,
44
- body,
41
+ nil,
45
42
  headers
46
43
  )
47
44
  end
@@ -24,9 +24,8 @@ module Elastic
24
24
  # Schema - Retrieve engine schema
25
25
  # Retrieve current schema for the engine
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body The request body
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
30
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
30
  #
32
31
  # @see https://www.elastic.co/guide/en/app-search/current/schema.html#schema-read
@@ -34,14 +33,12 @@ module Elastic
34
33
  def schema(engine_name, arguments = {})
35
34
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
36
35
 
37
- body = arguments.delete(:body) || {}
38
36
  headers = arguments.delete(:headers) || {}
39
-
40
37
  request(
41
38
  :get,
42
39
  "api/as/v1/engines/#{engine_name}/schema/",
43
40
  arguments,
44
- body,
41
+ nil,
45
42
  headers
46
43
  )
47
44
  end
@@ -24,10 +24,10 @@ module Elastic
24
24
  # Search - Submit a search
25
25
  # Submit a search and receive a set of results with meta data
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body (Required: query)
30
- # @option body [String] :query (*Required)
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
+ # @option arguments [Hash] :body (Required: query)
30
+ # @option body [string] :query
31
31
  # @option body :analytics
32
32
  # @option body :boost
33
33
  # @option body :facets
@@ -43,10 +43,10 @@ module Elastic
43
43
  #
44
44
  def search(engine_name, arguments = {})
45
45
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
46
+ raise ArgumentError, "Required parameter 'body (query)' missing" unless arguments[:body]
46
47
 
47
48
  body = arguments.delete(:body) || {}
48
49
  headers = arguments.delete(:headers) || {}
49
-
50
50
  request(
51
51
  :post,
52
52
  "api/as/v1/engines/#{engine_name}/search/",
@@ -24,9 +24,8 @@ module Elastic
24
24
  # SearchSettings - Retrieve search settings
25
25
  # Retrieve current search settings for the engine
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body The request body
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
30
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
31
30
  #
32
31
  # @see https://www.elastic.co/guide/en/app-search/current/search-settings.html#search-settings-show
@@ -34,14 +33,12 @@ module Elastic
34
33
  def search_settings(engine_name, arguments = {})
35
34
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
36
35
 
37
- body = arguments.delete(:body) || {}
38
36
  headers = arguments.delete(:headers) || {}
39
-
40
37
  request(
41
38
  :get,
42
39
  "api/as/v1/engines/#{engine_name}/search_settings/",
43
40
  arguments,
44
- body,
41
+ nil,
45
42
  headers
46
43
  )
47
44
  end
@@ -24,10 +24,9 @@ module Elastic
24
24
  # Synonyms - Retrieve a synonym set
25
25
  # Retrieves a synonym set by ID
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [String] :synonym_set_id Synonym Set ID (*Required*)
30
- # @option arguments [Hash] :body The request body
31
30
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
32
31
  #
33
32
  # @see https://www.elastic.co/guide/en/app-search/current/synonyms.html#synonyms-list-one
@@ -36,15 +35,13 @@ module Elastic
36
35
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
37
36
  raise ArgumentError, "Required parameter 'synonym_set_id' missing" unless arguments[:synonym_set_id]
38
37
 
39
- synonym_set_id = arguments[:synonym_set_id]
40
- body = arguments.delete(:body) || {}
38
+ synonym_set_id = arguments.delete(:synonym_set_id)
41
39
  headers = arguments.delete(:headers) || {}
42
-
43
40
  request(
44
41
  :get,
45
42
  "api/as/v1/engines/#{engine_name}/synonyms/#{synonym_set_id}/",
46
43
  arguments,
47
- body,
44
+ nil,
48
45
  headers
49
46
  )
50
47
  end
@@ -24,12 +24,12 @@ module Elastic
24
24
  # Analytics - Query for analytics click data
25
25
  # Returns the number of clicks received by a document in descending order
26
26
  #
27
- # @param engine_name [String] Name of the engine (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] engine_name Name of the engine (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [Hash] :body
30
- # @option body [String] :query
30
+ # @option body [string] :query
31
31
  # @option body :filters
32
- # @option body [Object] :page
32
+ # @option body [Hash] :page (Required: size)
33
33
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
34
34
  #
35
35
  # @see https://www.elastic.co/guide/en/app-search/current/clicks.html
@@ -39,7 +39,6 @@ module Elastic
39
39
 
40
40
  body = arguments.delete(:body) || {}
41
41
  headers = arguments.delete(:headers) || {}
42
-
43
42
  request(
44
43
  :post,
45
44
  "api/as/v1/engines/#{engine_name}/analytics/clicks/",