braintree 2.102.0 → 3.1.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (94) hide show
  1. checksums.yaml +4 -4
  2. data/LICENSE +1 -1
  3. data/braintree.gemspec +6 -3
  4. data/lib/braintree.rb +3 -17
  5. data/lib/braintree/address.rb +0 -22
  6. data/lib/braintree/address_gateway.rb +2 -2
  7. data/lib/braintree/base_module.rb +6 -0
  8. data/lib/braintree/bin_data.rb +9 -2
  9. data/lib/braintree/configuration.rb +1 -1
  10. data/lib/braintree/credit_card.rb +5 -76
  11. data/lib/braintree/credit_card_gateway.rb +3 -32
  12. data/lib/braintree/credit_card_verification.rb +14 -0
  13. data/lib/braintree/customer.rb +3 -72
  14. data/lib/braintree/customer_gateway.rb +0 -23
  15. data/lib/braintree/dispute.rb +1 -7
  16. data/lib/braintree/dispute/{history_event.rb → status_history.rb} +3 -1
  17. data/lib/braintree/dispute/transaction.rb +2 -0
  18. data/lib/braintree/dispute_gateway.rb +2 -7
  19. data/lib/braintree/error_codes.rb +152 -170
  20. data/lib/braintree/exceptions.rb +5 -3
  21. data/lib/braintree/gateway.rb +0 -14
  22. data/lib/braintree/{android_pay_card.rb → google_pay_card.rb} +1 -1
  23. data/lib/braintree/local_payment_completed.rb +1 -1
  24. data/lib/braintree/merchant_account_gateway.rb +2 -0
  25. data/lib/braintree/payment_instrument_type.rb +1 -4
  26. data/lib/braintree/payment_method_gateway.rb +4 -8
  27. data/lib/braintree/payment_method_parser.rb +1 -7
  28. data/lib/braintree/risk_data.rb +4 -1
  29. data/lib/braintree/subscription.rb +5 -5
  30. data/lib/braintree/successful_result.rb +0 -1
  31. data/lib/braintree/test/credit_card.rb +1 -0
  32. data/lib/braintree/test/nonce.rb +5 -20
  33. data/lib/braintree/transaction.rb +9 -73
  34. data/lib/braintree/transaction/address_details.rb +11 -0
  35. data/lib/braintree/transaction/disbursement_details.rb +1 -0
  36. data/lib/braintree/transaction/{android_pay_details.rb → google_pay_details.rb} +1 -1
  37. data/lib/braintree/transaction/paypal_details.rb +3 -0
  38. data/lib/braintree/transaction/subscription_details.rb +2 -0
  39. data/lib/braintree/transaction_gateway.rb +14 -21
  40. data/lib/braintree/transaction_search.rb +0 -1
  41. data/lib/braintree/util.rb +17 -2
  42. data/lib/braintree/version.rb +2 -2
  43. data/lib/braintree/webhook_notification.rb +0 -10
  44. data/lib/braintree/webhook_testing_gateway.rb +0 -43
  45. data/lib/braintree/xml/libxml.rb +1 -0
  46. data/lib/braintree/xml/parser.rb +11 -34
  47. data/spec/integration/braintree/address_spec.rb +2 -89
  48. data/spec/integration/braintree/client_api/spec_helper.rb +92 -66
  49. data/spec/integration/braintree/credit_card_spec.rb +20 -467
  50. data/spec/integration/braintree/credit_card_verification_spec.rb +1 -0
  51. data/spec/integration/braintree/customer_spec.rb +22 -362
  52. data/spec/integration/braintree/dispute_search_spec.rb +3 -3
  53. data/spec/integration/braintree/dispute_spec.rb +1 -2
  54. data/spec/integration/braintree/merchant_spec.rb +2 -2
  55. data/spec/integration/braintree/payment_method_spec.rb +77 -120
  56. data/spec/integration/braintree/paypal_account_spec.rb +1 -1
  57. data/spec/integration/braintree/subscription_spec.rb +11 -16
  58. data/spec/integration/braintree/transaction_search_spec.rb +3 -3
  59. data/spec/integration/braintree/transaction_spec.rb +274 -524
  60. data/spec/integration/spec_helper.rb +1 -4
  61. data/spec/spec_helper.rb +1 -11
  62. data/spec/unit/braintree/address_spec.rb +0 -8
  63. data/spec/unit/braintree/credit_card_spec.rb +28 -21
  64. data/spec/unit/braintree/credit_card_verification_spec.rb +7 -0
  65. data/spec/unit/braintree/customer_spec.rb +4 -12
  66. data/spec/unit/braintree/dispute_spec.rb +4 -12
  67. data/spec/unit/braintree/http_spec.rb +3 -3
  68. data/spec/unit/braintree/local_payment_completed_spec.rb +14 -0
  69. data/spec/unit/braintree/transaction/paypal_details_spec.rb +59 -0
  70. data/spec/unit/braintree/transaction_spec.rb +17 -37
  71. data/spec/unit/braintree/util_spec.rb +37 -3
  72. data/spec/unit/braintree/webhook_notification_spec.rb +1 -1
  73. data/spec/unit/braintree/xml/parser_spec.rb +21 -16
  74. metadata +28 -32
  75. data/lib/braintree/amex_express_checkout_card.rb +0 -38
  76. data/lib/braintree/coinbase_account.rb +0 -34
  77. data/lib/braintree/europe_bank_account.rb +0 -36
  78. data/lib/braintree/europe_bank_account_gateway.rb +0 -17
  79. data/lib/braintree/ideal_payment.rb +0 -61
  80. data/lib/braintree/ideal_payment_gateway.rb +0 -19
  81. data/lib/braintree/masterpass_card.rb +0 -81
  82. data/lib/braintree/transaction/amex_express_checkout_details.rb +0 -21
  83. data/lib/braintree/transaction/coinbase_details.rb +0 -16
  84. data/lib/braintree/transaction/ideal_payment_details.rb +0 -19
  85. data/lib/braintree/transaction/masterpass_card_details.rb +0 -47
  86. data/lib/braintree/transparent_redirect.rb +0 -40
  87. data/lib/braintree/transparent_redirect_gateway.rb +0 -105
  88. data/lib/braintree/xml/rexml.rb +0 -71
  89. data/spec/hacks/tcp_socket.rb +0 -18
  90. data/spec/integration/braintree/coinbase_spec.rb +0 -34
  91. data/spec/integration/braintree/masterpass_card_spec.rb +0 -97
  92. data/spec/integration/braintree/transparent_redirect_spec.rb +0 -268
  93. data/spec/unit/braintree/transparent_redirect_spec.rb +0 -223
  94. data/spec/unit/braintree/xml/rexml_spec.rb +0 -51
