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) Shippo Create a BatchDemonstrates how to create and purchase up to 10,000 shipments in a single API request. For more information, see https://goshippo.com/docs/batch/
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 assumes 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") ' Use this online tool to generate code from sample JSON: ' Generate Code to Create JSON ' The following JSON is sent in the request body. ' { ' "default_carrier_account": "078870331023437cb917f5187429b093", ' "default_servicelevel_token": "usps_priority", ' "label_filetype": "PDF_4x6", ' "metadata": "BATCH #170", ' "batch_shipments": [ ' { ' "shipment": { ' "address_from": { ' "name": "Mr Hippo", ' "street1": "965 Mission St", ' "street2": "Ste 201", ' "city": "San Francisco", ' "state": "CA", ' "zip": "94103", ' "country": "US", ' "phone": "4151234567", ' "email": "mrhippo@goshippo.com" ' }, ' "address_to": { ' "name": "Mrs Hippo", ' "company": "", ' "street1": "Broadway 1", ' "street2": "", ' "city": "New York", ' "state": "NY", ' "zip": "10007", ' "country": "US", ' "phone": "4151234567", ' "email": "mrshippo@goshippo.com" ' }, ' "parcels": [ ' { ' "length": "5", ' "width": "5", ' "height": "5", ' "distance_unit": "in", ' "weight": "2", ' "mass_unit": "oz" ' } ' ] ' } ' }, ' { ' "shipment": { ' "address_from": { ' "name": "Mr Hippo", ' "street1": "1092 Indian Summer Ct", ' "city": "San Jose", ' "state": "CA", ' "zip": "95122", ' "country": "US", ' "phone": "4151234567", ' "email": "mrhippo@goshippo.com" ' }, ' "address_to": { ' "name": "Mrs Hippo", ' "company": "", ' "street1": "Broadway 1", ' "street2": "", ' "city": "New York", ' "state": "NY", ' "zip": "10007", ' "country": "US", ' "phone": "4151234567", ' "email": "mrshippo@goshippo.com" ' }, ' "parcels": [ ' { ' "length": "5", ' "width": "5", ' "height": "5", ' "distance_unit": "in", ' "weight": "20", ' "mass_unit": "lb" ' } ' ] ' }, ' "carrier_account": "a4391cd4ab974f478f55dc08b5c8e3b3", ' "servicelevel_token": "fedex_2_day" ' } ' ] ' } ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set json = CreateObject("Chilkat.JsonObject") success = json.UpdateString("default_carrier_account","078870331023437cb917f5187429b093") success = json.UpdateString("default_servicelevel_token","usps_priority") success = json.UpdateString("label_filetype","PDF_4x6") success = json.UpdateString("metadata","BATCH #170") success = json.UpdateString("batch_shipments[0].shipment.address_from.name","Mr Hippo") success = json.UpdateString("batch_shipments[0].shipment.address_from.street1","965 Mission St") success = json.UpdateString("batch_shipments[0].shipment.address_from.street2","Ste 201") success = json.UpdateString("batch_shipments[0].shipment.address_from.city","San Francisco") success = json.UpdateString("batch_shipments[0].shipment.address_from.state","CA") success = json.UpdateString("batch_shipments[0].shipment.address_from.zip","94103") success = json.UpdateString("batch_shipments[0].shipment.address_from.country","US") success = json.UpdateString("batch_shipments[0].shipment.address_from.phone","4151234567") success = json.UpdateString("batch_shipments[0].shipment.address_from.email","mrhippo@goshippo.com") success = json.UpdateString("batch_shipments[0].shipment.address_to.name","Mrs Hippo") success = json.UpdateString("batch_shipments[0].shipment.address_to.company","") success = json.UpdateString("batch_shipments[0].shipment.address_to.street1","Broadway 1") success = json.UpdateString("batch_shipments[0].shipment.address_to.street2","") success = json.UpdateString("batch_shipments[0].shipment.address_to.city","New York") success = json.UpdateString("batch_shipments[0].shipment.address_to.state","NY") success = json.UpdateString("batch_shipments[0].shipment.address_to.zip","10007") success = json.UpdateString("batch_shipments[0].shipment.address_to.country","US") success = json.UpdateString("batch_shipments[0].shipment.address_to.phone","4151234567") success = json.UpdateString("batch_shipments[0].shipment.address_to.email","mrshippo@goshippo.com") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].length","5") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].width","5") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].height","5") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].distance_unit","in") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].weight","2") success = json.UpdateString("batch_shipments[0].shipment.parcels[0].mass_unit","oz") success = json.UpdateString("batch_shipments[1].shipment.address_from.name","Mr Hippo") success = json.UpdateString("batch_shipments[1].shipment.address_from.street1","1092 Indian Summer Ct") success = json.UpdateString("batch_shipments[1].shipment.address_from.city","San Jose") success = json.UpdateString("batch_shipments[1].shipment.address_from.state","CA") success = json.UpdateString("batch_shipments[1].shipment.address_from.zip","95122") success = json.UpdateString("batch_shipments[1].shipment.address_from.country","US") success = json.UpdateString("batch_shipments[1].shipment.address_from.phone","4151234567") success = json.UpdateString("batch_shipments[1].shipment.address_from.email","mrhippo@goshippo.com") success = json.UpdateString("batch_shipments[1].shipment.address_to.name","Mrs Hippo") success = json.UpdateString("batch_shipments[1].shipment.address_to.company","") success = json.UpdateString("batch_shipments[1].shipment.address_to.street1","Broadway 1") success = json.UpdateString("batch_shipments[1].shipment.address_to.street2","") success = json.UpdateString("batch_shipments[1].shipment.address_to.city","New York") success = json.UpdateString("batch_shipments[1].shipment.address_to.state","NY") success = json.UpdateString("batch_shipments[1].shipment.address_to.zip","10007") success = json.UpdateString("batch_shipments[1].shipment.address_to.country","US") success = json.UpdateString("batch_shipments[1].shipment.address_to.phone","4151234567") success = json.UpdateString("batch_shipments[1].shipment.address_to.email","mrshippo@goshippo.com") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].length","5") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].width","5") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].height","5") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].distance_unit","in") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].weight","20") success = json.UpdateString("batch_shipments[1].shipment.parcels[0].mass_unit","lb") success = json.UpdateString("batch_shipments[1].carrier_account","a4391cd4ab974f478f55dc08b5c8e3b3") success = json.UpdateString("batch_shipments[1].servicelevel_token","fedex_2_day") http.SetRequestHeader "Authorization","ShippoToken shippo_test_3af5d574e2f845d30efcaf9b2f47d9c2aef4807a" http.SetRequestHeader "Content-Type","application/json" ' resp is a Chilkat.HttpResponse Set resp = http.PostJson3("https://api.goshippo.com/batches/","application/json",json) If (http.LastMethodSuccess = 0) Then outFile.WriteLine(http.LastErrorText) WScript.Quit End If ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.StringBuilder") set sbResponseBody = CreateObject("Chilkat.StringBuilder") success = resp.GetBodySb(sbResponseBody) ' For versions of Chilkat < 10.0.0, use CreateObject("Chilkat_9_5_0.JsonObject") set jResp = CreateObject("Chilkat.JsonObject") success = jResp.LoadSb(sbResponseBody) jResp.EmitCompact = 0 outFile.WriteLine("Response Body:") outFile.WriteLine(jResp.Emit()) respStatusCode = resp.StatusCode outFile.WriteLine("Response Status Code = " & respStatusCode) If (respStatusCode >= 400) Then outFile.WriteLine("Response Header:") outFile.WriteLine(resp.Header) outFile.WriteLine("Failed.") WScript.Quit End If ' Sample JSON response: ' (Sample code for parsing the JSON response is shown below) ' { ' "object_id": "a015eb693cca465dbb6523ce6d2e3c65", ' "object_owner": "admin", ' "status": "VALIDATING", ' "object_created": "2016-09-12T15:25:43.465Z", ' "object_updated": "2016-09-12T15:25:43.465Z", ' "metadata": "BATCH #170", ' "default_carrier_account": "078870331023437cb917f5187429b093", ' "default_servicelevel_token": "usps_priority", ' "label_filetype": "PDF_4x6", ' "batch_shipments": { ' "next": null, ' "previous": null, ' "results": [ ' ] ' }, ' "object_results": { ' "purchase_succeeded": 0, ' "purchase_failed": 0, ' "creation_failed": 0, ' "creation_succeeded": 0 ' }, ' "label_url": [ ' ] ' } ' Sample code for parsing the JSON response... ' Use the following online tool to generate parsing code from sample JSON: ' Generate Parsing Code from JSON object_id = jResp.StringOf("object_id") object_owner = jResp.StringOf("object_owner") status = jResp.StringOf("status") object_created = jResp.StringOf("object_created") object_updated = jResp.StringOf("object_updated") metadata = jResp.StringOf("metadata") default_carrier_account = jResp.StringOf("default_carrier_account") default_servicelevel_token = jResp.StringOf("default_servicelevel_token") label_filetype = jResp.StringOf("label_filetype") batch_shipmentsNext = jResp.StringOf("batch_shipments.next") batch_shipmentsPrevious = jResp.StringOf("batch_shipments.previous") object_resultsPurchase_succeeded = jResp.IntOf("object_results.purchase_succeeded") object_resultsPurchase_failed = jResp.IntOf("object_results.purchase_failed") object_resultsCreation_failed = jResp.IntOf("object_results.creation_failed") object_resultsCreation_succeeded = jResp.IntOf("object_results.creation_succeeded") i = 0 count_i = jResp.SizeOfArray("batch_shipments.results") Do While i < count_i jResp.I = i i = i + 1 Loop i = 0 count_i = jResp.SizeOfArray("label_url") Do While i < count_i jResp.I = i i = i + 1 Loop outFile.Close |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.