fangkuai.rb 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (61) hide show
  1. checksums.yaml +7 -0
  2. data/LICENSE +10 -0
  3. data/README.md +1 -0
  4. data/lib/square.rb +61 -0
  5. data/lib/square/api/apple_pay_api.rb +50 -0
  6. data/lib/square/api/bank_accounts_api.rb +136 -0
  7. data/lib/square/api/base_api.rb +43 -0
  8. data/lib/square/api/cash_drawers_api.rb +150 -0
  9. data/lib/square/api/catalog_api.rb +572 -0
  10. data/lib/square/api/checkout_api.rb +49 -0
  11. data/lib/square/api/customer_groups_api.rb +182 -0
  12. data/lib/square/api/customer_segments_api.rb +78 -0
  13. data/lib/square/api/customers_api.rb +418 -0
  14. data/lib/square/api/devices_api.rb +120 -0
  15. data/lib/square/api/disputes_api.rb +398 -0
  16. data/lib/square/api/employees_api.rb +87 -0
  17. data/lib/square/api/inventory_api.rb +296 -0
  18. data/lib/square/api/invoices_api.rb +358 -0
  19. data/lib/square/api/labor_api.rb +630 -0
  20. data/lib/square/api/locations_api.rb +151 -0
  21. data/lib/square/api/loyalty_api.rb +543 -0
  22. data/lib/square/api/merchants_api.rb +83 -0
  23. data/lib/square/api/mobile_authorization_api.rb +52 -0
  24. data/lib/square/api/o_auth_api.rb +163 -0
  25. data/lib/square/api/orders_api.rb +280 -0
  26. data/lib/square/api/payments_api.rb +279 -0
  27. data/lib/square/api/refunds_api.rb +145 -0
  28. data/lib/square/api/subscriptions_api.rb +251 -0
  29. data/lib/square/api/team_api.rb +326 -0
  30. data/lib/square/api/terminal_api.rb +141 -0
  31. data/lib/square/api/transactions_api.rb +369 -0
  32. data/lib/square/api/v1_employees_api.rb +723 -0
  33. data/lib/square/api/v1_items_api.rb +1686 -0
  34. data/lib/square/api/v1_locations_api.rb +65 -0
  35. data/lib/square/api/v1_transactions_api.rb +572 -0
  36. data/lib/square/api_helper.rb +276 -0
  37. data/lib/square/client.rb +211 -0
  38. data/lib/square/configuration.rb +101 -0
  39. data/lib/square/exceptions/api_exception.rb +15 -0
  40. data/lib/square/http/api_response.rb +45 -0
  41. data/lib/square/http/auth/o_auth2.rb +12 -0
  42. data/lib/square/http/faraday_client.rb +55 -0
  43. data/lib/square/http/http_call_back.rb +19 -0
  44. data/lib/square/http/http_client.rb +99 -0
  45. data/lib/square/http/http_method_enum.rb +8 -0
  46. data/lib/square/http/http_request.rb +45 -0
  47. data/lib/square/http/http_response.rb +24 -0
  48. data/lib/square/utilities/file_wrapper.rb +12 -0
  49. data/spec/user_journey_spec.rb +148 -0
  50. data/test/api/api_test_base.rb +24 -0
  51. data/test/api/test_catalog_api.rb +59 -0
  52. data/test/api/test_customers_api.rb +45 -0
  53. data/test/api/test_employees_api.rb +36 -0
  54. data/test/api/test_labor_api.rb +74 -0
  55. data/test/api/test_locations_api.rb +35 -0
  56. data/test/api/test_merchants_api.rb +40 -0
  57. data/test/api/test_payments_api.rb +42 -0
  58. data/test/api/test_refunds_api.rb +41 -0
  59. data/test/http_response_catcher.rb +19 -0
  60. data/test/test_helper.rb +94 -0
  61. metadata +199 -0