@@ -8,9 +8,7 @@ module Braintree # :nodoc:
8
8
 
9
9
  class ConfigurationError < BraintreeError; end
10
10
 
11
- class DownForMaintenanceError < BraintreeError; end
12
-
13
- class ForgedQueryString < BraintreeError; end
11
+ class GatewayTimeoutError < BraintreeError; end
14
12
 
15
13
  class InvalidSignature < BraintreeError; end
16
14
 
@@ -18,8 +16,12 @@ module Braintree # :nodoc:
18
16
 
19
17
  class NotFoundError < BraintreeError; end
20
18
 
19
+ class RequestTimeoutError < BraintreeError; end
20
+
21
21
  class ServerError < BraintreeError; end
22
22
 
23
+ class ServiceUnavailableError < BraintreeError; end
24
+
23
25
  class SSLCertificateError < BraintreeError; end
24
26
 
25
27
  class TooManyRequestsError < BraintreeError; end
@@ -74,12 +74,6 @@ module Braintree
74
74
  UsBankAccountGateway.new(self)
75
75
  end
76
76
 
77
- # NEXT_MAJOR_VERSION Remove this class as legacy Ideal has been removed/disabled in the Braintree Gateway
78
- # DEPRECATED If you're looking to accept iDEAL as a payment method contact accounts@braintreepayments.com for a solution.
79
- def ideal_payment
80
- IdealPaymentGateway.new(self)
81
- end
82
-
83
77
  def merchant
