Sample code for 30+ languages & platforms
Objective-C

GeoOp - Get a list of all users

See more GeoOp Examples

Gets a list of all GeoOp users.

Chilkat Objective-C Downloads

Objective-C
#import <CkoJsonObject.h>
#import <CkoOAuth2.h>
#import <CkoRest.h>
#import <NSString.h>
#import <CkoDateTime.h>
#import <CkoDtObj.h>

BOOL success = NO;

// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.

// This example also assumes an OAuth2 access token was previously fetched.
// and saved in a JSON file.  

// First get our previously obtained access token.
// {"access_token":"e6dqdG....mzjpT04w==","token_type":"Bearer","expires_in":2592000,"owner_id":999236}
CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init];
success = [jsonToken LoadFile: @"qa_data/tokens/geoop.json"];

// This example assumes we previously obtained an access token
CkoOAuth2 *oauth2 = [[CkoOAuth2 alloc] init];
oauth2.AccessToken = [jsonToken StringOf: @"access_token"];

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

// Connect to GeoOp and send the following GET request:

// GET /users HTTP/1.1
// Host: api.geoop.com
BOOL bAutoReconnect = YES;
success = [rest Connect: @"api.geoop.com" port: [NSNumber numberWithInt: 443] tls: YES autoReconnect: bAutoReconnect];
if (success == NO) {
    NSLog(@"%@",rest.LastErrorText);
    return;
}

// Provide the authentication credentials (i.e. the access token)
[rest SetAuthOAuth2: oauth2];

// Set the X-Version header.
[rest AddHeader: @"X-Version" value: @"1.0"];

NSString *responseBody = [rest FullRequestNoBody: @"GET" uriPath: @"/users"];
if (rest.LastMethodSuccess == NO) {
    NSLog(@"%@",rest.LastErrorText);
    return;
}

// If the response status code did not indicate success, then see what happened..
if ([rest.ResponseStatusCode intValue] != 200) {
    NSLog(@"%@",@"Request Header: ");
    NSLog(@"%@",rest.LastRequestHeader);
    NSLog(@"%@",@"----");
    NSLog(@"%@%d",@"Response StatusCode = ",[rest.ResponseStatusCode intValue]);
    NSLog(@"%@%@",@"Response StatusLine: ",rest.ResponseStatusText);
    NSLog(@"%@",@"Response Header:");
    NSLog(@"%@",rest.ResponseHeader);
    NSLog(@"%@",responseBody);
    return;
}

CkoJsonObject *json = [[CkoJsonObject alloc] init];
json.EmitCompact = NO;
[json Load: responseBody];
// Show the full JSON response..
NSLog(@"%@",[json Emit]);

// These will be used for parsing date/time strings..
CkoDateTime *dtime = [[CkoDateTime alloc] init];
BOOL bLocalTime = YES;
CkoDtObj *dt = [[CkoDtObj alloc] init];

// Iterate over each user and get information from each.
int numRecords = [[json SizeOfArray: @"users"] intValue];
int i = 0;
while (i < numRecords) {

    json.I = [NSNumber numberWithInt: i];
    NSLog(@"%@%@",@"id: ",[json StringOf: @"users[i].id"]);
    NSLog(@"%@%@",@"firstName: ",[json StringOf: @"users[i].firstName"]);
    NSLog(@"%@%@",@"lastName: ",[json StringOf: @"users[i].lastName"]);
    NSLog(@"%@%@",@"companyName: ",[json StringOf: @"users[i].companyName"]);
    NSLog(@"%@%d",@"active: ",[[json IntOf: @"users[i].active"] intValue]);
    NSLog(@"%@%d",@"isAssignable: ",[json BoolOf: @"users[i].isAssignable"]);
    NSLog(@"%@%d",@"account id: ",[json BoolOf: @"users[i].account.id"]);

    [dtime SetFromTimestamp: [json StringOf: @"users[i].created"]];
    [dtime ToDtObj: bLocalTime dtObj: dt];

    NSLog(@"%@%d%@%d%@%d%@%d%@%d",@"created: ",[dt.Month intValue],@"/",[dt.Day intValue],@"/",[dt.Year intValue]
        ,@"  ",[dt.Hour intValue],@":",[dt.Minute intValue]);

    NSLog(@"%@",@"----");
    i = i + 1;
}

// The responseJson looks like this:
// {
//   "result": "success",
//   "users": [
//     {
//       "id": 984236,
//       "firstName": "Joe",
//       "lastName": "Smith",
//       "companyName": "Chilkat Software, Inc.",
//       "email": "support@chilkatsoft.com",
//       "phone": "",
//       "mobile": "1-630-555-5555",
//       "hourlyRate": 0,
//       "active": 1,
//       "deleted": false,
//       "colour": "#D2BC14",
//       "created": "2016-10-26T12:05:09+00:00",
//       "modified": "2016-10-26T12:05:09+00:00",
//       "isAssignable": true,
//       "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984236.jpg",
//       "role": {
//         "id": 1
//       },
//       "account": {
//         "id": 39409
//       },
//       "status": {}
//     },
//     {
//       "id": 984237,
//       "firstName": "Demo",
//       "lastName": "Employee",
//       "companyName": "",
//       "email": "",
//       "phone": "",
//       "mobile": "58458458475854758",
//       "hourlyRate": 0,
//       "active": 0,
//       "deleted": true,
//       "colour": "#4C4CFF",
//       "created": "2015-09-03T01:56:17+00:00",
//       "modified": "2016-06-14T20:20:58+00:00",
//       "isAssignable": true,
//       "avatarUrl": "https:\/\/www.geoop.com\/images\/mobithumb_984237.jpg",
//       "role": {
//         "id": 2
//       },
//       "account": {
//         "id": 39409
//       },
//       "status": {
//         "message": null,
//         "timestamp": "2015-09-03T01:57:45+00:00"
//       }
//     }
//   ],
//   "metadata": {
//     "page": 1,
//     "pagesCount": 1,
//     "recordsPerPage": 20,
//     "recordsCount": 2
//   }
// }
// 
//