xero-ruby 3.4.0 → 3.5.0

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 (91) hide show
  1. checksums.yaml +4 -4
  2. data/lib/xero-ruby/api/finance_api.rb +866 -0
  3. data/lib/xero-ruby/api_client.rb +11 -0
  4. data/lib/xero-ruby/configuration.rb +2 -0
  5. data/lib/xero-ruby/models/accounting/contact.rb +86 -1
  6. data/lib/xero-ruby/models/finance/account_usage.rb +342 -0
  7. data/lib/xero-ruby/models/finance/account_usage_response.rb +254 -0
  8. data/lib/xero-ruby/models/finance/balance_sheet_account_detail.rb +262 -0
  9. data/lib/xero-ruby/models/finance/balance_sheet_account_group.rb +234 -0
  10. data/lib/xero-ruby/models/finance/balance_sheet_account_type.rb +244 -0
  11. data/lib/xero-ruby/models/finance/balance_sheet_response.rb +252 -0
  12. data/lib/xero-ruby/models/finance/bank_statement_response.rb +232 -0
  13. data/lib/xero-ruby/models/finance/cash_account_response.rb +262 -0
  14. data/lib/xero-ruby/models/finance/cash_balance.rb +242 -0
  15. data/lib/xero-ruby/models/finance/cash_validation_response.rb +262 -0
  16. data/lib/xero-ruby/models/finance/cashflow_account.rb +282 -0
  17. data/lib/xero-ruby/models/finance/cashflow_activity.rb +244 -0
  18. data/lib/xero-ruby/models/finance/cashflow_response.rb +254 -0
  19. data/lib/xero-ruby/models/finance/cashflow_type.rb +244 -0
  20. data/lib/xero-ruby/models/finance/contact_detail.rb +274 -0
  21. data/lib/xero-ruby/models/finance/contact_total_detail.rb +242 -0
  22. data/lib/xero-ruby/models/finance/contact_total_other.rb +252 -0
  23. data/lib/xero-ruby/models/finance/current_statement_response.rb +272 -0
  24. data/lib/xero-ruby/models/finance/data_source_response.rb +362 -0
  25. data/lib/xero-ruby/models/finance/history_record_response.rb +262 -0
  26. data/lib/xero-ruby/models/finance/income_by_contact_response.rb +284 -0
  27. data/lib/xero-ruby/models/finance/lock_history_model.rb +242 -0
  28. data/lib/xero-ruby/models/finance/lock_history_response.rb +244 -0
  29. data/lib/xero-ruby/models/finance/manual_journal_total.rb +222 -0
  30. data/lib/xero-ruby/models/finance/pnl_account.rb +272 -0
  31. data/lib/xero-ruby/models/finance/pnl_account_class.rb +234 -0
  32. data/lib/xero-ruby/models/finance/pnl_account_type.rb +244 -0
  33. data/lib/xero-ruby/models/finance/practice_response.rb +262 -0
  34. data/lib/xero-ruby/models/finance/problem.rb +252 -0
  35. data/lib/xero-ruby/models/finance/problem_type.rb +39 -0
  36. data/lib/xero-ruby/models/finance/profit_and_loss_response.rb +262 -0
  37. data/lib/xero-ruby/models/finance/report_history_model.rb +242 -0
  38. data/lib/xero-ruby/models/finance/report_history_response.rb +244 -0
  39. data/lib/xero-ruby/models/finance/statement_balance_response.rb +232 -0
  40. data/lib/xero-ruby/models/finance/statement_lines_response.rb +382 -0
  41. data/lib/xero-ruby/models/finance/total_detail.rb +242 -0
  42. data/lib/xero-ruby/models/finance/total_other.rb +242 -0
  43. data/lib/xero-ruby/models/finance/trial_balance_account.rb +312 -0
  44. data/lib/xero-ruby/models/finance/trial_balance_entry.rb +232 -0
  45. data/lib/xero-ruby/models/finance/trial_balance_movement.rb +252 -0
  46. data/lib/xero-ruby/models/finance/trial_balance_response.rb +244 -0
  47. data/lib/xero-ruby/models/finance/user_activities_response.rb +244 -0
  48. data/lib/xero-ruby/models/finance/user_response.rb +336 -0
  49. data/lib/xero-ruby/version.rb +6 -6
  50. data/lib/xero-ruby.rb +44 -0
  51. data/spec/api_client_spec.rb +3 -0
  52. data/spec/app_store/api/app_store_api_spec.rb +1 -1
  53. data/spec/configuration_spec.rb +1 -0
  54. data/spec/finance/api/finance_api_spec.rb +156 -0
  55. data/spec/finance/models/account_usage_response_spec.rb +58 -0
  56. data/spec/finance/models/account_usage_spec.rb +112 -0
  57. data/spec/finance/models/balance_sheet_account_detail_spec.rb +64 -0
  58. data/spec/finance/models/balance_sheet_account_group_spec.rb +46 -0
  59. data/spec/finance/models/balance_sheet_account_type_spec.rb +52 -0
  60. data/spec/finance/models/balance_sheet_response_spec.rb +58 -0
  61. data/spec/finance/models/bank_statement_response_spec.rb +46 -0
  62. data/spec/finance/models/cash_account_response_spec.rb +64 -0
  63. data/spec/finance/models/cash_balance_spec.rb +52 -0
  64. data/spec/finance/models/cash_validation_response_spec.rb +64 -0
  65. data/spec/finance/models/cashflow_account_spec.rb +76 -0
  66. data/spec/finance/models/cashflow_activity_spec.rb +52 -0
  67. data/spec/finance/models/cashflow_response_spec.rb +58 -0
  68. data/spec/finance/models/cashflow_type_spec.rb +52 -0
  69. data/spec/finance/models/current_statement_response_spec.rb +70 -0
  70. data/spec/finance/models/data_source_response_spec.rb +124 -0
  71. data/spec/finance/models/history_record_response_spec.rb +64 -0
  72. data/spec/finance/models/lock_history_model_spec.rb +52 -0
  73. data/spec/finance/models/lock_history_response_spec.rb +52 -0
  74. data/spec/finance/models/pnl_account_class_spec.rb +46 -0
  75. data/spec/finance/models/pnl_account_spec.rb +70 -0
  76. data/spec/finance/models/pnl_account_type_spec.rb +52 -0
  77. data/spec/finance/models/practice_response_spec.rb +64 -0
  78. data/spec/finance/models/problem_spec.rb +58 -0
  79. data/spec/finance/models/problem_type_spec.rb +34 -0
  80. data/spec/finance/models/profit_and_loss_response_spec.rb +64 -0
  81. data/spec/finance/models/report_history_model_spec.rb +52 -0
  82. data/spec/finance/models/report_history_response_spec.rb +52 -0
  83. data/spec/finance/models/statement_balance_response_spec.rb +46 -0
  84. data/spec/finance/models/statement_lines_response_spec.rb +136 -0
  85. data/spec/finance/models/trial_balance_account_spec.rb +94 -0
  86. data/spec/finance/models/trial_balance_entry_spec.rb +46 -0
  87. data/spec/finance/models/trial_balance_movement_spec.rb +58 -0
  88. data/spec/finance/models/trial_balance_response_spec.rb +52 -0
  89. data/spec/finance/models/user_activities_response_spec.rb +52 -0
  90. data/spec/finance/models/user_response_spec.rb +106 -0
  91. metadata +120 -2
