Sample code for 30+ languages & platforms
Visual Basic 6.0

Global Payments Card Authorization

See more Global Payments Examples

Demonstrates how to send a card payments authorization request.

Chilkat Visual Basic 6.0 Downloads

Visual Basic 6.0
Dim success As Long
success = 0

' This example requires the Chilkat API to have been previously unlocked.
' See Global Unlock Sample for sample code.

Dim http As New ChilkatHttp

' if you don't have a Client ID yet you can still quickly test some basic request types using the following URL and credentials:

' Test URL - https://test.realexpayments.com/epage-remote.cgi
' Client ID: realexsandbox
' Shared Secret: Po8lRRT67a
Dim testUrl As String
testUrl = "https://test.realexpayments.com/epage-remote.cgi"
Dim clientID As String
clientID = "realexsandbox"
Dim sharedSecret As String
sharedSecret = "Po8lRRT67a"

Dim amount As String
amount = "1001"
Dim currency As String
currency = "EUR"
Dim cardNumber As String
cardNumber = "4263970000005262"

' We'll be sending the following XML in the body of the request:

' <?xml version="1.0" encoding="UTF-8"?>
' <request type="auth" timestamp="20180613141207">
'   <merchantid>MerchantId</merchantid>
'   <account>internet</account>
'   <channel>ECOM</channel>
'   <orderid>N6qsk4kYRZihmPrTXWYS6g</orderid>
'   <amount currency="EUR">1001</amount>
'   <card>
'     <number>4263970000005262</number>
'     <expdate>0425</expdate>
'     <chname>James Mason</chname>
'     <type>VISA</type>
'     <cvn>
'       <number>123</number>
'       <presind>1</presind>
'     </cvn>
'   </card>
'   <autosettle flag="1"/>
'   <sha1hash>87707637a34ba651b6185718c863abc64b673f20</sha1hash>
' </request>

' Use this online tool to generate code from sample XML: 
' Generate Code to Create XML

' Get the current date/time in this format:  20180613141207
Dim dt As New CkDateTime
success = dt.SetFromCurrentSystemTime()
Dim dtStr As String
dtStr = dt.GetAsIso8601("YYYYMMDDhhmmss",1)

' Generate a unique order ID
Dim prng As New ChilkatPrng
Dim orderId As String
orderId = prng.GenRandom(32,"base64url")

' Compute the sha1hash
Dim crypt As New ChilkatCrypt2
crypt.HashAlgorithm = "sha1"
crypt.EncodingMode = "hexlower"

Dim sbA As New ChilkatStringBuilder
success = sbA.Append("timestamp.merchantid.orderid.amount.currency.cardnumber")
Dim numReplaced As Long
numReplaced = sbA.Replace("timestamp",dtStr)
numReplaced = sbA.Replace("merchantid",clientID)
numReplaced = sbA.Replace("orderid",orderId)
numReplaced = sbA.Replace("amount",amount)
numReplaced = sbA.Replace("currency",currency)
numReplaced = sbA.Replace("cardnumber",cardNumber)

Dim hashA As String
hashA = crypt.HashStringENC(sbA.GetAsString())

Dim sbB As New ChilkatStringBuilder
success = sbB.Append(hashA)
success = sbB.Append(".")
success = sbB.Append(sharedSecret)

Dim hashB As String
hashB = crypt.HashStringENC(sbB.GetAsString())

Dim xml As New ChilkatXml
xml.Tag = "request"
success = xml.AddAttribute("type","auth")
success = xml.AddAttribute("timestamp",dtStr)
xml.UpdateChildContent "merchantid",clientID
xml.UpdateChildContent "account","internet"
xml.UpdateChildContent "channel","ECOM"
xml.UpdateChildContent "orderid",orderId
success = xml.UpdateAttrAt("amount",1,"currency",currency)
xml.UpdateChildContent "amount",amount
xml.UpdateChildContent "card|number",cardNumber
xml.UpdateChildContent "card|expdate","0425"
xml.UpdateChildContent "card|chname","James Mason"
xml.UpdateChildContent "card|type","VISA"
xml.UpdateChildContent "card|cvn|number","123"
xml.UpdateChildContent "card|cvn|presind","1"
success = xml.UpdateAttrAt("autosettle",1,"flag","1")
xml.UpdateChildContent "sha1hash",hashB

Dim resp As New ChilkatHttpResponse
success = http.HttpStr("POST",testUrl,xml.GetXml(),"utf-8","application/xml",resp)
If (success = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

Debug.Print "Response Status Code: " & resp.StatusCode

Debug.Print "Response Body:"
Debug.Print resp.BodyStr

If (resp.StatusCode <> 200) Then
    Debug.Print "Failed."
    Exit Sub
End If

' A status code of 200 indicates we received an XML response, but it could be an error message.
' Here's an example of an error response:

' <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
' <response timestamp="20200418142356">
'     <orderid>N6qsk4kYRZihmPrTXWYS6g</orderid>
'     <result>508</result>
'     <message>Invalid timestamp: '{' Value exceeds allowable limit: '}'</message>
' </response>

' We need to check the "result" within the XML.
success = xml.LoadXml(resp.BodyStr)

Dim result As Long
result = xml.GetChildIntValue("result")
Debug.Print "result = " & result

' A successful result looks like this:

' <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
' <response timestamp="20200418145519">
'     <merchantid>realexsandbox</merchantid>
'     <account>internet</account>
'     <orderid>Cw93I1nFWVZuaATh46qMUCBlCcfrOvLo65C2cq5X-AY</orderid>
'     <result>00</result>
'     <authcode>L3pHww</authcode>
'     <message>AUTH CODE: L3pHww</message>
'     <pasref>96838535689610806</pasref>
'     <cvnresult>M</cvnresult>
'     <timetaken>87</timetaken>
'     <authtimetaken>67</authtimetaken>
'     <batchid>6322506</batchid>
'     <sha1hash>2fd2f15f97f1775779fe9bda536dc8317a4b39f6</sha1hash>
' </response>

If (result = 0) Then
    Debug.Print "authcode = " & xml.GetChildContent("authcode")
    Debug.Print "Success."

Else
    Debug.Print "Failed."
End If