Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Perl) 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
use chilkat(); # This example requires the Chilkat API to have been previously unlocked. # See Global Unlock Sample for sample code. $authAws = chilkat::CkAuthAws->new(); $authAws->put_AccessKey("AWS_ACCESS_KEY"); $authAws->put_SecretKey("AWS_SECRET_KEY"); $authAws->put_ServiceName("execute-api"); # Use the region that is correct for your needs. $authAws->put_Region("eu-west-1"); $rest = chilkat::CkRest->new(); $bTls = 1; $port = 443; $bAutoReconnect = 1; # 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 == 0) { print $rest->lastErrorText() . "\r\n"; exit; } $success = $rest->SetAuthAws($authAws); # Load the previously obtained LWA access token. # See Fetch SP-API LWA Access Token $jsonToken = chilkat::CkJsonObject->new(); $success = $jsonToken->LoadFile("qa_data/tokens/sp_api_lwa_token.json"); if ($success == 0) { print "Failed to load LWA access token." . "\r\n"; 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 = chilkat::CkJsonObject->new(); $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 = chilkat::CkStringBuilder->new(); $json->EmitSb($sbRequest); $sbResponse = chilkat::CkStringBuilder->new(); $uri = "/tokens/2021-03-01/restrictedDataToken"; $success = $rest->FullRequestSb("POST",$uri,$sbRequest,$sbResponse); if ($success == 0) { print $rest->lastErrorText() . "\r\n"; 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->get_ResponseStatusCode(); if ($statusCode != 200) { print "Response status code: " . $statusCode . "\r\n"; print "Response status text: " . $rest->responseStatusText() . "\r\n"; print "Response body: " . "\r\n"; print $sbResponse->getAsString() . "\r\n"; print "Failed." . "\r\n"; exit; } print $sbResponse->getAsString() . "\r\n"; # 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 = chilkat::CkJsonObject->new(); $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"); print "Success!" . "\r\n"; |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.