Chilkat HOME Android™ Classic ASP C C++ C# Mono C# .NET Core C# C# UWP/WinRT DataFlex Delphi ActiveX Delphi DLL Visual FoxPro Java Lianja MFC Objective-C Perl PHP ActiveX PHP Extension PowerBuilder PowerShell PureBasic CkPython Chilkat2-Python Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ Visual Basic 6.0 VB.NET VB.NET UWP/WinRT VBScript Xojo Plugin Node.js Excel Go
(Excel) effectconnect Create or Replace Product CatalogUse this call to create or replace a product catalog in EffectConnect. This is always a purge and replace action for the entire catalog.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. uri = "/products" apiVersion = "2.0" Dim http As Chilkat.Http Set http = Chilkat.NewHttp Dim req As Chilkat.HttpRequest Set req = Chilkat.NewHttpRequest ' Use your effectconnect public key here... req.AddHeader "KEY","PUBLIC_KEY" req.AddHeader "VERSION",apiVersion req.AddHeader "URI",uri req.AddHeader "RESPONSETYPE","XML" req.AddHeader "RESPONSELANGUAGE","en" ' Get the current date/time in timestamp format. Dim dt As Chilkat.CkDateTime Set dt = Chilkat.NewCkDateTime success = dt.SetFromCurrentSystemTime() timestamp = dt.GetAsTimestamp(True) req.AddHeader "TIME",timestamp Debug.Print "timestamp = "; timestamp Dim sbXml As Chilkat.StringBuilder Set sbXml = Chilkat.NewStringBuilder success = sbXml.LoadFile("qa_data/xml/effectconnect/effconCreate.xml","utf-8") Debug.Print "length = "; sbXml.Length req.HttpVerb = "POST" req.Path = uri req.ContentType = "multipart/form-data" success = req.AddStringForUpload("payload","effcon.xml",sbXml.GetAsString(),"utf-8") If (success = False) Then Debug.Print req.LastErrorText Exit Sub End If ' Build a string-to-sign and sign it using our effectconnect private key Dim sbStringToSign As Chilkat.StringBuilder Set sbStringToSign = Chilkat.NewStringBuilder success = sbStringToSign.AppendInt(sbXml.Length) success = sbStringToSign.Append("POST") success = sbStringToSign.Append(uri) success = sbStringToSign.Append(apiVersion) success = sbStringToSign.Append(timestamp) Dim crypt As Chilkat.Crypt2 Set crypt = Chilkat.NewCrypt2 crypt.MacAlgorithm = "hmac" crypt.HashAlgorithm = "sha512" crypt.EncodingMode = "base64" ' Use your effectconnect private key here: success = crypt.SetMacKeyString("PRIVATE_KEY") req.AddHeader "SIGNATURE",crypt.MacStringENC(sbStringToSign.GetAsString()) Set resp = http.SynchronousRequest("submit.effectconnect.com",443,True,req) If (http.LastMethodSuccess = False) Then Debug.Print http.LastErrorText Exit Sub End If Debug.Print "response status code = "; resp.StatusCode ' Examine the response. The response status code can be 200 for both errors and success. ' The success or error is based on the XML returned in the response body. Dim xmlResp As Chilkat.Xml Set xmlResp = Chilkat.NewXml success = xmlResp.LoadXml(resp.BodyStr) Debug.Print "response body:" Debug.Print xmlResp.GetXml() ' A sample response: ' <?xml version="1.0" encoding="utf-8"?> ' <ApiResponseContainer> ' <Request> ' <RequestType>Products</RequestType> ' <RequestAction>Create</RequestAction> ' <RequestVersion>2.0</RequestVersion> ' <RequestIdentifier/> ' <ProcessedAt>2019-04-18T15:28:55+02:00</ProcessedAt> ' </Request> ' <Response> ' <Result>Success</Result> ' <ProductsCreateResponseContainer> ' <ProcessID><![CDATA[J048hgS4OkNn0JnH]]></ProcessID> ' </ProductsCreateResponseContainer> ' </Response> ' </ApiResponseContainer> ' Parsing the response... RequestType = xmlResp.GetChildContent("Request|RequestType") RequestAction = xmlResp.GetChildContent("Request|RequestAction") RequestVersion = xmlResp.GetChildContent("Request|RequestVersion") ProcessedAt = xmlResp.GetChildContent("Request|ProcessedAt") Result = xmlResp.GetChildContent("Response|Result") ProcessID = xmlResp.GetChildContent("Response|ProductsCreateResponseContainer|ProcessID") |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.