Sample code for 30+ languages & platforms
Visual Basic 6.0

Payeezy Place Temp Authorization Hold on Buyer’s Credit Card

See more HTTP Misc Examples

Demonstrates how to place a temporary authorization hold for the desired amount on the buyer’s credit card. You can Capture the authorized amount on completion of service or Void/Refund the transaction as required.

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 crypt As New ChilkatCrypt2
Dim prng As New ChilkatPrng

' An API key such as y6pWAJNyJyjGv66IsVuWnklkKUPFbb0a
Dim apiKey As String
apiKey = "my_api_key"
' An API secret such as 86fbae7030253af3cd15faef2a1f4b67353e41fb6799f576b5093ae52901e6f7
Dim apiSecret As String
apiSecret = "my_api_secret"
' A token such as fdoa-a480ce8951daa73262734cf102641994c1e55e7cdf4c02b6
Dim token As String
token = "my_merchant_token"

' The nonce is a random number (bytes), something like "6057786719490086000"
Dim nonce As String
nonce = prng.GenRandom(8,"decimal")
Debug.Print "nonce = " & nonce

Dim dtNow As New CkDateTime
success = dtNow.SetFromCurrentSystemTime()
Dim sbTimestamp As New ChilkatStringBuilder
' Get the epoch timestamp in seconds
success = sbTimestamp.Append(dtNow.GetAsUnixTimeStr(0))
' Change it to milliseconds
success = sbTimestamp.Append("000")
' The timestamp is a number similar to this: 1546011905000 (which is a timestamp taken on 28-Dec-2018).
Dim timestamp As String
timestamp = sbTimestamp.GetAsString()
Debug.Print "timestamp = " & timestamp

' Generate the following JSON request body:
' {
'   "merchant_ref": "Astonishing-Sale",
'   "transaction_type": "authorize",
'   "method": "credit_card",
'   "amount": "1299",
'   "currency_code": "USD",
'   "credit_card": {
'     "type": "visa",
'     "cardholder_name": "John Smith",
'     "card_number": "4788250000028291",
'     "exp_date": "1020",
'     "cvv": "123"
'   }
' }

Dim json As New ChilkatJsonObject
success = json.UpdateString("merchant_ref","Astonishing-Sale")
success = json.UpdateString("transaction_type","authorize")
success = json.UpdateString("method","credit_card")
success = json.UpdateString("amount","1299")
success = json.UpdateString("currency_code","USD")
success = json.UpdateString("credit_card.type","visa")
success = json.UpdateString("credit_card.cardholder_name","John Smith")
success = json.UpdateString("credit_card.card_number","4788250000028291")
success = json.UpdateString("credit_card.exp_date","1020")
success = json.UpdateString("credit_card.cvv","123")
json.EmitCompact = 0
Debug.Print json.Emit()

' string hashData = apiKey + nonce + timestamp + token + jsonString;
Dim sbHmacData As New ChilkatStringBuilder
success = sbHmacData.Append(apiKey)
success = sbHmacData.Append(nonce)
success = sbHmacData.Append(timestamp)
success = sbHmacData.Append(token)
success = sbHmacData.Append(json.Emit())

' HMAC the data to produce a hex string.
crypt.EncodingMode = "hexlower"
crypt.MacAlgorithm = "hmac"
success = crypt.SetMacKeyString(apiSecret)
crypt.HashAlgorithm = "sha256"
crypt.Charset = "utf-8"
Dim hexHash As String
hexHash = crypt.MacStringENC(sbHmacData.GetAsString())
Debug.Print "hexHash = " & hexHash

' Now base64 encode the hex string:
Dim sbBase64Hash As New ChilkatStringBuilder
success = sbBase64Hash.Append(hexHash)
success = sbBase64Hash.Encode("base64","utf-8")

Debug.Print "This is the Authorization header to be sent with the payeezy request:"
Debug.Print "Authorization: " & sbBase64Hash.GetAsString()

' -----------------------------------------------------------
' Now that we have the value for the Authorization header, send the POST containing the JSON.

Dim http As New ChilkatHttp

http.Accept = "*/*"
http.UserAgent = ""
http.SetRequestHeader "Authorization",sbBase64Hash.GetAsString()
http.SetRequestHeader "apikey",apiKey
http.SetRequestHeader "nonce",nonce
http.SetRequestHeader "timestamp",timestamp
http.SetRequestHeader "token",token

http.SessionLogFilename = "qa_output/payeezy.txt"

Dim url As String
url = "https://api-cert.payeezy.com/v1/transactions"
Dim resp As New ChilkatHttpResponse
success = http.HttpJson("POST",url,json,"application/json",resp)
If (success = 0) Then
    Debug.Print http.LastErrorText
    Exit Sub
End If

Debug.Print "response status code = " & resp.StatusCode
success = json.Load(resp.BodyStr)
Debug.Print json.Emit()

' Sample JSON response:

' {
'   "correlation_id": "228.4604632998994",
'   "transaction_status": "approved",
'   "validation_status": "success",
'   "transaction_type": "authorize",
'   "transaction_id": "ET175628",
'   "transaction_tag": "2313721985",
'   "method": "credit_card",
'   "amount": "1299",
'   "currency": "USD",
'   "cvv2": "M",
'   "token": {
'     "token_type": "FDToken",
'     "token_data": {
'       "value": "9732261336638291"
'     }
'   },
'   "card": {
'     "type": "visa",
'     "cardholder_name": "John Smith",
'     "card_number": "8291",
'     "exp_date": "1020"
'   },
'   "bank_resp_code": "100",
'   "bank_message": "Approved",
'   "gateway_resp_code": "00",
'   "gateway_message": "Transaction Normal"
' }
' 

Debug.Print json.StringOf("correlation_id")
Debug.Print json.StringOf("transaction_status")
Debug.Print json.StringOf("validation_status")
Debug.Print json.StringOf("transaction_type")
Debug.Print json.StringOf("transaction_id")
Debug.Print json.StringOf("transaction_tag")
Debug.Print json.StringOf("method")
Debug.Print json.StringOf("amount")
Debug.Print json.StringOf("currency")
Debug.Print json.StringOf("cvv2")
Debug.Print json.StringOf("token.token_type")
Debug.Print json.StringOf("token.token_data.value")
Debug.Print json.StringOf("card.type")
Debug.Print json.StringOf("card.cardholder_name")
Debug.Print json.StringOf("card.card_number")
Debug.Print json.StringOf("card.exp_date")
Debug.Print json.StringOf("bank_resp_code")
Debug.Print json.StringOf("bank_message")
Debug.Print json.StringOf("gateway_resp_code")
Debug.Print json.StringOf("gateway_message")