elastic-enterprise-search 7.17.0 → 8.0.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (163) hide show
  1. checksums.yaml +4 -4
  2. data/.ci/jobs/elastic+enterprise-search-ruby+7.13.yml +12 -0
  3. data/.ci/jobs/elastic+enterprise-search-ruby+7.14.yml +12 -0
  4. data/.ci/jobs/elastic+enterprise-search-ruby+7.15.yml +12 -0
  5. data/.ci/jobs/elastic+enterprise-search-ruby+7.16.yml +12 -0
  6. data/.ci/test-matrix.yml +1 -2
  7. data/.github/workflows/testing.yml +3 -3
  8. data/.rubocop.yml +1 -1
  9. data/CHANGELOG +1 -0
  10. data/CODE_OF_CONDUCT +1 -0
  11. data/CONTRIBUTING.md +37 -0
  12. data/NOTICE +2 -0
  13. data/README.md +25 -29
  14. data/docs/guide/app-search-api.asciidoc +52 -18
  15. data/docs/guide/connecting.asciidoc +0 -1
  16. data/docs/guide/overview.asciidoc +27 -4
  17. data/docs/guide/release_notes/712.asciidoc +10 -0
  18. data/docs/guide/release_notes/714.asciidoc +0 -12
  19. data/docs/guide/release_notes/715.asciidoc +0 -12
  20. data/docs/guide/release_notes/80.asciidoc +128 -0
  21. data/docs/guide/release_notes/index.asciidoc +4 -0
  22. data/docs/guide/workplace-search-api.asciidoc +38 -11
  23. data/elastic-enterprise-search.gemspec +3 -3
  24. data/lib/elastic/api/response.rb +52 -0
  25. data/lib/elastic/{workplace-search/api/user_permissions.rb → app-search/api/adaptive_relevance_settings.rb} +10 -15
  26. data/lib/elastic/{workplace-search/api/add_user_permissions.rb → app-search/api/adaptive_relevance_suggestions.rb} +20 -14
  27. data/lib/elastic/app-search/api/add_meta_engine_source.rb +4 -5
  28. data/lib/elastic/app-search/api/api_key.rb +4 -6
  29. data/lib/elastic/app-search/api/api_logs.rb +8 -15
  30. data/lib/elastic/app-search/api/count_analytics.rb +5 -5
  31. data/lib/elastic/app-search/api/crawler_active_crawl_request.rb +4 -7
  32. data/lib/elastic/app-search/api/crawler_crawl_request.rb +6 -8
  33. data/lib/elastic/app-search/api/crawler_crawl_schedule.rb +4 -7
  34. data/lib/elastic/app-search/api/crawler_domain.rb +6 -8
  35. data/lib/elastic/app-search/api/crawler_domain_validation_result.rb +6 -5
  36. data/lib/elastic/app-search/api/crawler_metrics.rb +3 -6
  37. data/lib/elastic/app-search/api/crawler_overview.rb +4 -7
  38. data/lib/elastic/app-search/api/crawler_process_crawl.rb +6 -8
  39. data/lib/elastic/app-search/api/crawler_process_crawl_denied_urls.rb +6 -8
  40. data/lib/elastic/app-search/api/crawler_url_extraction_result.rb +6 -6
  41. data/lib/elastic/app-search/api/crawler_url_tracing_result.rb +7 -7
  42. data/lib/elastic/app-search/api/crawler_url_validation_result.rb +7 -7
  43. data/lib/elastic/app-search/api/crawler_user_agent.rb +3 -6
  44. data/lib/elastic/app-search/api/create_api_key.rb +10 -10
  45. data/lib/elastic/app-search/api/create_crawler_crawl_request.rb +9 -5
  46. data/lib/elastic/app-search/api/create_crawler_crawl_rule.rb +13 -11
  47. data/lib/elastic/app-search/api/create_crawler_domain.rb +8 -8
  48. data/lib/elastic/app-search/api/create_crawler_entry_point.rb +10 -8
  49. data/lib/elastic/app-search/api/create_crawler_process_crawl.rb +6 -6
  50. data/lib/elastic/app-search/api/create_crawler_sitemap.rb +10 -8
  51. data/lib/elastic/app-search/api/create_curation.rb +10 -8
  52. data/lib/elastic/app-search/api/create_engine.rb +8 -7
  53. data/lib/elastic/app-search/api/create_synonym_set.rb +6 -6
  54. data/lib/elastic/app-search/api/curation.rb +5 -7
  55. data/lib/elastic/app-search/api/delete_api_key.rb +4 -6
  56. data/lib/elastic/app-search/api/delete_crawler_active_crawl_request.rb +4 -7
  57. data/lib/elastic/app-search/api/delete_crawler_crawl_rule.rb +7 -9
  58. data/lib/elastic/app-search/api/delete_crawler_crawl_schedule.rb +4 -7
  59. data/lib/elastic/app-search/api/delete_crawler_domain.rb +6 -8
  60. data/lib/elastic/app-search/api/delete_crawler_entry_point.rb +7 -9
  61. data/lib/elastic/app-search/api/delete_crawler_sitemap.rb +7 -9
  62. data/lib/elastic/app-search/api/delete_curation.rb +5 -7
  63. data/lib/elastic/app-search/api/delete_documents.rb +4 -5
  64. data/lib/elastic/app-search/api/delete_engine.rb +3 -6
  65. data/lib/elastic/app-search/api/delete_meta_engine_source.rb +4 -4
  66. data/lib/elastic/app-search/api/delete_synonym_set.rb +5 -7
  67. data/lib/elastic/app-search/api/documents.rb +5 -5
  68. data/lib/elastic/app-search/api/engine.rb +3 -6
  69. data/lib/elastic/app-search/api/index_documents.rb +4 -5
  70. data/lib/elastic/{workplace-search/api/remove_user_permissions.rb → app-search/api/list_adaptive_relevance_suggestions.rb} +13 -14
  71. data/lib/elastic/app-search/api/list_api_keys.rb +2 -5
  72. data/lib/elastic/app-search/api/list_crawler_crawl_requests.rb +6 -8
  73. data/lib/elastic/{workplace-search/api/list_permissions.rb → app-search/api/list_crawler_domains.rb} +12 -13
  74. data/lib/elastic/app-search/api/list_crawler_process_crawls.rb +6 -7
  75. data/lib/elastic/app-search/api/list_curations.rb +3 -6
  76. data/lib/elastic/app-search/api/list_documents.rb +3 -6
  77. data/lib/elastic/app-search/api/list_engines.rb +2 -5
  78. data/lib/elastic/app-search/api/list_synonym_sets.rb +3 -6
  79. data/lib/elastic/app-search/api/log_clickthrough.rb +9 -8
  80. data/lib/elastic/{workplace-search/api/put_user_permissions.rb → app-search/api/put_adaptive_relevance_settings.rb} +13 -14
  81. data/lib/elastic/app-search/api/put_adaptive_relevance_suggestions.rb +51 -0
  82. data/lib/elastic/app-search/api/put_api_key.rb +11 -10
  83. data/lib/elastic/app-search/api/put_crawler_crawl_rule.rb +14 -12
  84. data/lib/elastic/app-search/api/put_crawler_crawl_schedule.rb +8 -7
  85. data/lib/elastic/app-search/api/put_crawler_domain.rb +9 -9
  86. data/lib/elastic/app-search/api/put_crawler_entry_point.rb +11 -9
  87. data/lib/elastic/app-search/api/put_crawler_sitemap.rb +11 -9
  88. data/lib/elastic/app-search/api/put_curation.rb +11 -9
  89. data/lib/elastic/app-search/api/put_documents.rb +4 -4
  90. data/lib/elastic/app-search/api/put_schema.rb +4 -4
  91. data/lib/elastic/app-search/api/put_search_settings.rb +6 -6
  92. data/lib/elastic/app-search/api/put_synonym_set.rb +8 -8
  93. data/lib/elastic/app-search/api/query_suggestion.rb +5 -5
  94. data/lib/elastic/app-search/api/refresh_adaptive_relevance_update_process.rb +56 -0
  95. data/lib/elastic/app-search/api/reset_search_settings.rb +3 -6
  96. data/lib/elastic/app-search/api/schema.rb +3 -6
  97. data/lib/elastic/app-search/api/search.rb +6 -5
  98. data/lib/elastic/app-search/api/search_settings.rb +3 -6
  99. data/lib/elastic/app-search/api/synonym_set.rb +5 -7
  100. data/lib/elastic/app-search/api/top_clicks_analytics.rb +5 -5
  101. data/lib/elastic/app-search/api/top_queries_analytics.rb +4 -4
  102. data/lib/elastic/enterprise-search/api/health.rb +2 -3
  103. data/lib/elastic/enterprise-search/api/put_read_only.rb +6 -4
  104. data/lib/elastic/enterprise-search/api/read_only.rb +2 -3
  105. data/lib/elastic/enterprise-search/api/stats.rb +2 -3
  106. data/lib/elastic/enterprise-search/api/version.rb +2 -3
  107. data/lib/elastic/enterprise-search/client.rb +21 -14
  108. data/lib/elastic/enterprise-search/request.rb +5 -3
  109. data/lib/elastic/enterprise-search/version.rb +1 -1
  110. data/lib/elastic/workplace-search/api/auto_query_refinement_details.rb +3 -4
  111. data/lib/elastic/workplace-search/api/command_sync_jobs.rb +4 -5
  112. data/lib/elastic/workplace-search/api/content_source.rb +3 -4
  113. data/lib/elastic/workplace-search/api/create_analytics_event.rb +16 -12
  114. data/lib/elastic/workplace-search/api/create_batch_synonym_sets.rb +4 -3
  115. data/lib/elastic/workplace-search/api/create_content_source.rb +6 -5
  116. data/lib/elastic/workplace-search/api/create_external_identity.rb +11 -6
  117. data/lib/elastic/workplace-search/api/current_user.rb +3 -5
  118. data/lib/elastic/workplace-search/api/delete_content_source.rb +3 -4
  119. data/lib/elastic/workplace-search/api/delete_documents.rb +4 -4
  120. data/lib/elastic/workplace-search/api/delete_documents_by_query.rb +4 -3
  121. data/lib/elastic/workplace-search/api/delete_external_identity.rb +7 -9
  122. data/lib/elastic/workplace-search/api/delete_synonym_set.rb +3 -5
  123. data/lib/elastic/workplace-search/api/document.rb +4 -6
  124. data/lib/elastic/workplace-search/api/external_identity.rb +7 -9
  125. data/lib/elastic/workplace-search/api/index_documents.rb +3 -4
  126. data/lib/elastic/workplace-search/api/list_content_sources.rb +2 -3
  127. data/lib/elastic/workplace-search/api/list_documents.rb +4 -5
  128. data/lib/elastic/workplace-search/api/list_external_identities.rb +3 -4
  129. data/lib/elastic/workplace-search/api/list_synonym_sets.rb +1 -2
  130. data/lib/elastic/workplace-search/api/put_content_source.rb +6 -6
  131. data/lib/elastic/workplace-search/api/put_content_source_icons.rb +6 -6
  132. data/lib/elastic/workplace-search/api/put_external_identity.rb +11 -10
  133. data/lib/elastic/workplace-search/api/put_synonym_set.rb +4 -4
  134. data/lib/elastic/workplace-search/api/put_triggers_blocklist.rb +3 -5
  135. data/lib/elastic/workplace-search/api/search.rb +13 -13
  136. data/lib/elastic/workplace-search/api/synonym_set.rb +3 -5
  137. data/lib/elastic/workplace-search/api/triggers_blocklist.rb +3 -3
  138. data/lib/elastic/workplace-search/workplace_search.rb +9 -2
  139. data/spec/app-search/client_spec.rb +29 -0
  140. data/spec/enterprise-search/client_spec.rb +29 -0
  141. data/spec/enterprise-search/request_spec.rb +1 -1
  142. data/spec/integration/app-search/adaptive_relevance_settings_spec.rb +60 -0
  143. data/spec/integration/app-search/adaptive_relevance_suggestions_spec.rb +54 -0
  144. data/spec/integration/app-search/api_logs_spec.rb +11 -3
  145. data/spec/integration/app-search/app_search_helper.rb +2 -2
  146. data/spec/integration/app-search/count_analytics_spec.rb +3 -2
  147. data/spec/integration/app-search/crawler_domain_spec.rb +16 -0
  148. data/spec/integration/app-search/curations_spec.rb +15 -9
  149. data/spec/integration/app-search/engines_spec.rb +24 -26
  150. data/spec/integration/app-search/log_clickthrough_spec.rb +1 -1
  151. data/spec/integration/app-search/meta_engines_spec.rb +5 -5
  152. data/spec/integration/app-search/search_and_multiple_search_spec.rb +1 -1
  153. data/spec/integration/workplace-search/content_sources_spec.rb +6 -6
  154. data/spec/integration/workplace-search/documents_spec.rb +20 -10
  155. data/spec/integration/workplace-search/external_identities_spec.rb +26 -16
  156. data/spec/integration/workplace-search/triggers_spec.rb +2 -2
  157. data/spec/integration/workplace-search/users_spec.rb +0 -6
  158. data/spec/workplace-search/client_spec.rb +39 -2
  159. metadata +29 -20
  160. data/.ci/jobs/elastic+enterprise-search-ruby+7.10.0.beta.1.yml +0 -12
  161. data/.github/compatibility/Gemfile +0 -23
  162. data/.github/workflows/compatibility.yml +0 -20
  163. data/spec/integration/workplace-search/permissions_spec.rb +0 -77