84
78
  MerchantGateway.new(self)
85
79
  end
@@ -88,10 +82,6 @@ module Braintree
88
82
  MerchantAccountGateway.new(self)
89
83
  end
90
84
 
91
- def europe_bank_account
92
- EuropeBankAccountGateway.new(self)
93
- end
94
-
95
85
  def settlement_batch_summary
96
86
  SettlementBatchSummaryGateway.new(self)
97
87
  end
@@ -100,10 +90,6 @@ module Braintree
100
90
  SubscriptionGateway.new(self)
101
91
  end
102
92
 
103
- def transparent_redirect
104
- TransparentRedirectGateway.new(self)
105
- end
106
-
107
93
  def transaction
108
94
  TransactionGateway.new(self)
109
95
  end
@@ -1,5 +1,5 @@
1
1
  module Braintree
2
- class AndroidPayCard
2
+ class GooglePayCard
3
3
  include BaseModule # :nodoc:
4
4
 
5
5
  attr_reader :bin
@@ -9,7 +9,7 @@ module Braintree
9
9
 
10
10
  def initialize(attributes) # :nodoc:
11
11
  set_instance_variables_from_hash(attributes)
12
- @transaction = Transaction._new(Configuration.gateway, transaction)
12
+ @transaction = Transaction._new(Configuration.gateway, transaction) unless transaction.nil?
13
13
  end
14
14
 
15
15
  class << self
@@ -83,6 +83,7 @@ module Braintree
83
83
  end
84
84
  end
85
85
 
86
+ # this is part of Marketplace and shouldn't be removed unless we're removing all Marketplace code
86
87
  def self._detect_signature(attributes)
87
88
  if attributes.has_key?(:applicant_details)
88
89
  warn "[DEPRECATED] Passing :applicant_details to create is deprecated. Please use :individual, :business, and :funding."
@@ -92,6 +93,7 @@ module Braintree
92
93
  end
93
94
  end
94
95
 
96
+ # this is part of Marketplace and shouldn't be removed unless we're removing all Marketplace code
95
97
  def self._deprecated_create_signature # :nodoc:
