Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Delphi DLL) CardConnect CaptureDemonstrates how to send a CardConnect Capture request. The capture service queues the transaction amount for settlement. Capture can occur within the authorization request or subsequently. ... See https://developer.cardconnect.com/cardconnect-api#capture
uses Winapi.Windows, Winapi.Messages, System.SysUtils, System.Variants, System.Classes, Vcl.Graphics, Vcl.Controls, Vcl.Forms, Vcl.Dialogs, Vcl.StdCtrls, JsonObject, Http; ... procedure TForm1.Button1Click(Sender: TObject); var http: HCkHttp; success: Boolean; json: HCkJsonObject; url: PWideChar; responseStr: PWideChar; jsonResp: HCkJsonObject; amount: PWideChar; resptext: PWideChar; setlstat: PWideChar; commcard: PWideChar; respcode: PWideChar; batchid: PWideChar; merchid: PWideChar; token: PWideChar; authcode: PWideChar; respproc: PWideChar; retref: PWideChar; respstat: PWideChar; account: PWideChar; begin // This example assumes the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. http := CkHttp_Create(); CkHttp_putBasicAuth(http,True); CkHttp_putLogin(http,'API_USERNAME'); CkHttp_putPassword(http,'API_PASSWORD'); // Build and send the following JSON: // The "retref" is the value returned in the JSON response for the Authorization request. // { // "retref":"112989260941", // "merchid":"MERCHANT_ID" // } json := CkJsonObject_Create(); CkJsonObject_UpdateString(json,'retref','112989260941'); CkJsonObject_UpdateString(json,'merchid','MERCHANT_ID'); url := 'https://<site>.cardconnect.com:<port>/cardconnect/rest/capture'; responseStr := CkHttp__putText(http,url,CkJsonObject__emit(json),'utf-8','application/json',False,False); if (CkHttp_getLastMethodSuccess(http) = False) then begin Memo1.Lines.Add(CkHttp__lastErrorText(http)); Exit; end; // 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. Memo1.Lines.Add('response status code = ' + IntToStr(CkHttp_getLastStatus(http))); jsonResp := CkJsonObject_Create(); CkJsonObject_Load(jsonResp,responseStr); CkJsonObject_putEmitCompact(jsonResp,False); Memo1.Lines.Add('response JSON:'); Memo1.Lines.Add(CkJsonObject__emit(jsonResp)); // A successful response looks like this: // { // "amount": "0.20", // "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 amount := CkJsonObject__stringOf(jsonResp,'amount'); resptext := CkJsonObject__stringOf(jsonResp,'resptext'); setlstat := CkJsonObject__stringOf(jsonResp,'setlstat'); commcard := CkJsonObject__stringOf(jsonResp,'commcard'); respcode := CkJsonObject__stringOf(jsonResp,'respcode'); batchid := CkJsonObject__stringOf(jsonResp,'batchid'); merchid := CkJsonObject__stringOf(jsonResp,'merchid'); token := CkJsonObject__stringOf(jsonResp,'token'); authcode := CkJsonObject__stringOf(jsonResp,'authcode'); respproc := CkJsonObject__stringOf(jsonResp,'respproc'); retref := CkJsonObject__stringOf(jsonResp,'retref'); respstat := CkJsonObject__stringOf(jsonResp,'respstat'); account := CkJsonObject__stringOf(jsonResp,'account'); CkHttp_Dispose(http); CkJsonObject_Dispose(json); CkJsonObject_Dispose(jsonResp); end; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.