@@ -110,6 +110,11 @@ module XeroRuby
110
110
  XeroRuby::AppStoreApi.new(self)
111
111
  end
112
112
 
113
+ def finance_api
114
+ @config.base_url = @config.finance_url
115
+ XeroRuby::FinanceApi.new(self)
116
+ end
117
+
113
118
  # Token Helpers
114
119
  def token_set
115
120
  @config.token_set
@@ -284,6 +289,10 @@ module XeroRuby
284
289
  method_base_url = @config.payroll_uk_url
285
290
  when "ProjectApi"
286
291
  method_base_url = @config.project_url
292
+ when "AppStoreApi"
293
+ method_base_url = @config.app_store_url
294
+ when "FinanceApi"
295
+ method_base_url = @config.finance_url
287
296
  else
288
297
  method_base_url = @config.accounting_url
289
298
  end
@@ -508,6 +517,8 @@ module XeroRuby
508
517
  XeroRuby::PayrollUk.const_get(return_type).build_from_hash(data)
509
518
  when 'AppStoreApi'
510
519
  XeroRuby::AppStore.const_get(return_type).build_from_hash(data)
520
+ when 'FinanceApi'
521
+ XeroRuby::Finance.const_get(return_type).build_from_hash(data)
511
522
  else
512
523
  XeroRuby::Accounting.const_get(return_type).build_from_hash(data)
513
524
  end
@@ -34,6 +34,7 @@ module XeroRuby
34
34
  attr_accessor :payroll_nz_url
35
35
  attr_accessor :payroll_uk_url
