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
(VBScript) Xero List Attachments for an Item (such as an Invoice)Demonstrates how to get information about the attachments for a particular Xero item. For more information, see https://developer.xero.com/documentation/api/attachments#GET
Dim fso, outFile Set fso = CreateObject("Scripting.FileSystemObject") 'Create a Unicode (utf-16) output text file. Set outFile = fso.CreateTextFile("output.txt", True, True) ' This example requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.Http") set http = CreateObject("Chilkat.Http") ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set jsonToken = CreateObject("Chilkat.JsonObject") success = jsonToken.LoadFile("qa_data/tokens/xero-access-token.json") If (success = 0) Then outFile.WriteLine(jsonToken.LastErrorText) WScript.Quit End If http.AuthToken = jsonToken.StringOf("access_token") ' Replace the value here with an actual tenant ID obtained from this example: ' Get Xero Tenant IDs http.SetRequestHeader "Xero-tenant-id","83299b9e-5747-4a14-a18a-a6c94f824eb7" http.Accept = "application/json" url = "https://api.xero.com/api.xro/2.0/{$Endpoint}/{$Guid}/Attachments/" ' Endpoint can be Invoices, Receipts, CreditNotes, PurchaseOrders, etc. success = http.SetUrlVar("Endpoint","Invoices") ' Guid is the ID of the item, such as the InvoiceID. success = http.SetUrlVar("Guid","0032f627-3156-4d30-9b1c-4d3b994dc921") ' resp is a Chilkat.HttpResponse Set resp = http.QuickRequest("GET",url) If (http.LastMethodSuccess <> 1) Then outFile.WriteLine(http.LastErrorText) WScript.Quit End If outFile.WriteLine("Response Status Code: " & resp.StatusCode) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set jsonResponse = CreateObject("Chilkat.JsonObject") success = jsonResponse.Load(resp.BodyStr) jsonResponse.EmitCompact = 0 outFile.WriteLine(jsonResponse.Emit()) If (resp.StatusCode <> 200) Then outFile.WriteLine("Failed.") WScript.Quit End If ' Sample response: ' ' Use the this online tool to generate parsing code from sample JSON: ' Generate Parsing Code from JSON ' { ' "Id": "24bfbcb9-dec9-4d33-835c-8f165d776766", ' "Status": "OK", ' "ProviderName": "Chilkat2222", ' "DateTimeUTC": "\/Date(1587213296972)\/", ' "Attachments": [ ' { ' "AttachmentID": "daf106e2-8634-4349-bfcc-86c1df0793b2", ' "FileName": "penguins.jpg", ' "Url": "https://api.xero.com/api.xro/2.0/Invoices/0032f627-3156-4d30-9b1c-4d3b994dc921/Attachments/penguins.jpg", ' "MimeType": "image/jpg", ' "ContentLength": 777835 ' } ' ] ' } Id = jsonResponse.StringOf("Id") Status = jsonResponse.StringOf("Status") ProviderName = jsonResponse.StringOf("ProviderName") DateTimeUTC = jsonResponse.StringOf("DateTimeUTC") i = 0 count_i = jsonResponse.SizeOfArray("Attachments") Do While i < count_i jsonResponse.I = i AttachmentID = jsonResponse.StringOf("Attachments[i].AttachmentID") FileName = jsonResponse.StringOf("Attachments[i].FileName") v_Url = jsonResponse.StringOf("Attachments[i].Url") MimeType = jsonResponse.StringOf("Attachments[i].MimeType") ContentLength = jsonResponse.IntOf("Attachments[i].ContentLength") i = i + 1 Loop outFile.Close |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.