algolia 3.0.0.beta.10 → 3.0.0.beta.12
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +19 -0
- data/Gemfile.lock +2 -2
- data/lib/algolia/api/ingestion_client.rb +912 -359
- data/lib/algolia/api/query_suggestions_client.rb +4 -10
- data/lib/algolia/api/search_client.rb +4 -4
- data/lib/algolia/api/usage_client.rb +4 -4
- data/lib/algolia/error.rb +10 -0
- data/lib/algolia/logger_helper.rb +11 -2
- data/lib/algolia/models/abtesting/{filter_effects_empty_search.rb → empty_search_filter.rb} +3 -3
- data/lib/algolia/models/abtesting/filter_effects.rb +2 -2
- data/lib/algolia/models/abtesting/{filter_effects_outliers.rb → outliers_filter.rb} +3 -3
- data/lib/algolia/models/analytics/{click_positions_inner.rb → click_position.rb} +3 -3
- data/lib/algolia/models/analytics/get_click_positions_response.rb +1 -1
- data/lib/algolia/models/analytics/top_search_with_analytics.rb +1 -1
- data/lib/algolia/models/analytics/top_search_with_revenue_analytics.rb +1 -1
- data/lib/algolia/models/ingestion/action.rb +45 -0
- data/lib/algolia/models/{search/search_for_hits_options.rb → ingestion/batch_request.rb} +22 -20
- data/lib/algolia/models/ingestion/{source_shopify_base.rb → batch_write_params.rb} +14 -12
- data/lib/algolia/models/ingestion/docker_streams_input.rb +1 -0
- data/lib/algolia/models/{recommend/recommendations_hits.rb → ingestion/list_tasks_response_v1.rb} +26 -14
- data/lib/algolia/models/ingestion/task.rb +30 -9
- data/lib/algolia/models/ingestion/task_create.rb +11 -12
- data/lib/algolia/models/{search/search_for_facets_options.rb → ingestion/task_create_v1.rb} +86 -51
- data/lib/algolia/models/ingestion/task_update.rb +8 -7
- data/lib/algolia/models/{search/browse_pagination.rb → ingestion/task_update_v1.rb} +50 -55
- data/lib/algolia/models/{recommend/looking_similar.rb → ingestion/task_v1.rb} +147 -30
- data/lib/algolia/models/ingestion/{transformation_try_response_error.rb → transformation_error.rb} +3 -3
- data/lib/algolia/models/ingestion/transformation_try_response.rb +1 -1
- data/lib/algolia/models/monitoring/{incidents_inner.rb → incident_entry.rb} +3 -3
- data/lib/algolia/models/monitoring/{indexing_time_response_metrics.rb → indexing_metric.rb} +3 -3
- data/lib/algolia/models/monitoring/indexing_time_response.rb +1 -1
- data/lib/algolia/models/monitoring/infrastructure_response.rb +1 -1
- data/lib/algolia/models/monitoring/{latency_response_metrics.rb → latency_metric.rb} +3 -3
- data/lib/algolia/models/monitoring/latency_response.rb +1 -1
- data/lib/algolia/models/monitoring/{infrastructure_response_metrics.rb → metrics.rb} +3 -6
- data/lib/algolia/models/monitoring/{time_inner.rb → time_entry.rb} +3 -3
- data/lib/algolia/models/{recommend/trending_items.rb → query-suggestions/config_status.rb} +46 -58
- data/lib/algolia/models/{recommend/related_products.rb → query-suggestions/log_file.rb} +36 -32
- data/lib/algolia/models/recommend/around_precision.rb +1 -1
- data/lib/algolia/models/recommend/fallback_params.rb +1 -1
- data/lib/algolia/models/recommend/{around_precision_from_value_inner.rb → range.rb} +3 -6
- data/lib/algolia/models/recommend/recommend_rule.rb +1 -1
- data/lib/algolia/models/recommend/{redirect_rule_index_metadata_data.rb → redirect_rule_index_data.rb} +3 -3
- data/lib/algolia/models/recommend/redirect_rule_index_metadata.rb +1 -1
- data/lib/algolia/models/recommend/{recommend_rule_metadata.rb → rule_metadata.rb} +3 -3
- data/lib/algolia/models/recommend/search_params.rb +1 -1
- data/lib/algolia/models/recommend/search_params_object.rb +1 -1
- data/lib/algolia/models/search/around_precision.rb +1 -1
- data/lib/algolia/models/search/browse_params_object.rb +1 -1
- data/lib/algolia/models/search/built_in_operation.rb +1 -2
- data/lib/algolia/models/search/built_in_operation_value.rb +105 -0
- data/lib/algolia/models/search/consequence_params.rb +1 -1
- data/lib/algolia/models/search/dictionary_entry.rb +0 -2
- data/lib/algolia/models/search/index_settings.rb +2 -2
- data/lib/algolia/models/search/{around_precision_from_value_inner.rb → range.rb} +3 -6
- data/lib/algolia/models/search/{redirect_rule_index_metadata_data.rb → redirect_rule_index_data.rb} +3 -3
- data/lib/algolia/models/search/redirect_rule_index_metadata.rb +1 -1
- data/lib/algolia/models/search/search_for_facets.rb +1 -1
- data/lib/algolia/models/search/search_for_hits.rb +1 -1
- data/lib/algolia/models/search/search_params_object.rb +1 -1
- data/lib/algolia/models/search/search_params_string.rb +1 -0
- data/lib/algolia/models/search/{index_settings_as_search_params.rb → settings_response.rb} +251 -11
- data/lib/algolia/models/usage/{get_usage400_response_error_errors_inner.rb → error_item.rb} +3 -3
- data/lib/algolia/models/usage/{get_usage400_response_error.rb → forbidden_error.rb} +4 -4
- data/lib/algolia/models/usage/{get_usage200_response.rb → index_usage.rb} +4 -4
- data/lib/algolia/models/usage/invalid_request_error.rb +231 -0
- data/lib/algolia/models/usage/{get_usage200_response_statistics_inner.rb → statistic_entry.rb} +3 -3
- data/lib/algolia/transport/transport.rb +8 -2
- data/lib/algolia/version.rb +1 -1
- metadata +32 -63
- data/lib/algolia/models/abtesting/custom_search_params.rb +0 -214
- data/lib/algolia/models/abtesting/error_base.rb +0 -212
- data/lib/algolia/models/analytics/error_base.rb +0 -212
- data/lib/algolia/models/ingestion/error_base.rb +0 -212
- data/lib/algolia/models/insights/error_base.rb +0 -212
- data/lib/algolia/models/monitoring/error_base.rb +0 -212
- data/lib/algolia/models/monitoring/get_servers403_response.rb +0 -211
- data/lib/algolia/models/personalization/error_base.rb +0 -212
- data/lib/algolia/models/query-suggestions/app_id.rb +0 -209
- data/lib/algolia/models/query-suggestions/error_base.rb +0 -212
- data/lib/algolia/models/recommend/base_recommend_request.rb +0 -281
- data/lib/algolia/models/recommend/base_search_params.rb +0 -635
- data/lib/algolia/models/recommend/base_search_params_without_query.rb +0 -616
- data/lib/algolia/models/recommend/base_search_response.rb +0 -499
- data/lib/algolia/models/recommend/error_base.rb +0 -212
- data/lib/algolia/models/recommend/frequently_bought_together.rb +0 -247
- data/lib/algolia/models/recommend/index_settings_as_search_params.rb +0 -788
- data/lib/algolia/models/recommend/recommended_for_you.rb +0 -244
- data/lib/algolia/models/recommend/search_pagination.rb +0 -282
- data/lib/algolia/models/recommend/search_params_query.rb +0 -212
- data/lib/algolia/models/recommend/trending_facets.rb +0 -258
- data/lib/algolia/models/search/base_get_api_key_response.rb +0 -224
- data/lib/algolia/models/search/base_index_settings.rb +0 -426
- data/lib/algolia/models/search/base_search_params.rb +0 -635
- data/lib/algolia/models/search/base_search_params_without_query.rb +0 -616
- data/lib/algolia/models/search/base_search_response.rb +0 -499
- data/lib/algolia/models/search/cursor.rb +0 -209
- data/lib/algolia/models/search/error_base.rb +0 -212
- data/lib/algolia/models/search/params.rb +0 -236
- data/lib/algolia/models/search/search_hits.rb +0 -240
- data/lib/algolia/models/search/search_pagination.rb +0 -282
- data/lib/algolia/models/search/search_params_query.rb +0 -212
- data/lib/algolia/models/usage/error_base.rb +0 -212
- data/lib/algolia/models/usage/get_usage400_response.rb +0 -213
@@ -1,499 +0,0 @@
|
|
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
|
-
|
3
|
-
require "date"
|
4
|
-
require "time"
|
5
|
-
|
6
|
-
module Algolia
|
7
|
-
module Recommend
|
8
|
-
class BaseSearchResponse
|
9
|
-
# A/B test ID. This is only included in the response for indices that are part of an A/B test.
|
10
|
-
attr_accessor :ab_test_id
|
11
|
-
|
12
|
-
# Variant ID. This is only included in the response for indices that are part of an A/B test.
|
13
|
-
attr_accessor :ab_test_variant_id
|
14
|
-
|
15
|
-
# Computed geographical location.
|
16
|
-
attr_accessor :around_lat_lng
|
17
|
-
|
18
|
-
# Distance from a central coordinate provided by `aroundLatLng`.
|
19
|
-
attr_accessor :automatic_radius
|
20
|
-
|
21
|
-
attr_accessor :exhaustive
|
22
|
-
|
23
|
-
# See the `facetsCount` field of the `exhaustive` object in the response.
|
24
|
-
attr_accessor :exhaustive_facets_count
|
25
|
-
|
26
|
-
# See the `nbHits` field of the `exhaustive` object in the response.
|
27
|
-
attr_accessor :exhaustive_nb_hits
|
28
|
-
|
29
|
-
# See the `typo` field of the `exhaustive` object in the response.
|
30
|
-
attr_accessor :exhaustive_typo
|
31
|
-
|
32
|
-
# Facet counts.
|
33
|
-
attr_accessor :facets
|
34
|
-
|
35
|
-
# Statistics for numerical facets.
|
36
|
-
attr_accessor :facets_stats
|
37
|
-
|
38
|
-
# Index name used for the query.
|
39
|
-
attr_accessor :index
|
40
|
-
|
41
|
-
# Index name used for the query. During A/B testing, the targeted index isn't always the index used by the query.
|
42
|
-
attr_accessor :index_used
|
43
|
-
|
44
|
-
# Warnings about the query.
|
45
|
-
attr_accessor :message
|
46
|
-
|
47
|
-
# Number of hits selected and sorted by the relevant sort algorithm.
|
48
|
-
attr_accessor :nb_sorted_hits
|
49
|
-
|
50
|
-
# Post-[normalization](https://www.algolia.com/doc/guides/managing-results/optimize-search-results/handling-natural-languages-nlp/#what-does-normalization-mean) query string that will be searched.
|
51
|
-
attr_accessor :parsed_query
|
52
|
-
|
53
|
-
# Time the server took to process the request, in milliseconds.
|
54
|
-
attr_accessor :processing_time_ms
|
55
|
-
|
56
|
-
# Experimental. List of processing steps and their times, in milliseconds. You can use this list to investigate performance issues.
|
57
|
-
attr_accessor :processing_timings_ms
|
58
|
-
|
59
|
-
# Markup text indicating which parts of the original query have been removed to retrieve a non-empty result set.
|
60
|
-
attr_accessor :query_after_removal
|
61
|
-
|
62
|
-
attr_accessor :redirect
|
63
|
-
|
64
|
-
attr_accessor :rendering_content
|
65
|
-
|
66
|
-
# Time the server took to process the request, in milliseconds.
|
67
|
-
attr_accessor :server_time_ms
|
68
|
-
|
69
|
-
# Host name of the server that processed the request.
|
70
|
-
attr_accessor :server_used
|
71
|
-
|
72
|
-
# An object with custom data. You can store up to 32kB as custom data.
|
73
|
-
attr_accessor :user_data
|
74
|
-
|
75
|
-
# Unique identifier for the query. This is used for [click analytics](https://www.algolia.com/doc/guides/analytics/click-analytics/).
|
76
|
-
attr_accessor :query_id
|
77
|
-
|
78
|
-
attr_accessor :additional_properties
|
79
|
-
|
80
|
-
# Attribute mapping from ruby-style variable name to JSON key.
|
81
|
-
def self.attribute_map
|
82
|
-
{
|
83
|
-
:ab_test_id => :abTestID,
|
84
|
-
:ab_test_variant_id => :abTestVariantID,
|
85
|
-
:around_lat_lng => :aroundLatLng,
|
86
|
-
:automatic_radius => :automaticRadius,
|
87
|
-
:exhaustive => :exhaustive,
|
88
|
-
:exhaustive_facets_count => :exhaustiveFacetsCount,
|
89
|
-
:exhaustive_nb_hits => :exhaustiveNbHits,
|
90
|
-
:exhaustive_typo => :exhaustiveTypo,
|
91
|
-
:facets => :facets,
|
92
|
-
:facets_stats => :facets_stats,
|
93
|
-
:index => :index,
|
94
|
-
:index_used => :indexUsed,
|
95
|
-
:message => :message,
|
96
|
-
:nb_sorted_hits => :nbSortedHits,
|
97
|
-
:parsed_query => :parsedQuery,
|
98
|
-
:processing_time_ms => :processingTimeMS,
|
99
|
-
:processing_timings_ms => :processingTimingsMS,
|
100
|
-
:query_after_removal => :queryAfterRemoval,
|
101
|
-
:redirect => :redirect,
|
102
|
-
:rendering_content => :renderingContent,
|
103
|
-
:server_time_ms => :serverTimeMS,
|
104
|
-
:server_used => :serverUsed,
|
105
|
-
:user_data => :userData,
|
106
|
-
:query_id => :queryID
|
107
|
-
}
|
108
|
-
end
|
109
|
-
|
110
|
-
# Returns all the JSON keys this model knows about
|
111
|
-
def self.acceptable_attributes
|
112
|
-
attribute_map.values
|
113
|
-
end
|
114
|
-
|
115
|
-
# Attribute type mapping.
|
116
|
-
def self.types_mapping
|
117
|
-
{
|
118
|
-
:ab_test_id => :"Integer",
|
119
|
-
:ab_test_variant_id => :"Integer",
|
120
|
-
:around_lat_lng => :"String",
|
121
|
-
:automatic_radius => :"String",
|
122
|
-
:exhaustive => :"Exhaustive",
|
123
|
-
:exhaustive_facets_count => :"Boolean",
|
124
|
-
:exhaustive_nb_hits => :"Boolean",
|
125
|
-
:exhaustive_typo => :"Boolean",
|
126
|
-
:facets => :"Hash<String, Hash<String, Integer>>",
|
127
|
-
:facets_stats => :"Hash<String, FacetsStats>",
|
128
|
-
:index => :"String",
|
129
|
-
:index_used => :"String",
|
130
|
-
:message => :"String",
|
131
|
-
:nb_sorted_hits => :"Integer",
|
132
|
-
:parsed_query => :"String",
|
133
|
-
:processing_time_ms => :"Integer",
|
134
|
-
:processing_timings_ms => :"Object",
|
135
|
-
:query_after_removal => :"String",
|
136
|
-
:redirect => :"Redirect",
|
137
|
-
:rendering_content => :"RenderingContent",
|
138
|
-
:server_time_ms => :"Integer",
|
139
|
-
:server_used => :"String",
|
140
|
-
:user_data => :"Object",
|
141
|
-
:query_id => :"String"
|
142
|
-
}
|
143
|
-
end
|
144
|
-
|
145
|
-
# List of attributes with nullable: true
|
146
|
-
def self.openapi_nullable
|
147
|
-
Set.new(
|
148
|
-
[]
|
149
|
-
)
|
150
|
-
end
|
151
|
-
|
152
|
-
# Initializes the object
|
153
|
-
# @param [Hash] attributes Model attributes in the form of hash
|
154
|
-
def initialize(attributes = {})
|
155
|
-
if (!attributes.is_a?(Hash))
|
156
|
-
raise(
|
157
|
-
ArgumentError,
|
158
|
-
"The input argument (attributes) must be a hash in `Algolia::BaseSearchResponse` initialize method"
|
159
|
-
)
|
160
|
-
end
|
161
|
-
|
162
|
-
if attributes.key?(:ab_test_id)
|
163
|
-
self.ab_test_id = attributes[:ab_test_id]
|
164
|
-
end
|
165
|
-
|
166
|
-
if attributes.key?(:ab_test_variant_id)
|
167
|
-
self.ab_test_variant_id = attributes[:ab_test_variant_id]
|
168
|
-
end
|
169
|
-
|
170
|
-
if attributes.key?(:around_lat_lng)
|
171
|
-
self.around_lat_lng = attributes[:around_lat_lng]
|
172
|
-
end
|
173
|
-
|
174
|
-
if attributes.key?(:automatic_radius)
|
175
|
-
self.automatic_radius = attributes[:automatic_radius]
|
176
|
-
end
|
177
|
-
|
178
|
-
if attributes.key?(:exhaustive)
|
179
|
-
self.exhaustive = attributes[:exhaustive]
|
180
|
-
end
|
181
|
-
|
182
|
-
if attributes.key?(:exhaustive_facets_count)
|
183
|
-
self.exhaustive_facets_count = attributes[:exhaustive_facets_count]
|
184
|
-
end
|
185
|
-
|
186
|
-
if attributes.key?(:exhaustive_nb_hits)
|
187
|
-
self.exhaustive_nb_hits = attributes[:exhaustive_nb_hits]
|
188
|
-
end
|
189
|
-
|
190
|
-
if attributes.key?(:exhaustive_typo)
|
191
|
-
self.exhaustive_typo = attributes[:exhaustive_typo]
|
192
|
-
end
|
193
|
-
|
194
|
-
if attributes.key?(:facets)
|
195
|
-
if (value = attributes[:facets]).is_a?(Hash)
|
196
|
-
self.facets = value
|
197
|
-
end
|
198
|
-
end
|
199
|
-
|
200
|
-
if attributes.key?(:facets_stats)
|
201
|
-
if (value = attributes[:facets_stats]).is_a?(Hash)
|
202
|
-
self.facets_stats = value
|
203
|
-
end
|
204
|
-
end
|
205
|
-
|
206
|
-
if attributes.key?(:index)
|
207
|
-
self.index = attributes[:index]
|
208
|
-
end
|
209
|
-
|
210
|
-
if attributes.key?(:index_used)
|
211
|
-
self.index_used = attributes[:index_used]
|
212
|
-
end
|
213
|
-
|
214
|
-
if attributes.key?(:message)
|
215
|
-
self.message = attributes[:message]
|
216
|
-
end
|
217
|
-
|
218
|
-
if attributes.key?(:nb_sorted_hits)
|
219
|
-
self.nb_sorted_hits = attributes[:nb_sorted_hits]
|
220
|
-
end
|
221
|
-
|
222
|
-
if attributes.key?(:parsed_query)
|
223
|
-
self.parsed_query = attributes[:parsed_query]
|
224
|
-
end
|
225
|
-
|
226
|
-
if attributes.key?(:processing_time_ms)
|
227
|
-
self.processing_time_ms = attributes[:processing_time_ms]
|
228
|
-
else
|
229
|
-
self.processing_time_ms = nil
|
230
|
-
end
|
231
|
-
|
232
|
-
if attributes.key?(:processing_timings_ms)
|
233
|
-
self.processing_timings_ms = attributes[:processing_timings_ms]
|
234
|
-
end
|
235
|
-
|
236
|
-
if attributes.key?(:query_after_removal)
|
237
|
-
self.query_after_removal = attributes[:query_after_removal]
|
238
|
-
end
|
239
|
-
|
240
|
-
if attributes.key?(:redirect)
|
241
|
-
self.redirect = attributes[:redirect]
|
242
|
-
end
|
243
|
-
|
244
|
-
if attributes.key?(:rendering_content)
|
245
|
-
self.rendering_content = attributes[:rendering_content]
|
246
|
-
end
|
247
|
-
|
248
|
-
if attributes.key?(:server_time_ms)
|
249
|
-
self.server_time_ms = attributes[:server_time_ms]
|
250
|
-
end
|
251
|
-
|
252
|
-
if attributes.key?(:server_used)
|
253
|
-
self.server_used = attributes[:server_used]
|
254
|
-
end
|
255
|
-
|
256
|
-
if attributes.key?(:user_data)
|
257
|
-
self.user_data = attributes[:user_data]
|
258
|
-
end
|
259
|
-
|
260
|
-
if attributes.key?(:query_id)
|
261
|
-
self.query_id = attributes[:query_id]
|
262
|
-
end
|
263
|
-
|
264
|
-
# add extra attribute to additional_properties
|
265
|
-
self.additional_properties ||= {}
|
266
|
-
self.additional_properties.merge!(attributes.reject { |k, _| self.class.attribute_map.key?(k.to_sym) })
|
267
|
-
end
|
268
|
-
|
269
|
-
# Custom attribute writer method with validation
|
270
|
-
# @param [Object] ab_test_variant_id Value to be assigned
|
271
|
-
def ab_test_variant_id=(ab_test_variant_id)
|
272
|
-
if ab_test_variant_id.nil?
|
273
|
-
raise ArgumentError, "ab_test_variant_id cannot be nil"
|
274
|
-
end
|
275
|
-
|
276
|
-
if ab_test_variant_id < 1
|
277
|
-
raise ArgumentError, "invalid value for \"ab_test_variant_id\", must be greater than or equal to 1."
|
278
|
-
end
|
279
|
-
|
280
|
-
@ab_test_variant_id = ab_test_variant_id
|
281
|
-
end
|
282
|
-
|
283
|
-
# Custom attribute writer method with validation
|
284
|
-
# @param [Object] around_lat_lng Value to be assigned
|
285
|
-
def around_lat_lng=(around_lat_lng)
|
286
|
-
if around_lat_lng.nil?
|
287
|
-
raise ArgumentError, "around_lat_lng cannot be nil"
|
288
|
-
end
|
289
|
-
|
290
|
-
pattern = /^(-?\d+(\.\d+)?),\s*(-?\d+(\.\d+)?)$/
|
291
|
-
if around_lat_lng !~ pattern
|
292
|
-
raise ArgumentError, "invalid value for \"around_lat_lng\", must conform to the pattern #{pattern}."
|
293
|
-
end
|
294
|
-
|
295
|
-
@around_lat_lng = around_lat_lng
|
296
|
-
end
|
297
|
-
|
298
|
-
# Checks equality by comparing each attribute.
|
299
|
-
# @param [Object] Object to be compared
|
300
|
-
def ==(other)
|
301
|
-
return true if self.equal?(other)
|
302
|
-
self.class == other.class &&
|
303
|
-
ab_test_id == other.ab_test_id &&
|
304
|
-
ab_test_variant_id == other.ab_test_variant_id &&
|
305
|
-
around_lat_lng == other.around_lat_lng &&
|
306
|
-
automatic_radius == other.automatic_radius &&
|
307
|
-
exhaustive == other.exhaustive &&
|
308
|
-
exhaustive_facets_count == other.exhaustive_facets_count &&
|
309
|
-
exhaustive_nb_hits == other.exhaustive_nb_hits &&
|
310
|
-
exhaustive_typo == other.exhaustive_typo &&
|
311
|
-
facets == other.facets &&
|
312
|
-
facets_stats == other.facets_stats &&
|
313
|
-
index == other.index &&
|
314
|
-
index_used == other.index_used &&
|
315
|
-
message == other.message &&
|
316
|
-
nb_sorted_hits == other.nb_sorted_hits &&
|
317
|
-
parsed_query == other.parsed_query &&
|
318
|
-
processing_time_ms == other.processing_time_ms &&
|
319
|
-
processing_timings_ms == other.processing_timings_ms &&
|
320
|
-
query_after_removal == other.query_after_removal &&
|
321
|
-
redirect == other.redirect &&
|
322
|
-
rendering_content == other.rendering_content &&
|
323
|
-
server_time_ms == other.server_time_ms &&
|
324
|
-
server_used == other.server_used &&
|
325
|
-
user_data == other.user_data &&
|
326
|
-
query_id == other.query_id
|
327
|
-
end
|
328
|
-
|
329
|
-
# @see the `==` method
|
330
|
-
# @param [Object] Object to be compared
|
331
|
-
def eql?(other)
|
332
|
-
self == other
|
333
|
-
end
|
334
|
-
|
335
|
-
# Calculates hash code according to all attributes.
|
336
|
-
# @return [Integer] Hash code
|
337
|
-
def hash
|
338
|
-
[
|
339
|
-
ab_test_id,
|
340
|
-
ab_test_variant_id,
|
341
|
-
around_lat_lng,
|
342
|
-
automatic_radius,
|
343
|
-
exhaustive,
|
344
|
-
exhaustive_facets_count,
|
345
|
-
exhaustive_nb_hits,
|
346
|
-
exhaustive_typo,
|
347
|
-
facets,
|
348
|
-
facets_stats,
|
349
|
-
index,
|
350
|
-
index_used,
|
351
|
-
message,
|
352
|
-
nb_sorted_hits,
|
353
|
-
parsed_query,
|
354
|
-
processing_time_ms,
|
355
|
-
processing_timings_ms,
|
356
|
-
query_after_removal,
|
357
|
-
redirect,
|
358
|
-
rendering_content,
|
359
|
-
server_time_ms,
|
360
|
-
server_used,
|
361
|
-
user_data,
|
362
|
-
query_id
|
363
|
-
].hash
|
364
|
-
end
|
365
|
-
|
366
|
-
# Builds the object from hash
|
367
|
-
# @param [Hash] attributes Model attributes in the form of hash
|
368
|
-
# @return [Object] Returns the model itself
|
369
|
-
def self.build_from_hash(attributes)
|
370
|
-
return nil unless attributes.is_a?(Hash)
|
371
|
-
attributes = attributes.transform_keys(&:to_sym)
|
372
|
-
transformed_hash = {}
|
373
|
-
types_mapping.each_pair do |key, type|
|
374
|
-
if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
|
375
|
-
transformed_hash[key.to_sym] = nil
|
376
|
-
elsif type =~ /\AArray<(.*)>/i
|
377
|
-
# check to ensure the input is an array given that the attribute
|
378
|
-
# is documented as an array but the input is not
|
379
|
-
if attributes[attribute_map[key]].is_a?(Array)
|
380
|
-
transformed_hash[key.to_sym] = attributes[attribute_map[key]].map { |v|
|
381
|
-
_deserialize(::Regexp.last_match(1), v)
|
382
|
-
}
|
383
|
-
end
|
384
|
-
elsif !attributes[attribute_map[key]].nil?
|
385
|
-
transformed_hash[key.to_sym] = _deserialize(type, attributes[attribute_map[key]])
|
386
|
-
end
|
387
|
-
end
|
388
|
-
|
389
|
-
# add extra attribute to transformed_hash
|
390
|
-
transformed_hash.merge!(attributes.reject { |k, _| attribute_map.key?(k.to_sym) })
|
391
|
-
new(transformed_hash)
|
392
|
-
end
|
393
|
-
|
394
|
-
# Deserializes the data based on type
|
395
|
-
# @param string type Data type
|
396
|
-
# @param string value Value to be deserialized
|
397
|
-
# @return [Object] Deserialized data
|
398
|
-
def self._deserialize(type, value)
|
399
|
-
case type.to_sym
|
400
|
-
when :Time
|
401
|
-
Time.parse(value)
|
402
|
-
when :Date
|
403
|
-
Date.parse(value)
|
404
|
-
when :String
|
405
|
-
value.to_s
|
406
|
-
when :Integer
|
407
|
-
value.to_i
|
408
|
-
when :Float
|
409
|
-
value.to_f
|
410
|
-
when :Boolean
|
411
|
-
if value.to_s =~ /\A(true|t|yes|y|1)\z/i
|
412
|
-
true
|
413
|
-
else
|
414
|
-
false
|
415
|
-
end
|
416
|
-
|
417
|
-
when :Object
|
418
|
-
# generic object (usually a Hash), return directly
|
419
|
-
value
|
420
|
-
when /\AArray<(?<inner_type>.+)>\z/
|
421
|
-
inner_type = Regexp.last_match[:inner_type]
|
422
|
-
value.map { |v| _deserialize(inner_type, v) }
|
423
|
-
when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
|
424
|
-
k_type = Regexp.last_match[:k_type]
|
425
|
-
v_type = Regexp.last_match[:v_type]
|
426
|
-
{}.tap do |hash|
|
427
|
-
value.each do |k, v|
|
428
|
-
hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
|
429
|
-
end
|
430
|
-
end
|
431
|
-
# model
|
432
|
-
else
|
433
|
-
# models (e.g. Pet) or oneOf
|
434
|
-
klass = Algolia::Recommend.const_get(type)
|
435
|
-
klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass
|
436
|
-
.build_from_hash(value)
|
437
|
-
end
|
438
|
-
end
|
439
|
-
|
440
|
-
# Returns the string representation of the object
|
441
|
-
# @return [String] String presentation of the object
|
442
|
-
def to_s
|
443
|
-
to_hash.to_s
|
444
|
-
end
|
445
|
-
|
446
|
-
# to_body is an alias to to_hash (backward compatibility)
|
447
|
-
# @return [Hash] Returns the object in the form of hash
|
448
|
-
def to_body
|
449
|
-
to_hash
|
450
|
-
end
|
451
|
-
|
452
|
-
def to_json(*_args)
|
453
|
-
to_hash.to_json
|
454
|
-
end
|
455
|
-
|
456
|
-
# Returns the object in the form of hash
|
457
|
-
# @return [Hash] Returns the object in the form of hash
|
458
|
-
def to_hash
|
459
|
-
hash = {}
|
460
|
-
self.class.attribute_map.each_pair do |attr, param|
|
461
|
-
value = send(attr)
|
462
|
-
if value.nil?
|
463
|
-
is_nullable = self.class.openapi_nullable.include?(attr)
|
464
|
-
next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
|
465
|
-
end
|
466
|
-
|
467
|
-
hash[param] = _to_hash(value)
|
468
|
-
end
|
469
|
-
|
470
|
-
# also add attributes from additional_properties to hash
|
471
|
-
self.additional_properties&.each_pair do |k, v|
|
472
|
-
hash[k.to_sym] = _to_hash(v)
|
473
|
-
end
|
474
|
-
|
475
|
-
hash
|
476
|
-
end
|
477
|
-
|
478
|
-
# Outputs non-array value in the form of hash
|
479
|
-
# For object, use to_hash. Otherwise, just return the value
|
480
|
-
# @param [Object] value Any valid value
|
481
|
-
# @return [Hash] Returns the value in the form of hash
|
482
|
-
def _to_hash(value)
|
483
|
-
if value.is_a?(Array)
|
484
|
-
value.compact.map { |v| _to_hash(v) }
|
485
|
-
elsif value.is_a?(Hash)
|
486
|
-
{}.tap do |hash|
|
487
|
-
value.each { |k, v| hash[k] = _to_hash(v) }
|
488
|
-
end
|
489
|
-
elsif value.respond_to?(:to_hash)
|
490
|
-
value.to_hash
|
491
|
-
else
|
492
|
-
value
|
493
|
-
end
|
494
|
-
end
|
495
|
-
|
496
|
-
end
|
497
|
-
|
498
|
-
end
|
499
|
-
end
|
@@ -1,212 +0,0 @@
|
|
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
|
-
|
3
|
-
require "date"
|
4
|
-
require "time"
|
5
|
-
|
6
|
-
module Algolia
|
7
|
-
module Recommend
|
8
|
-
# Error.
|
9
|
-
class ErrorBase
|
10
|
-
attr_accessor :message
|
11
|
-
|
12
|
-
attr_accessor :additional_properties
|
13
|
-
|
14
|
-
# Attribute mapping from ruby-style variable name to JSON key.
|
15
|
-
def self.attribute_map
|
16
|
-
{
|
17
|
-
:message => :message
|
18
|
-
}
|
19
|
-
end
|
20
|
-
|
21
|
-
# Returns all the JSON keys this model knows about
|
22
|
-
def self.acceptable_attributes
|
23
|
-
attribute_map.values
|
24
|
-
end
|
25
|
-
|
26
|
-
# Attribute type mapping.
|
27
|
-
def self.types_mapping
|
28
|
-
{
|
29
|
-
:message => :"String"
|
30
|
-
}
|
31
|
-
end
|
32
|
-
|
33
|
-
# List of attributes with nullable: true
|
34
|
-
def self.openapi_nullable
|
35
|
-
Set.new(
|
36
|
-
[]
|
37
|
-
)
|
38
|
-
end
|
39
|
-
|
40
|
-
# Initializes the object
|
41
|
-
# @param [Hash] attributes Model attributes in the form of hash
|
42
|
-
def initialize(attributes = {})
|
43
|
-
if (!attributes.is_a?(Hash))
|
44
|
-
raise(
|
45
|
-
ArgumentError,
|
46
|
-
"The input argument (attributes) must be a hash in `Algolia::ErrorBase` initialize method"
|
47
|
-
)
|
48
|
-
end
|
49
|
-
|
50
|
-
if attributes.key?(:message)
|
51
|
-
self.message = attributes[:message]
|
52
|
-
end
|
53
|
-
|
54
|
-
# add extra attribute to additional_properties
|
55
|
-
self.additional_properties ||= {}
|
56
|
-
self.additional_properties.merge!(attributes.reject { |k, _| self.class.attribute_map.key?(k.to_sym) })
|
57
|
-
end
|
58
|
-
|
59
|
-
# Checks equality by comparing each attribute.
|
60
|
-
# @param [Object] Object to be compared
|
61
|
-
def ==(other)
|
62
|
-
return true if self.equal?(other)
|
63
|
-
self.class == other.class &&
|
64
|
-
message == other.message
|
65
|
-
end
|
66
|
-
|
67
|
-
# @see the `==` method
|
68
|
-
# @param [Object] Object to be compared
|
69
|
-
def eql?(other)
|
70
|
-
self == other
|
71
|
-
end
|
72
|
-
|
73
|
-
# Calculates hash code according to all attributes.
|
74
|
-
# @return [Integer] Hash code
|
75
|
-
def hash
|
76
|
-
[message].hash
|
77
|
-
end
|
78
|
-
|
79
|
-
# Builds the object from hash
|
80
|
-
# @param [Hash] attributes Model attributes in the form of hash
|
81
|
-
# @return [Object] Returns the model itself
|
82
|
-
def self.build_from_hash(attributes)
|
83
|
-
return nil unless attributes.is_a?(Hash)
|
84
|
-
attributes = attributes.transform_keys(&:to_sym)
|
85
|
-
transformed_hash = {}
|
86
|
-
types_mapping.each_pair do |key, type|
|
87
|
-
if attributes.key?(attribute_map[key]) && attributes[attribute_map[key]].nil?
|
88
|
-
transformed_hash[key.to_sym] = nil
|
89
|
-
elsif type =~ /\AArray<(.*)>/i
|
90
|
-
# check to ensure the input is an array given that the attribute
|
91
|
-
# is documented as an array but the input is not
|
92
|
-
if attributes[attribute_map[key]].is_a?(Array)
|
93
|
-
transformed_hash[key.to_sym] = attributes[attribute_map[key]].map { |v|
|
94
|
-
_deserialize(::Regexp.last_match(1), v)
|
95
|
-
}
|
96
|
-
end
|
97
|
-
elsif !attributes[attribute_map[key]].nil?
|
98
|
-
transformed_hash[key.to_sym] = _deserialize(type, attributes[attribute_map[key]])
|
99
|
-
end
|
100
|
-
end
|
101
|
-
|
102
|
-
# add extra attribute to transformed_hash
|
103
|
-
transformed_hash.merge!(attributes.reject { |k, _| attribute_map.key?(k.to_sym) })
|
104
|
-
new(transformed_hash)
|
105
|
-
end
|
106
|
-
|
107
|
-
# Deserializes the data based on type
|
108
|
-
# @param string type Data type
|
109
|
-
# @param string value Value to be deserialized
|
110
|
-
# @return [Object] Deserialized data
|
111
|
-
def self._deserialize(type, value)
|
112
|
-
case type.to_sym
|
113
|
-
when :Time
|
114
|
-
Time.parse(value)
|
115
|
-
when :Date
|
116
|
-
Date.parse(value)
|
117
|
-
when :String
|
118
|
-
value.to_s
|
119
|
-
when :Integer
|
120
|
-
value.to_i
|
121
|
-
when :Float
|
122
|
-
value.to_f
|
123
|
-
when :Boolean
|
124
|
-
if value.to_s =~ /\A(true|t|yes|y|1)\z/i
|
125
|
-
true
|
126
|
-
else
|
127
|
-
false
|
128
|
-
end
|
129
|
-
|
130
|
-
when :Object
|
131
|
-
# generic object (usually a Hash), return directly
|
132
|
-
value
|
133
|
-
when /\AArray<(?<inner_type>.+)>\z/
|
134
|
-
inner_type = Regexp.last_match[:inner_type]
|
135
|
-
value.map { |v| _deserialize(inner_type, v) }
|
136
|
-
when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
|
137
|
-
k_type = Regexp.last_match[:k_type]
|
138
|
-
v_type = Regexp.last_match[:v_type]
|
139
|
-
{}.tap do |hash|
|
140
|
-
value.each do |k, v|
|
141
|
-
hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
|
142
|
-
end
|
143
|
-
end
|
144
|
-
# model
|
145
|
-
else
|
146
|
-
# models (e.g. Pet) or oneOf
|
147
|
-
klass = Algolia::Recommend.const_get(type)
|
148
|
-
klass.respond_to?(:openapi_any_of) || klass.respond_to?(:openapi_one_of) ? klass.build(value) : klass
|
149
|
-
.build_from_hash(value)
|
150
|
-
end
|
151
|
-
end
|
152
|
-
|
153
|
-
# Returns the string representation of the object
|
154
|
-
# @return [String] String presentation of the object
|
155
|
-
def to_s
|
156
|
-
to_hash.to_s
|
157
|
-
end
|
158
|
-
|
159
|
-
# to_body is an alias to to_hash (backward compatibility)
|
160
|
-
# @return [Hash] Returns the object in the form of hash
|
161
|
-
def to_body
|
162
|
-
to_hash
|
163
|
-
end
|
164
|
-
|
165
|
-
def to_json(*_args)
|
166
|
-
to_hash.to_json
|
167
|
-
end
|
168
|
-
|
169
|
-
# Returns the object in the form of hash
|
170
|
-
# @return [Hash] Returns the object in the form of hash
|
171
|
-
def to_hash
|
172
|
-
hash = {}
|
173
|
-
self.class.attribute_map.each_pair do |attr, param|
|
174
|
-
value = send(attr)
|
175
|
-
if value.nil?
|
176
|
-
is_nullable = self.class.openapi_nullable.include?(attr)
|
177
|
-
next if !is_nullable || (is_nullable && !instance_variable_defined?(:"@#{attr}"))
|
178
|
-
end
|
179
|
-
|
180
|
-
hash[param] = _to_hash(value)
|
181
|
-
end
|
182
|
-
|
183
|
-
# also add attributes from additional_properties to hash
|
184
|
-
self.additional_properties&.each_pair do |k, v|
|
185
|
-
hash[k.to_sym] = _to_hash(v)
|
186
|
-
end
|
187
|
-
|
188
|
-
hash
|
189
|
-
end
|
190
|
-
|
191
|
-
# Outputs non-array value in the form of hash
|
192
|
-
# For object, use to_hash. Otherwise, just return the value
|
193
|
-
# @param [Object] value Any valid value
|
194
|
-
# @return [Hash] Returns the value in the form of hash
|
195
|
-
def _to_hash(value)
|
196
|
-
if value.is_a?(Array)
|
197
|
-
value.compact.map { |v| _to_hash(v) }
|
198
|
-
elsif value.is_a?(Hash)
|
199
|
-
{}.tap do |hash|
|
200
|
-
value.each { |k, v| hash[k] = _to_hash(v) }
|
201
|
-
end
|
202
|
-
elsif value.respond_to?(:to_hash)
|
203
|
-
value.to_hash
|
204
|
-
else
|
205
|
-
value
|
206
|
-
end
|
207
|
-
end
|
208
|
-
|
209
|
-
end
|
210
|
-
|
211
|
-
end
|
212
|
-
end
|