Sample code for 30+ languages & platforms
Objective-C

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 Objective-C Downloads

Objective-C
#import <CkoAuthGoogle.h>
#import <CkoRest.h>
#import <CkoJsonObject.h>
#import <NSString.h>

BOOL success = NO;

success = YES;

// 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.

CkoAuthGoogle *gAuth = [[CkoAuthGoogle alloc] init];
gAuth.AccessToken = @"GOOGLE-DRIVE-ACCESS-TOKEN";

CkoRest *rest = [[CkoRest alloc] init];

// Connect using TLS.
BOOL bAutoReconnect = YES;
success = [rest Connect: @"www.googleapis.com" port: [NSNumber numberWithInt: 443] tls: YES autoReconnect: 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" value: @"5"];

// Our search filter is to list all files containing ".jpg" (i.e. all JPG image files)
[rest AddQueryParam: @"q" value: @"name contains '.jpg'"];

CkoJsonObject *json = [[CkoJsonObject alloc] init];
int i;
int numFiles;

// Send the request for the 1st page.
NSString *jsonResponse = [rest FullRequestNoBody: @"GET" uriPath: @"/drive/v3/files"];

int pageNumber = 1;
NSString *pageToken = 0;
BOOL bContinueLoop = rest.LastMethodSuccess && ([rest.ResponseStatusCode intValue] == 200);

while (bContinueLoop == YES) {

    NSLog(@"%@%d%@",@"---- Page ",pageNumber,@" ----");

    // Iterate over each file in the response and show the name, id, and mimeType.
    [json Load: jsonResponse];

    numFiles = [[json SizeOfArray: @"files"] intValue];
    i = 0;
    while (i < numFiles) {
        json.I = [NSNumber numberWithInt: i];
        NSLog(@"%@%@",@"name: ",[json StringOf: @"files[i].name"]);
        NSLog(@"%@%@",@"id: ",[json StringOf: @"files[i].id"]);
        NSLog(@"%@%@",@"mimeType: ",[json StringOf: @"files[i].mimeType"]);
        NSLog(@"%@",@"-");
        i = i + 1;
    }

    // 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 = NO;
    BOOL bHasMorePages = json.LastMethodSuccess;
    if (bHasMorePages == YES) {
        [rest ClearAllQueryParams];
        [rest AddQueryParam: @"pageSize" value: @"5"];
        [rest AddQueryParam: @"pageToken" value: pageToken];
        [rest AddQueryParam: @"q" value: @"name contains '.jpg'"];

        jsonResponse = [rest FullRequestNoBody: @"GET" uriPath: @"/drive/v3/files"];
        bContinueLoop = rest.LastMethodSuccess && ([rest.ResponseStatusCode intValue] == 200);
        pageNumber = pageNumber + 1;
    }

}

if (rest.LastMethodSuccess != YES) {
    NSLog(@"%@",rest.LastErrorText);
    return;
}

// A successful response will have a status code equal to 200.
if ([rest.ResponseStatusCode intValue] != 200) {
    NSLog(@"%@%d",@"response status code = ",[rest.ResponseStatusCode intValue]);
    NSLog(@"%@%@",@"response status text = ",rest.ResponseStatusText);
    NSLog(@"%@%@",@"response header: ",rest.ResponseHeader);
    NSLog(@"%@%@",@"response JSON: ",jsonResponse);
    return;
}