Class: ActiveMerchant::Billing::WirecardGateway
- Defined in:
- lib/active_merchant/billing/gateways/wirecard.rb
Constant Summary collapse
- TEST_URL =
Test server location
'https://c3-test.wirecard.com/secure/ssl-gateway'
- LIVE_URL =
Live server location
'https://c3.wirecard.com/secure/ssl-gateway'
- ENVELOPE_NAMESPACES =
The Namespaces are not really needed, because it just tells the System, that there’s actually no namespace used. It’s just specified here for completeness.
{ 'xmlns:xsi' => 'http://www.w3.org/1999/XMLSchema-instance', 'xsi:noNamespaceSchemaLocation' => 'wirecard.xsd' }
- PERMITTED_TRANSACTIONS =
%w[ AUTHORIZATION CAPTURE_AUTHORIZATION PURCHASE ]
- RETURN_CODES =
%w[ ACK NOK ]
- VALID_PHONE_FORMAT =
Wirecard only allows phone numbers with a format like this: +xxx(yyy)zzz-zzzz-ppp, where:
xxx = Country code yyy = Area or city code zzz-zzzz = Local number ppp = PBX extension
For example, a typical U.S. or Canadian number would be “+1(202)555-1234-739” indicating PBX extension 739 at phone number 5551234 within area code 202 (country code 1).
/\+\d{1,3}(\(?\d{3}\)?)?\d{3}-\d{4}-\d{3}/
Constants inherited from Gateway
Gateway::CREDIT_DEPRECATION_MESSAGE, Gateway::CURRENCIES_WITHOUT_FRACTIONS, Gateway::DEBIT_CARDS
Instance Attribute Summary
Attributes inherited from Gateway
Instance Method Summary collapse
-
#authorize(money, creditcard, options = {}) ⇒ Object
Authorization.
-
#capture(money, authorization, options = {}) ⇒ Object
Capture Authorization.
-
#initialize(options = {}) ⇒ WirecardGateway
constructor
A new instance of WirecardGateway.
-
#purchase(money, creditcard, options = {}) ⇒ Object
Purchase.
-
#test? ⇒ Boolean
Should run against the test servers or not?.
Methods inherited from Gateway
#card_brand, card_brand, inherited, supports?
Methods included from Utils
#deprecated, generate_unique_id
Methods included from CreditCardFormatting
Methods included from RequiresParameters
Methods included from PostsData
included, #raw_ssl_request, #ssl_get, #ssl_post, #ssl_request
Constructor Details
#initialize(options = {}) ⇒ WirecardGateway
Returns a new instance of WirecardGateway.
56 57 58 59 60 61 62 63 |
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 56 def initialize( = {}) # verify that username and password are supplied requires!(, :login, :password) # unfortunately Wirecard also requires a BusinessCaseSignature in the XML request requires!(, :signature) @options = super end |
Instance Method Details
#authorize(money, creditcard, options = {}) ⇒ Object
Authorization
71 72 73 74 75 76 |
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 71 def (money, creditcard, = {}) () @options[:credit_card] = creditcard request = build_request(:authorization, money, @options) commit(request) end |
#capture(money, authorization, options = {}) ⇒ Object
Capture Authorization
80 81 82 83 84 85 |
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 80 def capture(money, , = {}) () @options[:authorization] = request = build_request(:capture_authorization, money, @options) commit(request) end |
#purchase(money, creditcard, options = {}) ⇒ Object
Purchase
89 90 91 92 93 94 |
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 89 def purchase(money, creditcard, = {}) () @options[:credit_card] = creditcard request = build_request(:purchase, money, @options) commit(request) end |
#test? ⇒ Boolean
Should run against the test servers or not?
66 67 68 |
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 66 def test? @options[:test] || super end |