@@ -0,0 +1,56 @@
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
+
44
+ headers = arguments.delete(:headers) || {}
45
+ request(
46
+ :post,
47
+ "api/as/v0/engines/#{engine_name}/adaptive_relevance/update_process/#{adaptive_relevance_suggestion_type}/refresh/",
48
+ arguments,
49
+ nil,
50
+ headers
51
+ )
52
+ end
53
+ end
54
+ end
55
+ end
56
+ 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,11 @@ 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
- headers = arguments.delete(:headers) || {}
49
49
 
50
+ headers = arguments.delete(:headers) || {}
50
51
  request(
51
52
  :post,
52
53
  "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,14 @@ 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) || {}
41
- headers = arguments.delete(:headers) || {}
38
+ synonym_set_id = arguments.delete(:synonym_set_id)
42
39
 
40
+ headers = arguments.delete(:headers) || {}
43
41
  request(
44
42
  :get,
45
43
  "api/as/v1/engines/#{engine_name}/synonyms/#{synonym_set_id}/",
46
44
  arguments,
47
- body,
45
+ nil,
48
46
  headers
49
47
  )
50
48
  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
@@ -38,8 +38,8 @@ module Elastic
38
38
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
39
39
 
40
40
  body = arguments.delete(:body) || {}
41
- headers = arguments.delete(:headers) || {}
42
41
 
42
+ headers = arguments.delete(:headers) || {}
43
43
  request(
44
44
  :post,
45
45
  "api/as/v1/engines/#{engine_name}/analytics/clicks/",
@@ -24,11 +24,11 @@ module Elastic
24
24
  # Analytics - Query for analytics query data
25
25
  # Returns queries analytics by usage count
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
30
  # @option body :filters
31
- # @option body [Object] :page
31
+ # @option body [Hash] :page (Required: size)
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/queries.html#queries-top-queries
@@ -37,8 +37,8 @@ module Elastic
37
37
  raise ArgumentError, "Required parameter 'engine_name' missing" unless engine_name
38
38
 
39
39
  body = arguments.delete(:body) || {}
40
- headers = arguments.delete(:headers) || {}
41
40
 
41
+ headers = arguments.delete(:headers) || {}
42
42
  request(
43
43
  :post,
44
44
  "api/as/v1/engines/#{engine_name}/analytics/queries/",
@@ -23,19 +23,18 @@ module Elastic
23
23
  # Health - Get information on the health of a deployment and basic statistics around resource usage
24
24
  # Get information on the health of a deployment and basic statistics around resource usage
25
25
  #
26
- # @param arguments [Hash] endpoint arguments
26
+ # @param [Hash] arguments endpoint arguments
27
27
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
28
28
  #
29
29
  # @see https://www.elastic.co/guide/en/enterprise-search/current/monitoring-apis.html#health-api-example
30
30
  #
31
31
  def health(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
33
-
34
33
  request(
35
34
  :get,
36
35
  'api/ent/v1/internal/health/',
37
36
  arguments,
38
- {},
37
+ nil,
39
38
  headers
40
39
  )
41
40
  end
@@ -23,17 +23,19 @@ module Elastic
23
23
  # Read-Only - Update the read-only flag's state
24
24
  # Update the read-only flag's state
25
25
  #
26
- # @param arguments [Hash] endpoint arguments
27
- # @option arguments [Hash] :body (Required: enabled)
28
- # @option body [Boolean] :enabled (*Required)
26
+ # @param [Hash] arguments endpoint arguments
27
+ # @option arguments [Hash] :body (Required: enabled)
28
+ # @option body [boolean] :enabled
29
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
30
30
  #
31
31
  # @see https://www.elastic.co/guide/en/enterprise-search/current/read-only-api.html#setting-read-only-state
32
32
  #
33
33
  def put_read_only(arguments = {})
34
+ raise ArgumentError, "Required parameter 'body (enabled)' missing" unless arguments[:body]
35
+
34
36
  body = arguments.delete(:body) || {}
35
- headers = arguments.delete(:headers) || {}
36
37
 
38
+ headers = arguments.delete(:headers) || {}
37
39
  request(
38
40
  :put,
39
41
  'api/ent/v1/internal/read_only_mode/',
@@ -23,19 +23,18 @@ module Elastic
23
23
  # Read-Only - Get the read-only flag's state
24
24
  # Get the read-only flag's state
25
25
  #
26
- # @param arguments [Hash] endpoint arguments
26
+ # @param [Hash] arguments endpoint arguments
27
27
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
28
28
  #
29
29
  # @see https://www.elastic.co/guide/en/enterprise-search/current/read-only-api.html#getting-read-only-state
30
30
  #
31
31
  def read_only(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
33
-
34
33
  request(
35
34
  :get,
36
35
  'api/ent/v1/internal/read_only_mode/',
37
36
  arguments,
38
- {},
37
+ nil,
39
38
  headers
40
39
  )
41
40
  end
@@ -23,7 +23,7 @@ module Elastic
23
23
  # Stats - Get information about the resource usage of the application, the state of different internal queues, etc.
24
24
  # Get information about the resource usage of the application, the state of different internal queues, etc.
25
25
  #
26
- # @param arguments [Hash] endpoint arguments
26
+ # @param [Hash] arguments endpoint arguments
27
27
  # @option arguments [Array] :include Comma-separated list of stats to return
28
28
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
29
29
  #
@@ -31,12 +31,11 @@ module Elastic
31
31
  #
32
32
  def stats(arguments = {})
33
33
  headers = arguments.delete(:headers) || {}
34
-
35
34
  request(
36
35
  :get,
37
36
  'api/ent/v1/internal/stats/',
38
37
  arguments,
39
- {},
38
+ nil,
40
39
  headers
41
40
  )
42
41
  end
@@ -23,19 +23,18 @@ module Elastic
23
23
  # Version - Get version information for this server
24
24
  # Get version information for this server
25
25
  #
26
- # @param arguments [Hash] endpoint arguments
26
+ # @param [Hash] arguments endpoint arguments
27
27
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
28
28
  #
29
29
  # @see https://www.elastic.co/guide/en/enterprise-search/current/management-apis.html
30
30
  #
31
31
  def version(arguments = {})
32
32
  headers = arguments.delete(:headers) || {}
33
-
34
33
  request(
35
34
  :get,
36
35
  'api/ent/v1/internal/version/',
37
36
  arguments,
38
- {},
37
+ nil,
39
38
  headers
40
39
  )
41
40
  end
@@ -19,7 +19,7 @@
19
19
 
20
20
  require 'elastic/enterprise-search/request'
21
21
  require 'elastic/enterprise-search/utils'
22
- require 'elasticsearch-transport'
22
+ require 'elastic-transport'
23
23
 
24
24
  module Elastic
25
25
  module EnterpriseSearch
@@ -58,6 +58,9 @@ module Elastic
58
58
  # @option options [String] :proxy url of proxy to use, ex: "http://localhost:8888"
59
59
  # @option options [Boolean] :log Use the default logger (disabled by default)
60
60
  # @option arguments [Object] :logger An instance of a Logger-compatible object
61
+ # @option arguments [Boolean] :trace Use the default tracer (disabled by default)
62
+ # @option arguments [Object] :tracer An instance of a Logger-compatible object
63
+ # @option arguments [Symbol] :adapter A specific adapter for Faraday (e.g. `:patron`)
61
64
  # @option enable_meta_header [Boolean] :enable_meta_header Enable sending the meta data header to Cloud.
62
65
  # (Default: true)
63
66
  def initialize(options = {})
@@ -67,15 +70,18 @@ module Elastic
67
70
 
68
71
  def transport
69
72
  @options[:transport] ||
70
- transport_klass.new(
73
+ Elastic::Transport::Client.new(
71
74
  host: host,
72
75
  log: log,
73
76
  logger: logger,
74
77
  request_timeout: overall_timeout,
78
+ adapter: adapter,
75
79
  transport_options: {
76
80
  request: { open_timeout: open_timeout }
77
81
  },
78
- enable_meta_header: @options[:enable_meta_header] || true
82
+ enable_meta_header: @options[:enable_meta_header] || true,
83
+ trace: trace,
84
+ tracer: tracer
79
85
  )
80
86
  end
81
87
 
@@ -103,6 +109,18 @@ module Elastic
103
109
  @options[:logger]
104
110
  end
105
111
 
112
+ def adapter
113
+ @options[:adapter]
114
+ end
115
+
116
+ def tracer
117
+ @options[:tracer]
118
+ end
119
+
120
+ def trace
121
+ @options[:trace]
122
+ end
123
+
106
124
  def host
107
125
  return DEFAULT_HOST unless @options[:host]
108
126
 
@@ -110,17 +128,6 @@ module Elastic
110
128
 
111
129
  @options[:host]
112
130
  end
113
-
114
- private
115
-
116
- def transport_klass
117
- case Elasticsearch::Transport::VERSION
118
- when /7\.1[123]/
119
- Elasticsearch::Client
120
- else
121
- Elasticsearch::Transport::Client
122
- end
123
- end
124
131
  end
125
132
  end
126
133
  end
@@ -19,6 +19,7 @@
19
19
 
20
20
  require 'net/https'
21
21
  require 'json'
22
+ require 'elastic/api/response'
22
23
  require 'elastic/enterprise-search/exceptions'
23
24
  require 'base64'
24
25
 
@@ -53,8 +54,9 @@ module Elastic
53
54
  else
54
55
  headers.merge(meta_headers)
55
56
  end
56
-
57
- @transport.perform_request(method.to_s.upcase, path, params, body, headers)
57
+ Elastic::API::Response.new(
58
+ @transport.perform_request(method.to_s.upcase, path, params, body, headers)
59
+ )
58
60
  end
59
61
 
60
62
  def setup_authentication_header
@@ -84,7 +86,7 @@ module Elastic
84
86
  meta << "#{RbConfig::CONFIG['host_os'].split('_').first[/[a-z]+/i].downcase} " \
85
87
  "#{RbConfig::CONFIG['target_cpu']}"
86
88
  end
87
- meta << "elasticsearch-transport: #{Elasticsearch::Transport::VERSION}"
89
+ meta << "elastic-transport: #{Elastic::Transport::VERSION}"
88
90
  "#{ua} (#{meta.join('; ')})"
89
91
  end
90
92
 
@@ -19,6 +19,6 @@
19
19
 
20
20
  module Elastic
21
21
  module EnterpriseSearch
22
- VERSION = '7.17.0'
22
+ VERSION = '8.0.1'
23
23
  end
24
24
  end
@@ -24,8 +24,8 @@ module Elastic
24
24
  # ContentSources - Retrieves a content source's automatic query refinement details
25
25
  # Retrieves a content source's automatic query refinement details
26
26
  #
27
- # @param content_source_id [String] Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] content_source_id Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
30
30
  #
31
31
  # @see https://www.elastic.co/guide/en/workplace-search/current/workplace-search-content-sources-api.html#get-automatic-query-refinement-details-api
@@ -34,12 +34,11 @@ module Elastic
34
34
  raise ArgumentError, "Required parameter 'content_source_id' missing" unless content_source_id
35
35
 
36
36
  headers = arguments.delete(:headers) || {}
37
-
38
37
  request(
39
38
  :get,
40
39
  "api/ws/v1/sources/#{content_source_id}/automatic_query_refinement/",
41
40
  arguments,
42
- {},
41
+ nil,
43
42
  headers
44
43
  )
45
44
  end
@@ -24,21 +24,20 @@ module Elastic
24
24
  # SyncJobs - Issue commands to a Content Source's sync jobs
25
25
  # Control a content source's sync jobs
26
26
  #
27
- # @param content_source_id [String] Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
- # @param arguments [Hash] endpoint arguments
29
- # @option arguments [Hash] :body Params to command a Workplace Search Content Source's sync jobs (Required: command)
27
+ # @param [String] content_source_id Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
30
29
  # @option arguments [Array] :job_type The type of sync job to consider
31
- # @option body :command (*Required)
30
+ # @option arguments [Any of: <Hash> - Command to start a synchronisation job for Content Source (force_interrupt<boolean>, command<string>) or <Hash> - Command to interrupt a synchronisation job for Content Source (command<string>)] :body *Required*
32
31
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
33
32
  #
34
33
  # @see https://www.elastic.co/guide/en/workplace-search/current/workplace-search-sync-jobs-api.html#command-sync-jobs-api
35
34
  #
36
35
  def command_sync_jobs(content_source_id, arguments = {})
37
36
  raise ArgumentError, "Required parameter 'content_source_id' missing" unless content_source_id
37
+ raise ArgumentError, "Required parameter 'body' missing" unless arguments[:body]
38
38
 
39
39
  body = arguments.delete(:body) || {}
40
40
  headers = arguments.delete(:headers) || {}
41
-
42
41
  request(
43
42
  :post,
44
43
  "api/ws/v1/sources/#{content_source_id}/sync/jobs/",
@@ -24,8 +24,8 @@ module Elastic
24
24
  # ContentSources - Retrieves a content source by ID
25
25
  # Retrieves a content source by ID
26
26
  #
27
- # @param content_source_id [String] Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
- # @param arguments [Hash] endpoint arguments
27
+ # @param [String] content_source_id Unique ID for a Custom API source, provided upon creation of a Custom API Source (*Required*)
28
+ # @param [Hash] arguments endpoint arguments
29
29
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
30
30
  #
31
31
  # @see https://www.elastic.co/guide/en/workplace-search/current/workplace-search-content-sources-api.html#get-content-source-api
@@ -34,12 +34,11 @@ module Elastic
34
34
  raise ArgumentError, "Required parameter 'content_source_id' missing" unless content_source_id
35
35
 
36
36
  headers = arguments.delete(:headers) || {}
37
-
38
37
  request(
39
38
  :get,
40
39
  "api/ws/v1/sources/#{content_source_id}/",
41
40
  arguments,
42
- {},
41
+ nil,
43
42
  headers
44
43
  )
45
44
  end
@@ -24,17 +24,17 @@ module Elastic
24
24
  # Analytics - Capture click and feedback analytic events
25
25
  # Capture Analytic events for click and feedback
26
26
  #
27
- # @param arguments [Hash] endpoint arguments
28
- # @option arguments [String] :access_token OAuth Access Token (*Required*)
29
- # @option arguments [Hash] :body Workplace Search analytics event (Required: type, query_id, page, content_source_id, document_id, rank)
30
- # @option body [String] :type (*Required)
31
- # @option body [String] :query_id query identifier for the event (*Required)
32
- # @option body [Integer] :page page number of the document in the query result set (*Required)
33
- # @option body [String] :content_source_id content source identifier for the event document (*Required)
34
- # @option body [String] :document_id document identifier for the event (*Required)
35
- # @option body [Integer] :rank rank of the document in the overall result set (*Required)
36
- # @option body [String] :event the target identifier for a click event
37
- # @option body [Integer] :score the feedback score, constrained to the values -1 or 1
27
+ # @param [Hash] arguments endpoint arguments
28
+ # @param [String] access_token OAuth Access Token (*Required*)
29
+ # @option arguments [Hash] :body (Required: type, query_id, page, content_source_id, document_id, rank)
30
+ # @option body [string] :type
31
+ # @option body [string] :query_id query identifier for the event
32
+ # @option body [integer] :page page number of the document in the query result set
33
+ # @option body [string] :content_source_id content source identifier for the event document
34
+ # @option body [string] :document_id document identifier for the event
35
+ # @option body [integer] :rank rank of the document in the overall result set
36
+ # @option body [string] :event the target identifier for a click event
37
+ # @option body [integer] :score the feedback score, constrained to the values -1 or 1
38
38
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
39
39
  #
40
40
  # @see https://www.elastic.co/guide/en/workplace-search/current/workplace-search-analytics-api.html
@@ -42,9 +42,13 @@ module Elastic
42
42
  def create_analytics_event(arguments = {})
43
43
  raise ArgumentError, "Required parameter 'access_token' missing" unless arguments[:access_token]
44
44
 
45
+ unless arguments[:body]
46
+ raise ArgumentError,
47
+ "Required parameter 'body (type,query_id,page,content_source_id,document_id,rank)' missing"
48
+ end
49
+
45
50
  body = arguments.delete(:body) || {}
46
51
  headers = arguments.delete(:headers) || {}
47
-
48
52
  request(
49
53
  :post,
50
54
  'api/ws/v1/analytics/event/',
@@ -24,8 +24,8 @@ module Elastic
24
24
  # Synonyms - Create a batch of synonym sets
25
25
  # Create batched synonym sets
26
26
  #
27
- # @param arguments [Hash] endpoint arguments
28
- # @option arguments [Hash] :body
27
+ # @param [Hash] arguments endpoint arguments
28
+ # @option arguments [Hash] :body *Required*
29
29
  # @option body :synonyms
30
30
  # @option body :synonym_sets
31
31
  # @option arguments [Hash] :headers optional HTTP headers to send with the request
@@ -33,9 +33,10 @@ module Elastic
33
33
  # @see https://www.elastic.co/guide/en/workplace-search/current/workplace-synonyms-api.html#create-synonyms
34
34
  #
35
35
  def create_batch_synonym_sets(arguments = {})
36
+ raise ArgumentError, "Required parameter 'body' missing" unless arguments[:body]
37
+
36
38
  body = arguments.delete(:body) || {}
37
39
  headers = arguments.delete(:headers) || {}
38
-
39
40
  request(
40
41
  :post,
41
42
  'api/ws/v1/synonyms/',