Class: ActiveMerchant::Billing::PinGateway
- Defined in:
- lib/active_merchant/billing/gateways/pin.rb
Constant Summary
Constants inherited from Gateway
Gateway::CREDIT_DEPRECATION_MESSAGE, Gateway::RECURRING_DEPRECATION_MESSAGE, Gateway::STANDARD_ERROR_CODE
Instance Attribute Summary
Attributes inherited from Gateway
Instance Method Summary collapse
-
#authorize(money, creditcard, options = {}) ⇒ Object
Authorize an amount on a credit card.
-
#capture(money, token, options = {}) ⇒ Object
Captures a previously authorized charge.
-
#initialize(options = {}) ⇒ PinGateway
constructor
A new instance of PinGateway.
-
#purchase(money, creditcard, options = {}) ⇒ Object
Create a charge using a credit card, card token or customer token.
-
#refund(money, token, options = {}) ⇒ Object
Refund a transaction.
- #scrub(transcript) ⇒ Object
-
#store(creditcard, options = {}) ⇒ Object
Create a customer and associated credit card.
- #supports_scrubbing ⇒ Object
-
#update(token, creditcard, options = {}) ⇒ Object
Updates the credit card for the customer.
Methods inherited from Gateway
#card_brand, card_brand, #generate_unique_id, inherited, supported_countries, #supported_countries, supported_countries=, supports?, #supports_network_tokenization?, #supports_scrubbing?, #test?
Methods included from CreditCardFormatting
Methods included from PostsData
included, #raw_ssl_request, #ssl_get, #ssl_post, #ssl_request
Constructor Details
#initialize(options = {}) ⇒ PinGateway
Returns a new instance of PinGateway.
14 15 16 17 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 14 def initialize( = {}) requires!(, :api_key) super end |
Instance Method Details
#authorize(money, creditcard, options = {}) ⇒ Object
Authorize an amount on a credit card. Once authorized, you can later capture this charge using the charge token that is returned.
55 56 57 58 59 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 55 def (money, creditcard, = {}) [:capture] = false purchase(money, creditcard, ) end |
#capture(money, token, options = {}) ⇒ Object
Captures a previously authorized charge. Capturing only part of the original authorization is currently not supported.
63 64 65 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 63 def capture(money, token, = {}) commit(:put, "charges/#{CGI.escape(token)}/capture", { :amount => amount(money) }, ) end |
#purchase(money, creditcard, options = {}) ⇒ Object
23 24 25 26 27 28 29 30 31 32 33 34 35 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 23 def purchase(money, creditcard, = {}) post = {} add_amount(post, money, ) add_customer_data(post, ) add_invoice(post, ) add_creditcard(post, creditcard) add_address(post, creditcard, ) add_capture(post, ) (post, ) commit(:post, 'charges', post, ) end |
#refund(money, token, options = {}) ⇒ Object
Refund a transaction
49 50 51 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 49 def refund(money, token, = {}) commit(:post, "charges/#{CGI.escape(token)}/refunds", { :amount => amount(money) }, ) end |
#scrub(transcript) ⇒ Object
81 82 83 84 85 86 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 81 def scrub(transcript) transcript. gsub(%r((Authorization: Basic )\w+), '\1[FILTERED]'). gsub(/(number\\?":\\?")(\d*)/, '\1[FILTERED]'). gsub(/(cvc\\?":\\?")(\d*)/, '\1[FILTERED]') end |
#store(creditcard, options = {}) ⇒ Object
Create a customer and associated credit card. The token that is returned can be used instead of a credit card parameter in the purchase method
39 40 41 42 43 44 45 46 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 39 def store(creditcard, = {}) post = {} add_creditcard(post, creditcard) add_customer_data(post, ) add_address(post, creditcard, ) commit(:post, 'customers', post, ) end |
#supports_scrubbing ⇒ Object
77 78 79 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 77 def supports_scrubbing true end |
#update(token, creditcard, options = {}) ⇒ Object
Updates the credit card for the customer.
68 69 70 71 72 73 74 75 |
# File 'lib/active_merchant/billing/gateways/pin.rb', line 68 def update(token, creditcard, = {}) post = {} add_creditcard(post, creditcard) add_customer_data(post, ) add_address(post, creditcard, ) commit(:put, "customers/#{CGI.escape(token)}", post, ) end |