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,279 @@
1
+ module Square
2
+ # PaymentsApi
3
+ class PaymentsApi < BaseApi
4
+ def initialize(config, http_call_back: nil)
5
+ super(config, http_call_back: http_call_back)
6
+ end
7
+
8
+ # Retrieves a list of payments taken by the account making the request.
9
+ # Max results per page: 100
10
+ # @param [String] begin_time Optional parameter: Timestamp for the beginning
11
+ # of the reporting period, in RFC 3339 format. Inclusive. Default: The
12
+ # current time minus one year.
13
+ # @param [String] end_time Optional parameter: Timestamp for the end of the
14
+ # requested reporting period, in RFC 3339 format. Default: The current
15
+ # time.
16
+ # @param [String] sort_order Optional parameter: The order in which results
17
+ # are listed. - `ASC` - oldest to newest - `DESC` - newest to oldest
18
+ # (default).
19
+ # @param [String] cursor Optional parameter: A pagination cursor returned by
20
+ # a previous call to this endpoint. Provide this to retrieve the next set of
21
+ # results for the original query. See
22
+ # [Pagination](https://developer.squareup.com/docs/basics/api101/pagination)
23
+ # for more information.
24
+ # @param [String] location_id Optional parameter: Limit results to the
25
+ # location supplied. By default, results are returned for all locations
26
+ # associated with the merchant.
27
+ # @param [Long] total Optional parameter: The exact amount in the
28
+ # total_money for a `Payment`.
29
+ # @param [String] last_4 Optional parameter: The last 4 digits of `Payment`
30
+ # card.
31
+ # @param [String] card_brand Optional parameter: The brand of `Payment`
32
+ # card. For example, `VISA`
33
+ # @return [ListPaymentsResponse Hash] response from the API call
34
+ def list_payments(begin_time: nil,
35
+ end_time: nil,
36
+ sort_order: nil,
37
+ cursor: nil,
38
+ location_id: nil,
39
+ total: nil,
40
+ last_4: nil,
41
+ card_brand: nil)
42
+ # Prepare query url.
43
+ _query_builder = config.get_base_uri
44
+ _query_builder << '/v2/payments'
45
+ _query_builder = APIHelper.append_url_with_query_parameters(
46
+ _query_builder,
47
+ 'begin_time' => begin_time,
48
+ 'end_time' => end_time,
49
+ 'sort_order' => sort_order,
50
+ 'cursor' => cursor,
51
+ 'location_id' => location_id,
52
+ 'total' => total,
53
+ 'last_4' => last_4,
54
+ 'card_brand' => card_brand
55
+ )
56
+ _query_url = APIHelper.clean_url _query_builder
57
+
58
+ # Prepare headers.
59
+ _headers = {
60
+ 'accept' => 'application/json'
61
+ }
62
+
63
+ # Prepare and execute HttpRequest.
64
+ _request = config.http_client.get(
65
+ _query_url,
66
+ headers: _headers
67
+ )
68
+ OAuth2.apply(config, _request)
69
+ _response = execute_request(_request)
70
+
71
+ # Return appropriate response type.
72
+ decoded = APIHelper.json_deserialize(_response.raw_body)
73
+ _errors = APIHelper.map_response(decoded, ['errors'])
74
+ ApiResponse.new(_response, data: decoded, errors: _errors)
75
+ end
76
+
77
+ # Charges a payment source, for example, a card
78
+ # represented by customer's card on file or a card nonce. In addition
79
+ # to the payment source, the request must also include the
80
+ # amount to accept for the payment.
81
+ # There are several optional parameters that you can include in the request.
82
+ # For example, tip money, whether to autocomplete the payment, or a
83
+ # reference ID
84
+ # to correlate this payment with another system.
85
+ # For more information about these
86
+ # payment options, see [Take
87
+ # Payments](https://developer.squareup.com/docs/payments-api/take-payments).
88
+ # The `PAYMENTS_WRITE_ADDITIONAL_RECIPIENTS` OAuth permission is required
89
+ # to enable application fees.
90
+ # @param [CreatePaymentRequest] body Required parameter: An object
91
+ # containing the fields to POST for the request. See the corresponding
92
+ # object definition for field details.
93
+ # @return [CreatePaymentResponse Hash] response from the API call
94
+ def create_payment(body:)
95
+ # Prepare query url.
96
+ _query_builder = config.get_base_uri
97
+ _query_builder << '/v2/payments'
98
+ _query_url = APIHelper.clean_url _query_builder
99
+
100
+ # Prepare headers.
101
+ _headers = {
102
+ 'accept' => 'application/json',
103
+ 'content-type' => 'application/json; charset=utf-8'
104
+ }
105
+
106
+ # Prepare and execute HttpRequest.
107
+ _request = config.http_client.post(
108
+ _query_url,
109
+ headers: _headers,
110
+ parameters: body.to_json
111
+ )
112
+ OAuth2.apply(config, _request)
113
+ _response = execute_request(_request)
114
+
115
+ # Return appropriate response type.
116
+ decoded = APIHelper.json_deserialize(_response.raw_body)
117
+ _errors = APIHelper.map_response(decoded, ['errors'])
118
+ ApiResponse.new(_response, data: decoded, errors: _errors)
119
+ end
120
+
121
+ # Cancels (voids) a payment identified by the idempotency key that is
122
+ # specified in the
123
+ # request.
124
+ # Use this method when status of a CreatePayment request is unknown. For
125
+ # example, after you send a
126
+ # CreatePayment request a network error occurs and you don't get a response.
127
+ # In this case, you can
128
+ # direct Square to cancel the payment using this endpoint. In the request,
129
+ # you provide the same
130
+ # idempotency key that you provided in your CreatePayment request you want
131
+ # to cancel. After
132
+ # cancelling the payment, you can submit your CreatePayment request again.
133
+ # Note that if no payment with the specified idempotency key is found, no
134
+ # action is taken, the end
135
+ # point returns successfully.
136
+ # @param [CancelPaymentByIdempotencyKeyRequest] body Required parameter: An
137
+ # object containing the fields to POST for the request. See the
138
+ # corresponding object definition for field details.
139
+ # @return [CancelPaymentByIdempotencyKeyResponse Hash] response from the API call
140
+ def cancel_payment_by_idempotency_key(body:)
141
+ # Prepare query url.
142
+ _query_builder = config.get_base_uri
143
+ _query_builder << '/v2/payments/cancel'
144
+ _query_url = APIHelper.clean_url _query_builder
145
+
146
+ # Prepare headers.
147
+ _headers = {
148
+ 'accept' => 'application/json',
149
+ 'content-type' => 'application/json; charset=utf-8'
150
+ }
151
+
152
+ # Prepare and execute HttpRequest.
153
+ _request = config.http_client.post(
154
+ _query_url,
155
+ headers: _headers,
156
+ parameters: body.to_json
157
+ )
158
+ OAuth2.apply(config, _request)
159
+ _response = execute_request(_request)
160
+
161
+ # Return appropriate response type.
162
+ decoded = APIHelper.json_deserialize(_response.raw_body)
163
+ _errors = APIHelper.map_response(decoded, ['errors'])
164
+ ApiResponse.new(_response, data: decoded, errors: _errors)
165
+ end
166
+
167
+ # Retrieves details for a specific Payment.
168
+ # @param [String] payment_id Required parameter: Unique ID for the desired
169
+ # `Payment`.
170
+ # @return [GetPaymentResponse Hash] response from the API call
171
+ def get_payment(payment_id:)
172
+ # Prepare query url.
173
+ _query_builder = config.get_base_uri
174
+ _query_builder << '/v2/payments/{payment_id}'
175
+ _query_builder = APIHelper.append_url_with_template_parameters(
176
+ _query_builder,
177
+ 'payment_id' => payment_id
178
+ )
179
+ _query_url = APIHelper.clean_url _query_builder
180
+
181
+ # Prepare headers.
182
+ _headers = {
183
+ 'accept' => 'application/json'
184
+ }
185
+
186
+ # Prepare and execute HttpRequest.
187
+ _request = config.http_client.get(
188
+ _query_url,
189
+ headers: _headers
190
+ )
191
+ OAuth2.apply(config, _request)
192
+ _response = execute_request(_request)
193
+
194
+ # Return appropriate response type.
195
+ decoded = APIHelper.json_deserialize(_response.raw_body)
196
+ _errors = APIHelper.map_response(decoded, ['errors'])
197
+ ApiResponse.new(_response, data: decoded, errors: _errors)
198
+ end
199
+
200
+ # Cancels (voids) a payment. If you set `autocomplete` to false when
201
+ # creating a payment,
202
+ # you can cancel the payment using this endpoint. For more information, see
203
+ # [Delayed
204
+ # Payments](https://developer.squareup.com/docs/payments-api/take-payments#d
205
+ # elayed-payments).
206
+ # @param [String] payment_id Required parameter: `payment_id` identifying
207
+ # the payment to be canceled.
208
+ # @return [CancelPaymentResponse Hash] response from the API call
209
+ def cancel_payment(payment_id:)
210
+ # Prepare query url.
211
+ _query_builder = config.get_base_uri
212
+ _query_builder << '/v2/payments/{payment_id}/cancel'
213
+ _query_builder = APIHelper.append_url_with_template_parameters(
214
+ _query_builder,
215
+ 'payment_id' => payment_id
216
+ )
217
+ _query_url = APIHelper.clean_url _query_builder
218
+
219
+ # Prepare headers.
220
+ _headers = {
221
+ 'accept' => 'application/json'
222
+ }
223
+
224
+ # Prepare and execute HttpRequest.
225
+ _request = config.http_client.post(
226
+ _query_url,
227
+ headers: _headers
228
+ )
229
+ OAuth2.apply(config, _request)
230
+ _response = execute_request(_request)
231
+
232
+ # Return appropriate response type.
233
+ decoded = APIHelper.json_deserialize(_response.raw_body)
234
+ _errors = APIHelper.map_response(decoded, ['errors'])
235
+ ApiResponse.new(_response, data: decoded, errors: _errors)
236
+ end
237
+
238
+ # Completes (captures) a payment.
239
+ # By default, payments are set to complete immediately after they are
240
+ # created.
241
+ # If you set autocomplete to false when creating a payment, you can complete
242
+ # (capture)
243
+ # the payment using this endpoint. For more information, see
244
+ # [Delayed
245
+ # Payments](https://developer.squareup.com/docs/payments-api/take-payments#d
246
+ # elayed-payments).
247
+ # @param [String] payment_id Required parameter: Unique ID identifying the
248
+ # payment to be completed.
249
+ # @return [CompletePaymentResponse Hash] response from the API call
250
+ def complete_payment(payment_id:)
251
+ # Prepare query url.
252
+ _query_builder = config.get_base_uri
253
+ _query_builder << '/v2/payments/{payment_id}/complete'
254
+ _query_builder = APIHelper.append_url_with_template_parameters(
255
+ _query_builder,
256
+ 'payment_id' => payment_id
257
+ )
258
+ _query_url = APIHelper.clean_url _query_builder
259
+
260
+ # Prepare headers.
261
+ _headers = {
262
+ 'accept' => 'application/json'
263
+ }
264
+
265
+ # Prepare and execute HttpRequest.
266
+ _request = config.http_client.post(
267
+ _query_url,
268
+ headers: _headers
269
+ )
270
+ OAuth2.apply(config, _request)
271
+ _response = execute_request(_request)
272
+
273
+ # Return appropriate response type.
274
+ decoded = APIHelper.json_deserialize(_response.raw_body)
275
+ _errors = APIHelper.map_response(decoded, ['errors'])
276
+ ApiResponse.new(_response, data: decoded, errors: _errors)
277
+ end
278
+ end
279
+ end
@@ -0,0 +1,145 @@
1
+ module Square
2
+ # RefundsApi
3
+ class RefundsApi < BaseApi
4
+ def initialize(config, http_call_back: nil)
5
+ super(config, http_call_back: http_call_back)
6
+ end
7
+
8
+ # Retrieves a list of refunds for the account making the request.
9
+ # Max results per page: 100
10
+ # @param [String] begin_time Optional parameter: Timestamp for the beginning
11
+ # of the requested reporting period, in RFC 3339 format. Default: The
12
+ # current time minus one year.
13
+ # @param [String] end_time Optional parameter: Timestamp for the end of the
14
+ # requested reporting period, in RFC 3339 format. Default: The current
15
+ # time.
16
+ # @param [String] sort_order Optional parameter: The order in which results
17
+ # are listed. - `ASC` - oldest to newest - `DESC` - newest to oldest
18
+ # (default).
19
+ # @param [String] cursor Optional parameter: A pagination cursor returned by
20
+ # a previous call to this endpoint. Provide this to retrieve the next set of
21
+ # results for the original query. See
22
+ # [Pagination](https://developer.squareup.com/docs/basics/api101/pagination)
23
+ # for more information.
24
+ # @param [String] location_id Optional parameter: Limit results to the
25
+ # location supplied. By default, results are returned for all locations
26
+ # associated with the merchant.
27
+ # @param [String] status Optional parameter: If provided, only refunds with
28
+ # the given status are returned. For a list of refund status values, see
29
+ # [PaymentRefund](#type-paymentrefund). Default: If omitted refunds are
30
+ # returned regardless of status.
31
+ # @param [String] source_type Optional parameter: If provided, only refunds
32
+ # with the given source type are returned. - `CARD` - List refunds only for
33
+ # payments where card was specified as payment source. Default: If omitted
34
+ # refunds are returned regardless of source type.
35
+ # @return [ListPaymentRefundsResponse Hash] response from the API call
36
+ def list_payment_refunds(begin_time: nil,
37
+ end_time: nil,
38
+ sort_order: nil,
39
+ cursor: nil,
40
+ location_id: nil,
41
+ status: nil,
42
+ source_type: nil)
43
+ # Prepare query url.
44
+ _query_builder = config.get_base_uri
45
+ _query_builder << '/v2/refunds'
46
+ _query_builder = APIHelper.append_url_with_query_parameters(
47
+ _query_builder,
48
+ 'begin_time' => begin_time,
49
+ 'end_time' => end_time,
50
+ 'sort_order' => sort_order,
51
+ 'cursor' => cursor,
52
+ 'location_id' => location_id,
53
+ 'status' => status,
54
+ 'source_type' => source_type
55
+ )
56
+ _query_url = APIHelper.clean_url _query_builder
57
+
58
+ # Prepare headers.
59
+ _headers = {
60
+ 'accept' => 'application/json'
61
+ }
62
+
63
+ # Prepare and execute HttpRequest.
64
+ _request = config.http_client.get(
65
+ _query_url,
66
+ headers: _headers
67
+ )
68
+ OAuth2.apply(config, _request)
69
+ _response = execute_request(_request)
70
+
71
+ # Return appropriate response type.
72
+ decoded = APIHelper.json_deserialize(_response.raw_body)
73
+ _errors = APIHelper.map_response(decoded, ['errors'])
74
+ ApiResponse.new(_response, data: decoded, errors: _errors)
75
+ end
76
+
77
+ # Refunds a payment. You can refund the entire payment amount or a
78
+ # portion of it. For more information, see
79
+ # [Payments and Refunds
80
+ # Overview](https://developer.squareup.com/docs/payments-api/overview).
81
+ # @param [RefundPaymentRequest] body Required parameter: An object
82
+ # containing the fields to POST for the request. See the corresponding
83
+ # object definition for field details.
84
+ # @return [RefundPaymentResponse Hash] response from the API call
85
+ def refund_payment(body:)
86
+ # Prepare query url.
87
+ _query_builder = config.get_base_uri
88
+ _query_builder << '/v2/refunds'
89
+ _query_url = APIHelper.clean_url _query_builder
90
+
91
+ # Prepare headers.
92
+ _headers = {
93
+ 'accept' => 'application/json',
94
+ 'content-type' => 'application/json; charset=utf-8'
95
+ }
96
+
97
+ # Prepare and execute HttpRequest.
98
+ _request = config.http_client.post(
99
+ _query_url,
100
+ headers: _headers,
101
+ parameters: body.to_json
102
+ )
103
+ OAuth2.apply(config, _request)
104
+ _response = execute_request(_request)
105
+
106
+ # Return appropriate response type.
107
+ decoded = APIHelper.json_deserialize(_response.raw_body)
108
+ _errors = APIHelper.map_response(decoded, ['errors'])
109
+ ApiResponse.new(_response, data: decoded, errors: _errors)
110
+ end
111
+
112
+ # Retrieves a specific `Refund` using the `refund_id`.
113
+ # @param [String] refund_id Required parameter: Unique ID for the desired
114
+ # `PaymentRefund`.
115
+ # @return [GetPaymentRefundResponse Hash] response from the API call
116
+ def get_payment_refund(refund_id:)
117
+ # Prepare query url.
118
+ _query_builder = config.get_base_uri
119
+ _query_builder << '/v2/refunds/{refund_id}'
120
+ _query_builder = APIHelper.append_url_with_template_parameters(
121
+ _query_builder,
122
+ 'refund_id' => refund_id
123
+ )
124
+ _query_url = APIHelper.clean_url _query_builder
125
+
126
+ # Prepare headers.
127
+ _headers = {
128
+ 'accept' => 'application/json'
129
+ }
130
+
131
+ # Prepare and execute HttpRequest.
132
+ _request = config.http_client.get(
133
+ _query_url,
134
+ headers: _headers
135
+ )
136
+ OAuth2.apply(config, _request)
137
+ _response = execute_request(_request)
138
+
139
+ # Return appropriate response type.
140
+ decoded = APIHelper.json_deserialize(_response.raw_body)
141
+ _errors = APIHelper.map_response(decoded, ['errors'])
142
+ ApiResponse.new(_response, data: decoded, errors: _errors)
143
+ end
144
+ end
145
+ end
@@ -0,0 +1,251 @@
1
+ module Square
2
+ # SubscriptionsApi
3
+ class SubscriptionsApi < BaseApi
4
+ def initialize(config, http_call_back: nil)
5
+ super(config, http_call_back: http_call_back)
6
+ end
7
+
8
+ # Creates a subscription for a customer to a subscription plan.
9
+ # If you provide a card on file in the request, Square charges the card for
10
+ # the subscription. Otherwise, Square bills an invoice to the customer's
11
+ # email
12
+ # address. The subscription starts immediately, unless the request includes
13
+ # the optional `start_date`. Each individual subscription is associated with
14
+ # a particular location.
15
+ # @param [CreateSubscriptionRequest] body Required parameter: An object
16
+ # containing the fields to POST for the request. See the corresponding
17
+ # object definition for field details.
18
+ # @return [CreateSubscriptionResponse Hash] response from the API call
19
+ def create_subscription(body:)
20
+ # Prepare query url.
21
+ _query_builder = config.get_base_uri
22
+ _query_builder << '/v2/subscriptions'
23
+ _query_url = APIHelper.clean_url _query_builder
24
+
25
+ # Prepare headers.
26
+ _headers = {
27
+ 'accept' => 'application/json',
28
+ 'content-type' => 'application/json; charset=utf-8'
29
+ }
30
+
31
+ # Prepare and execute HttpRequest.
32
+ _request = config.http_client.post(
33
+ _query_url,
34
+ headers: _headers,
35
+ parameters: body.to_json
36
+ )
37
+ OAuth2.apply(config, _request)
38
+ _response = execute_request(_request)
39
+
40
+ # Return appropriate response type.
41
+ decoded = APIHelper.json_deserialize(_response.raw_body)
42
+ _errors = APIHelper.map_response(decoded, ['errors'])
43
+ ApiResponse.new(_response, data: decoded, errors: _errors)
44
+ end
45
+
46
+ # Searches for subscriptions.
47
+ # Results are ordered chronologically by subscription creation date. If
48
+ # the request specifies more than one location ID,
49
+ # the endpoint orders the result
50
+ # by location ID, and then by creation date within each location. If no
51
+ # locations are given
52
+ # in the query, all locations are searched.
53
+ # You can also optionally specify `customer_ids` to search by customer.
54
+ # If left unset, all customers
55
+ # associated with the specified locations are returned.
56
+ # If the request specifies customer IDs, the endpoint orders results
57
+ # first by location, within location by customer ID, and within
58
+ # customer by subscription creation date.
59
+ # For more information, see
60
+ # [Retrieve
61
+ # subscriptions](https://developer.squareup.com/docs/docs/subscriptions-api/
62
+ # overview#retrieve-subscriptions).
63
+ # @param [SearchSubscriptionsRequest] body Required parameter: An object
64
+ # containing the fields to POST for the request. See the corresponding
65
+ # object definition for field details.
66
+ # @return [SearchSubscriptionsResponse Hash] response from the API call
67
+ def search_subscriptions(body:)
68
+ # Prepare query url.
69
+ _query_builder = config.get_base_uri
70
+ _query_builder << '/v2/subscriptions/search'
71
+ _query_url = APIHelper.clean_url _query_builder
72
+
73
+ # Prepare headers.
74
+ _headers = {
75
+ 'accept' => 'application/json',
76
+ 'content-type' => 'application/json; charset=utf-8'
77
+ }
78
+
79
+ # Prepare and execute HttpRequest.
80
+ _request = config.http_client.post(
81
+ _query_url,
82
+ headers: _headers,
83
+ parameters: body.to_json
84
+ )
85
+ OAuth2.apply(config, _request)
86
+ _response = execute_request(_request)
87
+
88
+ # Return appropriate response type.
89
+ decoded = APIHelper.json_deserialize(_response.raw_body)
90
+ _errors = APIHelper.map_response(decoded, ['errors'])
91
+ ApiResponse.new(_response, data: decoded, errors: _errors)
92
+ end
93
+
94
+ # Retrieves a subscription.
95
+ # @param [String] subscription_id Required parameter: The ID of the
96
+ # subscription to retrieve.
97
+ # @return [RetrieveSubscriptionResponse Hash] response from the API call
98
+ def retrieve_subscription(subscription_id:)
99
+ # Prepare query url.
100
+ _query_builder = config.get_base_uri
101
+ _query_builder << '/v2/subscriptions/{subscription_id}'
102
+ _query_builder = APIHelper.append_url_with_template_parameters(
103
+ _query_builder,
104
+ 'subscription_id' => subscription_id
105
+ )
106
+ _query_url = APIHelper.clean_url _query_builder
107
+
108
+ # Prepare headers.
109
+ _headers = {
110
+ 'accept' => 'application/json'
111
+ }
112
+
113
+ # Prepare and execute HttpRequest.
114
+ _request = config.http_client.get(
115
+ _query_url,
116
+ headers: _headers
117
+ )
118
+ OAuth2.apply(config, _request)
119
+ _response = execute_request(_request)
120
+
121
+ # Return appropriate response type.
122
+ decoded = APIHelper.json_deserialize(_response.raw_body)
123
+ _errors = APIHelper.map_response(decoded, ['errors'])
124
+ ApiResponse.new(_response, data: decoded, errors: _errors)
125
+ end
126
+
127
+ # Updates a subscription. You can set, modify, and clear the
128
+ # `subscription` field values.
129
+ # @param [String] subscription_id Required parameter: The ID for the
130
+ # subscription to update.
131
+ # @param [UpdateSubscriptionRequest] body Required parameter: An object
132
+ # containing the fields to POST for the request. See the corresponding
133
+ # object definition for field details.
134
+ # @return [UpdateSubscriptionResponse Hash] response from the API call
135
+ def update_subscription(subscription_id:,
136
+ body:)
137
+ # Prepare query url.
138
+ _query_builder = config.get_base_uri
139
+ _query_builder << '/v2/subscriptions/{subscription_id}'
140
+ _query_builder = APIHelper.append_url_with_template_parameters(
141
+ _query_builder,
142
+ 'subscription_id' => subscription_id
143
+ )
144
+ _query_url = APIHelper.clean_url _query_builder
145
+
146
+ # Prepare headers.
147
+ _headers = {
148
+ 'accept' => 'application/json',
149
+ 'content-type' => 'application/json; charset=utf-8'
150
+ }
151
+
152
+ # Prepare and execute HttpRequest.
153
+ _request = config.http_client.put(
154
+ _query_url,
155
+ headers: _headers,
156
+ parameters: body.to_json
157
+ )
158
+ OAuth2.apply(config, _request)
159
+ _response = execute_request(_request)
160
+
161
+ # Return appropriate response type.
162
+ decoded = APIHelper.json_deserialize(_response.raw_body)
163
+ _errors = APIHelper.map_response(decoded, ['errors'])
164
+ ApiResponse.new(_response, data: decoded, errors: _errors)
165
+ end
166
+
167
+ # Sets the `canceled_date` field to the end of the active billing period.
168
+ # After this date, the status changes from ACTIVE to CANCELED.
169
+ # @param [String] subscription_id Required parameter: The ID of the
170
+ # subscription to cancel.
171
+ # @return [CancelSubscriptionResponse Hash] response from the API call
172
+ def cancel_subscription(subscription_id:)
173
+ # Prepare query url.
174
+ _query_builder = config.get_base_uri
175
+ _query_builder << '/v2/subscriptions/{subscription_id}/cancel'
176
+ _query_builder = APIHelper.append_url_with_template_parameters(
177
+ _query_builder,
178
+ 'subscription_id' => subscription_id
179
+ )
180
+ _query_url = APIHelper.clean_url _query_builder
181
+
182
+ # Prepare headers.
183
+ _headers = {
184
+ 'accept' => 'application/json'
185
+ }
186
+
187
+ # Prepare and execute HttpRequest.
188
+ _request = config.http_client.post(
189
+ _query_url,
190
+ headers: _headers
191
+ )
192
+ OAuth2.apply(config, _request)
193
+ _response = execute_request(_request)
194
+
195
+ # Return appropriate response type.
196
+ decoded = APIHelper.json_deserialize(_response.raw_body)
197
+ _errors = APIHelper.map_response(decoded, ['errors'])
198
+ ApiResponse.new(_response, data: decoded, errors: _errors)
199
+ end
200
+
201
+ # Lists all events for a specific subscription.
202
+ # In the current implementation, only `START_SUBSCRIPTION` and
203
+ # `STOP_SUBSCRIPTION` (when the subscription was canceled) events are
204
+ # returned.
205
+ # @param [String] subscription_id Required parameter: The ID of the
206
+ # subscription to retrieve the events for.
207
+ # @param [String] cursor Optional parameter: A pagination cursor returned by
208
+ # a previous call to this endpoint. Provide this to retrieve the next set of
209
+ # results for the original query. For more information, see
210
+ # [Pagination](https://developer.squareup.com/docs/docs/working-with-apis/pa
211
+ # gination).
212
+ # @param [Integer] limit Optional parameter: The upper limit on the number
213
+ # of subscription events to return in the response. Default: `200`
214
+ # @return [ListSubscriptionEventsResponse Hash] response from the API call
215
+ def list_subscription_events(subscription_id:,
216
+ cursor: nil,
217
+ limit: nil)
218
+ # Prepare query url.
219
+ _query_builder = config.get_base_uri
220
+ _query_builder << '/v2/subscriptions/{subscription_id}/events'
221
+ _query_builder = APIHelper.append_url_with_template_parameters(
222
+ _query_builder,
223
+ 'subscription_id' => subscription_id
224
+ )
225
+ _query_builder = APIHelper.append_url_with_query_parameters(
226
+ _query_builder,
227
+ 'cursor' => cursor,
228
+ 'limit' => limit
229
+ )
230
+ _query_url = APIHelper.clean_url _query_builder
231
+
232
+ # Prepare headers.
233
+ _headers = {
234
+ 'accept' => 'application/json'
235
+ }
236
+
237
+ # Prepare and execute HttpRequest.
238
+ _request = config.http_client.get(
239
+ _query_url,
240
+ headers: _headers
241
+ )
242
+ OAuth2.apply(config, _request)
243
+ _response = execute_request(_request)
244
+
245
+ # Return appropriate response type.
246
+ decoded = APIHelper.json_deserialize(_response.raw_body)
247
+ _errors = APIHelper.map_response(decoded, ['errors'])
248
+ ApiResponse.new(_response, data: decoded, errors: _errors)
249
+ end
250
+ end
251
+ end