Sample code for 30+ languages & platforms
Tcl

Outlook Contacts Update (PATCH) a Contact

See more Outlook Contact Examples

Update the properties of an Outlook contact object.

Chilkat Tcl Downloads

Tcl

load ./chilkat.dll

set success 0

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

set http [new_CkHttp]

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

set jsonToken [new_CkJsonObject]

set success [CkJsonObject_LoadFile $jsonToken "qa_data/tokens/outlookContacts.json"]
if {$success == 0} then {
    puts [CkJsonObject_lastErrorText $jsonToken]
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    exit
}

CkHttp_put_AuthToken $http [CkJsonObject_stringOf $jsonToken "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

set json [new_CkJsonObject]

CkJsonObject_UpdateString $json "homeAddress.street" "123 Some street"
CkJsonObject_UpdateString $json "homeAddress.city" "Seattle"
CkJsonObject_UpdateString $json "homeAddress.state" "WA"
CkJsonObject_UpdateString $json "homeAddress.postalCode" "98121"
CkJsonObject_UpdateString $json "birthday" "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).

set id "AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQBGAAAAAAAu7cUXL5YOTrdsUIw7-v8FBwBUcG0qWqkmQYqWLHQataQxAAAAAAEOAABUcG0qWqkmQYqWLHQataQxAAD0sxexAAA="
CkHttp_SetUrlVar $http "id" $id

# Send the HTTP PATCH
set resp [new_CkHttpResponse]

set success [CkHttp_HttpJson $http "PATCH" "https://graph.microsoft.com/v1.0/me/contacts/{$id}" $json "application/json" $resp]
if {$success == 0} then {
    puts [CkHttp_lastErrorText $http]
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    delete_CkJsonObject $json
    delete_CkHttpResponse $resp
    exit
}

puts "Response status code = [CkHttpResponse_get_StatusCode $resp]"

set jResp [new_CkJsonObject]

CkJsonObject_Load $jResp [CkHttpResponse_bodyStr $resp]
CkJsonObject_put_EmitCompact $jResp 0
puts [CkJsonObject_emit $jResp]

# The send succeeded if the response status code = 201.
if {[CkHttpResponse_get_StatusCode $resp] != 200} then {
    puts "Failed"
    delete_CkHttp $http
    delete_CkJsonObject $jsonToken
    delete_CkJsonObject $json
    delete_CkHttpResponse $resp
    delete_CkJsonObject $jResp
    exit
}

# 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": {}
# }

puts "Contact updated."

delete_CkHttp $http
delete_CkJsonObject $jsonToken
delete_CkJsonObject $json
delete_CkHttpResponse $resp
delete_CkJsonObject $jResp