PowerShell
PowerShell
Calculate a X_RISKIFIED_HMAC_SHA256 for riskified.com API Calls
See more REST Misc Examples
Demonstrates how to calculate the value for the X_RISKIFIED_HMAC_SHA256 header for riskified.com HTTP requests (REST API calls).Chilkat PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
# This example requires the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
# Create the JSON that is to be the body of the HTTP request.
# The JSON created by this code is shown at the bottom of this example.
#
# The JSON Code Generator at http://tools.chilkat.io/ can be used
# to generate the following code from sample JSON.
$json = New-Object Chilkat.JsonObject
$json.UpdateNull("order.cancel_reason")
$json.UpdateNull("order.cancelled_at")
$json.UpdateString("order.cart_token","68778783ad298f1c80c3bafcddeea02f")
$json.UpdateNull("order.closed_at")
$json.UpdateString("order.created_at","2008-01-10T11:00:00-05:00")
$json.UpdateString("order.currency","USD")
$json.UpdateString("order.email","bob.norman@hostmail.com")
$json.UpdateString("order.gateway","authorize_net")
$json.UpdateNumber("order.id","450789469")
$json.UpdateString("order.total_discounts","0.00")
$json.UpdateString("order.total_price","409.94")
$json.UpdateString("order.updated_at","2008-01-10T11:00:00-05:00")
$json.UpdateString("order.note","some note made by the shop’s stuff member")
$json.UpdateNull("order.browser_ip")
$json.UpdateString("order.discount_codes[0].amount","10.00")
$json.UpdateString("order.discount_codes[0].code","TENOFF")
$json.UpdateString("order.line_items[0].title","IPod Nano - 8gb - green")
$json.UpdateNumber("order.line_items[0].price","199.00")
$json.UpdateNumber("order.line_items[0].product_id","632910392")
$json.UpdateNumber("order.line_items[0].quantity","1")
$json.UpdateString("order.line_items[0].sku","IPOD2008GREEN")
$json.UpdateString("order.shipping_lines[0].code","Free Shipping")
$json.UpdateString("order.shipping_lines[0].price","0.00")
$json.UpdateString("order.shipping_lines[0].title","Free Shipping")
$json.UpdateNull("order.payment_details.avs_result_code")
$json.UpdateNull("order.payment_details.credit_card_bin")
$json.UpdateString("order.payment_details.credit_card_company","Visa")
$json.UpdateString("order.payment_details.credit_card_number","XXXX-XXXX-XXXX-4242")
$json.UpdateNull("order.payment_details.cvv_result_code")
$json.UpdateString("order.payment_details.authorization_id","RK346IK124")
$json.UpdateString("order.billing_address.address1","Chestnut Street 92")
$json.UpdateString("order.billing_address.address2","")
$json.UpdateString("order.billing_address.city","Louisville")
$json.UpdateNull("order.billing_address.company")
$json.UpdateString("order.billing_address.country","United States")
$json.UpdateString("order.billing_address.country_code","US")
$json.UpdateString("order.billing_address.first_name","Bob")
$json.UpdateString("order.billing_address.last_name","Norman")
$json.UpdateString("order.billing_address.name","Bob Norman")
$json.UpdateString("order.billing_address.phone","555-625-1199")
$json.UpdateString("order.billing_address.province","Kentucky")
$json.UpdateString("order.billing_address.province_code","KY")
$json.UpdateString("order.billing_address.zip","40202")
$json.UpdateString("order.shipping_address.address1","Chestnut Street 92")
$json.UpdateString("order.shipping_address.address2","")
$json.UpdateString("order.shipping_address.city","Louisville")
$json.UpdateNull("order.shipping_address.company")
$json.UpdateString("order.shipping_address.country","United States")
$json.UpdateString("order.shipping_address.country_code","US")
$json.UpdateString("order.shipping_address.first_name","Bob")
$json.UpdateString("order.shipping_address.last_name","Norman")
$json.UpdateString("order.shipping_address.name","Bob Norman")
$json.UpdateString("order.shipping_address.phone","555-625-1199")
$json.UpdateString("order.shipping_address.province","Kentucky")
$json.UpdateString("order.shipping_address.province_code","KY")
$json.UpdateString("order.shipping_address.zip","40202")
$json.UpdateString("order.customer.created_at","2013-04-23T13:36:50-04:00")
$json.UpdateString("order.customer.email","bob.norman@hostmail.com")
$json.UpdateString("order.customer.first_name","Bob")
$json.UpdateNumber("order.customer.id","207119551")
$json.UpdateString("order.customer.last_name","Norman")
$json.UpdateNull("order.customer.note")
$json.UpdateNumber("order.customer.orders_count","0")
$json.UpdateBool("order.customer.verified_email",$true)
# Emit the JSON in compact format..
$json.EmitCompact = $true
# Get the JSON that will be HMAC'd and will also be the contents of the HTTP request body.
$jsonBody = $json.Emit()
$crypt = New-Object Chilkat.Crypt2
$crypt.EncodingMode = "hex"
$crypt.HashAlgorithm = "sha256"
$crypt.MacAlgorithm = "hmac"
$crypt.SetMacKeyString("55fe0f4d4023bbdfbc124cabd88bf9bb")
$hmacHexStr = $crypt.MacStringENC($jsonBody)
if ($crypt.LastMethodSuccess -ne $true) {
$($crypt.LastErrorText)
exit
}
# We need a lowercase hmacHexStr...
$sbHmacHex = New-Object Chilkat.StringBuilder
$sbHmacHex.Append($hmacHexStr)
$sbHmacHex.ToLowercase()
$hmacHexStr = $sbHmacHex.GetAsString()
$("The value of the X_RISKIFIED_HMAC_SHA256 should be: " + $hmacHexStr)
# This example is only to show the HMAC SHA256 calculation.
# See examples of sending REST requests to riskified.com at http://rest-examples.chilkat.io/riskified/default.cshtml
# ----------------------------------------------
# This is the JSON created by the above code..
# {
# "order": {
# "cancel_reason": null,
# "cancelled_at": null,
# "cart_token": "68778783ad298f1c80c3bafcddeea02f",
# "closed_at": null,
# "created_at": "2008-01-10T11:00:00-05:00",
# "currency": "USD",
# "email": "bob.norman@hostmail.com",
# "gateway": "authorize_net",
# "id": 450789469,
# "total_discounts": "0.00",
# "total_price": "409.94",
# "updated_at": "2008-01-10T11:00:00-05:00",
# "note": "some note made by the shop’s stuff member",
# "browser_ip": null,
# "discount_codes": [
# {
# "amount": "10.00",
# "code": "TENOFF"
# }
# ],
# "line_items": [
# {
# "title": "IPod Nano - 8gb - green",
# "price": 199.00,
# "product_id": 632910392,
# "quantity": 1,
# "sku": "IPOD2008GREEN"
# }
# ],
# "shipping_lines": [
# {
# "code": "Free Shipping",
# "price": "0.00",
# "title": "Free Shipping"
# }
# ],
# "payment_details": {
# "avs_result_code": null,
# "credit_card_bin": null,
# "credit_card_company": "Visa",
# "credit_card_number": "XXXX-XXXX-XXXX-4242",
# "cvv_result_code": null,
# "authorization_id": "RK346IK124"
# },
# "billing_address": {
# "address1": "Chestnut Street 92",
# "address2": "",
# "city": "Louisville",
# "company": null,
# "country": "United States",
# "country_code": "US",
# "first_name": "Bob",
# "last_name": "Norman",
# "name": "Bob Norman",
# "phone": "555-625-1199",
# "province": "Kentucky",
# "province_code": "KY",
# "zip": "40202"
# },
# "shipping_address": {
# "address1": "Chestnut Street 92",
# "address2": "",
# "city": "Louisville",
# "company": null,
# "country": "United States",
# "country_code": "US",
# "first_name": "Bob",
# "last_name": "Norman",
# "name": "Bob Norman",
# "phone": "555-625-1199",
# "province": "Kentucky",
# "province_code": "KY",
# "zip": "40202"
# },
# "customer": {
# "created_at": "2013-04-23T13:36:50-04:00",
# "email": "bob.norman@hostmail.com",
# "first_name": "Bob",
# "id": 207119551,
# "last_name": "Norman",
# "note": null,
# "orders_count": 0,
# "verified_email": true
# }
# }
# }