Class: ActiveMerchant::Billing::SmartPs

Inherits:
Gateway
  • Object
show all
Defined in:
lib/active_merchant/billing/gateways/smart_ps.rb

Overview

:nodoc:

Direct Known Subclasses

BraintreeOrangeGateway, TransaxGateway

Constant Summary

Constant Summary

Constants inherited from Gateway

Gateway::CREDIT_DEPRECATION_MESSAGE, Gateway::CURRENCIES_WITHOUT_FRACTIONS, Gateway::DEBIT_CARDS

Instance Attribute Summary

Attributes inherited from Gateway

#options

Instance Method Summary (collapse)

Methods inherited from Gateway

card_brand, #card_brand, inherited, supports?, #test?

Methods included from CreditCardFormatting

#format

Constructor Details

- (SmartPs) initialize(options = {})

Returns a new instance of SmartPs



12
13
14
15
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 12

def initialize(options = {})
  requires!(options, :login, :password)
  super
end

Instance Method Details

- (Object) amend(auth, options = {})

Amend an existing transaction



95
96
97
98
99
100
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 95

def amend(auth, options = {})
  post = {}
  add_invoice(post, options)
  add_transaction(post, auth)
  commit('update', nil, post)
end

- (Object) authorize(money, creditcard, options = {})

Pass :store => true in the options to store the payment info at the gateway and get a generated customer_vault_id in the response. Pass :store => some_number_or_string to specify the customer_vault_id the gateway should use (make sure it's unique).



23
24
25
26
27
28
29
30
31
32
33
34
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 23

def authorize(money, creditcard, options = {})
  post = {}
  add_invoice(post, options)
  add_payment_source(post, creditcard,options)
  add_address(post, options[:billing_address] || options[:address])
  add_address(post, options[:shipping_address], "shipping")
  add_customer_data(post, options)
  add_currency(post, money, options)
  add_taxes(post, options)
  add_processor(post, options)
  commit('auth', money, post)
end

- (Object) capture(money, authorization, options = {})



49
50
51
52
53
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 49

def capture(money, authorization, options = {})
  post ={}
  post[:transactionid] = authorization
  commit('capture', money, post)
end

- (Object) credit(money, payment_source, options = {})



61
62
63
64
65
66
67
68
69
70
71
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 61

def credit(money, payment_source, options = {})
  post = {}
  add_invoice(post, options)
  add_payment_source(post, payment_source, options)
  add_address(post, options[:billing_address] || options[:address])
  add_customer_data(post, options)
  add_sku(post,options)
  add_currency(post, money, options)
  add_processor(post, options)
  commit('credit', money, post)
end

- (Object) delete(vault_id) Also known as: unstore



103
104
105
106
107
108
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 103

def delete(vault_id)
  post = {}
  post[:customer_vault] = "delete_customer"
  add_customer_vault_id(post, vault_id)
  commit(nil, nil, post)
end

- (Object) purchase(money, payment_source, options = {})



36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 36

def purchase(money, payment_source, options = {})
  post = {}
  add_invoice(post, options)
  add_payment_source(post, payment_source, options)
  add_address(post, options[:billing_address] || options[:address])
  add_address(post, options[:shipping_address], "shipping")
  add_customer_data(post, options)
  add_currency(post, money, options)
  add_taxes(post, options)
  add_processor(post, options)
  commit('sale', money, post)
end

- (Object) refund(money, auth, options = {})



73
74
75
76
77
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 73

def refund(money, auth, options = {})
  post = {}
  add_transaction(post, auth)
  commit('refund', money, post)
end

- (Object) store(payment_source, options = {})

To match the other stored-value gateways, like TrustCommerce, store and unstore need to be defined



112
113
114
115
116
117
118
119
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 112

def store(payment_source, options = {})
  post = {}
  billing_id = options.delete(:billing_id).to_s || true
  add_payment_source(post, payment_source, :store => billing_id)
  add_address(post, options[:billing_address] || options[:address])
  add_customer_data(post, options)
  commit(nil, nil, post)
end

- (Object) update(vault_id, creditcard, options = {})

Update the values (such as CC expiration) stored at the gateway. The CC number must be supplied in the CreditCard object.



83
84
85
86
87
88
89
90
91
92
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 83

def update(vault_id, creditcard, options = {})
  post = {}
  post[:customer_vault] = "update_customer"
  add_customer_vault_id(post, vault_id)
  add_creditcard(post, creditcard, options)
  add_address(post, options[:billing_address] || options[:address])
  add_customer_data(post, options)

  commit(nil, nil, post)
end

- (Object) void(authorization, options = {})



55
56
57
58
59
# File 'lib/active_merchant/billing/gateways/smart_ps.rb', line 55

def void(authorization, options = {})
  post ={}
  post[:transactionid] = authorization
  commit('void', nil, post)
end