Sample code for 30+ languages & platforms
AutoIt

Walmart Partner API Authentication (Generate a Signature for a Request)

See more RSA Examples

Demonstrates how to generate a signature for a Walmart Partner REST API call.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

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

Local $sConsumerId = "b68d2a72...."
Local $sBaseUrl = "https://marketplace.walmartapis.com/v2/feeds"
; This is your Base64 encoded private key
Local $sPrivateEncodedStr = "MIICeAIBADANBgkqhkiG9w0BAQEFAA......"
Local $sHttpMethod = "GET"

; We need a timestamp in decimal string form representing the number of milliseconds since Jan 01 1970 UTC.
$oDt = ObjCreate("Chilkat.CkDateTime")
; Set bLocal = True for a timestamp in the local timezone.  Set bLocal = False for a UTC timestamp.
Local $bLocal = False
; This gets the timestamp in seconds, not milliseconds.
Local $iTimeStampVal = $oDt.GetAsUnixTime($bLocal)

; Build the string to sign.
$oSbStringToSign = ObjCreate("Chilkat.StringBuilder")
$oSbStringToSign.Append($sConsumerId)
$oSbStringToSign.Append(@LF)
$oSbStringToSign.Append($sBaseUrl)
$oSbStringToSign.Append(@LF)
$oSbStringToSign.Append($sHttpMethod)
$oSbStringToSign.Append(@LF)
$oSbStringToSign.AppendInt($iTimeStampVal)
; We add three zero's so that the timestamp value is in milliseconds.
; We don't care about accuracy down to less than a second.
; All the server cares about is that the request was signed at the current date/time
; within some reasonable margin of error (to account for systems having clocks
; that may be slightly different).
$oSbStringToSign.Append("000" & @LF)

$oPrivKey = ObjCreate("Chilkat.PrivateKey")
; Load the private key into a private key object.
; Note: Technically the private key is not PEM because it lacks the header/footer strings
; used for PEM.  However, the LoadPem method will still accept it and load it correctly.
$bSuccess = $oPrivKey.LoadPem($sPrivateEncodedStr)
If ($bSuccess = False) Then
    ConsoleWrite($oPrivKey.LastErrorText & @CRLF)
    Exit
EndIf

$oRsa = ObjCreate("Chilkat.Rsa")
$bSuccess = $oRsa.UsePrivateKey($oPrivKey)
If ($bSuccess = False) Then
    ConsoleWrite($oRsa.LastErrorText & @CRLF)
    Exit
EndIf

; We want a base64 signature string.
$oRsa.EncodingMode = "base64"

Local $signatureString = $oRsa.SignStringENC($oSbStringToSign.GetAsString(),"SHA256")
If ($oRsa.LastMethodSuccess = False) Then
    ConsoleWrite($oRsa.LastErrorText & @CRLF)
    Exit
EndIf

ConsoleWrite("Signature String: " & $signatureString & @CRLF)