C#
C#
Payeezy HMAC Computation
See more HTTP Misc Examples
Demonstrates how to calculate the HMAC for a Payeezy REST request.Chilkat C# Downloads
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());