Class: Braintree::TransactionGateway
- Inherits:
-
Object
- Object
- Braintree::TransactionGateway
- Includes:
- BaseModule
- Defined in:
- lib/braintree/transaction_gateway.rb
Class Method Summary collapse
- ._adjust_authorization_signature ⇒ Object
- ._clone_signature ⇒ Object
-
._create_signature ⇒ Object
NEXT_MAJOR_VERSION Remove venmo_sdk_payment_method_code, venmo_sdk_session, and three_d_secure_token The old venmo SDK class has been deprecated three_d_secure_token has been deprecated in favor of three_d_secure_authentication_id.
- ._package_tracking_request_signature ⇒ Object
- ._refund_signature ⇒ Object
- ._submit_for_partial_settlement_signature ⇒ Object
- ._submit_for_settlement_signature ⇒ Object
- ._update_details_signature ⇒ Object
Instance Method Summary collapse
- #_do_create(path, params = nil) ⇒ Object
- #_fetch_transactions(search, ids) ⇒ Object
- #_handle_transaction_response(response) ⇒ Object
- #adjust_authorization(transaction_id, amount) ⇒ Object
- #adjust_authorization!(*args) ⇒ Object
- #cancel_release(transaction_id) ⇒ Object
- #cancel_release!(*args) ⇒ Object
- #clone_transaction(transaction_id, attributes) ⇒ Object
- #clone_transaction!(*args) ⇒ Object
- #create(attributes) ⇒ Object
- #credit(attributes) ⇒ Object
- #credit!(*args) ⇒ Object
- #find(id) ⇒ Object
- #hold_in_escrow(transaction_id) ⇒ Object
- #hold_in_escrow!(*args) ⇒ Object
-
#initialize(gateway) ⇒ TransactionGateway
constructor
A new instance of TransactionGateway.
- #package_tracking(transaction_id, package_tracking_request) ⇒ Object
- #package_tracking!(*args) ⇒ Object
- #refund(transaction_id, amount_or_options = nil) ⇒ Object
- #refund!(*args) ⇒ Object
- #release_from_escrow(transaction_id) ⇒ Object
- #release_from_escrow!(*args) ⇒ Object
- #retry_subscription_charge(subscription_id, amount = nil, submit_for_settlement = false) ⇒ Object
- #sale(attributes) ⇒ Object
- #sale!(*args) ⇒ Object
- #search(&block) ⇒ Object
- #submit_for_partial_settlement(authorized_transaction_id, amount = nil, options = {}) ⇒ Object
- #submit_for_partial_settlement!(*args) ⇒ Object
- #submit_for_settlement(transaction_id, amount = nil, options = {}) ⇒ Object
- #submit_for_settlement!(*args) ⇒ Object
- #update_details(transaction_id, options = {}) ⇒ Object
- #void(transaction_id) ⇒ Object
- #void!(*args) ⇒ Object
Methods included from BaseModule
Methods included from BaseModule::Methods
#copy_instance_variables_from_object, #return_object_or_raise, #set_instance_variables_from_hash, #singleton_class
Constructor Details
#initialize(gateway) ⇒ TransactionGateway
Returns a new instance of TransactionGateway.
5 6 7 8 9 |
# File 'lib/braintree/transaction_gateway.rb', line 5 def initialize(gateway) @gateway = gateway @config = gateway.config @config.assert_has_access_token_or_keys end |
Class Method Details
._adjust_authorization_signature ⇒ Object
333 334 335 336 337 |
# File 'lib/braintree/transaction_gateway.rb', line 333 def self. [ :amount ] end |
._clone_signature ⇒ Object
208 209 210 |
# File 'lib/braintree/transaction_gateway.rb', line 208 def self._clone_signature [:amount, :channel, {:options => [:submit_for_settlement]}] end |
._create_signature ⇒ Object
NEXT_MAJOR_VERSION Remove venmo_sdk_payment_method_code, venmo_sdk_session, and three_d_secure_token The old venmo SDK class has been deprecated three_d_secure_token has been deprecated in favor of three_d_secure_authentication_id
215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 |
# File 'lib/braintree/transaction_gateway.rb', line 215 def self._create_signature [ :amount, :billing_address_id, :channel, :currency_iso_code, :customer_id, :device_data, :discount_amount, :exchange_rate_quote_id, :foreign_retailer, :merchant_account_id, :order_id, :payment_method_nonce, :payment_method_token, :product_sku, :purchase_order_number, :service_fee_amount, :shared_billing_address_id, :shared_customer_id, :shared_payment_method_nonce, :shared_payment_method_token, :shared_shipping_address_id, :shipping_address_id, :shipping_amount, :shipping_tax_amount, :ships_from_postal_code, :tax_amount, :tax_exempt, :three_d_secure_authentication_id,:three_d_secure_token, #Deprecated :transaction_source, :type, :venmo_sdk_payment_method_code, # Deprecated :sca_exemption, {:apple_pay_card => [:number, :cardholder_name, :cryptogram, :expiration_month, :expiration_year, :eci_indicator]}, { :billing => AddressGateway._shared_signature }, {:credit_card => [:token, :cardholder_name, :cvv, :expiration_date, :expiration_month, :expiration_year, :number, {:payment_reader_card_details => [:encrypted_card_data, :key_serial_number]}, {:network_tokenization_attributes => [:cryptogram, :ecommerce_indicator, :token_requestor_id]}]}, {:customer => [:id, :company, :email, :fax, :first_name, :last_name, :phone, :website]}, {:custom_fields => :_any_key_}, {:descriptor => [:name, :phone, :url]}, {:external_vault => [ :status, :previous_network_transaction_id, ]}, {:google_pay_card => [:number, :cryptogram, :google_transaction_id, :expiration_month, :expiration_year, :source_card_type, :source_card_last_four, :eci_indicator]}, {:industry => [ :industry_type, {:data => [ :country_code, :date_of_birth, :folio_number, :check_in_date, :check_out_date, :travel_package, :lodging_check_in_date, :lodging_check_out_date, :departure_date, :lodging_name, :room_rate, :room_tax, :passenger_first_name, :passenger_last_name, :passenger_middle_initial, :passenger_title, :issued_date, :travel_agency_name, :travel_agency_code, :ticket_number, :issuing_carrier_code, :customer_code, :fare_amount, :fee_amount, :tax_amount, :restricted_ticket, :no_show, :advanced_deposit, :fire_safe, :property_phone, :ticket_issuer_address, :arrival_date, {:legs => [ :conjunction_ticket, :exchange_ticket, :coupon_number, :service_class, :carrier_code, :fare_basis_code, :flight_number, :departure_date, :departure_airport_code, :departure_time, :arrival_airport_code, :arrival_time, :stopover_permitted, :fare_amount, :fee_amount, :tax_amount, :endorsement_or_restrictions, ]}, {:additional_charges => [ :kind, :amount, ]}, ]}, ]}, {:installments => [:count]}, {:line_items => [:commodity_code, :description, :discount_amount, :image_url, :kind, :name, :product_code, :quantity, :tax_amount, :total_amount, :unit_amount, :unit_of_measure, :unit_tax_amount, :upc_code, :upc_type, :url]}, {:options => [ :hold_in_escrow, :store_in_vault, :store_in_vault_on_success, :submit_for_settlement, :add_billing_address_to_payment_method, :store_shipping_address_in_vault, :venmo_sdk_session, # Deprecated :payee_id, :payee_email, :skip_advanced_fraud_checking, :skip_avs, :skip_cvv, {:paypal => [:custom_field, :payee_id, :payee_email, :description, {:supplementary_data => :_any_key_}]}, {:processing_overrides => [:customer_email, :customer_first_name, :customer_last_name, :customer_tax_identifier]}, {:three_d_secure => [:required]}, {:amex_rewards => [:request_id, :points, :currency_amount, :currency_iso_code]}, {:venmo => [:profile_id]}, {:credit_card => [:account_type, :process_debit_as_credit]}, ] }, {:paypal_account => [:email, :token, :paypal_data, :payee_id, :payee_email, :payer_id, :payment_id]}, {:risk_data => [:customer_browser, :customer_device_id, :customer_ip, :customer_location_zip, :customer_tenure]}, { :shipping => AddressGateway._shared_signature + [:shipping_method], }, { :three_d_secure_pass_thru => [ :eci_flag, :cavv, :xid, :three_d_secure_version, :authentication_response, :directory_response, :cavv_algorithm, :ds_transaction_id, ] }, ] end |
._package_tracking_request_signature ⇒ Object
200 201 202 203 204 205 206 |
# File 'lib/braintree/transaction_gateway.rb', line 200 def self._package_tracking_request_signature [ :carrier, {:line_items => [:commodity_code, :description, :discount_amount, :image_url, :kind, :name, :product_code, :quantity, :tax_amount, :total_amount, :unit_amount, :unit_of_measure, :unit_tax_amount, :upc_code, :upc_type, :url]}, :notify_payer, :tracking_number, ] end |
._refund_signature ⇒ Object
347 348 349 350 351 352 353 |
# File 'lib/braintree/transaction_gateway.rb', line 347 def self._refund_signature [ :amount, :merchant_account_id, :order_id, ] end |
._submit_for_partial_settlement_signature ⇒ Object
327 328 329 330 331 |
# File 'lib/braintree/transaction_gateway.rb', line 327 def self._submit_for_partial_settlement_signature _submit_for_settlement_signature + [ :final_capture ] end |
._submit_for_settlement_signature ⇒ Object
297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 |
# File 'lib/braintree/transaction_gateway.rb', line 297 def self._submit_for_settlement_signature [ :order_id, {:descriptor => [:name, :phone, :url]}, {:industry => [ :industry_type, {:data => [ :country_code, :date_of_birth, :folio_number, :check_in_date, :check_out_date, :travel_package, :lodging_check_in_date, :lodging_check_out_date, :departure_date, :lodging_name, :room_rate, :room_tax, :passenger_first_name, :passenger_last_name, :passenger_middle_initial, :passenger_title, :issued_date, :travel_agency_name, :travel_agency_code, :ticket_number, :issuing_carrier_code, :customer_code, :fare_amount, :fee_amount, :tax_amount, :restricted_ticket, :no_show, :advanced_deposit, :fire_safe, :property_phone, :ticket_issuer_address, :arrival_date, {:legs => [ :conjunction_ticket, :exchange_ticket, :coupon_number, :service_class, :carrier_code, :fare_basis_code, :flight_number, :departure_date, :departure_airport_code, :departure_time, :arrival_airport_code, :arrival_time, :stopover_permitted, :fare_amount, :fee_amount, :tax_amount, :endorsement_or_restrictions, ]}, {:additional_charges => [ :kind, :amount, ]}, ]}, ]}, :purchase_order_number, :tax_amount, :tax_exempt, :discount_amount, :shipping_amount, :shipping_tax_amount, :ships_from_postal_code, :line_items => [:commodity_code, :description, :discount_amount, :image_url, :kind, :name, :product_code, :quantity, :tax_amount, :total_amount, :unit_amount, :unit_of_measure, :unit_tax_amount, :upc_code, :upc_type, :url], ] end |
._update_details_signature ⇒ Object
339 340 341 342 343 344 345 |
# File 'lib/braintree/transaction_gateway.rb', line 339 def self._update_details_signature [ :amount, :order_id, {:descriptor => [:name, :phone, :url]}, ] end |
Instance Method Details
#_do_create(path, params = nil) ⇒ Object
355 356 357 358 359 360 361 |
# File 'lib/braintree/transaction_gateway.rb', line 355 def _do_create(path, params=nil) if !params.nil? params = Util.replace_key(params, :google_pay_card, :android_pay_card) end response = @config.http.post("#{@config.base_merchant_path}#{path}", params) _handle_transaction_response(response) end |
#_fetch_transactions(search, ids) ⇒ Object
363 364 365 366 367 368 |
# File 'lib/braintree/transaction_gateway.rb', line 363 def _fetch_transactions(search, ids) search.ids.in ids response = @config.http.post("#{@config.base_merchant_path}/transactions/advanced_search", {:search => search.to_hash}) attributes = response[:credit_card_transactions] Util.extract_attribute_as_array(attributes, :transaction).map { |attrs| Transaction._new(@gateway, attrs) } end |
#_handle_transaction_response(response) ⇒ Object
44 45 46 47 48 49 50 51 52 |
# File 'lib/braintree/transaction_gateway.rb', line 44 def _handle_transaction_response(response) if response[:transaction] SuccessfulResult.new(:transaction => Transaction._new(@gateway, response[:transaction])) elsif response[:api_error_response] ErrorResult.new(@gateway, response[:api_error_response]) else raise UnexpectedError, "expected :transaction or :response" end end |
#adjust_authorization(transaction_id, amount) ⇒ Object
160 161 162 163 164 165 166 |
# File 'lib/braintree/transaction_gateway.rb', line 160 def (transaction_id, amount) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ Util.verify_keys(TransactionGateway., {}) transaction_params = {:amount => amount} response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/adjust_authorization", :transaction => transaction_params) _handle_transaction_response(response) end |
#adjust_authorization!(*args) ⇒ Object
168 169 170 |
# File 'lib/braintree/transaction_gateway.rb', line 168 def (*args) return_object_or_raise(:transaction) { (*args) } end |
#cancel_release(transaction_id) ⇒ Object
24 25 26 27 28 |
# File 'lib/braintree/transaction_gateway.rb', line 24 def cancel_release(transaction_id) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/cancel_release") _handle_transaction_response(response) end |
#cancel_release!(*args) ⇒ Object
30 31 32 |
# File 'lib/braintree/transaction_gateway.rb', line 30 def cancel_release!(*args) return_object_or_raise(:transaction) { cancel_release(*args) } end |
#clone_transaction(transaction_id, attributes) ⇒ Object
54 55 56 57 |
# File 'lib/braintree/transaction_gateway.rb', line 54 def clone_transaction(transaction_id, attributes) Util.verify_keys(TransactionGateway._clone_signature, attributes) _do_create "/transactions/#{transaction_id}/clone", :transaction_clone => attributes end |
#clone_transaction!(*args) ⇒ Object
59 60 61 |
# File 'lib/braintree/transaction_gateway.rb', line 59 def clone_transaction!(*args) return_object_or_raise(:transaction) { clone_transaction(*args) } end |
#create(attributes) ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 |
# File 'lib/braintree/transaction_gateway.rb', line 11 def create(attributes) # NEXT_MAJOR_VERSION remove this check if attributes.has_key?(:venmo_sdk_payment_method_code) || attributes.has_key?(:venmo_sdk_session) warn "[DEPRECATED] The Venmo SDK integration is Unsupported. Please update your integration to use Pay with Venmo instead." end # NEXT_MAJOR_VERSION remove this check if attributes.has_key?(:three_d_secure_token) warn "[DEPRECATED] Passing :three_d_secure_token to create is deprecated. Please use :three_d_secure_authentication_id" end Util.verify_keys(TransactionGateway._create_signature, attributes) _do_create "/transactions", :transaction => attributes end |
#credit(attributes) ⇒ Object
63 64 65 |
# File 'lib/braintree/transaction_gateway.rb', line 63 def credit(attributes) create(attributes.merge(:type => "credit")) end |
#credit!(*args) ⇒ Object
67 68 69 |
# File 'lib/braintree/transaction_gateway.rb', line 67 def credit!(*args) return_object_or_raise(:transaction) { credit(*args) } end |
#find(id) ⇒ Object
71 72 73 74 75 76 77 |
# File 'lib/braintree/transaction_gateway.rb', line 71 def find(id) raise ArgumentError, "id can not be empty" if id.nil? || id.strip.to_s == "" response = @config.http.get("#{@config.base_merchant_path}/transactions/#{id}") Transaction._new(@gateway, response[:transaction]) rescue NotFoundError raise NotFoundError, "transaction with id #{id.inspect} not found" end |
#hold_in_escrow(transaction_id) ⇒ Object
34 35 36 37 38 |
# File 'lib/braintree/transaction_gateway.rb', line 34 def hold_in_escrow(transaction_id) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/hold_in_escrow") _handle_transaction_response(response) end |
#hold_in_escrow!(*args) ⇒ Object
40 41 42 |
# File 'lib/braintree/transaction_gateway.rb', line 40 def hold_in_escrow!(*args) return_object_or_raise(:transaction) { hold_in_escrow(*args) } end |
#package_tracking(transaction_id, package_tracking_request) ⇒ Object
115 116 117 118 119 |
# File 'lib/braintree/transaction_gateway.rb', line 115 def package_tracking(transaction_id, package_tracking_request) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ Util.verify_keys(TransactionGateway._package_tracking_request_signature, package_tracking_request) _do_create "/transactions/#{transaction_id}/shipments", :shipment => package_tracking_request end |
#package_tracking!(*args) ⇒ Object
121 122 123 |
# File 'lib/braintree/transaction_gateway.rb', line 121 def package_tracking!(*args) return_object_or_raise(:transaction) { package_tracking(*args) } end |
#refund(transaction_id, amount_or_options = nil) ⇒ Object
79 80 81 82 83 84 85 86 87 88 89 |
# File 'lib/braintree/transaction_gateway.rb', line 79 def refund(transaction_id, = nil) = if .is_a?(Hash) else {:amount => } end Util.verify_keys(TransactionGateway._refund_signature, ) response = @config.http.post("#{@config.base_merchant_path}/transactions/#{transaction_id}/refund", :transaction => ) _handle_transaction_response(response) end |
#refund!(*args) ⇒ Object
91 92 93 |
# File 'lib/braintree/transaction_gateway.rb', line 91 def refund!(*args) return_object_or_raise(:transaction) { refund(*args) } end |
#release_from_escrow(transaction_id) ⇒ Object
138 139 140 141 142 |
# File 'lib/braintree/transaction_gateway.rb', line 138 def release_from_escrow(transaction_id) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/release_from_escrow") _handle_transaction_response(response) end |
#release_from_escrow!(*args) ⇒ Object
144 145 146 |
# File 'lib/braintree/transaction_gateway.rb', line 144 def release_from_escrow!(*args) return_object_or_raise(:transaction) { release_from_escrow(*args) } end |
#retry_subscription_charge(subscription_id, amount = nil, submit_for_settlement = false) ⇒ Object
95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/braintree/transaction_gateway.rb', line 95 def retry_subscription_charge(subscription_id, amount=nil, submit_for_settlement=false) attributes = { :amount => amount, :subscription_id => subscription_id, :type => Transaction::Type::Sale, :options => { :submit_for_settlement => submit_for_settlement } } _do_create "/transactions", :transaction => attributes end |
#sale(attributes) ⇒ Object
107 108 109 |
# File 'lib/braintree/transaction_gateway.rb', line 107 def sale(attributes) create(attributes.merge(:type => "sale")) end |
#sale!(*args) ⇒ Object
111 112 113 |
# File 'lib/braintree/transaction_gateway.rb', line 111 def sale!(*args) return_object_or_raise(:transaction) { sale(*args) } end |
#search(&block) ⇒ Object
125 126 127 128 129 130 131 132 133 134 135 136 |
# File 'lib/braintree/transaction_gateway.rb', line 125 def search(&block) search = TransactionSearch.new block.call(search) if block response = @config.http.post("#{@config.base_merchant_path}/transactions/advanced_search_ids", {:search => search.to_hash}) if response.has_key?(:search_results) ResourceCollection.new(response) { |ids| _fetch_transactions(search, ids) } else raise UnexpectedError, "expected :search_results" end end |
#submit_for_partial_settlement(authorized_transaction_id, amount = nil, options = {}) ⇒ Object
179 180 181 182 183 184 185 |
# File 'lib/braintree/transaction_gateway.rb', line 179 def submit_for_partial_settlement(, amount = nil, = {}) raise ArgumentError, "authorized_transaction_id is invalid" unless =~ /\A[0-9a-z]+\z/ Util.verify_keys(TransactionGateway._submit_for_partial_settlement_signature, ) transaction_params = {:amount => amount}.merge() response = @config.http.post("#{@config.base_merchant_path}/transactions/#{}/submit_for_partial_settlement", :transaction => transaction_params) _handle_transaction_response(response) end |
#submit_for_partial_settlement!(*args) ⇒ Object
187 188 189 |
# File 'lib/braintree/transaction_gateway.rb', line 187 def submit_for_partial_settlement!(*args) return_object_or_raise(:transaction) { submit_for_partial_settlement(*args) } end |
#submit_for_settlement(transaction_id, amount = nil, options = {}) ⇒ Object
148 149 150 151 152 153 154 |
# File 'lib/braintree/transaction_gateway.rb', line 148 def submit_for_settlement(transaction_id, amount = nil, = {}) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ Util.verify_keys(TransactionGateway._submit_for_settlement_signature, ) transaction_params = {:amount => amount}.merge() response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/submit_for_settlement", :transaction => transaction_params) _handle_transaction_response(response) end |
#submit_for_settlement!(*args) ⇒ Object
156 157 158 |
# File 'lib/braintree/transaction_gateway.rb', line 156 def submit_for_settlement!(*args) return_object_or_raise(:transaction) { submit_for_settlement(*args) } end |
#update_details(transaction_id, options = {}) ⇒ Object
172 173 174 175 176 177 |
# File 'lib/braintree/transaction_gateway.rb', line 172 def update_details(transaction_id, = {}) raise ArgumentError, "transaction_id is invalid" unless transaction_id =~ /\A[0-9a-z]+\z/ Util.verify_keys(TransactionGateway._update_details_signature, ) response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/update_details", :transaction => ) _handle_transaction_response(response) end |
#void(transaction_id) ⇒ Object
191 192 193 194 |
# File 'lib/braintree/transaction_gateway.rb', line 191 def void(transaction_id) response = @config.http.put("#{@config.base_merchant_path}/transactions/#{transaction_id}/void") _handle_transaction_response(response) end |
#void!(*args) ⇒ Object
196 197 198 |
# File 'lib/braintree/transaction_gateway.rb', line 196 def void!(*args) return_object_or_raise(:transaction) { void(*args) } end |