Class: ActiveMerchant::Billing::WirecardGateway

Inherits:
Gateway
  • Object
show all
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::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?

Methods included from Utils

generate_unique_id

Methods included from CreditCardFormatting

#format

Methods included from RequiresParameters

#requires!

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(options = {})
  # verify that username and password are supplied
  requires!(options, :login, :password)
  # unfortunately Wirecard also requires a BusinessCaseSignature in the XML request
  requires!(options, :signature)
  @options = 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 authorize(money, creditcard, options = {})
  prepare_options_hash(options)
  @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, authorization, options = {})
  prepare_options_hash(options)
  @options[:authorization] = 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 = {})
  prepare_options_hash(options)
  @options[:credit_card] = creditcard
  request = build_request(:purchase, money, @options)
  commit(request)
end

#test?Boolean

Should run against the test servers or not?

Returns:

  • (Boolean)


66
67
68
# File 'lib/active_merchant/billing/gateways/wirecard.rb', line 66

def test?
  @options[:test] || super
end