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
(SQL Server) hotelbeds.com REST API AuthenticationDemonstrates how to calculate the X-Signature header and add to requests sent to api.test.hotelbeds.com. For more information, see https://developer.hotelbeds.com/documentation/getting-started/
-- Important: See this note about string length limitations for strings returned by sp_OAMethod calls. -- CREATE PROCEDURE ChilkatSample AS BEGIN DECLARE @hr int DECLARE @iTmp0 int -- Important: Do not use nvarchar(max). See the warning about using nvarchar(max). DECLARE @sTmp0 nvarchar(4000) -- This example requires the Chilkat API to have been previously unlocked. -- See Global Unlock Sample for sample code. -- This example duplicates the following CURL statement provided in the hotelbeds.com "Getting Started" -- developer documentation: -- #!/bin/bash -- apiKey="yourApiKey" -- secret="yourSecret" -- curl -i \ -- -X GET \ -- -H 'Accept:application/json' \ -- -H 'Api-key:'$apiKey'' \ -- -H 'X-Signature:'$(echo -n ${apiKey}${secret}$(date +%s)|sha256sum|awk '{ print $1}')'' \ -- https://api.test.hotelbeds.com/hotel-api/1.0/status DECLARE @success int -- The "date + %s" command emits a UNIX date/time number such as 1605548842 -- We need to concatenate the apiKey, secret, and current date/time in UNIX (numeric) time format. DECLARE @dt int -- Use "Chilkat_9_5_0.CkDateTime" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.CkDateTime', @dt OUT IF @hr <> 0 BEGIN PRINT 'Failed to create ActiveX component' RETURN END EXEC sp_OAMethod @dt, 'SetFromCurrentSystemTime', @success OUT -- Get the UNIX time string in the GMT timezone. DECLARE @bLocalTime int SELECT @bLocalTime = 0 DECLARE @unixTimeStr nvarchar(4000) EXEC sp_OAMethod @dt, 'GetAsUnixTimeStr', @unixTimeStr OUT, @bLocalTime PRINT @unixTimeStr -- Use your own API key and secret. (These are not valid values) DECLARE @apiKey nvarchar(4000) SELECT @apiKey = '227b20a2cb705e45f3b0a0944672dc07' DECLARE @secret nvarchar(4000) SELECT @secret = '54dc7ba9e2' DECLARE @sb int -- Use "Chilkat_9_5_0.StringBuilder" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.StringBuilder', @sb OUT EXEC sp_OAMethod @sb, 'Append', @success OUT, @apiKey EXEC sp_OAMethod @sb, 'Append', @success OUT, @secret EXEC sp_OAMethod @sb, 'Append', @success OUT, @unixTimeStr DECLARE @crypt int -- Use "Chilkat_9_5_0.Crypt2" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Crypt2', @crypt OUT EXEC sp_OASetProperty @crypt, 'HashAlgorithm', 'sha256' EXEC sp_OASetProperty @crypt, 'EncodingMode', 'hexlower' DECLARE @signature nvarchar(4000) EXEC sp_OAMethod @sb, 'GetAsString', @sTmp0 OUT EXEC sp_OAMethod @crypt, 'HashStringENC', @signature OUT, @sTmp0 PRINT @signature DECLARE @http int -- Use "Chilkat_9_5_0.Http" for versions of Chilkat < 10.0.0 EXEC @hr = sp_OACreate 'Chilkat.Http', @http OUT EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'Accept', 'application/json' EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'Api-key', @apiKey EXEC sp_OAMethod @http, 'SetRequestHeader', NULL, 'X-Signature', @signature DECLARE @jsonResponse nvarchar(4000) EXEC sp_OAMethod @http, 'QuickGetStr', @jsonResponse OUT, 'https://api.test.hotelbeds.com/hotel-api/1.0/status' PRINT @jsonResponse EXEC sp_OAGetProperty @http, 'LastStatus', @iTmp0 OUT PRINT @iTmp0 -- Sample output: -- 1605549542 -- 2146aefb36e7331b3b29aafd7638398ca22e689573224f1a71274d60bd201ec2 -- {"auditData":{"timestamp":"2020-11-16 18:59:02.430"},"status":"OK"} -- 200 EXEC @hr = sp_OADestroy @dt EXEC @hr = sp_OADestroy @sb EXEC @hr = sp_OADestroy @crypt EXEC @hr = sp_OADestroy @http END GO |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.