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) List all Pages of Files in Google DriveDemonstrates how iterate over pages to list files in Google Drive. See Google Drive Files list for more optional HTTP parameters.
success = True ' It requires the Chilkat API to have been previously unlocked. ' See Global Unlock Sample for sample code. ' This example uses a previously obtained access token having permission for the ' Google Drive scope. Dim gAuth As Chilkat.AuthGoogle Set gAuth = Chilkat.NewAuthGoogle gAuth.AccessToken = "GOOGLE-DRIVE-ACCESS-TOKEN" Dim rest As Chilkat.Rest Set rest = Chilkat.NewRest ' Connect using TLS. bAutoReconnect = True success = rest.Connect("www.googleapis.com",443,True,bAutoReconnect) ' Provide the authentication credentials (i.e. the access token) Dim success As Boolean success = rest.SetAuthGoogle(gAuth) ' Get 5 results per page for testing. (The default page size is 100, with a max of 1000. success = rest.AddQueryParam("pageSize","5") Dim json As Chilkat.JsonObject Set json = Chilkat.NewJsonObject ' Send the request for the 1st page. jsonResponse = rest.FullRequestNoBody("GET","/drive/v3/files") pageNumber = 1 bContinueLoop = rest.LastMethodSuccess And (rest.ResponseStatusCode = 200) Do While bContinueLoop = True Debug.Print "---- Page "; pageNumber; " ----" ' Iterate over each file in the response and show the name, id, and mimeType. success = json.Load(jsonResponse) ' See the sample JSON response at the bottom of this example. numFiles = json.SizeOfArray("files") i = 0 Do While i < numFiles json.I = i Debug.Print "name: "; json.StringOf("files[i].name") Debug.Print "id: "; json.StringOf("files[i].id") Debug.Print "mimeType: "; json.StringOf("files[i].mimeType") Debug.Print "-" i = i + 1 Loop ' Get the next page of files. ' If the "nextPageToken" is present in the JSON response, then use it in the "pageToken" parameter ' for the next request. If no "nextPageToken" was present, then this was the last page of files. pageToken = json.StringOf("nextPageToken") bContinueLoop = False bHasMorePages = json.LastMethodSuccess If (bHasMorePages = True) Then success = rest.ClearAllQueryParams() success = rest.AddQueryParam("pageSize","5") success = rest.AddQueryParam("pageToken",pageToken) jsonResponse = rest.FullRequestNoBody("GET","/drive/v3/files") bContinueLoop = rest.LastMethodSuccess And (rest.ResponseStatusCode = 200) pageNumber = pageNumber + 1 End If Loop If (rest.LastMethodSuccess <> True) Then Debug.Print rest.LastErrorText Exit Sub End If ' A successful response will have a status code equal to 200. If (rest.ResponseStatusCode <> 200) Then Debug.Print "response status code = "; rest.ResponseStatusCode Debug.Print "response status text = "; rest.ResponseStatusText Debug.Print "response header: "; rest.ResponseHeader Debug.Print "response JSON: "; jsonResponse Exit Sub End If ' A successful JSON response looks like this: ' { ' "kind": "drive#fileList", ' "files": [ ' { ' "kind": "drive#file", ' "id": "0B53Q6OSTWYolenpjTEU4ekJlQUU", ' "name": "test", ' "mimeType": "application/vnd.google-apps.folder" ' }, ' { ' "kind": "drive#file", ' "id": "0B53Q6OSTWYolRm4ycjZtdXhRaEE", ' "name": "starfish4.jpg", ' "mimeType": "image/jpeg" ' }, ' { ' "kind": "drive#file", ' "id": "0B53Q6OSTWYolMWt2VzN0Qlo1UjA", ' "name": "hamlet2.xml", ' "mimeType": "text/xml" ' }, ' ... ' { ' "kind": "drive#file", ' "id": "0B53Q6OSTWYolc3RhcnRlcl9maWxlX2Rhc2hlclYw", ' "name": "Getting started", ' "mimeType": "application/pdf" ' } ' ] ' } |
© 2000-2022 Chilkat Software, Inc. All Rights Reserved.