Sample code for 30+ languages & platforms
Objective-C

Outlook Contacts Update (PATCH) a Contact

See more Outlook Contact Examples

Update the properties of an Outlook contact object.

Chilkat Objective-C Downloads

Objective-C
#import <CkoHttp.h>
#import <CkoJsonObject.h>
#import <NSString.h>
#import <CkoHttpResponse.h>

BOOL success = NO;

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

CkoHttp *http = [[CkoHttp alloc] init];

// Use your previously obtained access token here: Get Outlook Contacts OAuth2 Access Token (Azure AD v2.0 Endpoint).

CkoJsonObject *jsonToken = [[CkoJsonObject alloc] init];
success = [jsonToken LoadFile: @"qa_data/tokens/outlookContacts.json"];
if (success == NO) {
    NSLog(@"%@",jsonToken.LastErrorText);
    return;
}

http.AuthToken = [jsonToken StringOf: @"access_token"];

// Send the following PATCH:

// PATCH https://graph.microsoft.com/v1.0/me/contacts/{id}
// Content-type: application/json
// Content-length: 1977
// 
// {
//   "homeAddress": {
//     "street": "123 Some street",
//     "city": "Seattle",
//     "state": "WA",
//     "postalCode": "98121"
//   },
//   "birthday": "1974-07-22"
// }

// Build the JSON body of the POST.

// Use this online tool to generate code from sample JSON: 
// Generate Code to Create JSON

CkoJsonObject *json = [[CkoJsonObject alloc] init];
[json UpdateString: @"homeAddress.street" value: @"123 Some street"];
[json UpdateString: @"homeAddress.city" value: @"Seattle"];
[json UpdateString: @"homeAddress.state" value: @"WA"];
[json UpdateString: @"homeAddress.postalCode" value: @"98121"];
[json UpdateString: @"birthday" value: @"1974-07-22"];

// We need the ID of the contact to be updated.
// This was available in the response when we created the contact:  Create an Outlook Contact.
// Or you can list contacts to get the ID: List Outlook Contacts).

NSString *id = @"AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQBGAAAAAAAu7cUXL5YOTrdsUIw7-v8FBwBUcG0qWqkmQYqWLHQataQxAAAAAAEOAABUcG0qWqkmQYqWLHQataQxAAD0sxexAAA=";
[http SetUrlVar: @"id" value: id];

// Send the HTTP PATCH
CkoHttpResponse *resp = [[CkoHttpResponse alloc] init];
success = [http HttpJson: @"PATCH" url: @"https://graph.microsoft.com/v1.0/me/contacts/{$id}" json: json contentType: @"application/json" response: resp];
if (success == NO) {
    NSLog(@"%@",http.LastErrorText);
    return;
}

NSLog(@"%@%d",@"Response status code = ",[resp.StatusCode intValue]);

CkoJsonObject *jResp = [[CkoJsonObject alloc] init];
[jResp Load: resp.BodyStr];
jResp.EmitCompact = NO;
NSLog(@"%@",[jResp Emit]);

// The send succeeded if the response status code = 201.
if ([resp.StatusCode intValue] != 200) {
    NSLog(@"%@",@"Failed");
    return;
}

// Sample JSON response:

// {
//   "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('4ee732c3-322e-4a6b-b729-2fd1eb5c6004')/contacts/$entity",
//   "@odata.etag": "W/\"EQAAABYAAABUcG0qWqkmQYqWLHQataQxAAD0iYu5\"",
//   "id": "AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQBGAAAAAAAu7cUXL5YOTrdsUIw7-v8FBwBUcG0qWqkmQYqWLHQataQxAAAAAAEOAABUcG0qWqkmQYqWLHQataQxAAD0sxexAAA=",
//   "createdDateTime": "2021-06-29T16:32:05Z",
//   "lastModifiedDateTime": "2021-06-29T16:57:39Z",
//   "changeKey": "EQAAABYAAABUcG0qWqkmQYqWLHQataQxAAD0iYu5",
//   "categories": [
//   ],
//   "parentFolderId": "AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQAuAAAAAAAu7cUXL5YOTrdsUIw7-v8FAQBUcG0qWqkmQYqWLHQataQxAAAAAAEOAAA=",
//   "birthday": "1974-07-22T11:59:00Z",
//   "fileAs": "",
//   "displayName": "Pavel Bansky",
//   "givenName": "Pavel",
//   "initials": null,
//   "middleName": null,
//   "nickName": null,
//   "surname": "Bansky",
//   "title": null,
//   "yomiGivenName": null,
//   "yomiSurname": null,
//   "yomiCompanyName": null,
//   "generation": null,
//   "imAddresses": [
//   ],
//   "jobTitle": null,
//   "companyName": null,
//   "department": null,
//   "officeLocation": null,
//   "profession": null,
//   "businessHomePage": null,
//   "assistantName": null,
//   "manager": null,
//   "homePhones": [
//   ],
//   "mobilePhone": null,
//   "businessPhones": [
//     "+1 732 555 0102"
//   ],
//   "spouseName": null,
//   "personalNotes": "",
//   "children": [
//   ],
//   "emailAddresses": [
//     {
//       "name": "Pavel Bansky",
//       "address": "pavelb@fabrikam.onmicrosoft.com"
//     }
//   ],
//   "homeAddress": {
//     "street": "123 Some street",
//     "city": "Seattle",
//     "state": "WA",
//     "postalCode": "98121"
//   },
//   "businessAddress": {},
//   "otherAddress": {}
// }

NSLog(@"%@",@"Contact updated.");