processout 2.20.0 → 2.21.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (65) hide show
  1. checksums.yaml +4 -4
  2. data/.gitignore +52 -0
  3. data/.rspec +2 -0
  4. data/.travis.yml +5 -0
  5. data/Dockerfile +7 -0
  6. data/Gemfile +4 -0
  7. data/LICENSE.txt +21 -0
  8. data/Makefile +4 -0
  9. data/README.md +12 -0
  10. data/Rakefile +6 -0
  11. data/bin/console +14 -0
  12. data/bin/setup +8 -0
  13. data/lib/processout/activity.rb +206 -0
  14. data/lib/processout/addon.rb +401 -0
  15. data/lib/processout/alternative_merchant_certificate.rb +115 -0
  16. data/lib/processout/api_request.rb +295 -0
  17. data/lib/processout/api_version.rb +92 -0
  18. data/lib/processout/apple_pay_alternative_merchant_certificates.rb +121 -0
  19. data/lib/processout/balance.rb +92 -0
  20. data/lib/processout/balances.rb +111 -0
  21. data/lib/processout/card.rb +503 -0
  22. data/lib/processout/card_information.rb +164 -0
  23. data/lib/processout/coupon.rb +352 -0
  24. data/lib/processout/customer.rb +755 -0
  25. data/lib/processout/customer_action.rb +81 -0
  26. data/lib/processout/discount.rb +360 -0
  27. data/lib/processout/dunning_action.rb +81 -0
  28. data/lib/processout/errors/authentication_error.rb +9 -0
  29. data/lib/processout/errors/generic_error.rb +9 -0
  30. data/lib/processout/errors/internal_error.rb +9 -0
  31. data/lib/processout/errors/notfound_error.rb +9 -0
  32. data/lib/processout/errors/validation_error.rb +9 -0
  33. data/lib/processout/event.rb +237 -0
  34. data/lib/processout/gateway.rb +210 -0
  35. data/lib/processout/gateway_configuration.rb +346 -0
  36. data/lib/processout/gateway_request.rb +26 -0
  37. data/lib/processout/invoice.rb +984 -0
  38. data/lib/processout/invoice_detail.rb +235 -0
  39. data/lib/processout/invoice_device.rb +92 -0
  40. data/lib/processout/invoice_external_fraud_tools.rb +70 -0
  41. data/lib/processout/invoice_risk.rb +81 -0
  42. data/lib/processout/invoice_shipping.rb +202 -0
  43. data/lib/processout/invoice_tax.rb +81 -0
  44. data/lib/processout/networking/request.rb +102 -0
  45. data/lib/processout/networking/response.rb +67 -0
  46. data/lib/processout/payment_data_network_authentication.rb +70 -0
  47. data/lib/processout/payment_data_three_ds_authentication.rb +70 -0
  48. data/lib/processout/payment_data_three_ds_request.rb +103 -0
  49. data/lib/processout/payout.rb +379 -0
  50. data/lib/processout/payout_item.rb +238 -0
  51. data/lib/processout/plan.rb +368 -0
  52. data/lib/processout/product.rb +368 -0
  53. data/lib/processout/project.rb +353 -0
  54. data/lib/processout/refund.rb +277 -0
  55. data/lib/processout/subscription.rb +910 -0
  56. data/lib/processout/three_ds.rb +158 -0
  57. data/lib/processout/token.rb +493 -0
  58. data/lib/processout/transaction.rb +905 -0
  59. data/lib/processout/transaction_operation.rb +418 -0
  60. data/lib/processout/version.rb +3 -0
  61. data/lib/processout/webhook.rb +237 -0
  62. data/lib/processout/webhook_endpoint.rb +149 -0
  63. data/lib/processout.rb +263 -0
  64. data/processout.gemspec +26 -0
  65. metadata +66 -3