36
36
  attr_accessor :app_store_url
37
+ attr_accessor :finance_url
37
38
 
38
39
  # Defines API keys used with API Key authentications.
39
40
  #
@@ -151,6 +152,7 @@ module XeroRuby
151
152
  @payroll_nz_url = 'https://api.xero.com/payroll.xro/2.0/'
152
153
  @payroll_uk_url = 'https://api.xero.com/payroll.xro/2.0/'
153
154
  @app_store_url = 'https://api.xero.com/appstore/2.0/'
155
+ @finance_url = 'https://api.xero.com/finance.xro/1.0/'
154
156
  @access_token = nil
155
157
  @id_token = nil
156
158
  @api_key = {}
@@ -19,6 +19,9 @@ module XeroRuby::Accounting
19
19
  # Xero identifier
20
20
  attr_accessor :contact_id
21
21
 
22
+ # ID for the destination of a merged contact. Only returned when using paging or when fetching a contact by ContactId or ContactNumber.
23
+ attr_accessor :merged_to_contact_id
24
+
22
25
  # This can be updated via the API only i.e. This field is read only on the Xero contact screen, used to identify contacts in external systems (max length = 50). If the Contact Number is used, this is displayed as Contact Code in the Contacts UI in Xero.
23
26
  attr_accessor :contact_number
24
27
 
@@ -40,6 +43,9 @@ module XeroRuby::Accounting
40
43
  # Last name of contact person (max length = 255)
41
44
  attr_accessor :last_name
42
45
 
46
+ # Company registration number (max length = 50)
47
+ attr_accessor :company_number
48
+
43
49
  # Email address of contact person (umlauts not supported) (max length = 255)
44
50
  attr_accessor :email_address
45
51
 
@@ -73,6 +79,18 @@ module XeroRuby::Accounting
73
79
  # true or false – Boolean that describes if a contact has any AR invoices entered against them. Cannot be set via PUT or POST – it is automatically set when an accounts receivable invoice is generated against this contact.
74
80
  attr_accessor :is_customer
75
81
 
82
+ # The default sales line amount type for a contact. Only available when summaryOnly parameter or paging is used, or when fetch by ContactId or ContactNumber.
83
+ attr_accessor :sales_default_line_amount_type
84
+ INCLUSIVE = "INCLUSIVE".freeze
85
+ EXCLUSIVE = "EXCLUSIVE".freeze
86
+ # NONE = "NONE".freeze
87
+
88
+ # The default purchases line amount type for a contact Only available when summaryOnly parameter or paging is used, or when fetch by ContactId or ContactNumber.
89
+ attr_accessor :purchases_default_line_amount_type
90
+ # INCLUSIVE = "INCLUSIVE".freeze
91
+ # EXCLUSIVE = "EXCLUSIVE".freeze
92
+ # NONE = "NONE".freeze
93
+
76
94
 
77
95
  attr_accessor :default_currency
78
96
 
@@ -162,12 +180,14 @@ module XeroRuby::Accounting
162
180
  def self.attribute_map
