Class: ActiveMerchant::Billing::FatZebraGateway

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

Constant Summary

Constants inherited from Gateway

Gateway::CREDIT_DEPRECATION_MESSAGE, Gateway::CURRENCIES_WITHOUT_FRACTIONS, Gateway::DEBIT_CARDS, Gateway::RECURRING_DEPRECATION_MESSAGE, Gateway::STANDARD_ERROR_CODE

Instance Attribute Summary

Attributes inherited from Gateway

#options

Instance Method Summary collapse

Methods inherited from Gateway

#card_brand, card_brand, #generate_unique_id, inherited, non_fractional_currency?, #scrub, supported_countries, #supported_countries, supported_countries=, supports?, #supports_scrubbing?, #test?

Methods included from CreditCardFormatting

#expdate, #format

Methods included from PostsData

included, #raw_ssl_request, #ssl_get, #ssl_post, #ssl_request

Constructor Details

#initialize(options = {}) ⇒ FatZebraGateway

Setup a new instance of the gateway.

The options hash should include :username and :token You can find your username and token at dashboard.fatzebra.com.au Under the Your Account section



22
23
24
25
26
27
# File 'lib/active_merchant/billing/gateways/fat_zebra.rb', line 22

def initialize(options = {})
  requires!(options, :username, :token)
  @username = options[:username]
  @token    = options[:token]
  super
end

Instance Method Details

#purchase(money, creditcard, options = {}) ⇒ Object

To create a purchase on a credit card use:

purchase(money, creditcard)

To charge a tokenized card

purchase(money, "abzy87u", :cvv => "123")


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

def purchase(money, creditcard, options = {})
  post = {}

  add_amount(post, money, options)
  add_creditcard(post, creditcard, options)
  post[:reference] = options[:order_id]
  post[:customer_ip] = options[:ip]

  commit(:post, 'purchases', post)
end

#refund(money, txn_id, reference) ⇒ Object

Refund a transaction

amount - Integer - the amount to refund txn_id - String - the original transaction to be refunded reference - String - your transaction reference



52
53
54
55
56
57
58
59
60
# File 'lib/active_merchant/billing/gateways/fat_zebra.rb', line 52

def refund(money, txn_id, reference)
  post = {}

  post[:amount] = money
  post[:transaction_id] = txn_id
  post[:reference] = reference

  commit(:post, "refunds", post)
end

#store(creditcard) ⇒ Object

Tokenize a credit card

The token is returned in the Response#authorization



65
66
67
68
69
70
# File 'lib/active_merchant/billing/gateways/fat_zebra.rb', line 65

def store(creditcard)
  post = {}
  add_creditcard(post, creditcard)

  commit(:post, "credit_cards", post)
end