I can't get cybersource to work with activemerchant. Activemerchant works fine with authorize.net and paypal. I am attempting to test it from the console since it failed in the site.
gateway = ActiveMerchant::Billing::CyberSourceGateway.new(
:login => "CybersourceUserID",
:password => "CybersourceKey",
:nexus => "NJ",
:vat_reg_number =>""
)
response = gateway.authorize(1000, credit_card, :ip => "127.0.0.1", :order_id=>"23434", :email=>"[email protected]")
This is the error that I am getting back:
#<Net::HTTPInternalServerError:0x1113f0838>
<?xml version="1.0" encoding="UTF-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Body>
<soap:Fault xmlns:wsse="http://schemas.xmlsoap.org/ws/2002/04/secext" xmlns:c="urn:schemas-cybersource-com:transaction-data-1.0">
<faultcode>soap:Client</faultcode>
<faultstring>
XML parse error.
PI with the name 'xml' can occur only in the beginning of the document.
</faultstring>
</soap:Fault>
</soap:Body>
</soap:Envelope>
Any advise here would be appreciated!!!
Thanks,
Rob.
------- here is the fake cc info ------
credit_card = ActiveMerchant::Billing::CreditCard.new(
:type => "visa",
:number => "4111111111111111",
:verification_value => "123",
:month => 1,
:year => 2020,
:first_name => "First",
:last_name => "Last"
)
Also here is the generated XML: (edited out the private info)
<?xml version="1.0" encoding="UTF-8"?>
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/">
<s:Header>
<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd" s:mustUnderstand="1">
<wsse:UsernameToken>
<wsse:Username>CybersourceUserID</wsse:Username>
<wsse:Password Type="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-username-token-profile-1.0#PasswordText">CybersourceKey</wsse:Password>
</wsse:UsernameToken>
</wsse:Security>
</s:Header>
<s:Body xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<requestMessage xmlns="urn:schemas-cybersource-com:transaction-data-1.69">
<merchantID>CybersourceUserID</merchantID>
<merchantReferenceCode>23434</merchantReferenceCode>
<clientLibrary>Ruby Active Merchant</clientLibrary>
<clientLibraryVersion>1.34.1</clientLibraryVersion>
<clientEnvironment>i686-darwin12.2.0</clientEnvironment>
<billTo>
<firstName>First</firstName>
<lastName>Last</lastName>
<street1></street1>
<city></city>
<state></state>
<postalCode></postalCode>
<country></country>
<email>[email protected]</email>
</billTo>
<purchaseTotals>
<currency>USD</currency>
<grandTotalAmount>10.00</grandTotalAmount>
</purchaseTotals>
<card>
<accountNumber>4111111111111111</accountNumber>
<expirationMonth>01</expirationMonth>
<expirationYear>2020</expirationYear>
<cvNumber>123</cvNumber>
<cardType>001</cardType>
</card>
<ccAuthService run="true"/>
<businessRules>
</businessRules>
</requestMessage>
</s:Body>
</s:Envelope>
NEW INFO:
Interestingly enough, if I take the XML above (with the correct merchant ID, etc. And use curl to process it through the production gateway I get this:
Roberts-MacBook-Air:documents rlittle$ curl --header "content-type: application/soap+xml" --data @testxml2.xml https://ics2ws.ic3.com/commerce/1.x/transactionProcessor
<?xml version="1.0" encoding="utf-8"?>
<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/">
<soap:Header>
<wsse:Security xmlns:wsse="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-secext-1.0.xsd">
<wsu:Timestamp xmlns:wsu="http://docs.oasis-open.org/wss/2004/01/oasis-200401-wss-wssecurity-utility-1.0.xsd" wsu:Id="Timestamp-1851182716">
<wsu:Created>2013-07-12T03:32:05.030Z</wsu:Created>
</wsu:Timestamp>
</wsse:Security>
</soap:Header>
<soap:Body>
<c:replyMessage xmlns:c="urn:schemas-cybersource-com:transaction-data-1.69">
<c:merchantReferenceCode>
23434
</c:merchantReferenceCode>
<c:requestID>
3735999249970176056695
</c:requestID>
<c:decision>
REJECT
</c:decision>
<c:reasonCode>
101
</c:reasonCode>
<c:missingField>
c:billTo/c:country
</c:missingField>
<c:missingField>
c:billTo/c:city
</c:missingField>
<c:missingField>
c:billTo/c:street1
</c:missingField>
<c:requestToken>
(a token)
</c:requestToken>
<c:ccAuthReply>
<c:reasonCode>
101
</c:reasonCode>
</c:ccAuthReply>
</c:replyMessage>
</soap:Body>
</soap:Envelope>
So it must be an xml parsing issue in the gem???
Thanks for the help.
I contacted cybersource (they were very helpful).
Tonight it just started to work, so I guess they fixed something on their end.