Ruby
Ruby
Search for Files in Google Drive
See more Google Drive Examples
This example follows the same methodology for listing all files in Google Drive in pages, but applies a search filter. It shows how to apply a query parameter for filtering the file results. See the Google Drive Files list for more optional HTTP parameters.Chilkat Ruby Downloads
require 'chilkat'
success = false
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.
gAuth = Chilkat::CkAuthGoogle.new()
gAuth.put_AccessToken("GOOGLE-DRIVE-ACCESS-TOKEN")
rest = Chilkat::CkRest.new()
# Connect using TLS.
bAutoReconnect = true
success = rest.Connect("www.googleapis.com",443,true,bAutoReconnect)
# Provide the authentication credentials (i.e. the access token)
rest.SetAuthGoogle(gAuth)
# Get 5 results per page for testing. (The default page size is 100, with a max of 1000.
rest.AddQueryParam("pageSize","5")
# Our search filter is to list all files containing ".jpg" (i.e. all JPG image files)
rest.AddQueryParam("q","name contains '.jpg'")
json = Chilkat::CkJsonObject.new()
# Send the request for the 1st page.
jsonResponse = rest.fullRequestNoBody("GET","/drive/v3/files")
pageNumber = 1
bContinueLoop = rest.get_LastMethodSuccess() and (rest.get_ResponseStatusCode() == 200)
while bContinueLoop == true
print "---- Page " + pageNumber.to_s() + " ----" + "\n";
# Iterate over each file in the response and show the name, id, and mimeType.
json.Load(jsonResponse)
numFiles = json.SizeOfArray("files")
i = 0
while i < numFiles
json.put_I(i)
print "name: " + json.stringOf("files[i].name") + "\n";
print "id: " + json.stringOf("files[i].id") + "\n";
print "mimeType: " + json.stringOf("files[i].mimeType") + "\n";
print "-" + "\n";
i = i + 1
end
# 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.get_LastMethodSuccess()
if (bHasMorePages == true)
rest.ClearAllQueryParams()
rest.AddQueryParam("pageSize","5")
rest.AddQueryParam("pageToken",pageToken)
rest.AddQueryParam("q","name contains '.jpg'")
jsonResponse = rest.fullRequestNoBody("GET","/drive/v3/files")
bContinueLoop = rest.get_LastMethodSuccess() and (rest.get_ResponseStatusCode() == 200)
pageNumber = pageNumber + 1
end
end
if (rest.get_LastMethodSuccess() != true)
print rest.lastErrorText() + "\n";
exit
end
# A successful response will have a status code equal to 200.
if (rest.get_ResponseStatusCode() != 200)
print "response status code = " + rest.get_ResponseStatusCode().to_s() + "\n";
print "response status text = " + rest.responseStatusText() + "\n";
print "response header: " + rest.responseHeader() + "\n";
print "response JSON: " + jsonResponse + "\n";
exit
end