163
181
  {
164
182
  :'contact_id' => :'ContactID',
183
+ :'merged_to_contact_id' => :'MergedToContactID',
165
184
  :'contact_number' => :'ContactNumber',
166
185
  :'account_number' => :'AccountNumber',
167
186
  :'contact_status' => :'ContactStatus',
168
187
  :'name' => :'Name',
169
188
  :'first_name' => :'FirstName',
170
189
  :'last_name' => :'LastName',
190
+ :'company_number' => :'CompanyNumber',
171
191
  :'email_address' => :'EmailAddress',
172
192
  :'skype_user_name' => :'SkypeUserName',
173
193
  :'contact_persons' => :'ContactPersons',
@@ -179,6 +199,8 @@ module XeroRuby::Accounting
179
199
  :'phones' => :'Phones',
180
200
  :'is_supplier' => :'IsSupplier',
181
201
  :'is_customer' => :'IsCustomer',
202
+ :'sales_default_line_amount_type' => :'SalesDefaultLineAmountType',
203
+ :'purchases_default_line_amount_type' => :'PurchasesDefaultLineAmountType',
182
204
  :'default_currency' => :'DefaultCurrency',
183
205
  :'xero_network_key' => :'XeroNetworkKey',
184
206
  :'sales_default_account_code' => :'SalesDefaultAccountCode',
@@ -207,12 +229,14 @@ module XeroRuby::Accounting
207
229
  def self.openapi_types
208
230
  {
209
231
  :'contact_id' => :'String',
232
+ :'merged_to_contact_id' => :'String',
210
233
  :'contact_number' => :'String',
211
234
  :'account_number' => :'String',
212
235
  :'contact_status' => :'String',
213
236
  :'name' => :'String',
214
237
  :'first_name' => :'String',
215
238
  :'last_name' => :'String',
239
+ :'company_number' => :'String',
216
240
  :'email_address' => :'String',
217
241
  :'skype_user_name' => :'String',
218
242
  :'contact_persons' => :'Array<ContactPerson>',
@@ -224,6 +248,8 @@ module XeroRuby::Accounting
224
248
  :'phones' => :'Array<Phone>',
225
249
  :'is_supplier' => :'Boolean',
226
250
  :'is_customer' => :'Boolean',
251
+ :'sales_default_line_amount_type' => :'String',
252
+ :'purchases_default_line_amount_type' => :'String',
227
253
  :'default_currency' => :'CurrencyCode',
228
254
  :'xero_network_key' => :'String',
229
255
  :'sales_default_account_code' => :'String',
@@ -267,6 +293,10 @@ module XeroRuby::Accounting
267
293
  self.contact_id = attributes[:'contact_id']
268
294
  end
269
295
 
296
+ if attributes.key?(:'merged_to_contact_id')
297
+ self.merged_to_contact_id = attributes[:'merged_to_contact_id']
298
+ end
299
+
270
300
  if attributes.key?(:'contact_number')
271
301
  self.contact_number = attributes[:'contact_number']
272
302
  end
@@ -291,6 +321,10 @@ module XeroRuby::Accounting
291
321
  self.last_name = attributes[:'last_name']
292
322
  end
293
323
 
324
+ if attributes.key?(:'company_number')
325
+ self.company_number = attributes[:'company_number']
326
+ end
327
+
294
328
  if attributes.key?(:'email_address')
295
329
  self.email_address = attributes[:'email_address']
296
330
  end
@@ -341,6 +375,14 @@ module XeroRuby::Accounting
341
375
  self.is_customer = attributes[:'is_customer']
342
376
  end
343
377
 
378
+ if attributes.key?(:'sales_default_line_amount_type')
379
+ self.sales_default_line_amount_type = attributes[:'sales_default_line_amount_type']
380
+ end
381
+
382
+ if attributes.key?(:'purchases_default_line_amount_type')
383
+ self.purchases_default_line_amount_type = attributes[:'purchases_default_line_amount_type']
384
+ end
385
+
344
386
  if attributes.key?(:'default_currency')
345
387
  self.default_currency = attributes[:'default_currency']
346
388
  end
@@ -464,6 +506,10 @@ module XeroRuby::Accounting
464
506
  invalid_properties.push('invalid value for "last_name", the character length must be smaller than or equal to 255.')
465
507
  end
466
508
 
509
+ if !@company_number.nil? && @company_number.to_s.length > 50
510
+ invalid_properties.push('invalid value for "company_number", the character length must be smaller than or equal to 50.')
511
+ end
512
+
467
513
  if !@email_address.nil? && @email_address.to_s.length > 255
468
514
  invalid_properties.push('invalid value for "email_address", the character length must be smaller than or equal to 255.')
469
515
  end
@@ -485,8 +531,13 @@ module XeroRuby::Accounting
485
531
  return false if !@name.nil? && @name.to_s.length > 255
486
532
  return false if !@first_name.nil? && @first_name.to_s.length > 255
487
533
  return false if !@last_name.nil? && @last_name.to_s.length > 255
534
+ return false if !@company_number.nil? && @company_number.to_s.length > 50
488
535
  return false if !@email_address.nil? && @email_address.to_s.length > 255
489
536
  return false if !@tax_number.nil? && @tax_number.to_s.length > 50
537
+ sales_default_line_amount_type_validator = EnumAttributeValidator.new('String', ["INCLUSIVE", "EXCLUSIVE", "NONE"])
538
+ return false unless sales_default_line_amount_type_validator.valid?(@sales_default_line_amount_type)
539
+ purchases_default_line_amount_type_validator = EnumAttributeValidator.new('String', ["INCLUSIVE", "EXCLUSIVE", "NONE"])
540
+ return false unless purchases_default_line_amount_type_validator.valid?(@purchases_default_line_amount_type)
490
541
  true
491
542
  end
492
543
 
@@ -550,6 +601,16 @@ module XeroRuby::Accounting
550
601
  @last_name = last_name
551
602
  end
552
603
 
604
+ # Custom attribute writer method with validation
605
+ # @param [Object] company_number Value to be assigned
606
+ def company_number=(company_number)
607
+ if !company_number.nil? && company_number.to_s.length > 50
608
+ fail ArgumentError, 'invalid value for "company_number", the character length must be smaller than or equal to 50.'
609
+ end
610
+
611
+ @company_number = company_number
612
+ end
613
+
553
614
  # Custom attribute writer method with validation
554
615
  # @param [Object] email_address Value to be assigned
555
616
  def email_address=(email_address)
@@ -570,18 +631,40 @@ module XeroRuby::Accounting
570
631
  @tax_number = tax_number
571
632
  end
572
633
 
634
+ # Custom attribute writer method checking allowed values (enum).
635
+ # @param [Object] sales_default_line_amount_type Object to be assigned
636
+ def sales_default_line_amount_type=(sales_default_line_amount_type)
637
+ validator = EnumAttributeValidator.new('String', ["INCLUSIVE", "EXCLUSIVE", "NONE"])
638
+ unless validator.valid?(sales_default_line_amount_type)
639
+ fail ArgumentError, "invalid value for \"sales_default_line_amount_type\", must be one of #{validator.allowable_values}."
640
+ end
641
+ @sales_default_line_amount_type = sales_default_line_amount_type
642
+ end
643
+
644
+ # Custom attribute writer method checking allowed values (enum).
645
+ # @param [Object] purchases_default_line_amount_type Object to be assigned
646
+ def purchases_default_line_amount_type=(purchases_default_line_amount_type)
647
+ validator = EnumAttributeValidator.new('String', ["INCLUSIVE", "EXCLUSIVE", "NONE"])
648
+ unless validator.valid?(purchases_default_line_amount_type)
649
+ fail ArgumentError, "invalid value for \"purchases_default_line_amount_type\", must be one of #{validator.allowable_values}."
650
+ end
651
+ @purchases_default_line_amount_type = purchases_default_line_amount_type
652
+ end
653
+
573
654
  # Checks equality by comparing each attribute.
574
655
  # @param [Object] Object to be compared
575
656
  def ==(o)
576
657
  return true if self.equal?(o)
577
658
  self.class == o.class &&
578
659
  contact_id == o.contact_id &&
660
+ merged_to_contact_id == o.merged_to_contact_id &&
579
661
  contact_number == o.contact_number &&
580
662
  account_number == o.account_number &&
581
663
  contact_status == o.contact_status &&
582
664
  name == o.name &&
583
665
  first_name == o.first_name &&
584
666
  last_name == o.last_name &&
667
+ company_number == o.company_number &&
585
668
  email_address == o.email_address &&
586
669
  skype_user_name == o.skype_user_name &&
587
670
  contact_persons == o.contact_persons &&
@@ -593,6 +676,8 @@ module XeroRuby::Accounting
593
676
  phones == o.phones &&
594
677
  is_supplier == o.is_supplier &&
595
678
  is_customer == o.is_customer &&
679
+ sales_default_line_amount_type == o.sales_default_line_amount_type &&
680
+ purchases_default_line_amount_type == o.purchases_default_line_amount_type &&
596
681
  default_currency == o.default_currency &&
597
682
  xero_network_key == o.xero_network_key &&
598
683
  sales_default_account_code == o.sales_default_account_code &&
@@ -625,7 +710,7 @@ module XeroRuby::Accounting
625
710
  # Calculates hash code according to all attributes.
626
711
  # @return [Integer] Hash code
627
712
  def hash
628
- [contact_id, contact_number, account_number, contact_status, name, first_name, last_name, email_address, skype_user_name, contact_persons, bank_account_details, tax_number, accounts_receivable_tax_type, accounts_payable_tax_type, addresses, phones, is_supplier, is_customer, default_currency, xero_network_key, sales_default_account_code, purchases_default_account_code, sales_tracking_categories, purchases_tracking_categories, tracking_category_name, tracking_category_option, payment_terms, updated_date_utc, contact_groups, website, branding_theme, batch_payments, discount, balances, attachments, has_attachments, validation_errors, has_validation_errors, status_attribute_string].hash
713
+ [contact_id, merged_to_contact_id, contact_number, account_number, contact_status, name, first_name, last_name, company_number, email_address, skype_user_name, contact_persons, bank_account_details, tax_number, accounts_receivable_tax_type, accounts_payable_tax_type, addresses, phones, is_supplier, is_customer, sales_default_line_amount_type, purchases_default_line_amount_type, default_currency, xero_network_key, sales_default_account_code, purchases_default_account_code, sales_tracking_categories, purchases_tracking_categories, tracking_category_name, tracking_category_option, payment_terms, updated_date_utc, contact_groups, website, branding_theme, batch_payments, discount, balances, attachments, has_attachments, validation_errors, has_validation_errors, status_attribute_string].hash
629
714
  end
630
715
 
631
716
  # Builds the object from hash
@@ -0,0 +1,342 @@
1
+ =begin
2
+ #Xero Finance API
3
+
4
+ #The Finance API is a collection of endpoints which customers can use in the course of a loan application, which may assist lenders to gain the confidence they need to provide capital.
5
+
6
+ Contact: api@xero.com
7
+ Generated by: https://openapi-generator.tech
8
+ OpenAPI Generator version: 4.3.1
9
+
10
+ =end
11
+
12
+ require 'time'
13
+ require 'date'
14
+
15
+ module XeroRuby::Finance
16
+ require 'bigdecimal'
17
+
18
+ class AccountUsage
19
+ # The month this usage item contains data for
20
+ attr_accessor :month
21
+
22
+ # The account this usage item contains data for
23
+ attr_accessor :account_id
24
+
25
+ # The currency code this usage item contains data for
26
+ attr_accessor :currency_code
27
+
28
+ # Total received
29
+ attr_accessor :total_received
30
+
31
+ # Count of received
32
+ attr_accessor :count_received
33
+
34
+ # Total paid
35
+ attr_accessor :total_paid
36
+
37
+ # Count of paid
38
+ attr_accessor :count_paid
39
+
40
+ # Total value of manual journals
41
+ attr_accessor :total_manual_journal
42
+
43
+ # Count of manual journals
44
+ attr_accessor :count_manual_journal
45
+
46
+ # The name of the account
47
+ attr_accessor :account_name
48
+
49
+ # Shown if set
50
+ attr_accessor :reporting_code
51
+
52
+ # Shown if set
53
+ attr_accessor :reporting_code_name
54
+
55
+ # Last modified date UTC format
56
+ attr_accessor :report_code_updated_date_utc
57
+
58
+ # Attribute mapping from ruby-style variable name to JSON key.
59
+ def self.attribute_map
60
+ {
61
+ :'month' => :'month',
62
+ :'account_id' => :'accountId',
63
+ :'currency_code' => :'currencyCode',
64
+ :'total_received' => :'totalReceived',
65
+ :'count_received' => :'countReceived',
66
+ :'total_paid' => :'totalPaid',
67
+ :'count_paid' => :'countPaid',
68
+ :'total_manual_journal' => :'totalManualJournal',
69
+ :'count_manual_journal' => :'countManualJournal',
70
+ :'account_name' => :'accountName',
71
+ :'reporting_code' => :'reportingCode',
72
+ :'reporting_code_name' => :'reportingCodeName',
73
+ :'report_code_updated_date_utc' => :'reportCodeUpdatedDateUtc'
74
+ }
75
+ end
76
+
77
+ # Attribute type mapping.
78
+ def self.openapi_types
79
+ {
80
+ :'month' => :'String',
81
+ :'account_id' => :'String',
82
+ :'currency_code' => :'String',
83
+ :'total_received' => :'BigDecimal',
84
+ :'count_received' => :'Integer',
85
+ :'total_paid' => :'BigDecimal',
86
+ :'count_paid' => :'Integer',
87
+ :'total_manual_journal' => :'BigDecimal',
88
+ :'count_manual_journal' => :'Integer',
89
+ :'account_name' => :'String',
90
+ :'reporting_code' => :'String',
91
+ :'reporting_code_name' => :'String',
92
+ :'report_code_updated_date_utc' => :'DateTime'
93
+ }
94
+ end
95
+
96
+ # Initializes the object
97
+ # @param [Hash] attributes Model attributes in the form of hash
98
+ def initialize(attributes = {})
99
+ if (!attributes.is_a?(Hash))
100
+ fail ArgumentError, "The input argument (attributes) must be a hash in `XeroRuby::Finance::AccountUsage` initialize method"
101
+ end
102
+
103
+ # check to see if the attribute exists and convert string to symbol for hash key
104
+ attributes = attributes.each_with_object({}) { |(k, v), h|
105
+ if (!self.class.attribute_map.key?(k.to_sym))
106
+ fail ArgumentError, "`#{k}` is not a valid attribute in `XeroRuby::Finance::AccountUsage`. Please check the name to make sure it's valid. List of attributes: " + self.class.attribute_map.keys.inspect
107
+ end
108
+ h[k.to_sym] = v
109
+ }
110
+
111
+ if attributes.key?(:'month')
112
+ self.month = attributes[:'month']
113
+ end
114
+
115
+ if attributes.key?(:'account_id')
116
+ self.account_id = attributes[:'account_id']
117
+ end
118
+
119
+ if attributes.key?(:'currency_code')
120
+ self.currency_code = attributes[:'currency_code']
121
+ end
122
+
123
+ if attributes.key?(:'total_received')
124
+ self.total_received = attributes[:'total_received']
125
+ end
126
+
127
+ if attributes.key?(:'count_received')
128
+ self.count_received = attributes[:'count_received']
129
+ end
130
+
131
+ if attributes.key?(:'total_paid')
132
+ self.total_paid = attributes[:'total_paid']
133
+ end
134
+
135
+ if attributes.key?(:'count_paid')
136
+ self.count_paid = attributes[:'count_paid']
137
+ end
138
+
139
+ if attributes.key?(:'total_manual_journal')
140
+ self.total_manual_journal = attributes[:'total_manual_journal']
141
+ end
142
+
143
+ if attributes.key?(:'count_manual_journal')
144
+ self.count_manual_journal = attributes[:'count_manual_journal']
145
+ end
146
+
147
+ if attributes.key?(:'account_name')
148
+ self.account_name = attributes[:'account_name']
149
+ end
150
+
151
+ if attributes.key?(:'reporting_code')
152
+ self.reporting_code = attributes[:'reporting_code']
153
+ end
154
+
155
+ if attributes.key?(:'reporting_code_name')
156
+ self.reporting_code_name = attributes[:'reporting_code_name']
157
+ end
158
+
159
+ if attributes.key?(:'report_code_updated_date_utc')
160
+ self.report_code_updated_date_utc = attributes[:'report_code_updated_date_utc']
161
+ end
162
+ end
163
+
164
+ # Show invalid properties with the reasons. Usually used together with valid?
165
+ # @return Array for valid properties with the reasons
166
+ def list_invalid_properties
167
+ invalid_properties = Array.new
168
+ invalid_properties
169
+ end
170
+
171
+ # Check to see if the all the properties in the model are valid
172
+ # @return true if the model is valid
173
+ def valid?
174
+ true
175
+ end
176
+
177
+ # Checks equality by comparing each attribute.
178
+ # @param [Object] Object to be compared
179
+ def ==(o)
180
+ return true if self.equal?(o)
181
+ self.class == o.class &&
182
+ month == o.month &&
183
+ account_id == o.account_id &&
184
+ currency_code == o.currency_code &&
185
+ total_received == o.total_received &&
186
+ count_received == o.count_received &&
187
+ total_paid == o.total_paid &&
188
+ count_paid == o.count_paid &&
189
+ total_manual_journal == o.total_manual_journal &&
190
+ count_manual_journal == o.count_manual_journal &&
191
+ account_name == o.account_name &&
192
+ reporting_code == o.reporting_code &&
193
+ reporting_code_name == o.reporting_code_name &&
194
+ report_code_updated_date_utc == o.report_code_updated_date_utc
195
+ end
196
+
197
+ # @see the `==` method
198
+ # @param [Object] Object to be compared
199
+ def eql?(o)
200
+ self == o
201
+ end
202
+
203
+ # Calculates hash code according to all attributes.
204
+ # @return [Integer] Hash code
205
+ def hash
206
+ [month, account_id, currency_code, total_received, count_received, total_paid, count_paid, total_manual_journal, count_manual_journal, account_name, reporting_code, reporting_code_name, report_code_updated_date_utc].hash
207
+ end
208
+
209
+ # Builds the object from hash
210
+ # @param [Hash] attributes Model attributes in the form of hash
211
+ # @return [Object] Returns the model itself
212
+ def self.build_from_hash(attributes)
213
+ new.build_from_hash(attributes)
214
+ end
215
+
216
+ # Builds the object from hash
217
+ # @param [Hash] attributes Model attributes in the form of hash
218
+ # @return [Object] Returns the model itself
219
+ def build_from_hash(attributes)
220
+ return nil unless attributes.is_a?(Hash)
221
+ self.class.openapi_types.each_pair do |key, type|
222
+ if type =~ /\AArray<(.*)>/i
223
+ # check to ensure the input is an array given that the attribute
224
+ # is documented as an array but the input is not
225
+ if attributes[self.class.attribute_map[key]].is_a?(Array)
226
+ self.send("#{key}=", attributes[self.class.attribute_map[key]].map { |v| _deserialize($1, v) })
227
+ end
228
+ elsif !attributes[self.class.attribute_map[key]].nil?
229
+ self.send("#{key}=", _deserialize(type, attributes[self.class.attribute_map[key]]))
230
+ end # or else data not found in attributes(hash), not an issue as the data can be optional
231
+ end
232
+
233
+ self
234
+ end
235
+
236
+ # Deserializes the data based on type
237
+ # @param string type Data type
238
+ # @param string value Value to be deserialized
239
+ # @return [Object] Deserialized data
240
+ def _deserialize(type, value)
241
+ case type.to_sym
242
+ when :DateTime
243
+ DateTime.parse(parse_date(value))
244
+ when :Date
245
+ Date.parse(parse_date(value))
246
+ when :String
247
+ value.to_s
248
+ when :Integer
249
+ value.to_i
250
+ when :Float
251
+ value.to_f
252
+ when :BigDecimal
253
+ BigDecimal(value.to_s)
254
+ when :Boolean
255
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
256
+ true
257
+ else
258
+ false
259
+ end
260
+ when :Object
261
+ # generic object (usually a Hash), return directly
262
+ value
263
+ when /\AArray<(?<inner_type>.+)>\z/
264
+ inner_type = Regexp.last_match[:inner_type]
265
+ value.map { |v| _deserialize(inner_type, v) }
266
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
267
+ k_type = Regexp.last_match[:k_type]
268
+ v_type = Regexp.last_match[:v_type]
269
+ {}.tap do |hash|
270
+ value.each do |k, v|
271
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
272
+ end
273
+ end
274
+ else # model
275
+ XeroRuby::Finance.const_get(type).build_from_hash(value)
276
+ end
277
+ end
278
+
279
+ # Returns the string representation of the object
280
+ # @return [String] String presentation of the object
281
+ def to_s
282
+ to_hash.to_s
283
+ end
284
+
285
+ # to_body is an alias to to_hash (backward compatibility)
286
+ # @return [Hash] Returns the object in the form of hash
287
+ def to_body
288
+ to_hash
289
+ end
290
+
291
+ # Returns the object in the form of hash
292
+ # @return [Hash] Returns the object in the form of hash
293
+ def to_hash(downcase: false)
294
+ hash = {}
295
+ self.class.attribute_map.each_pair do |attr, param|
296
+ value = self.send(attr)
297
+ next if value.nil?
298
+ key = downcase ? attr : param
299
+ hash[key] = _to_hash(value, downcase: downcase)
300
+ end
301
+ hash
302
+ end
303
+
304
+ # Returns the object in the form of hash with snake_case
305
+ def to_attributes
306
+ to_hash(downcase: true)
307
+ end
308
+
309
+ # Outputs non-array value in the form of hash
310
+ # For object, use to_hash. Otherwise, just return the value
311
+ # @param [Object] value Any valid value
312
+ # @return [Hash] Returns the value in the form of hash
313
+ def _to_hash(value, downcase: false)
314
+ if value.is_a?(Array)
315
+ value.map do |v|
316
+ v.to_hash(downcase: downcase)
317
+ end
318
+ elsif value.is_a?(Hash)
319
+ {}.tap do |hash|
320
+ value.map { |k, v| hash[k] = _to_hash(v, downcase: downcase) }
321
+ end
322
+ elsif value.respond_to? :to_hash
323
+ value.to_hash(downcase: downcase)
324
+ else
325
+ value
326
+ end
327
+ end
328
+
329
+ def parse_date(datestring)
330
+ if datestring.include?('Date')
331
+ date_pattern = /\/Date\((-?\d+)(\+\d+)?\)\//
332
+ original, date, timezone = *date_pattern.match(datestring)
333
+ date = (date.to_i / 1000)
334
+ Time.at(date).utc.strftime('%Y-%m-%dT%H:%M:%S%z').to_s
335
+ elsif /(\d\d\d\d)-(\d\d)/.match(datestring) # handles dates w/out Days: YYYY-MM*-DD
336
+ Time.parse(datestring + '-01').strftime('%Y-%m-%dT%H:%M:%S').to_s
337
+ else # handle date 'types' for small subset of payroll API's
338
+ Time.parse(datestring).strftime('%Y-%m-%dT%H:%M:%S').to_s
339
+ end
340
+ end
341
+ end
342
+ end