96
98
  [
97
99
  {:applicant_details => [
@@ -1,15 +1,12 @@
1
1
  module Braintree
2
2
  module PaymentInstrumentType
3
3
  PayPalAccount = 'paypal_account'
4
- EuropeBankAccount = 'europe_bank_account'
5
4
  CreditCard = 'credit_card'
6
- CoinbaseAccount = 'coinbase_account'
7
5
  ApplePayCard = 'apple_pay_card'
8
- AndroidPayCard = 'android_pay_card'
6
+ GooglePayCard = 'android_pay_card'
9
7
  VenmoAccount = 'venmo_account'
10
8
  UsBankAccount = 'us_bank_account'
11
9
  VisaCheckoutCard = 'visa_checkout_card'
12
- MasterpassCard = 'masterpass_card'
13
10
  SamsungPayCard = 'samsung_pay_card'
14
11
  LocalPayment = 'local_payment'
15
12
  PayPalHere = 'paypal_here'
@@ -43,16 +43,12 @@ module Braintree
43
43
  CreditCard._new(@gateway, response[:credit_card])
44
44
  elsif response.has_key?(:paypal_account)
45
45
  PayPalAccount._new(@gateway, response[:paypal_account])
46
- elsif response[:coinbase_account]
47
- SuccessfulResult.new(:payment_method => CoinbaseAccount._new(@gateway, response[:coinbase_account]))
48
46
  elsif response.has_key?(:us_bank_account)
49
47
  UsBankAccount._new(@gateway, response[:us_bank_account])
50
- elsif response.has_key?(:europe_bank_account)
51
- EuropeBankAccount._new(@gateway, response[:europe_bank_account])
52
48
  elsif response.has_key?(:apple_pay_card)
53
49
  ApplePayCard._new(@gateway, response[:apple_pay_card])
54
50
  elsif response.has_key?(:android_pay_card)
55
- AndroidPayCard._new(@gateway, response[:android_pay_card])
51
+ GooglePayCard._new(@gateway, response[:android_pay_card])
56
52
  elsif response.has_key?(:venmo_account)
57
53
  VenmoAccount._new(@gateway, response[:venmo_account])
58
54
  else
@@ -166,9 +162,9 @@ module Braintree
166
162
  ],
167
163
  ]
168
164
  signature = [
169
- :billing_address_id, :cardholder_name, :cvv, :device_session_id, :expiration_date,
170
- :expiration_month, :expiration_year, :number, :token, :venmo_sdk_payment_method_code,
171
- :device_data, :fraud_merchant_id, :payment_method_nonce,
165
+ :billing_address_id, :cardholder_name, :cvv, :expiration_date, :expiration_month,
166
+ :expiration_year, :number, :token, :venmo_sdk_payment_method_code, :device_data,
167
+ :payment_method_nonce,
172
168
  {:options => options},
173
169
  {:billing_address => billing_address_params}
174
170
  ]
@@ -6,22 +6,16 @@ module Braintree
6
6
  CreditCard._new(gateway, attributes[:credit_card])
7
7
  elsif attributes[:paypal_account]
8
8
  PayPalAccount._new(gateway, attributes[:paypal_account])
9
- elsif attributes[:coinbase_account]
10
- CoinbaseAccount._new(gateway, attributes[:coinbase_account])
11
9
  elsif attributes[:us_bank_account]
12
10
  UsBankAccount._new(gateway, attributes[:us_bank_account])
13
11
  elsif attributes[:apple_pay_card]
14
12
  ApplePayCard._new(gateway, attributes[:apple_pay_card])
15
13
  elsif attributes[:android_pay_card]
16
- AndroidPayCard._new(gateway, attributes[:android_pay_card])
17
- elsif attributes[:amex_express_checkout_card]
18
- AmexExpressCheckoutCard._new(gateway, attributes[:amex_express_checkout_card])
14
+ GooglePayCard._new(gateway, attributes[:android_pay_card])
19
15
  elsif attributes[:venmo_account]
20
16
  VenmoAccount._new(gateway, attributes[:venmo_account])
21
17
  elsif attributes[:visa_checkout_card]
22
18
  VisaCheckoutCard._new(gateway, attributes[:visa_checkout_card])
23
- elsif attributes[:masterpass_card]
24
- MasterpassCard._new(gateway, attributes[:masterpass_card])
25
19
  elsif attributes[:samsung_pay_card]
26
20
  SamsungPayCard._new(gateway, attributes[:samsung_pay_card])
27
21
  else
@@ -2,10 +2,13 @@ module Braintree
2
2
  class RiskData # :nodoc:
3
3
  include BaseModule
4
4
 
5
+ attr_reader :customer_device_id
6
+ attr_reader :customer_location_zip
7
+ attr_reader :customer_tenure
5
8
  attr_reader :decision
6
9
  attr_reader :device_data_captured
7
- attr_reader :id
8
10
  attr_reader :fraud_service_provider
11
+ attr_reader :id
9
12
 
10
13
  def initialize(attributes)
11
14
  set_instance_variables_from_hash attributes unless attributes.nil?
@@ -101,11 +101,11 @@ module Braintree
101
101
  add_ons.map! { |attrs| AddOn._new(attrs) }
102
102
  discounts.map! { |attrs| Discount._new(attrs) }
103
103
  @status_history = attributes[:status_history] ? attributes[:status_history].map { |s| StatusDetails.new(s) } : []
104
- end
105
-
106
- def next_bill_amount
107
- warn "[DEPRECATED] Subscription.next_bill_amount is deprecated. Please use Subscription.next_billing_period_amount"
108
- @next_bill_amount
104
+ @first_billing_date = Date.parse(first_billing_date) unless first_billing_date.nil?
105
+ @next_billing_date = Date.parse(next_billing_date) unless next_billing_date.nil?
106
+ @billing_period_start_date = Date.parse(billing_period_start_date) unless billing_period_start_date.nil?
107
+ @billing_period_end_date = Date.parse(billing_period_end_date) unless billing_period_end_date.nil?
108
+ @paid_through_date = Date.parse(paid_through_date) unless paid_through_date.nil?
109
109
  end
110
110
 
111
111
  def never_expires?
@@ -13,7 +13,6 @@ module Braintree
13
13
  attr_reader :merchant
14
14
  attr_reader :merchant_account
15
15
  attr_reader :merchant_accounts
16
- attr_reader :new_transaction
17
16
  attr_reader :payment_method
18
17
  attr_reader :payment_method_nonce
19
18
  attr_reader :paypal_account
@@ -40,6 +40,7 @@ module Braintree
40
40
  VisaPrepaid = "4500600000000061"
41
41
 
42
42
  Fraud = "4000111111111511"
43
+ RiskThreshold = "4111130000000003"
43
44
 
44
45
  Visas = %w[4009348888881881 4012888888881881 4111111111111111 4000111111111115 4500600000000061]
45
46
  Unknowns = %w[1000000000000008]
@@ -12,12 +12,10 @@ module Braintree
12
12
  ApplePayAmEx = "fake-apple-pay-amex-nonce"
13
13
  AbstractTransactable = "fake-abstract-transactable-nonce"
14
14
  Europe = "fake-europe-bank-account-nonce"
15
- Coinbase = "fake-coinbase-nonce"
16
- AndroidPayDiscover = "fake-android-pay-discover-nonce"
17
- AndroidPayVisa = "fake-android-pay-visa-nonce"
18
- AndroidPayMasterCard = "fake-android-pay-mastercard-nonce"
19
- AndroidPayAmEx = "fake-android-pay-amex-nonce"
20
- AmexExpressCheckout = "fake-amex-express-checkout-nonce"
15
+ GooglePayDiscover = "fake-android-pay-discover-nonce"
16
+ GooglePayVisa = "fake-android-pay-visa-nonce"
17
+ GooglePayMasterCard = "fake-android-pay-mastercard-nonce"
18
+ GooglePayAmEx = "fake-android-pay-amex-nonce"
21
19
  VenmoAccount = "fake-venmo-account-nonce"
22
20
  VenmoAccountTokenIssuanceError = "fake-token-issuance-error-venmo-account-nonce"
23
21
  ThreeDSecureVisaFullAuthentication = "fake-three-d-secure-visa-full-authentication-nonce"
@@ -60,12 +58,8 @@ module Braintree
60
58
  ProcessorFailureJCB = "fake-processor-failure-jcb-nonce"
61
59
  LuhnInvalid = "fake-luhn-invalid-nonce"
62
60
  PayPalFuturePaymentRefreshToken = "fake-paypal-future-refresh-token-nonce"
63
- SEPA = "fake-sepa-bank-account-nonce"
64
61
  GatewayRejectedFraud = "fake-gateway-rejected-fraud-nonce"
65
- MasterpassAmEx = "fake-masterpass-amex-nonce"
66
- MasterpassDiscover = "fake-masterpass-discover-nonce"
67
- MasterpassMasterCard = "fake-masterpass-mastercard-nonce"
68
- MasterpassVisa = "fake-masterpass-visa-nonce"
62
+ GatewayRejectedRiskThresholds = "fake-gateway-rejected-risk-thresholds-nonce"
69
63
  VisaCheckoutAmEx = "fake-visa-checkout-amex-nonce"
70
64
  VisaCheckoutDiscover = "fake-visa-checkout-discover-nonce"
71
65
  VisaCheckoutMasterCard = "fake-visa-checkout-mastercard-nonce"
@@ -74,15 +68,6 @@ module Braintree
74
68
  SamsungPayDiscover = "tokensam_fake_discover"
75
69
  SamsungPayMasterCard = "tokensam_fake_mastercard"
76
70
  SamsungPayVisa = "tokensam_fake_visa"
77
-
78
- def self.const_missing(const_name)
79
- if const_name == :AndroidPay
80
- warn "[DEPRECATED] Braintree::Test::Nonce::AndroidPay is deprecated. Use a card-specific nonce, e.g. Braintree::Test::Nonce::AndroidPayMasterCard"
81
- "fake-android-pay-nonce"
82
- else
83
- super
84
- end
85
- end
86
71
  end
87
72
  end
88
73
  end
@@ -25,6 +25,7 @@ module Braintree
25
25
  CVV = "cvv"
26
26
  Duplicate = "duplicate"
27
27
  Fraud = "fraud"
28
+ RiskThreshold = "risk_threshold"
28
29
  ThreeDSecure = "three_d_secure"
29
30
  TokenIssuance = "token_issuance"
30
31
  Unrecognized = "unrecognized"
@@ -89,11 +90,10 @@ module Braintree
89
90
  end
90
91
  end
91
92
 
93
+ attr_reader :acquirer_reference_number
92
94
  attr_reader :add_ons
93
95
  attr_reader :additional_processor_response # The raw response from the processor.
94
- attr_reader :amex_express_checkout_details
95
96
  attr_reader :amount
96
- attr_reader :android_pay_details
97
97
  attr_reader :apple_pay_details
98
98
  attr_reader :authorization_adjustments
99
99
  attr_reader :authorization_expires_at
@@ -103,7 +103,6 @@ module Braintree
103
103
  attr_reader :avs_street_address_response_code
104
104
  attr_reader :billing_details
105
105
  attr_reader :channel
106
- attr_reader :coinbase_details
107
106
  attr_reader :created_at
108
107
  attr_reader :credit_card_details
109
108
  attr_reader :currency_iso_code
@@ -119,13 +118,10 @@ module Braintree
119
118
  attr_reader :facilitated_details
120
119
  attr_reader :facilitator_details
121
120
  attr_reader :gateway_rejection_reason
121
+ attr_reader :google_pay_details
122
122
  attr_reader :graphql_id
123
123
  attr_reader :id
124
- # NEXT_MAJOR_VERSION Remove this class as legacy Ideal has been removed/disabled in the Braintree Gateway
125
- # DEPRECATED If you're looking to accept iDEAL as a payment method contact accounts@braintreepayments.com for a solution.
126
- attr_reader :ideal_payment_details
127
124
  attr_reader :local_payment_details
128
- attr_reader :masterpass_card_details
129
125
  attr_reader :merchant_account_id
130
126
  attr_reader :network_response_code # Response code from the card network
131
127
  attr_reader :network_response_text # Response text from the card network
@@ -142,10 +138,12 @@ module Braintree
142
138
  attr_reader :processor_response_type # Response type from the processor.
143
139
  attr_reader :processor_settlement_response_code # Settlement response code from the processor.
144
140
  attr_reader :processor_settlement_response_text # Settlement response text from the processor.
141
+ attr_reader :product_sku
145
142
  attr_reader :purchase_order_number
146
143
  attr_reader :recurring
147
144
  attr_reader :refund_ids
148
145
  attr_reader :refunded_transaction_id
146
+ attr_reader :retrieval_reference_number
149
147
  attr_reader :risk_data
150
148
  attr_reader :samsung_pay_card_details
151
149
  attr_reader :service_fee_amount
@@ -166,7 +164,6 @@ module Braintree
166
164
  attr_reader :venmo_account_details
167
165
  attr_reader :visa_checkout_card_details
168
166
  attr_reader :voice_referral_number
169
- attr_reader :retrieval_reference_number
170
167
 
171
168
  def self.create(*args)
172
169
  Configuration.gateway.transaction.create(*args)
@@ -192,18 +189,6 @@ module Braintree
192
189
  Configuration.gateway.transaction.clone_transaction!(*args)
193
190
  end
194
191
 
195
- # Deprecated. Use Braintree::TransparentRedirect.confirm
196
- def self.create_from_transparent_redirect(*args)
197
- warn "[DEPRECATED] Transaction.create_from_transparent_redirect is deprecated. Please use TransparentRedirect.confirm"
198
- Configuration.gateway.transaction.create_from_transparent_redirect(*args)
199
- end
200
-
201
- # Deprecated. Use Braintree::TransparentRedirect.url
202
- def self.create_transaction_url
203
- warn "[DEPRECATED] Transaction.create_transaction_url is deprecated. Please use TransparentRedirect.url"
204
- Configuration.gateway.transaction.create_transaction_url
205
- end
206
-
207
192
  def self.credit(*args)
208
193
  Configuration.gateway.transaction.credit(*args)
209
194
  end
@@ -306,10 +291,8 @@ module Braintree
306
291
  @paypal_details = PayPalDetails.new(@paypal)
307
292
  @paypal_here_details = PayPalHereDetails.new(@paypal_here)
308
293
  @apple_pay_details = ApplePayDetails.new(@apple_pay)
309
- @android_pay_details = AndroidPayDetails.new(@android_pay_card)
310
- @amex_express_checkout_details = AmexExpressCheckoutDetails.new(@amex_express_checkout_card)
294
+ @google_pay_details = GooglePayDetails.new(@google_pay_card)
311
295
  @venmo_account_details = VenmoAccountDetails.new(@venmo_account)
312
- @coinbase_details = CoinbaseDetails.new(@coinbase_account)
313
296
  disputes.map! { |attrs| Dispute._new(attrs) } if disputes
314
297
  @custom_fields = attributes[:custom_fields].is_a?(Hash) ? attributes[:custom_fields] : {}
315
298
  add_ons.map! { |attrs| AddOn._new(attrs) } if add_ons
@@ -320,9 +303,7 @@ module Braintree
320
303
  @facilitator_details = FacilitatorDetails.new(attributes[:facilitator_details]) if attributes[:facilitator_details]
321
304
  @three_d_secure_info = ThreeDSecureInfo.new(attributes[:three_d_secure_info]) if attributes[:three_d_secure_info]
322
305
  @us_bank_account_details = UsBankAccountDetails.new(attributes[:us_bank_account]) if attributes[:us_bank_account]
323
- @ideal_payment_details = IdealPaymentDetails.new(attributes[:ideal_payment]) if attributes[:ideal_payment]
324
306
  @visa_checkout_card_details = VisaCheckoutCardDetails.new(attributes[:visa_checkout_card])
325
- @masterpass_card_details = MasterpassCardDetails.new(attributes[:masterpass_card])
326
307
  @samsung_pay_card_details = SamsungPayCardDetails.new(attributes[:samsung_pay_card])
327
308
  authorization_adjustments.map! { |attrs| AuthorizationAdjustment._new(attrs) } if authorization_adjustments
328
309
  end
@@ -344,18 +325,6 @@ module Braintree
344
325
  @gateway.transaction_line_item.find_all(id)
345
326
  end
346
327
 
347
- # Deprecated. Use Braintree::Transaction.refund
348
- def refund(amount = nil)
349
- warn "[DEPRECATED] refund as an instance method is deprecated. Please use Transaction.refund"
350
- result = @gateway.transaction.refund(id, amount)
351
-
352
- if result.success?
353
- SuccessfulResult.new(:new_transaction => result.transaction)
354
- else
355
- result
356
- end
357
- end
358
-
359
328
  # Returns true if the transaction has been refunded. False otherwise.
360
329
  def refunded?
361
330
  !@refund_id.nil?
@@ -366,27 +335,6 @@ module Braintree
366
335
  @disbursement_details.valid?
367
336
  end
368
337
 
369
- def refund_id
370
- warn "[DEPRECATED] Transaction.refund_id is deprecated. Please use Transaction.refund_ids"
371
- @refund_id
372
- end
373
-
374
- # Deprecated. Use Braintree::Transaction.submit_for_settlement
375
- def submit_for_settlement(amount = nil)
376
- warn "[DEPRECATED] submit_for_settlement as an instance method is deprecated. Please use Transaction.submit_for_settlement"
377
- result = @gateway.transaction.submit_for_settlement(id, amount)
378
- if result.success?
379
- copy_instance_variables_from_object result.transaction
380
- end
381
- result
382
- end
383
-
384
- # Deprecated. Use Braintree::Transaction.submit_for_settlement!
385
- def submit_for_settlement!(amount = nil)
386
- warn "[DEPRECATED] submit_for_settlement! as an instance method is deprecated. Please use Transaction.submit_for_settlement!"
387
- return_object_or_raise(:transaction) { submit_for_settlement(amount) }
388
- end
389
-
390
338
  # If this transaction was stored in the vault, or created from vault records,
391
339
  # vault_billing_address will return the associated Braintree::Address. Because the
392
340
  # vault billing address can be updated after the transaction was created, the attributes
@@ -423,20 +371,8 @@ module Braintree
423
371
  @gateway.address.find(customer_details.id, shipping_details.id)
424
372
  end
425
373
 
426
- # Deprecated. Use Braintree::Transaction.void
427
- def void
428
- warn "[DEPRECATED] void as an instance method is deprecated. Please use Transaction.void"
429
- result = @gateway.transaction.void(id)
430
- if result.success?
431
- copy_instance_variables_from_object result.transaction
432
- end
433
- result
434
- end
435
-
436
- # Deprecated. Use Braintree::Transaction.void!
437
- def void!
438
- warn "[DEPRECATED] void! as an instance method is deprecated. Please use Transaction.void!"
439
- return_object_or_raise(:transaction) { void }
374
+ def processed_with_network_token?
375
+ @processed_with_network_token
440
376
  end
441
377
 
442
378
  class << self
@@ -447,7 +383,7 @@ module Braintree
447
383
  end
448
384
 
449
385
  def self._attributes # :nodoc:
450
- [:amount, :created_at, :credit_card_details, :customer_details, :id, :status, :subscription_details, :type, :updated_at]
386
+ [:amount, :created_at, :credit_card_details, :customer_details, :id, :status, :subscription_details, :type, :updated_at, :processed_with_network_token?]
451
387
  end
452
388
  end
453
389
  end
@@ -3,6 +3,15 @@ module Braintree
3
3
  class AddressDetails # :nodoc:
4
4
  include BaseModule
5
5
 
6
+ module ShippingMethod
7
+ SameDay = "same_day"
8
+ NextDay = "next_day"
9
+ Priority = "priority"
10
+ Ground = "ground"
11
+ Electronic = "electronic"
12
+ ShipToStore = "ship_to_store"
13
+ end
14
+
6
15
  attr_reader :company
7
16
  attr_reader :country_code_alpha2
8
17
  attr_reader :country_code_alpha3
@@ -13,8 +22,10 @@ module Braintree
13
22
  attr_reader :id
14
23
  attr_reader :last_name
15
24
  attr_reader :locality
25
+ attr_reader :phone_number
16
26
  attr_reader :postal_code
17
27
  attr_reader :region
28
+ attr_reader :shipping_method
18
29
  attr_reader :street_address
19
30
 
20
31
  def initialize(attributes)