Sample code for 30+ languages & platforms
.NET Core C#

Payeezy HMAC Computation

See more HTTP Misc Examples

Demonstrates how to calculate the HMAC for a Payeezy REST request.

Chilkat .NET Core C# Downloads

.NET Core C#
bool success = false;

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

Chilkat.Crypt2 crypt = new Chilkat.Crypt2();
Chilkat.Prng prng = new Chilkat.Prng();

// 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");
Debug.WriteLine("nonce = " + nonce);

Chilkat.CkDateTime dtNow = new Chilkat.CkDateTime();
dtNow.SetFromCurrentSystemTime();
Chilkat.StringBuilder sbTimestamp = new Chilkat.StringBuilder();
// 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();
Debug.WriteLine("timestamp = " + timestamp);

// Generate the following JSON request body:
// 	{
// 	  "merchant_ref": "Astonishing-Sale",
// 	  "transaction_type": "authorize",
// 	  "method": "token",
// 	  "amount": "200",
// 	  "currency_code": "USD",
// 	  "token": {
// 	    "token_type": "FDToken",
// 	    "token_data": {
// 	      "type": "visa",
// 	      "value": "2537446225198291",
// 	      "cardholder_name": "JohnSmith",
// 	      "exp_date": "1030",
// 	      "special_payment": "B"
// 	    }
// 	  }
// 	}

Chilkat.JsonObject json = new Chilkat.JsonObject();
json.UpdateString("merchant_ref","Astonishing-Sale");
json.UpdateString("transaction_type","authorize");
json.UpdateString("method","token");
json.UpdateString("amount","200");
json.UpdateString("currency_code","USD");
json.UpdateString("token.token_type","FDToken");
json.UpdateString("token.token_data.type","visa");
json.UpdateString("token.token_data.value","2537446225198291");
json.UpdateString("token.token_data.cardholder_name","JohnSmith");
json.UpdateString("token.token_data.exp_date","1030");
json.UpdateString("token.token_data.special_payment","B");

// string hashData = apiKey + nonce + timestamp + token + jsonString;
Chilkat.StringBuilder sbHmacData = new Chilkat.StringBuilder();
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.EncodingMode = "hexlower";
crypt.MacAlgorithm = "hmac";
crypt.SetMacKeyString(apiSecret);
crypt.HashAlgorithm = "sha256";
crypt.Charset = "utf-8";
string hexHash = crypt.MacStringENC(sbHmacData.GetAsString());

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

Debug.WriteLine("This is the Authorization header to be sent with the payeezy request:");
Debug.WriteLine("Authorization: " + sbBase64Hash.GetAsString());