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 Read OrderlistGet a set of orders filtered by the parameters in the XML payload.
' This example assumes the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. fullUri = "https://submit.effectconnect.com/orderlist" uri = "/orderlist" apiVersion = "2.0" Dim http As Chilkat.Http Set http = Chilkat.NewHttp ' Use your effectconnect public key here.. http.SetRequestHeader "KEY","PUBLIC_KEY" http.SetRequestHeader "VERSION",apiVersion http.SetRequestHeader "URI",uri http.SetRequestHeader "RESPONSETYPE","XML" http.SetRequestHeader "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) http.SetRequestHeader "TIME",timestamp Debug.Print "timestamp = "; timestamp ' Create the following XML request body: ' <?xml version="1.0" encoding="utf-8"?> ' <list> ' <filters> ' <fromDateFilter> ' <filterValue>2018-09-14T12:12:12+01:00</filterValue> ' </fromDateFilter> ' <toDateFilter> ' <filterValue>2019-04-13T23:59:59+01:00</filterValue> ' </toDateFilter> ' <hasStatusFilter> ' <filterValue>paid</filterValue> ' </hasStatusFilter> ' <hasTagFilter> ' <filterValue> ' <tagName>Test</tagName> ' <exclude>false</exclude> ' </filterValue> ' </hasTagFilter> ' </filters> ' </list> ' Use this online tool to generate the code from sample XML: ' Generate Code to Create XML Dim xml As Chilkat.Xml Set xml = Chilkat.NewXml xml.Tag = "list" xml.UpdateChildContent "filters|fromDateFilter|filterValue","2018-09-14T12:12:12+01:00" xml.UpdateChildContent "filters|toDateFilter|filterValue","2019-04-13T23:59:59+01:00" xml.UpdateChildContent "filters|hasStatusFilter|filterValue","paid" xml.UpdateChildContent "filters|hasTagFilter|filterValue|tagName","Test" xml.UpdateChildContent "filters|hasTagFilter|filterValue|exclude","false" xml.EmitCompact = True Dim sbXml As Chilkat.StringBuilder Set sbXml = Chilkat.NewStringBuilder success = xml.GetXmlSb(sbXml) ' 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") http.SetRequestHeader "SIGNATURE",crypt.MacStringENC(sbStringToSign.GetAsString()) ' Send the POST.. Set resp = http.PostXml(fullUri,xml.GetXml(),"utf-8") 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() ' Remove previously set headers (unless we want the same headers for the next request, ' in which case we may remove or update individual headers by calling SetRequestHeader. http.ClearHeaders |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.