@@ -0,0 +1,120 @@
1
+ module Square
2
+ # DevicesApi
3
+ class DevicesApi < BaseApi
4
+ def initialize(config, http_call_back: nil)
5
+ super(config, http_call_back: http_call_back)
6
+ end
7
+
8
+ # Lists all DeviceCodes associated with the merchant.
9
+ # @param [String] cursor Optional parameter: A pagination cursor returned by
10
+ # a previous call to this endpoint. Provide this to retrieve the next set of
11
+ # results for your original query. See [Paginating
12
+ # results](#paginatingresults) for more information.
13
+ # @param [String] location_id Optional parameter: If specified, only returns
14
+ # DeviceCodes of the specified location. Returns DeviceCodes of all
15
+ # locations if empty.
16
+ # @param [ProductType] product_type Optional parameter: If specified, only
17
+ # returns DeviceCodes targeting the specified product type. Returns
18
+ # DeviceCodes of all product types if empty.
19
+ # @return [ListDeviceCodesResponse Hash] response from the API call
20
+ def list_device_codes(cursor: nil,
21
+ location_id: nil,
22
+ product_type: nil)
23
+ # Prepare query url.
24
+ _query_builder = config.get_base_uri
25
+ _query_builder << '/v2/devices/codes'
26
+ _query_builder = APIHelper.append_url_with_query_parameters(
27
+ _query_builder,
28
+ 'cursor' => cursor,
29
+ 'location_id' => location_id,
30
+ 'product_type' => product_type
31
+ )
32
+ _query_url = APIHelper.clean_url _query_builder
33
+
34
+ # Prepare headers.
35
+ _headers = {
36
+ 'accept' => 'application/json'
37
+ }
38
+
39
+ # Prepare and execute HttpRequest.
40
+ _request = config.http_client.get(
41
+ _query_url,
42
+ headers: _headers
43
+ )
44
+ OAuth2.apply(config, _request)
45
+ _response = execute_request(_request)
46
+
47
+ # Return appropriate response type.
48
+ decoded = APIHelper.json_deserialize(_response.raw_body)
49
+ _errors = APIHelper.map_response(decoded, ['errors'])
50
+ ApiResponse.new(_response, data: decoded, errors: _errors)
51
+ end
52
+
53
+ # Creates a DeviceCode that can be used to login to a Square Terminal device
54
+ # to enter the connected
55
+ # terminal mode.
56
+ # @param [CreateDeviceCodeRequest] body Required parameter: An object
57
+ # containing the fields to POST for the request. See the corresponding
58
+ # object definition for field details.
59
+ # @return [CreateDeviceCodeResponse Hash] response from the API call
60
+ def create_device_code(body:)
61
+ # Prepare query url.
62
+ _query_builder = config.get_base_uri
63
+ _query_builder << '/v2/devices/codes'
64
+ _query_url = APIHelper.clean_url _query_builder
65
+
66
+ # Prepare headers.
67
+ _headers = {
68
+ 'accept' => 'application/json',
69
+ 'content-type' => 'application/json; charset=utf-8'
70
+ }
71
+
72
+ # Prepare and execute HttpRequest.
73
+ _request = config.http_client.post(
74
+ _query_url,
75
+ headers: _headers,
76
+ parameters: body.to_json
77
+ )
78
+ OAuth2.apply(config, _request)
79
+ _response = execute_request(_request)
80
+
81
+ # Return appropriate response type.
82
+ decoded = APIHelper.json_deserialize(_response.raw_body)
83
+ _errors = APIHelper.map_response(decoded, ['errors'])
84
+ ApiResponse.new(_response, data: decoded, errors: _errors)
85
+ end
86
+
87
+ # Retrieves DeviceCode with the associated ID.
88
+ # @param [String] id Required parameter: The unique identifier for the
89
+ # device code.
90
+ # @return [GetDeviceCodeResponse Hash] response from the API call
91
+ def get_device_code(id:)
92
+ # Prepare query url.
93
+ _query_builder = config.get_base_uri
94
+ _query_builder << '/v2/devices/codes/{id}'
95
+ _query_builder = APIHelper.append_url_with_template_parameters(
96
+ _query_builder,
97
+ 'id' => id
98
+ )
99
+ _query_url = APIHelper.clean_url _query_builder
100
+
101
+ # Prepare headers.
102
+ _headers = {
103
+ 'accept' => 'application/json'
104
+ }
105
+
106
+ # Prepare and execute HttpRequest.
107
+ _request = config.http_client.get(
108
+ _query_url,
109
+ headers: _headers
110
+ )
111
+ OAuth2.apply(config, _request)
112
+ _response = execute_request(_request)
113
+
114
+ # Return appropriate response type.
115
+ decoded = APIHelper.json_deserialize(_response.raw_body)
116
+ _errors = APIHelper.map_response(decoded, ['errors'])
117
+ ApiResponse.new(_response, data: decoded, errors: _errors)
118
+ end
119
+ end
120
+ end
@@ -0,0 +1,398 @@
1
+ module Square
2
+ # DisputesApi
3
+ class DisputesApi < BaseApi
4
+ def initialize(config, http_call_back: nil)
5
+ super(config, http_call_back: http_call_back)
6
+ end
7
+
8
+ # Returns a list of disputes associated
9
+ # with a particular account.
10
+ # @param [String] cursor Optional parameter: A pagination cursor returned by
11
+ # a previous call to this endpoint. Provide this to retrieve the next set of
12
+ # results for the original query. For more information, see
13
+ # [Paginating](https://developer.squareup.com/docs/basics/api101/pagination)
14
+ # .
15
+ # @param [DisputeState] states Optional parameter: The dispute states to
16
+ # filter the result. If not specified, the endpoint returns all open
17
+ # disputes (dispute status is not `INQUIRY_CLOSED`, `WON`, or `LOST`).
18
+ # @param [String] location_id Optional parameter: The ID of the location for
19
+ # which to return a list of disputes. If not specified, the endpoint
20
+ # returns all open disputes (dispute status is not `INQUIRY_CLOSED`, `WON`,
21
+ # or `LOST`) associated with all locations.
22
+ # @return [ListDisputesResponse Hash] response from the API call
23
+ def list_disputes(cursor: nil,
24
+ states: nil,
25
+ location_id: nil)
26
+ # Prepare query url.
27
+ _query_builder = config.get_base_uri
28
+ _query_builder << '/v2/disputes'
29
+ _query_builder = APIHelper.append_url_with_query_parameters(
30
+ _query_builder,
31
+ 'cursor' => cursor,
32
+ 'states' => states,
33
+ 'location_id' => location_id
34
+ )
35
+ _query_url = APIHelper.clean_url _query_builder
36
+
37
+ # Prepare headers.
38
+ _headers = {
39
+ 'accept' => 'application/json'
40
+ }
41
+
42
+ # Prepare and execute HttpRequest.
43
+ _request = config.http_client.get(
44
+ _query_url,
45
+ headers: _headers
46
+ )
47
+ OAuth2.apply(config, _request)
48
+ _response = execute_request(_request)
49
+
50
+ # Return appropriate response type.
51
+ decoded = APIHelper.json_deserialize(_response.raw_body)
52
+ _errors = APIHelper.map_response(decoded, ['errors'])
53
+ ApiResponse.new(_response, data: decoded, errors: _errors)
54
+ end
55
+
56
+ # Returns details of a specific dispute.
57
+ # @param [String] dispute_id Required parameter: The ID of the dispute you
58
+ # want more details about.
59
+ # @return [RetrieveDisputeResponse Hash] response from the API call
60
+ def retrieve_dispute(dispute_id:)
61
+ # Prepare query url.
62
+ _query_builder = config.get_base_uri
63
+ _query_builder << '/v2/disputes/{dispute_id}'
64
+ _query_builder = APIHelper.append_url_with_template_parameters(
65
+ _query_builder,
66
+ 'dispute_id' => dispute_id
67
+ )
68
+ _query_url = APIHelper.clean_url _query_builder
69
+
70
+ # Prepare headers.
71
+ _headers = {
72
+ 'accept' => 'application/json'
73
+ }
74
+
75
+ # Prepare and execute HttpRequest.
76
+ _request = config.http_client.get(
77
+ _query_url,
78
+ headers: _headers
79
+ )
80
+ OAuth2.apply(config, _request)
81
+ _response = execute_request(_request)
82
+
83
+ # Return appropriate response type.
84
+ decoded = APIHelper.json_deserialize(_response.raw_body)
85
+ _errors = APIHelper.map_response(decoded, ['errors'])
86
+ ApiResponse.new(_response, data: decoded, errors: _errors)
87
+ end
88
+
89
+ # Accepts loss on a dispute. Square returns
90
+ # the disputed amount to the cardholder and updates the
91
+ # dispute state to ACCEPTED.
92
+ # Square debits the disputed amount from the seller’s Square
93
+ # account. If the Square account balance does not have
94
+ # sufficient funds, Square debits the associated bank account.
95
+ # For an overview of the Disputes API, see
96
+ # [Overview](https://developer.squareup.com/docs/docs/disputes-api/overview)
97
+ # .
98
+ # @param [String] dispute_id Required parameter: ID of the dispute you want
99
+ # to accept.
100
+ # @return [AcceptDisputeResponse Hash] response from the API call
101
+ def accept_dispute(dispute_id:)
102
+ # Prepare query url.
103
+ _query_builder = config.get_base_uri
104
+ _query_builder << '/v2/disputes/{dispute_id}/accept'
105
+ _query_builder = APIHelper.append_url_with_template_parameters(
106
+ _query_builder,
107
+ 'dispute_id' => dispute_id
108
+ )
109
+ _query_url = APIHelper.clean_url _query_builder
110
+
111
+ # Prepare headers.
112
+ _headers = {
113
+ 'accept' => 'application/json'
114
+ }
115
+
116
+ # Prepare and execute HttpRequest.
117
+ _request = config.http_client.post(
118
+ _query_url,
119
+ headers: _headers
120
+ )
121
+ OAuth2.apply(config, _request)
122
+ _response = execute_request(_request)
123
+
124
+ # Return appropriate response type.
125
+ decoded = APIHelper.json_deserialize(_response.raw_body)
126
+ _errors = APIHelper.map_response(decoded, ['errors'])
127
+ ApiResponse.new(_response, data: decoded, errors: _errors)
128
+ end
129
+
130
+ # Returns a list of evidence associated with a dispute.
131
+ # @param [String] dispute_id Required parameter: The ID of the dispute.
132
+ # @return [ListDisputeEvidenceResponse Hash] response from the API call
133
+ def list_dispute_evidence(dispute_id:)
134
+ # Prepare query url.
135
+ _query_builder = config.get_base_uri
136
+ _query_builder << '/v2/disputes/{dispute_id}/evidence'
137
+ _query_builder = APIHelper.append_url_with_template_parameters(
138
+ _query_builder,
139
+ 'dispute_id' => dispute_id
140
+ )
141
+ _query_url = APIHelper.clean_url _query_builder
142
+
143
+ # Prepare headers.
144
+ _headers = {
145
+ 'accept' => 'application/json'
146
+ }
147
+
148
+ # Prepare and execute HttpRequest.
149
+ _request = config.http_client.get(
150
+ _query_url,
151
+ headers: _headers
152
+ )
153
+ OAuth2.apply(config, _request)
154
+ _response = execute_request(_request)
155
+
156
+ # Return appropriate response type.
157
+ decoded = APIHelper.json_deserialize(_response.raw_body)
158
+ _errors = APIHelper.map_response(decoded, ['errors'])
159
+ ApiResponse.new(_response, data: decoded, errors: _errors)
160
+ end
161
+
162
+ # Removes specified evidence from a dispute.
163
+ # Square does not send the bank any evidence that
164
+ # is removed. Also, you cannot remove evidence after
165
+ # submitting it to the bank using
166
+ # [SubmitEvidence](https://developer.squareup.com/docs/reference/square/disp
167
+ # utes-api/submit-evidence).
168
+ # @param [String] dispute_id Required parameter: The ID of the dispute you
169
+ # want to remove evidence from.
170
+ # @param [String] evidence_id Required parameter: The ID of the evidence you
171
+ # want to remove.
172
+ # @return [RemoveDisputeEvidenceResponse Hash] response from the API call
173
+ def remove_dispute_evidence(dispute_id:,
174
+ evidence_id:)
175
+ # Prepare query url.
176
+ _query_builder = config.get_base_uri
177
+ _query_builder << '/v2/disputes/{dispute_id}/evidence/{evidence_id}'
178
+ _query_builder = APIHelper.append_url_with_template_parameters(
179
+ _query_builder,
180
+ 'dispute_id' => dispute_id,
181
+ 'evidence_id' => evidence_id
182
+ )
183
+ _query_url = APIHelper.clean_url _query_builder
184
+
185
+ # Prepare headers.
186
+ _headers = {
187
+ 'accept' => 'application/json'
188
+ }
189
+
190
+ # Prepare and execute HttpRequest.
191
+ _request = config.http_client.delete(
192
+ _query_url,
193
+ headers: _headers
194
+ )
195
+ OAuth2.apply(config, _request)
196
+ _response = execute_request(_request)
197
+
198
+ # Return appropriate response type.
199
+ decoded = APIHelper.json_deserialize(_response.raw_body)
200
+ _errors = APIHelper.map_response(decoded, ['errors'])
201
+ ApiResponse.new(_response, data: decoded, errors: _errors)
202
+ end
203
+
204
+ # Returns the specific evidence metadata associated with a specific dispute.
205
+ # You must maintain a copy of the evidence you upload if you want to
206
+ # reference it later. You cannot download the evidence
207
+ # after you upload it.
208
+ # @param [String] dispute_id Required parameter: The ID of the dispute that
209
+ # you want to retrieve evidence from.
210
+ # @param [String] evidence_id Required parameter: The ID of the evidence to
211
+ # retrieve.
212
+ # @return [RetrieveDisputeEvidenceResponse Hash] response from the API call
213
+ def retrieve_dispute_evidence(dispute_id:,
214
+ evidence_id:)
215
+ # Prepare query url.
216
+ _query_builder = config.get_base_uri
217
+ _query_builder << '/v2/disputes/{dispute_id}/evidence/{evidence_id}'
218
+ _query_builder = APIHelper.append_url_with_template_parameters(
219
+ _query_builder,
220
+ 'dispute_id' => dispute_id,
221
+ 'evidence_id' => evidence_id
222
+ )
223
+ _query_url = APIHelper.clean_url _query_builder
224
+
225
+ # Prepare headers.
226
+ _headers = {
227
+ 'accept' => 'application/json'
228
+ }
229
+
230
+ # Prepare and execute HttpRequest.
231
+ _request = config.http_client.get(
232
+ _query_url,
233
+ headers: _headers
234
+ )
235
+ OAuth2.apply(config, _request)
236
+ _response = execute_request(_request)
237
+
238
+ # Return appropriate response type.
239
+ decoded = APIHelper.json_deserialize(_response.raw_body)
240
+ _errors = APIHelper.map_response(decoded, ['errors'])
241
+ ApiResponse.new(_response, data: decoded, errors: _errors)
242
+ end
243
+
244
+ # Uploads a file to use as evidence in a dispute challenge. The endpoint
245
+ # accepts
246
+ # HTTP multipart/form-data file uploads in HEIC, HEIF, JPEG, PDF, PNG,
247
+ # and TIFF formats.
248
+ # For more information, see [Challenge a
249
+ # Dispute](https://developer.squareup.com/docs/docs/disputes-api/process-dis
250
+ # putes#challenge-a-dispute).
251
+ # @param [String] dispute_id Required parameter: ID of the dispute you want
252
+ # to upload evidence for.
253
+ # @param [CreateDisputeEvidenceFileRequest] request Optional parameter:
254
+ # Defines parameters for a CreateDisputeEvidenceFile request.
255
+ # @param [File | UploadIO] image_file Optional parameter: Example:
256
+ # @return [CreateDisputeEvidenceFileResponse Hash] response from the API call
257
+ def create_dispute_evidence_file(dispute_id:,
258
+ request: nil,
259
+ image_file: nil)
260
+ # Prepare query url.
261
+ _query_builder = config.get_base_uri
262
+ _query_builder << '/v2/disputes/{dispute_id}/evidence_file'
263
+ _query_builder = APIHelper.append_url_with_template_parameters(
264
+ _query_builder,
265
+ 'dispute_id' => dispute_id
266
+ )
267
+ _query_url = APIHelper.clean_url _query_builder
268
+
269
+ if image_file.is_a? FileWrapper
270
+ image_file_wrapper = image_file.file
271
+ image_file_content_type = image_file.content_type
272
+ else
273
+ image_file_wrapper = image_file
274
+ image_file_content_type = 'image/jpeg'
275
+ end
276
+
277
+ # Prepare headers.
278
+ _headers = {
279
+ 'accept' => 'application/json'
280
+ }
281
+
282
+ # Prepare form parameters.
283
+ _parameters = {
284
+ 'request' => Faraday::UploadIO.new(
285
+ StringIO.new(request.to_json),
286
+ 'application/json'
287
+ ),
288
+ 'image_file' => Faraday::UploadIO.new(
289
+ image_file_wrapper,
290
+ image_file_content_type
291
+ )
292
+ }
293
+ _parameters = APIHelper.form_encode_parameters(_parameters)
294
+
295
+ # Prepare and execute HttpRequest.
296
+ _request = config.http_client.post(
297
+ _query_url,
298
+ headers: _headers,
299
+ parameters: _parameters
300
+ )
301
+ OAuth2.apply(config, _request)
302
+ _response = execute_request(_request)
303
+
304
+ # Return appropriate response type.
305
+ decoded = APIHelper.json_deserialize(_response.raw_body)
306
+ _errors = APIHelper.map_response(decoded, ['errors'])
307
+ ApiResponse.new(_response, data: decoded, errors: _errors)
308
+ end
309
+
310
+ # Uploads text to use as evidence for a dispute challenge. For more
311
+ # information, see
312
+ # [Challenge a
313
+ # Dispute](https://developer.squareup.com/docs/docs/disputes-api/process-dis
314
+ # putes#challenge-a-dispute).
315
+ # @param [String] dispute_id Required parameter: The ID of the dispute you
316
+ # want to upload evidence for.
317
+ # @param [CreateDisputeEvidenceTextRequest] body Required parameter: An
318
+ # object containing the fields to POST for the request. See the
319
+ # corresponding object definition for field details.
320
+ # @return [CreateDisputeEvidenceTextResponse Hash] response from the API call
321
+ def create_dispute_evidence_text(dispute_id:,
322
+ body:)
323
+ # Prepare query url.
324
+ _query_builder = config.get_base_uri
325
+ _query_builder << '/v2/disputes/{dispute_id}/evidence_text'
326
+ _query_builder = APIHelper.append_url_with_template_parameters(
327
+ _query_builder,
328
+ 'dispute_id' => dispute_id
329
+ )
330
+ _query_url = APIHelper.clean_url _query_builder
331
+
332
+ # Prepare headers.
333
+ _headers = {
334
+ 'accept' => 'application/json',
335
+ 'content-type' => 'application/json; charset=utf-8'
336
+ }
337
+
338
+ # Prepare and execute HttpRequest.
339
+ _request = config.http_client.post(
340
+ _query_url,
341
+ headers: _headers,
342
+ parameters: body.to_json
343
+ )
344
+ OAuth2.apply(config, _request)
345
+ _response = execute_request(_request)
346
+
347
+ # Return appropriate response type.
348
+ decoded = APIHelper.json_deserialize(_response.raw_body)
349
+ _errors = APIHelper.map_response(decoded, ['errors'])
350
+ ApiResponse.new(_response, data: decoded, errors: _errors)
351
+ end
352
+
353
+ # Submits evidence to the cardholder's bank.
354
+ # Before submitting evidence, Square compiles all available evidence. This
355
+ # includes
356
+ # evidence uploaded using the
357
+ # [CreateDisputeEvidenceFile](https://developer.squareup.com/docs/reference/
358
+ # square/disputes-api/create-dispute-evidence-file) and
359
+ # [CreateDisputeEvidenceText](https://developer.squareup.com/docs/reference/
360
+ # square/disputes-api/create-dispute-evidence-text) endpoints,
361
+ # and evidence automatically provided by Square, when
362
+ # available. For more information, see
363
+ # [Challenge a
364
+ # Dispute](https://developer.squareup.com/docs/docs/disputes-api/process-dis
365
+ # putes#challenge-a-dispute).
366
+ # @param [String] dispute_id Required parameter: The ID of the dispute you
367
+ # want to submit evidence for.
368
+ # @return [SubmitEvidenceResponse Hash] response from the API call
369
+ def submit_evidence(dispute_id:)
370
+ # Prepare query url.
371
+ _query_builder = config.get_base_uri
372
+ _query_builder << '/v2/disputes/{dispute_id}/submit-evidence'
373
+ _query_builder = APIHelper.append_url_with_template_parameters(
374
+ _query_builder,
375
+ 'dispute_id' => dispute_id
376
+ )
377
+ _query_url = APIHelper.clean_url _query_builder
378
+
379
+ # Prepare headers.
380
+ _headers = {
381
+ 'accept' => 'application/json'
382
+ }
383
+
384
+ # Prepare and execute HttpRequest.
385
+ _request = config.http_client.post(
386
+ _query_url,
387
+ headers: _headers
388
+ )
389
+ OAuth2.apply(config, _request)
390
+ _response = execute_request(_request)
391
+
392
+ # Return appropriate response type.
393
+ decoded = APIHelper.json_deserialize(_response.raw_body)
394
+ _errors = APIHelper.map_response(decoded, ['errors'])
395
+ ApiResponse.new(_response, data: decoded, errors: _errors)
396
+ end
397
+ end
398
+ end