Sample code for 30+ languages & platforms
Tcl

CardConnect Capture Level 3 Data

See more CardConnect Examples

Demonstrates how to send a CardConnect Capture request with Lavel 3 line item data.
If available, Level 3 line item data can be sent with the capture request, particularly for any commercial or corporate payment cards. To qualify for Level 3 Interchange rates, Level 2 data must also be provided. ...

See https://developer.cardconnect.com/cardconnect-api#capture-level-3-data

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

set http [new_CkHttp]

CkHttp_put_BasicAuth $http 1
CkHttp_put_Login $http "API_USERNAME"
CkHttp_put_Password $http "API_PASSWORD"

# Build and send the following JSON:

# The "retref" is the value returned in the JSON response for the Authorization request.

# {
#   "retref": "2880000333",
#   "shiptozip": "11111-1111",
#   "shipfromzip": "99999-9999",
#   "amount": "596.00",
#   "items": [
#     {
#       "discamnt": "0",
#       "unitcost": "900",
#       "uom": "CS",
#       "lineno": "1",
#       "description": "DESCRIPTION-1",
#       "taxamnt": "117",
#       "quantity": "1000",
#       "upc": "UPC-1",
#       "netamnt": "150",
#       "material": "MATERIAL-1"
#     },
#     {
#       "discamnt": "0",
#       "unitcost": "450",
#       "uom": "CS",
#       "lineno": "2",
#       "description": "DESCRIPTION-2",
#       "taxamnt": "117",
#       "quantity": "2000",
#       "upc": "UPC-1",
#       "netamnt": "300",
#       "material": "MATERIAL-2"
#     }
#   ],
#   "taxamount": "40.00",
#   "merchid": "123456789012",
#   "account": "4111111111111111",
#   "ponumber": "PO-0736332"
# }
# 
# Use this online tool to generate the code from sample JSON: 
# Generate Code to Create JSON

set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "retref" "112989260941"
CkJsonObject_UpdateString $json "shiptozip" "11111-1111"
CkJsonObject_UpdateString $json "shipfromzip" "99999-9999"
CkJsonObject_UpdateString $json "amount" "596.00"
CkJsonObject_UpdateString $json "items[0].discamnt" "0"
CkJsonObject_UpdateString $json "items[0].unitcost" "900"
CkJsonObject_UpdateString $json "items[0].uom" "CS"
CkJsonObject_UpdateString $json "items[0].lineno" "1"
CkJsonObject_UpdateString $json "items[0].description" "DESCRIPTION-1"
CkJsonObject_UpdateString $json "items[0].taxamnt" "117"
CkJsonObject_UpdateString $json "items[0].quantity" "1000"
CkJsonObject_UpdateString $json "items[0].upc" "UPC-1"
CkJsonObject_UpdateString $json "items[0].netamnt" "150"
CkJsonObject_UpdateString $json "items[0].material" "MATERIAL-1"
CkJsonObject_UpdateString $json "items[1].discamnt" "0"
CkJsonObject_UpdateString $json "items[1].unitcost" "450"
CkJsonObject_UpdateString $json "items[1].uom" "CS"
CkJsonObject_UpdateString $json "items[1].lineno" "2"
CkJsonObject_UpdateString $json "items[1].description" "DESCRIPTION-2"
CkJsonObject_UpdateString $json "items[1].taxamnt" "117"
CkJsonObject_UpdateString $json "items[1].quantity" "2000"
CkJsonObject_UpdateString $json "items[1].upc" "UPC-1"
CkJsonObject_UpdateString $json "items[1].netamnt" "300"
CkJsonObject_UpdateString $json "items[1].material" "MATERIAL-2"
CkJsonObject_UpdateString $json "taxamount" "40.00"
CkJsonObject_UpdateString $json "merchid" "MERCHANT_ID"
CkJsonObject_UpdateString $json "account" "4111111111111111"
CkJsonObject_UpdateString $json "ponumber" "PO-0736332"

set url "https://<site>.cardconnect.com:<port>/cardconnect/rest/capture"

set resp [new_CkHttpResponse]

set success [CkHttp_HttpStr $http "PUT" $url [CkJsonObject_emit $json] "utf-8" "application/json" $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkJsonObject $json
    delete_CkHttpResponse $resp
    exit
}

# A response status of 200 indicates potential success.  The JSON response body
# must be examined to determine if it was truly successful or an error.
puts "response status code = [CkHttpResponse_get_StatusCode $resp]"

set jsonResp [new_CkJsonObject]

CkJsonObject_Load $jsonResp [CkHttpResponse_bodyStr $resp]
CkJsonObject_put_EmitCompact $jsonResp 0

puts "response JSON:"
puts [CkJsonObject_emit $jsonResp]

# A successful response looks like this:

# {
#   "amount": "596.00",
#   "resptext": "Approval",
#   "setlstat": "Queued for Capture",
#   "commcard": " C ",
#   "respcode": "00",
#   "batchid": "1900942291",
#   "merchid": "MERCHANT_ID",
#   "token": "9418594164541111",
#   "authcode": "PPS158",
#   "respproc": "FNOR",
#   "retref": "112989260941",
#   "respstat": "A",
#   "account": "9418594164541111"
# }

# Use this online tool to generate parsing code from sample JSON: 
# Generate Parsing Code from JSON

set amount [CkJsonObject_stringOf $jsonResp "amount"]
set resptext [CkJsonObject_stringOf $jsonResp "resptext"]
set setlstat [CkJsonObject_stringOf $jsonResp "setlstat"]
set commcard [CkJsonObject_stringOf $jsonResp "commcard"]
set respcode [CkJsonObject_stringOf $jsonResp "respcode"]
set batchid [CkJsonObject_stringOf $jsonResp "batchid"]
set merchid [CkJsonObject_stringOf $jsonResp "merchid"]
set token [CkJsonObject_stringOf $jsonResp "token"]
set authcode [CkJsonObject_stringOf $jsonResp "authcode"]
set respproc [CkJsonObject_stringOf $jsonResp "respproc"]
set retref [CkJsonObject_stringOf $jsonResp "retref"]
set respstat [CkJsonObject_stringOf $jsonResp "respstat"]
set account [CkJsonObject_stringOf $jsonResp "account"]

delete_CkHttp $http
delete_CkJsonObject $json
delete_CkHttpResponse $resp
delete_CkJsonObject $jsonResp