Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(PowerShell) Create Restricted Data Token (RDT)See more Amazon SP-API ExamplesReturns a Restricted Data Token (RDT) for one or more restricted resources that you specify. For more information, see https://developer-docs.amazon.com/sp-api/docs/tokens-api-v2021-03-01-reference#post-tokens2021-03-01restricteddatatoken
Add-Type -Path "C:\chilkat\ChilkatDotNet47-9.5.0-x64\ChilkatDotNet47.dll" # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $authAws = New-Object Chilkat.AuthAws $authAws.AccessKey = "AWS_ACCESS_KEY" $authAws.SecretKey = "AWS_SECRET_KEY" $authAws.ServiceName = "execute-api" # Use the region that is correct for your needs. $authAws.Region = "eu-west-1" $rest = New-Object Chilkat.Rest $bTls = $true $port = 443 $bAutoReconnect = $true # The sandbox endpoint (sandbox.sellingpartnerapi-eu.amazon.com) fails. # Use the production endpoint and see the note below. $success = $rest.Connect("sellingpartnerapi-eu.amazon.com",$port,$bTls,$bAutoReconnect) if ($success -eq $false) { $($rest.LastErrorText) exit } $success = $rest.SetAuthAws($authAws) # Load the previously obtained LWA access token. # See Fetch SP-API LWA Access Token $jsonToken = New-Object Chilkat.JsonObject $success = $jsonToken.LoadFile("qa_data/tokens/sp_api_lwa_token.json") if ($success -eq $false) { $("Failed to load LWA access token.") exit } # Add the x-amz-access-token request header. $lwa_token = $jsonToken.StringOf("access_token") $rest.ClearAllHeaders() $rest.AddHeader("x-amz-access-token",$lwa_token) # We're going to send a POST with the following JSON body: # { # "restrictedResources": [ # { # "method": "GET", # "path": "/orders/v0/orders", # "dataElements": ["buyerInfo", "shippingAddress"] # } # ] # } # Use this online tool to generate code from sample JSON: # Generate Code to Create JSON $json = New-Object Chilkat.JsonObject $json.UpdateString("restrictedResources[0].method","GET") $json.UpdateString("restrictedResources[0].path","/orders/v0/orders") $json.UpdateString("restrictedResources[0].dataElements[0]","buyerInfo") $json.UpdateString("restrictedResources[0].dataElements[1]","shippingAddress") $sbRequest = New-Object Chilkat.StringBuilder $json.EmitSb($sbRequest) $sbResponse = New-Object Chilkat.StringBuilder $uri = "/tokens/2021-03-01/restrictedDataToken" $success = $rest.FullRequestSb("POST",$uri,$sbRequest,$sbResponse) if ($success -eq $false) { $($rest.LastErrorText) exit } # ------------------------------------------------------------------------------------ # Note: Using the sandbox endpoint, such as sandbox.sellingpartnerapi-eu.amazon.com # results in a response status code of 400 with the following error: # [{"code":"InvalidInput","message":"Could not match input arguments"}] # Getting a restricted data token seems to only work with the production endpoint. # ------------------------------------------------------------------------------------ # Examine the response status. $statusCode = $rest.ResponseStatusCode if ($statusCode -ne 200) { $("Response status code: " + $statusCode) $("Response status text: " + $rest.ResponseStatusText) $("Response body: ") $($sbResponse.GetAsString()) $("Failed.") exit } $($sbResponse.GetAsString()) # If successful, gets a JSON response such as the following: # { # "expiresIn": 3600, # "restrictedDataToken": "Atz.sprdt|AYAB.....TQ=" # } # Use this online tool to generate parsing code from sample JSON: # Generate Parsing Code from JSON $jsonResp = New-Object Chilkat.JsonObject $jsonResp.LoadSb($sbResponse) $expiresIn = $jsonResp.IntOf("expiresIn") $restrictedDataToken = $jsonResp.StringOf("restrictedDataToken") # Save the RDT for subsequent use.. $success = $jsonResp.WriteFile("qa_data/tokens/sp_api_rdt_token.json") $("Success!") |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.