Sample code for 30+ languages & platforms
Java

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 Java Downloads

Java
import com.chilkatsoft.*;

public class ChilkatExample {

  static {
    try {
        System.loadLibrary("chilkat");
    } catch (UnsatisfiedLinkError e) {
      System.err.println("Native code library failed to load.\n" + e);
      System.exit(1);
    }
  }

  public static void main(String argv[])
  {
    boolean success = false;

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

    CkCrypt2 crypt = new CkCrypt2();
    CkPrng prng = new CkPrng();

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

    // The nonce is a random number (bytes), something like "6057786719490086000"
    String nonce = prng.genRandom(8,"decimal");
    System.out.println("nonce = " + nonce);

    CkDateTime dtNow = new CkDateTime();
    dtNow.SetFromCurrentSystemTime();
    CkStringBuilder sbTimestamp = new CkStringBuilder();
    // Get the epoch timestamp in seconds
    sbTimestamp.Append(dtNow.getAsUnixTimeStr(false));
    // Change it to milliseconds
    sbTimestamp.Append("000");
    // The timestamp is a number similar to this: 1546011905000 (which is a timestamp taken on 28-Dec-2018).
    String timestamp = sbTimestamp.getAsString();
    System.out.println("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"
    //   }
    // }

    CkJsonObject json = new CkJsonObject();
    json.UpdateString("merchant_ref","Astonishing-Sale");
    json.UpdateString("transaction_type","authorize");
    json.UpdateString("method","credit_card");
    json.UpdateString("amount","1299");
    json.UpdateString("currency_code","USD");
    json.UpdateString("credit_card.type","visa");
    json.UpdateString("credit_card.cardholder_name","John Smith");
    json.UpdateString("credit_card.card_number","4788250000028291");
    json.UpdateString("credit_card.exp_date","1020");
    json.UpdateString("credit_card.cvv","123");
    json.put_EmitCompact(false);
    System.out.println(json.emit());

    // string hashData = apiKey + nonce + timestamp + token + jsonString;
    CkStringBuilder sbHmacData = new CkStringBuilder();
    sbHmacData.Append(apiKey);
    sbHmacData.Append(nonce);
    sbHmacData.Append(timestamp);
    sbHmacData.Append(token);
    sbHmacData.Append(json.emit());

    // HMAC the data to produce a hex string.
    crypt.put_EncodingMode("hexlower");
    crypt.put_MacAlgorithm("hmac");
    crypt.SetMacKeyString(apiSecret);
    crypt.put_HashAlgorithm("sha256");
    crypt.put_Charset("utf-8");
    String hexHash = crypt.macStringENC(sbHmacData.getAsString());
    System.out.println("hexHash = " + hexHash);

    // Now base64 encode the hex string:
    CkStringBuilder sbBase64Hash = new CkStringBuilder();
    sbBase64Hash.Append(hexHash);
    sbBase64Hash.Encode("base64","utf-8");

    System.out.println("This is the Authorization header to be sent with the payeezy request:");
    System.out.println("Authorization: " + sbBase64Hash.getAsString());

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

    CkHttp http = new CkHttp();

    http.put_Accept("*/*");
    http.put_UserAgent("");
    http.SetRequestHeader("Authorization",sbBase64Hash.getAsString());
    http.SetRequestHeader("apikey",apiKey);
    http.SetRequestHeader("nonce",nonce);
    http.SetRequestHeader("timestamp",timestamp);
    http.SetRequestHeader("token",token);

    http.put_SessionLogFilename("qa_output/payeezy.txt");

    String url = "https://api-cert.payeezy.com/v1/transactions";
    CkHttpResponse resp = new CkHttpResponse();
    success = http.HttpJson("POST",url,json,"application/json",resp);
    if (success == false) {
        System.out.println(http.lastErrorText());
        return;
        }

    System.out.println("response status code = " + resp.get_StatusCode());
    json.Load(resp.bodyStr());
    System.out.println(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"
    // }
    // 

    System.out.println(json.stringOf("correlation_id"));
    System.out.println(json.stringOf("transaction_status"));
    System.out.println(json.stringOf("validation_status"));
    System.out.println(json.stringOf("transaction_type"));
    System.out.println(json.stringOf("transaction_id"));
    System.out.println(json.stringOf("transaction_tag"));
    System.out.println(json.stringOf("method"));
    System.out.println(json.stringOf("amount"));
    System.out.println(json.stringOf("currency"));
    System.out.println(json.stringOf("cvv2"));
    System.out.println(json.stringOf("token.token_type"));
    System.out.println(json.stringOf("token.token_data.value"));
    System.out.println(json.stringOf("card.type"));
    System.out.println(json.stringOf("card.cardholder_name"));
    System.out.println(json.stringOf("card.card_number"));
    System.out.println(json.stringOf("card.exp_date"));
    System.out.println(json.stringOf("bank_resp_code"));
    System.out.println(json.stringOf("bank_message"));
    System.out.println(json.stringOf("gateway_resp_code"));
    System.out.println(json.stringOf("gateway_message"));
  }
}