@@ -0,0 +1,401 @@
1
+ # The content of this file was automatically generated
2
+
3
+ require "cgi"
4
+ require "json"
5
+ require "processout/networking/request"
6
+ require "processout/networking/response"
7
+
8
+ module ProcessOut
9
+ class Addon
10
+
11
+ attr_reader :id
12
+ attr_reader :project
13
+ attr_reader :project_id
14
+ attr_reader :subscription
15
+ attr_reader :subscription_id
16
+ attr_reader :plan
17
+ attr_reader :plan_id
18
+ attr_reader :type
19
+ attr_reader :name
20
+ attr_reader :amount
21
+ attr_reader :quantity
22
+ attr_reader :metadata
23
+ attr_reader :sandbox
24
+ attr_reader :created_at
25
+
26
+
27
+ def id=(val)
28
+ @id = val
29
+ end
30
+
31
+ def project=(val)
32
+ if val.nil?
33
+ @project = val
34
+ return
35
+ end
36
+
37
+ if val.instance_of? Project
38
+ @project = val
39
+ else
40
+ obj = Project.new(@client)
41
+ obj.fill_with_data(val)
42
+ @project = obj
43
+ end
44
+
45
+ end
46
+
47
+ def project_id=(val)
48
+ @project_id = val
49
+ end
50
+
51
+ def subscription=(val)
52
+ if val.nil?
53
+ @subscription = val
54
+ return
55
+ end
56
+
57
+ if val.instance_of? Subscription
58
+ @subscription = val
59
+ else
60
+ obj = Subscription.new(@client)
61
+ obj.fill_with_data(val)
62
+ @subscription = obj
63
+ end
64
+
65
+ end
66
+
67
+ def subscription_id=(val)
68
+ @subscription_id = val
69
+ end
70
+
71
+ def plan=(val)
72
+ if val.nil?
73
+ @plan = val
74
+ return
75
+ end
76
+
77
+ if val.instance_of? Plan
78
+ @plan = val
79
+ else
80
+ obj = Plan.new(@client)
81
+ obj.fill_with_data(val)
82
+ @plan = obj
83
+ end
84
+
85
+ end
86
+
87
+ def plan_id=(val)
88
+ @plan_id = val
89
+ end
90
+
91
+ def type=(val)
92
+ @type = val
93
+ end
94
+
95
+ def name=(val)
96
+ @name = val
97
+ end
98
+
99
+ def amount=(val)
100
+ @amount = val
101
+ end
102
+
103
+ def quantity=(val)
104
+ @quantity = val
105
+ end
106
+
107
+ def metadata=(val)
108
+ @metadata = val
109
+ end
110
+
111
+ def sandbox=(val)
112
+ @sandbox = val
113
+ end
114
+
115
+ def created_at=(val)
116
+ @created_at = val
117
+ end
118
+
119
+
120
+ # Initializes the Addon object
121
+ # Params:
122
+ # +client+:: +ProcessOut+ client instance
123
+ # +data+:: data that can be used to fill the object
124
+ def initialize(client, data = {})
125
+ @client = client
126
+
127
+ self.id = data.fetch(:id, nil)
128
+ self.project = data.fetch(:project, nil)
129
+ self.project_id = data.fetch(:project_id, nil)
130
+ self.subscription = data.fetch(:subscription, nil)
131
+ self.subscription_id = data.fetch(:subscription_id, nil)
132
+ self.plan = data.fetch(:plan, nil)
133
+ self.plan_id = data.fetch(:plan_id, nil)
134
+ self.type = data.fetch(:type, nil)
135
+ self.name = data.fetch(:name, nil)
136
+ self.amount = data.fetch(:amount, nil)
137
+ self.quantity = data.fetch(:quantity, nil)
138
+ self.metadata = data.fetch(:metadata, nil)
139
+ self.sandbox = data.fetch(:sandbox, nil)
140
+ self.created_at = data.fetch(:created_at, nil)
141
+
142
+ end
143
+
144
+ # Create a new Addon using the current client
145
+ def new(data = {})
146
+ Addon.new(@client, data)
147
+ end
148
+
149
+ # Overrides the JSON marshaller to only send the fields we want
150
+ def to_json(options)
151
+ {
152
+ "id": self.id,
153
+ "project": self.project,
154
+ "project_id": self.project_id,
155
+ "subscription": self.subscription,
156
+ "subscription_id": self.subscription_id,
157
+ "plan": self.plan,
158
+ "plan_id": self.plan_id,
159
+ "type": self.type,
160
+ "name": self.name,
161
+ "amount": self.amount,
162
+ "quantity": self.quantity,
163
+ "metadata": self.metadata,
164
+ "sandbox": self.sandbox,
165
+ "created_at": self.created_at,
166
+ }.to_json
167
+ end
168
+
169
+ # Fills the object with data coming from the API
170
+ # Params:
171
+ # +data+:: +Hash+ of data coming from the API
172
+ def fill_with_data(data)
173
+ if data.nil?
174
+ return self
175
+ end
176
+ if data.include? "id"
177
+ self.id = data["id"]
178
+ end
179
+ if data.include? "project"
180
+ self.project = data["project"]
181
+ end
182
+ if data.include? "project_id"
183
+ self.project_id = data["project_id"]
184
+ end
185
+ if data.include? "subscription"
186
+ self.subscription = data["subscription"]
187
+ end
188
+ if data.include? "subscription_id"
189
+ self.subscription_id = data["subscription_id"]
190
+ end
191
+ if data.include? "plan"
192
+ self.plan = data["plan"]
193
+ end
194
+ if data.include? "plan_id"
195
+ self.plan_id = data["plan_id"]
196
+ end
197
+ if data.include? "type"
198
+ self.type = data["type"]
199
+ end
200
+ if data.include? "name"
201
+ self.name = data["name"]
202
+ end
203
+ if data.include? "amount"
204
+ self.amount = data["amount"]
205
+ end
206
+ if data.include? "quantity"
207
+ self.quantity = data["quantity"]
208
+ end
209
+ if data.include? "metadata"
210
+ self.metadata = data["metadata"]
211
+ end
212
+ if data.include? "sandbox"
213
+ self.sandbox = data["sandbox"]
214
+ end
215
+ if data.include? "created_at"
216
+ self.created_at = data["created_at"]
217
+ end
218
+
219
+ self
220
+ end
221
+
222
+ # Prefills the object with the data passed as parameters
223
+ # Params:
224
+ # +data+:: +Hash+ of data
225
+ def prefill(data)
226
+ if data.nil?
227
+ return self
228
+ end
229
+ self.id = data.fetch(:id, self.id)
230
+ self.project = data.fetch(:project, self.project)
231
+ self.project_id = data.fetch(:project_id, self.project_id)
232
+ self.subscription = data.fetch(:subscription, self.subscription)
233
+ self.subscription_id = data.fetch(:subscription_id, self.subscription_id)
234
+ self.plan = data.fetch(:plan, self.plan)
235
+ self.plan_id = data.fetch(:plan_id, self.plan_id)
236
+ self.type = data.fetch(:type, self.type)
237
+ self.name = data.fetch(:name, self.name)
238
+ self.amount = data.fetch(:amount, self.amount)
239
+ self.quantity = data.fetch(:quantity, self.quantity)
240
+ self.metadata = data.fetch(:metadata, self.metadata)
241
+ self.sandbox = data.fetch(:sandbox, self.sandbox)
242
+ self.created_at = data.fetch(:created_at, self.created_at)
243
+
244
+ self
245
+ end
246
+
247
+ # Get the addons applied to the subscription.
248
+ # Params:
249
+ # +subscription_id+:: ID of the subscription
250
+ # +options+:: +Hash+ of options
251
+ def fetch_subscription_addons(subscription_id, options = {})
252
+ self.prefill(options)
253
+
254
+ request = Request.new(@client)
255
+ path = "/subscriptions/" + CGI.escape(subscription_id) + "/addons"
256
+ data = {
257
+
258
+ }
259
+
260
+ response = Response.new(request.get(path, data, options))
261
+ return_values = Array.new
262
+
263
+ a = Array.new
264
+ body = response.body
265
+ for v in body['addons']
266
+ tmp = Addon.new(@client)
267
+ tmp.fill_with_data(v)
268
+ a.push(tmp)
269
+ end
270
+
271
+ return_values.push(a)
272
+
273
+
274
+
275
+ return_values[0]
276
+ end
277
+
278
+ # Create a new addon to the given subscription ID.
279
+ # Params:
280
+ # +options+:: +Hash+ of options
281
+ def create(options = {})
282
+ self.prefill(options)
283
+
284
+ request = Request.new(@client)
285
+ path = "/subscriptions/" + CGI.escape(@subscription_id) + "/addons"
286
+ data = {
287
+ "plan_id" => @plan_id,
288
+ "type" => @type,
289
+ "name" => @name,
290
+ "amount" => @amount,
291
+ "quantity" => @quantity,
292
+ "metadata" => @metadata,
293
+ "prorate" => options.fetch(:prorate, nil),
294
+ "proration_date" => options.fetch(:proration_date, nil),
295
+ "preview" => options.fetch(:preview, nil)
296
+ }
297
+
298
+ response = Response.new(request.post(path, data, options))
299
+ return_values = Array.new
300
+
301
+ body = response.body
302
+ body = body["addon"]
303
+
304
+
305
+ return_values.push(self.fill_with_data(body))
306
+
307
+
308
+
309
+ return_values[0]
310
+ end
311
+
312
+ # Find a subscription's addon by its ID.
313
+ # Params:
314
+ # +subscription_id+:: ID of the subscription on which the addon was applied
315
+ # +addon_id+:: ID of the addon
316
+ # +options+:: +Hash+ of options
317
+ def find(subscription_id, addon_id, options = {})
318
+ self.prefill(options)
319
+
320
+ request = Request.new(@client)
321
+ path = "/subscriptions/" + CGI.escape(subscription_id) + "/addons/" + CGI.escape(addon_id) + ""
322
+ data = {
323
+
324
+ }
325
+
326
+ response = Response.new(request.get(path, data, options))
327
+ return_values = Array.new
328
+
329
+ body = response.body
330
+ body = body["addon"]
331
+
332
+
333
+ obj = Addon.new(@client)
334
+ return_values.push(obj.fill_with_data(body))
335
+
336
+
337
+
338
+ return_values[0]
339
+ end
340
+
341
+ # Save the updated addon attributes.
342
+ # Params:
343
+ # +options+:: +Hash+ of options
344
+ def save(options = {})
345
+ self.prefill(options)
346
+
347
+ request = Request.new(@client)
348
+ path = "/subscriptions/" + CGI.escape(@subscription_id) + "/addons/" + CGI.escape(@id) + ""
349
+ data = {
350
+ "plan_id" => @plan_id,
351
+ "type" => @type,
352
+ "name" => @name,
353
+ "amount" => @amount,
354
+ "quantity" => @quantity,
355
+ "metadata" => @metadata,
356
+ "prorate" => options.fetch(:prorate, nil),
357
+ "proration_date" => options.fetch(:proration_date, nil),
358
+ "preview" => options.fetch(:preview, nil),
359
+ "increment_quantity_by" => options.fetch(:increment_quantity_by, nil)
360
+ }
361
+
362
+ response = Response.new(request.put(path, data, options))
363
+ return_values = Array.new
364
+
365
+ body = response.body
366
+ body = body["addon"]
367
+
368
+
369
+ return_values.push(self.fill_with_data(body))
370
+
371
+
372
+
373
+ return_values[0]
374
+ end
375
+
376
+ # Delete an addon applied to a subscription.
377
+ # Params:
378
+ # +options+:: +Hash+ of options
379
+ def delete(options = {})
380
+ self.prefill(options)
381
+
382
+ request = Request.new(@client)
383
+ path = "/subscriptions/" + CGI.escape(@subscription_id) + "/addons/" + CGI.escape(@id) + ""
384
+ data = {
385
+ "prorate" => options.fetch(:prorate, nil),
386
+ "proration_date" => options.fetch(:proration_date, nil),
387
+ "preview" => options.fetch(:preview, nil)
388
+ }
389
+
390
+ response = Response.new(request.delete(path, data, options))
391
+ return_values = Array.new
392
+
393
+ return_values.push(response.success)
394
+
395
+
396
+ return_values[0]
397
+ end
398
+
399
+
400
+ end
401
+ end
@@ -0,0 +1,115 @@
1
+ # The content of this file was automatically generated
2
+
3
+ require "cgi"
4
+ require "json"
5
+ require "processout/networking/request"
6
+ require "processout/networking/response"
7
+
8
+ module ProcessOut
9
+ class AlternativeMerchantCertificate
10
+
11
+ attr_reader :id
12
+
13
+
14
+ def id=(val)
15
+ @id = val
16
+ end
17
+
18
+
19
+ # Initializes the AlternativeMerchantCertificate object
20
+ # Params:
21
+ # +client+:: +ProcessOut+ client instance
22
+ # +data+:: data that can be used to fill the object
23
+ def initialize(client, data = {})
24
+ @client = client
25
+
26
+ self.id = data.fetch(:id, nil)
27
+
28
+ end
29
+
30
+ # Create a new AlternativeMerchantCertificate using the current client
31
+ def new(data = {})
32
+ AlternativeMerchantCertificate.new(@client, data)
33
+ end
34
+
35
+ # Overrides the JSON marshaller to only send the fields we want
36
+ def to_json(options)
37
+ {
38
+ "id": self.id,
39
+ }.to_json
40
+ end
41
+
42
+ # Fills the object with data coming from the API
43
+ # Params:
44
+ # +data+:: +Hash+ of data coming from the API
45
+ def fill_with_data(data)
46
+ if data.nil?
47
+ return self
48
+ end
49
+ if data.include? "id"
50
+ self.id = data["id"]
51
+ end
52
+
53
+ self
54
+ end
55
+
56
+ # Prefills the object with the data passed as parameters
57
+ # Params:
58
+ # +data+:: +Hash+ of data
59
+ def prefill(data)
60
+ if data.nil?
61
+ return self
62
+ end
63
+ self.id = data.fetch(:id, self.id)
64
+
65
+ self
66
+ end
67
+
68
+ # Save new alternative apple pay certificates
69
+ # Params:
70
+ # +options+:: +Hash+ of options
71
+ def save(options = {})
72
+ self.prefill(options)
73
+
74
+ request = Request.new(@client)
75
+ path = "/projects/applepay/alternative-merchant-certificates"
76
+ data = {
77
+
78
+ }
79
+
80
+ response = Response.new(request.post(path, data, options))
81
+ return_values = Array.new
82
+
83
+ body = response.body
84
+ body = body["alternative_merchant_certificate"]
85
+ alternative_merchant_certificate = AlternativeMerchantCertificate.new(@client)
86
+ return_values.push(alternative_merchant_certificate.fill_with_data(body))
87
+
88
+
89
+ return_values[0]
90
+ end
91
+
92
+ # Delete a given alternative merchant certificate
93
+ # Params:
94
+ # +options+:: +Hash+ of options
95
+ def delete(options = {})
96
+ self.prefill(options)
97
+
98
+ request = Request.new(@client)
99
+ path = "/projects/applepay/alternative-merchant-certificates/" + CGI.escape(@id) + ""
100
+ data = {
101
+
102
+ }
103
+
104
+ response = Response.new(request.delete(path, data, options))
105
+ return_values = Array.new
106
+
107
+ return_values.push(response.success)
108
+
109
+
110
+ return_values[0]
111
+ end
112
+
113
+
114
+ end
115
+ end