module Braintree class Transaction include BaseModule include Braintree::Util::IdEquality module CreatedUsing FullInformation = 'full_information' Token = 'token' Unrecognized = 'unrecognized' end module EscrowStatus HoldPending = 'hold_pending' Held = 'held' ReleasePending = 'release_pending' Released = 'released' Refunded = 'refunded' Unrecognized = 'unrecognized' end module GatewayRejectionReason ApplicationIncomplete = "application_incomplete" AVS = "avs" AVSAndCVV = "avs_and_cvv" CVV = "cvv" Duplicate = "duplicate" Fraud = "fraud" ThreeDSecure = "three_d_secure" TokenIssuance = "token_issuance" Unrecognized = "unrecognized" end module Status AuthorizationExpired = 'authorization_expired' Authorizing = 'authorizing' Authorized = 'authorized' GatewayRejected = 'gateway_rejected' Failed = 'failed' ProcessorDeclined = 'processor_declined' Settled = 'settled' SettlementConfirmed = 'settlement_confirmed' SettlementDeclined = 'settlement_declined' SettlementPending = 'settlement_pending' Settling = 'settling' SubmittedForSettlement = 'submitted_for_settlement' Voided = 'voided' Unrecognized = 'unrecognized' All = constants.map { |c| const_get(c) } end module Source Api = "api" ControlPanel = "control_panel" Recurring = "recurring" Unrecognized = "unrecognized" end module IndustryType Lodging = "lodging" TravelAndCruise = "travel_cruise" TravelAndFlight = "travel_flight" All = constants.map { |c| const_get(c) } end module Type # :nodoc: Credit = "credit" # :nodoc: Sale = "sale" # :nodoc: All = constants.map { |c| const_get(c) } end module ExternalVault module Status WillVault = "will_vault" Vaulted = "vaulted" end end attr_reader :add_ons attr_reader :additional_processor_response # The raw response from the processor. attr_reader :amex_express_checkout_details attr_reader :amount attr_reader :android_pay_details attr_reader :apple_pay_details attr_reader :authorization_adjustments attr_reader :authorization_expires_at attr_reader :authorized_transaction_id attr_reader :avs_error_response_code attr_reader :avs_postal_code_response_code attr_reader :avs_street_address_response_code attr_reader :billing_details attr_reader :channel attr_reader :coinbase_details attr_reader :created_at attr_reader :credit_card_details attr_reader :currency_iso_code attr_reader :custom_fields attr_reader :customer_details attr_reader :cvv_response_code attr_reader :descriptor attr_reader :disbursement_details attr_reader :discount_amount attr_reader :discounts attr_reader :disputes attr_reader :escrow_status attr_reader :facilitated_details attr_reader :facilitator_details attr_reader :gateway_rejection_reason attr_reader :id # NEXT_MAJOR_VERSION Remove this class as legacy Ideal has been removed/disabled in the Braintree Gateway # DEPRECATED If you're looking to accept iDEAL as a payment method contact accounts@braintreepayments.com for a solution. attr_reader :ideal_payment_details attr_reader :local_payment_details attr_reader :masterpass_card_details attr_reader :merchant_account_id attr_reader :network_transaction_id attr_reader :order_id attr_reader :partial_settlement_transaction_ids attr_reader :payment_instrument_type attr_reader :paypal_details attr_reader :plan_id attr_reader :processor_authorization_code # Authorization code from the processor. attr_reader :processor_response_code # Response code from the processor. attr_reader :processor_response_text # Response text from the processor. attr_reader :processor_response_type # Response type from the processor. attr_reader :processor_settlement_response_code # Settlement response code from the processor. attr_reader :processor_settlement_response_text # Settlement response text from the processor. attr_reader :purchase_order_number attr_reader :recurring attr_reader :refund_ids attr_reader :refunded_transaction_id attr_reader :risk_data attr_reader :samsung_pay_card_details attr_reader :service_fee_amount attr_reader :settlement_batch_id attr_reader :shipping_amount attr_reader :shipping_details attr_reader :ships_from_postal_code attr_reader :status # See Transaction::Status attr_reader :status_history attr_reader :subscription_details attr_reader :subscription_id attr_reader :tax_amount attr_reader :tax_exempt attr_reader :three_d_secure_info attr_reader :type # Will either be "sale" or "credit" attr_reader :updated_at attr_reader :us_bank_account_details attr_reader :venmo_account_details attr_reader :visa_checkout_card_details attr_reader :voice_referral_number def self.create(*args) Configuration.gateway.transaction.create(*args) end def self.create!(*args) return_object_or_raise(:transaction) { create(*args) } end def self.cancel_release(*args) Configuration.gateway.transaction.cancel_release(*args) end def self.cancel_release!(*args) Configuration.gateway.transaction.cancel_release!(*args) end def self.clone_transaction(*args) Configuration.gateway.transaction.clone_transaction(*args) end def self.clone_transaction!(*args) Configuration.gateway.transaction.clone_transaction!(*args) end # Deprecated. Use Braintree::TransparentRedirect.confirm def self.create_from_transparent_redirect(*args) warn "[DEPRECATED] Transaction.create_from_transparent_redirect is deprecated. Please use TransparentRedirect.confirm" Configuration.gateway.transaction.create_from_transparent_redirect(*args) end # Deprecated. Use Braintree::TransparentRedirect.url def self.create_transaction_url warn "[DEPRECATED] Transaction.create_transaction_url is deprecated. Please use TransparentRedirect.url" Configuration.gateway.transaction.create_transaction_url end def self.credit(*args) Configuration.gateway.transaction.credit(*args) end def self.credit!(*args) Configuration.gateway.transaction.credit!(*args) end def self.find(*args) Configuration.gateway.transaction.find(*args) end def self.line_items(*args) Configuration.gateway.transaction_line_item.find_all(*args) end def self.hold_in_escrow(*args) Configuration.gateway.transaction.hold_in_escrow(*args) end def self.hold_in_escrow!(*args) Configuration.gateway.transaction.hold_in_escrow!(*args) end def self.refund(*args) Configuration.gateway.transaction.refund(*args) end def self.refund!(*args) Configuration.gateway.transaction.refund!(*args) end def self.sale(*args) Configuration.gateway.transaction.sale(*args) end def self.sale!(*args) Configuration.gateway.transaction.sale!(*args) end def self.search(&block) Configuration.gateway.transaction.search(&block) end def self.release_from_escrow(*args) Configuration.gateway.transaction.release_from_escrow(*args) end def self.release_from_escrow!(*args) Configuration.gateway.transaction.release_from_escrow!(*args) end def self.submit_for_settlement(*args) Configuration.gateway.transaction.submit_for_settlement(*args) end def self.submit_for_settlement!(*args) Configuration.gateway.transaction.submit_for_settlement!(*args) end def self.update_details(*args) Configuration.gateway.transaction.update_details(*args) end def self.update_details!(*args) return_object_or_raise(:transaction) { update_details(*args) } end def self.submit_for_partial_settlement(*args) Configuration.gateway.transaction.submit_for_partial_settlement(*args) end def self.submit_for_partial_settlement!(*args) Configuration.gateway.transaction.submit_for_partial_settlement!(*args) end def self.void(*args) Configuration.gateway.transaction.void(*args) end def self.void!(*args) Configuration.gateway.transaction.void!(*args) end def initialize(gateway, attributes) # :nodoc: @gateway = gateway set_instance_variables_from_hash(attributes) @amount = Util.to_big_decimal(amount) @credit_card_details = CreditCardDetails.new(@credit_card) @service_fee_amount = Util.to_big_decimal(service_fee_amount) @subscription_details = SubscriptionDetails.new(@subscription) @customer_details = CustomerDetails.new(@customer) @billing_details = AddressDetails.new(@billing) @disbursement_details = DisbursementDetails.new(@disbursement_details) @shipping_details = AddressDetails.new(@shipping) @status_history = attributes[:status_history] ? attributes[:status_history].map { |s| StatusDetails.new(s) } : [] @tax_amount = Util.to_big_decimal(tax_amount) @descriptor = Descriptor.new(@descriptor) @local_payment_details = LocalPaymentDetails.new(@local_payment) @paypal_details = PayPalDetails.new(@paypal) @apple_pay_details = ApplePayDetails.new(@apple_pay) @android_pay_details = AndroidPayDetails.new(@android_pay_card) @amex_express_checkout_details = AmexExpressCheckoutDetails.new(@amex_express_checkout_card) @venmo_account_details = VenmoAccountDetails.new(@venmo_account) @coinbase_details = CoinbaseDetails.new(@coinbase_account) disputes.map! { |attrs| Dispute._new(attrs) } if disputes @custom_fields = attributes[:custom_fields].is_a?(Hash) ? attributes[:custom_fields] : {} add_ons.map! { |attrs| AddOn._new(attrs) } if add_ons discounts.map! { |attrs| Discount._new(attrs) } if discounts @payment_instrument_type = attributes[:payment_instrument_type] @risk_data = RiskData.new(attributes[:risk_data]) if attributes[:risk_data] @facilitated_details = FacilitatedDetails.new(attributes[:facilitated_details]) if attributes[:facilitated_details] @facilitator_details = FacilitatorDetails.new(attributes[:facilitator_details]) if attributes[:facilitator_details] @three_d_secure_info = ThreeDSecureInfo.new(attributes[:three_d_secure_info]) if attributes[:three_d_secure_info] @us_bank_account_details = UsBankAccountDetails.new(attributes[:us_bank_account]) if attributes[:us_bank_account] @ideal_payment_details = IdealPaymentDetails.new(attributes[:ideal_payment]) if attributes[:ideal_payment] @visa_checkout_card_details = VisaCheckoutCardDetails.new(attributes[:visa_checkout_card]) @masterpass_card_details = MasterpassCardDetails.new(attributes[:masterpass_card]) @samsung_pay_card_details = SamsungPayCardDetails.new(attributes[:samsung_pay_card]) authorization_adjustments.map! { |attrs| AuthorizationAdjustment._new(attrs) } if authorization_adjustments end def inspect # :nodoc: first = [:id, :type, :amount, :status] order = first + (self.class._attributes - first) nice_attributes = order.map do |attr| if attr == :amount Util.inspect_amount(self.amount) else "#{attr}: #{send(attr).inspect}" end end "#<#{self.class} #{nice_attributes.join(', ')}>" end def line_items @gateway.transaction_line_item.find_all(id) end # Deprecated. Use Braintree::Transaction.refund def refund(amount = nil) warn "[DEPRECATED] refund as an instance method is deprecated. Please use Transaction.refund" result = @gateway.transaction.refund(id, amount) if result.success? SuccessfulResult.new(:new_transaction => result.transaction) else result end end # Returns true if the transaction has been refunded. False otherwise. def refunded? !@refund_id.nil? end # Returns true if the transaction has been disbursed. False otherwise. def disbursed? @disbursement_details.valid? end def refund_id warn "[DEPRECATED] Transaction.refund_id is deprecated. Please use Transaction.refund_ids" @refund_id end # Deprecated. Use Braintree::Transaction.submit_for_settlement def submit_for_settlement(amount = nil) warn "[DEPRECATED] submit_for_settlement as an instance method is deprecated. Please use Transaction.submit_for_settlement" result = @gateway.transaction.submit_for_settlement(id, amount) if result.success? copy_instance_variables_from_object result.transaction end result end # Deprecated. Use Braintree::Transaction.submit_for_settlement! def submit_for_settlement!(amount = nil) warn "[DEPRECATED] submit_for_settlement! as an instance method is deprecated. Please use Transaction.submit_for_settlement!" return_object_or_raise(:transaction) { submit_for_settlement(amount) } end # If this transaction was stored in the vault, or created from vault records, # vault_billing_address will return the associated Braintree::Address. Because the # vault billing address can be updated after the transaction was created, the attributes # on vault_billing_address may not match the attributes on billing_details. def vault_billing_address return nil if billing_details.id.nil? @gateway.address.find(customer_details.id, billing_details.id) end # If this transaction was stored in the vault, or created from vault records, # vault_credit_card will return the associated Braintree::CreditCard. Because the # vault credit card can be updated after the transaction was created, the attributes # on vault_credit_card may not match the attributes on credit_card_details. def vault_credit_card return nil if credit_card_details.token.nil? @gateway.credit_card.find(credit_card_details.token) end # If this transaction was stored in the vault, or created from vault records, # vault_customer will return the associated Braintree::Customer. Because the # vault customer can be updated after the transaction was created, the attributes # on vault_customer may not match the attributes on customer_details. def vault_customer return nil if customer_details.id.nil? @gateway.customer.find(customer_details.id) end # If this transaction was stored in the vault, or created from vault records, # vault_shipping_address will return the associated Braintree::Address. Because the # vault shipping address can be updated after the transaction was created, the attributes # on vault_shipping_address may not match the attributes on shipping_details. def vault_shipping_address return nil if shipping_details.id.nil? @gateway.address.find(customer_details.id, shipping_details.id) end # Deprecated. Use Braintree::Transaction.void def void warn "[DEPRECATED] void as an instance method is deprecated. Please use Transaction.void" result = @gateway.transaction.void(id) if result.success? copy_instance_variables_from_object result.transaction end result end # Deprecated. Use Braintree::Transaction.void! def void! warn "[DEPRECATED] void! as an instance method is deprecated. Please use Transaction.void!" return_object_or_raise(:transaction) { void } end class << self protected :new def _new(*args) # :nodoc: self.new *args end end def self._attributes # :nodoc: [:amount, :created_at, :credit_card_details, :customer_details, :id, :status, :subscription_details, :type, :updated_at] end end end