Sample code for 30+ languages & platforms
Android™

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 Android™ Downloads

Android™
// Important: Don't forget to include the call to System.loadLibrary
// as shown at the bottom of this code sample.
package com.test;

import android.app.Activity;
import com.chilkatsoft.*;

import android.widget.TextView;
import android.os.Bundle;

public class SimpleActivity extends Activity {

  private static final String TAG = "Chilkat";

  // Called when the activity is first created.
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    boolean success = false;

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

    CkHttp http = new CkHttp();

    http.put_BasicAuth(true);
    http.put_Login("API_USERNAME");
    http.put_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

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

    String url = "https://<site>.cardconnect.com:<port>/cardconnect/rest/capture";

    CkHttpResponse resp = new CkHttpResponse();
    success = http.HttpStr("PUT",url,json.emit(),"utf-8","application/json",resp);
    if (success == false) {
        Log.i(TAG, http.lastErrorText());
        return;
        }

    // 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.
    Log.i(TAG, "response status code = " + String.valueOf(resp.get_StatusCode()));

    CkJsonObject jsonResp = new CkJsonObject();
    jsonResp.Load(resp.bodyStr());
    jsonResp.put_EmitCompact(false);

    Log.i(TAG, "response JSON:");
    Log.i(TAG, jsonResp.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

    String amount = jsonResp.stringOf("amount");
    String resptext = jsonResp.stringOf("resptext");
    String setlstat = jsonResp.stringOf("setlstat");
    String commcard = jsonResp.stringOf("commcard");
    String respcode = jsonResp.stringOf("respcode");
    String batchid = jsonResp.stringOf("batchid");
    String merchid = jsonResp.stringOf("merchid");
    String token = jsonResp.stringOf("token");
    String authcode = jsonResp.stringOf("authcode");
    String respproc = jsonResp.stringOf("respproc");
    String retref = jsonResp.stringOf("retref");
    String respstat = jsonResp.stringOf("respstat");
    String account = jsonResp.stringOf("account");

  }

  static {
      System.loadLibrary("chilkat");

      // Note: If the incorrect library name is passed to System.loadLibrary,
      // then you will see the following error message at application startup:
      //"The application <your-application-name> has stopped unexpectedly. Please try again."
  }
}