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.