Sample code for 30+ languages & platforms
Visual FoxPro

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 Visual FoxPro Downloads

Visual FoxPro
LOCAL lnSuccess
LOCAL loHttp
LOCAL loJson
LOCAL lcUrl
LOCAL loResp
LOCAL loJsonResp
LOCAL lcAmount
LOCAL lcResptext
LOCAL lcSetlstat
LOCAL lcCommcard
LOCAL lcRespcode
LOCAL lcBatchid
LOCAL lcMerchid
LOCAL lcToken
LOCAL lcAuthcode
LOCAL lcRespproc
LOCAL lcRetref
LOCAL lcRespstat
LOCAL lcAccount

lnSuccess = 0

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

loHttp = CreateObject('Chilkat.Http')

loHttp.BasicAuth = 1
loHttp.Login = "API_USERNAME"
loHttp.Password = "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

loJson = CreateObject('Chilkat.JsonObject')
loJson.UpdateString("retref","112989260941")
loJson.UpdateString("shiptozip","11111-1111")
loJson.UpdateString("shipfromzip","99999-9999")
loJson.UpdateString("amount","596.00")
loJson.UpdateString("items[0].discamnt","0")
loJson.UpdateString("items[0].unitcost","900")
loJson.UpdateString("items[0].uom","CS")
loJson.UpdateString("items[0].lineno","1")
loJson.UpdateString("items[0].description","DESCRIPTION-1")
loJson.UpdateString("items[0].taxamnt","117")
loJson.UpdateString("items[0].quantity","1000")
loJson.UpdateString("items[0].upc","UPC-1")
loJson.UpdateString("items[0].netamnt","150")
loJson.UpdateString("items[0].material","MATERIAL-1")
loJson.UpdateString("items[1].discamnt","0")
loJson.UpdateString("items[1].unitcost","450")
loJson.UpdateString("items[1].uom","CS")
loJson.UpdateString("items[1].lineno","2")
loJson.UpdateString("items[1].description","DESCRIPTION-2")
loJson.UpdateString("items[1].taxamnt","117")
loJson.UpdateString("items[1].quantity","2000")
loJson.UpdateString("items[1].upc","UPC-1")
loJson.UpdateString("items[1].netamnt","300")
loJson.UpdateString("items[1].material","MATERIAL-2")
loJson.UpdateString("taxamount","40.00")
loJson.UpdateString("merchid","MERCHANT_ID")
loJson.UpdateString("account","4111111111111111")
loJson.UpdateString("ponumber","PO-0736332")

lcUrl = "https://<site>.cardconnect.com:<port>/cardconnect/rest/capture"

loResp = CreateObject('Chilkat.HttpResponse')
lnSuccess = loHttp.HttpStr("PUT",lcUrl,loJson.Emit(),"utf-8","application/json",loResp)
IF (lnSuccess = 0) THEN
    ? loHttp.LastErrorText
    RELEASE loHttp
    RELEASE loJson
    RELEASE loResp
    CANCEL
ENDIF

* 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.
? "response status code = " + STR(loResp.StatusCode)

loJsonResp = CreateObject('Chilkat.JsonObject')
loJsonResp.Load(loResp.BodyStr)
loJsonResp.EmitCompact = 0

? "response JSON:"
? loJsonResp.Emit()

* 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

lcAmount = loJsonResp.StringOf("amount")
lcResptext = loJsonResp.StringOf("resptext")
lcSetlstat = loJsonResp.StringOf("setlstat")
lcCommcard = loJsonResp.StringOf("commcard")
lcRespcode = loJsonResp.StringOf("respcode")
lcBatchid = loJsonResp.StringOf("batchid")
lcMerchid = loJsonResp.StringOf("merchid")
lcToken = loJsonResp.StringOf("token")
lcAuthcode = loJsonResp.StringOf("authcode")
lcRespproc = loJsonResp.StringOf("respproc")
lcRetref = loJsonResp.StringOf("retref")
lcRespstat = loJsonResp.StringOf("respstat")
lcAccount = loJsonResp.StringOf("account")

RELEASE loHttp
RELEASE loJson
RELEASE loResp
RELEASE loJsonResp