Chilkat HOME Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi DLL Go Java Node.js Objective-C PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) eBay -- Get Inventory ItemsRetrieves up to 100 inventory items. If an eBay account has more than 100 inventory items, then the Nth page of inventory items can be retrieved, until there are no more pages. (The first page of records has a value of 0, the second page of records has a value of 1, etc.)
LOCAL lcAccessToken LOCAL loHttp LOCAL loSbUrl LOCAL lnNumReplaced LOCAL loSbAuth LOCAL lcStrJson LOCAL loJson LOCAL lnNumItems LOCAL i LOCAL j LOCAL loBrands LOCAL lnNumBrands LOCAL loFeatures LOCAL lnNumFeatures * This example assumes the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * Use a previously obtained user token. The token should look something like this: * "v^1.1#i^1#r^0#p^3#I^3#f^0#t^H4sIAAAAAAAAAOVXa2wUVRTu9k ... 89xuCWYREAAA==" lcAccessToken = "EBAY_ACCESS_TOKEN" * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Http') loHttp = CreateObject('Chilkat.Http') * This example uses the sandbox. * Change "api.sandbox.ebay.com" to "api.ebay.com" to use the production system. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbUrl = CreateObject('Chilkat.StringBuilder') loSbUrl.Append("https://api.sandbox.ebay.com/sell/inventory/v1/inventory_item?limit=_LIMIT&offset=_OFFSET") lnNumReplaced = loSbUrl.Replace("_LIMIT","100") * The offset indicates the page number. Offset 0 gets items 0-99 (if limit=100), * Offset 1 gets items 100-199, etc. lnNumReplaced = loSbUrl.Replace("_OFFSET","0") * Add our access token to the request, which is a header * having the following format: * Authorization: Bearer <userAccessToken> * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.StringBuilder') loSbAuth = CreateObject('Chilkat.StringBuilder') loSbAuth.Append("Bearer ") loSbAuth.Append(lcAccessToken) loHttp.SetRequestHeader("Authorization",loSbAuth.GetAsString()) loHttp.Accept = "application/json" loHttp.AllowGzip = 1 lcStrJson = loHttp.QuickGetStr(loSbUrl.GetAsString()) IF (loHttp.LastMethodSuccess <> 1) THEN ? loHttp.LastErrorText RELEASE loHttp RELEASE loSbUrl RELEASE loSbAuth CANCEL ENDIF * The response should be JSON, even if an error. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJson = CreateObject('Chilkat.JsonObject') loJson.Load(lcStrJson) loJson.EmitCompact = 0 ? "Response status code = " + STR(loHttp.LastStatus) IF (loHttp.LastStatus <> 200) THEN ? loJson.Emit() ? "Failed" RELEASE loHttp RELEASE loSbUrl RELEASE loSbAuth RELEASE loJson CANCEL ENDIF * See the sample JSON response below.. ? loJson.Emit() * To iterate over the inventory items.. lnNumItems = loJson.SizeOfArray("inventoryItems") i = 0 DO WHILE i < lnNumItems loJson.I = i ? STR(i) + ") sku: " + loJson.StringOf("inventoryItems[i].sku") ? " title: " + loJson.StringOf("inventoryItems[i].product.title") IF (loJson.HasMember("inventoryItems[i].product.aspects.Brand") = 1) THEN loBrands = loJson.ArrayOf("inventoryItems[i].product.aspects.Brand") lnNumBrands = loBrands.Size j = 0 DO WHILE j < lnNumBrands ? " brand: " + loBrands.StringAt(j) j = j + 1 ENDDO ENDIF IF (loJson.HasMember("inventoryItems[i].product.aspects.Feature") = 1) THEN loFeatures = loJson.ArrayOf("inventoryItems[i].product.aspects.Feature") lnNumFeatures = loFeatures.Size j = 0 DO WHILE j < lnNumFeatures ? " feature: " + loFeatures.StringAt(j) j = j + 1 ENDDO ENDIF i = i + 1 ENDDO * The output of the above loop: * 0) sku: GP-Cam-01 * title: GoPro Hero4 Helmet Cam * brand: GoPro * 1) sku: AppleWatch * title: Test listing - do not bid or buy - awesome Apple watch test 2 * feature: Water resistance * feature: GPS * * * A sample JSON response with 2 inventory items. * { * "total": 2, * "size": 2, * "href": "/sell/inventory/v1/inventory_item?offset=0&limit=100", * "limit": 100, * "inventoryItems": [ * { * "sku": "GP-Cam-01", * "product": { * "title": "GoPro Hero4 Helmet Cam", * "aspects": { * "Brand": [ * "GoPro" * ], * "Optical Zoom": [ * "10x" * ], * "Type": [ * "Helmet/Action" * ], * "Recording Definition": [ * "High Definition" * ], * "Media Format": [ * "Flash Drive (SSD)" * ], * "Storage Type": [ * "Removable" * ] * }, * "description": "New GoPro Hero4 Helmet Cam. Unopened box.", * "imageUrls": [ * "http://i.ebayimg.com/images/i/182196556219-0-1/s-l1000.jpg", * "http://i.ebayimg.com/images/i/182196556219-0-1/s-l1001.jpg", * "http://i.ebayimg.com/images/i/182196556219-0-1/s-l1002.jpg" * ] * }, * "condition": "NEW", * "availability": { * "pickupAtLocationAvailability": [ * ], * "shipToLocationAvailability": { * "quantity": 50 * } * } * }, * { * "sku": "AppleWatch", * "product": { * "title": "Test listing - do not bid or buy - awesome Apple watch test 2", * "aspects": { * "CPU": [ * "Dual-Core Processor" * ], * "Feature": [ * "Water resistance", * "GPS" * ] * }, * "description": "Test listing - do not bid or buy\n Built-in GPS. Water resistance to 50 meters.1 A new lightning-fast dual-core processor. And a display that?s two times brighter than before. Full of features that help you stay active, motivated, and connected, Apple Watch Series 2 is designed for all the ways you move ", * "upc": [ * "888462079525" * ], * "imageUrls": [ * "http://store.storeimages.cdn-apple.com/4973/as-images.apple.com/is/image/AppleInc/aos/published/images/S/1/S1/42/S1-42-alu-silver-sport-white-grid?wid=332&hei=392&fmt=jpeg&qlt=95&op_sharpen=0&resMode=bicub&op_usm=0.5,0.5,0,0&iccEmbed=0&layer=comp&.v=1472247758975", * "http://store.storeimages.cdn-apple.com/4973/as-images.apple.com/is/image/AppleInc/aos/published/images/4/2/42/stainless/42-stainless-sport-white-grid?wid=332&hei=392&fmt=jpeg&qlt=95&op_sharpen=0&resMode=bicub&op_usm=0.5,0.5,0,0&iccEmbed=0&layer=comp&.v=1472247760390", * "http://store.storeimages.cdn-apple.com/4973/as-images.apple.com/is/image/AppleInc/aos/published/images/4/2/42/ceramic/42-ceramic-sport-cloud-grid?wid=332&hei=392&fmt=jpeg&qlt=95&op_sharpen=0&resMode=bicub&op_usm=0.5,0.5,0,0&iccEmbed=0&layer=comp&.v=1472247758007" * ] * }, * "condition": "NEW", * "packageWeightAndSize": { * "dimensions": { * "width": 15.0, * "length": 10.0, * "height": 5.0, * "unit": "INCH" * }, * "weight": { * "value": 2.0, * "unit": "POUND" * } * }, * "availability": { * "pickupAtLocationAvailability": [ * ], * "shipToLocationAvailability": { * "quantity": 10 * } * } * } * ] * } * * * RELEASE loHttp RELEASE loSbUrl RELEASE loSbAuth RELEASE loJson |
© 2000-2025 Chilkat Software, Inc. All Rights Reserved.