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
(Node.js) ebay: Add Digital Signature to HTTP RequestSee more eBay ExamplesDemonstrates how to add a digital signature to an ebay HTTP request. For more information, see https://developer.ebay.com/develop/guides/digital-signatures-for-apis
var os = require('os'); if (os.platform() == 'win32') { if (os.arch() == 'ia32') { var chilkat = require('@chilkat/ck-node21-win-ia32'); } else { var chilkat = require('@chilkat/ck-node21-win64'); } } else if (os.platform() == 'linux') { if (os.arch() == 'arm') { var chilkat = require('@chilkat/ck-node21-arm'); } else if (os.arch() == 'x86') { var chilkat = require('@chilkat/ck-node21-linux32'); } else { var chilkat = require('@chilkat/ck-node21-linux64'); } } else if (os.platform() == 'darwin') { if (os.arch() == 'arm64') { var chilkat = require('@chilkat/ck-node21-mac-m1'); } else { var chilkat = require('@chilkat/ck-node21-macosx'); } } function chilkatExample() { // This example requires the Chilkat API to have been previously unlocked. // See Global Unlock Sample for sample code. var success; // Note: Ebay provides a Key Management API // See https://developer.ebay.com/api-docs/developer/key-management/overview.html // The following test keys can be used: // // Ed25519 // // Private Key: // // -----BEGIN PRIVATE KEY----- // MC4CAQAwBQYDK2VwBCIEIJ+DYvh6SEqVTm50DFtMDoQikTmiCqirVv9mWG9qfSnF // -----END PRIVATE KEY----- var strPrivateKey = "MC4CAQAwBQYDK2VwBCIEIJ+DYvh6SEqVTm50DFtMDoQikTmiCqirVv9mWG9qfSnF"; // // Public Key: // // -----BEGIN PUBLIC KEY----- // MCowBQYDK2VwAyEAJrQLj5P/89iXES9+vFgrIy29clF9CC/oPPsw3c5D0bs= // -----END PUBLIC KEY----- var strPublicKey = "MCowBQYDK2VwAyEAJrQLj5P/89iXES9+vFgrIy29clF9CC/oPPsw3c5D0bs="; // This example assumes you got a JWE for your given private key from the Ebay Key Management REST API. // This JWE is just for example: var strJwe = "eyJ6aXAiOiJERUYiLCJlbmMiOiJBMjU2R0NNIiwidGFnIjoiSXh2dVRMb0FLS0hlS0Zoa3BxQ05CUSIsImFsZyI6IkEyNTZHQ01LVyIsIml2IjoiaFd3YjNoczk2QzEyOTNucCJ9.2o02pR9SoTF4g_5qRXZm6tF4H52TarilIAKxoVUqjd8.3qaF0KJN-rFHHm_P.AMUAe9PPduew09mANIZ-O_68CCuv6EIx096rm9WyLZnYz5N1WFDQ3jP0RBkbaOtQZHImMSPXIHVaB96RWshLuJsUgCKmTAwkPVCZv3zhLxZVxMXtPUuJ-ppVmPIv0NzznWCOU5Kvb9Xux7ZtnlvLXgwOFEix-BaWNomUAazbsrUCbrp514GIea3butbyxXLNi6R9TJUNh8V2uan-optT1MMyS7eMQnVGL5rYBULk.9K5ucUqAu0DqkkhgubsHHw"; var sbBody = new chilkat.StringBuilder(); sbBody.Append("{\"hello\": \"world\"}"); console.log("Body of request:"); console.log(sbBody.GetAsString()); // ------------------------------------------------- // Build the signature base string... var sbSigBase = new chilkat.StringBuilder(); sbSigBase.Append("\"content-digest\": sha-256=:"); sbSigBase.Append(sbBody.GetHash("sha256","base64","utf-8")); sbSigBase.Append(":\n"); sbSigBase.Append("\"x-ebay-signature-key\": "); sbSigBase.Append(strJwe); sbSigBase.Append("\n"); sbSigBase.Append("\"@method\": POST\n"); // This is the path part of the URL without query params... sbSigBase.Append("\"@path\": "); sbSigBase.Append("/verifysignature"); sbSigBase.Append("\n"); // The is the domain, such as "api.ebay.com" w/ port if the port is something unusual. // In this example, we're testing against a local docker test server (see the info at https://developer.ebay.com/develop/guides/digital-signatures-for-apis) // Normally, I think it would just be "api.ebay.com" instead of "localhost:8080". sbSigBase.Append("\"@authority\": "); sbSigBase.Append("localhost:8080"); sbSigBase.Append("\n"); sbSigBase.Append("\"@signature-params\": "); var sbSigInput = new chilkat.StringBuilder(); sbSigInput.Append("(\"content-digest\" \"x-ebay-signature-key\" \"@method\" \"@path\" \"@authority\")"); sbSigInput.Append(";created="); var dt = new chilkat.CkDateTime(); dt.SetFromCurrentSystemTime(); var unixTimeNow = dt.GetAsUnixTimeStr(false); sbSigInput.Append(unixTimeNow); sbSigBase.AppendSb(sbSigInput); // ------------------------------------------------- // Sign the signature base string using the Ed25519 private key var bdPrivKey = new chilkat.BinData(); bdPrivKey.AppendEncoded(strPrivateKey,"base64"); var privKey = new chilkat.PrivateKey(); success = privKey.LoadAnyFormat(bdPrivKey,""); if (success == false) { console.log(privKey.LastErrorText); return; } var bdToBeSigned = new chilkat.BinData(); bdToBeSigned.AppendSb(sbSigBase,"utf-8"); var eddsa = new chilkat.EdDSA(); var sigBase64 = eddsa.SignBdENC(bdToBeSigned,"base64",privKey); if (eddsa.LastMethodSuccess == false) { console.log(eddsa.LastErrorText); return; } console.log("sigBase64:"); console.log(sigBase64); // ---------------------------------------------------------- // Send the JSON POST var http = new chilkat.Http(); http.SetRequestHeader("x-ebay-signature-key",strJwe); var sbContentDigestHdr = new chilkat.StringBuilder(); sbContentDigestHdr.Append("sha-256=:"); sbContentDigestHdr.Append(sbBody.GetHash("sha256","base64","utf-8")); sbContentDigestHdr.Append(":"); http.SetRequestHeader("Content-Digest",sbContentDigestHdr.GetAsString()); var sbSigHdr = new chilkat.StringBuilder(); sbSigHdr.Append("sig1=:"); sbSigHdr.Append(sigBase64); sbSigHdr.Append(":"); http.SetRequestHeader("Signature",sbSigHdr.GetAsString()); sbSigInput.Prepend("sig1="); http.SetRequestHeader("Signature-Input",sbSigInput.GetAsString()); // Add this header to make eBay actually check the signature. http.SetRequestHeader("x-ebay-enforce-signature","true"); // Set the OAuth2 access token to add the "Authorization: Bearer <access_token>" to the header. http.AuthToken = "your_oauth2_access_token"; // The signature base string constructed above is valid if we send this POST to "http://localhost:8080/verifysignature" // Normally, you'll send your POST to some api.ebay.com endpoint. var url = "http://localhost:8080/verifysignature"; // resp: HttpResponse var resp = http.PostJson2("http://localhost:8080/verifysignature","application/json",sbBody.GetAsString()); if (http.LastMethodSuccess == false) { console.log(http.LastErrorText); return; } console.log("Response status code: " + resp.StatusCode); console.log("Response body:"); console.log(resp.BodyStr); } chilkatExample(); |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.