Sample code for 30+ languages & platforms
AutoIt

Outlook Contacts Create a Contact

See more Outlook Contact Examples

Creates an Outlook Contact.

Chilkat AutoIt Downloads

AutoIt
Local $bSuccess = False

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

$oHttp = ObjCreate("Chilkat.Http")

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

$oJsonToken = ObjCreate("Chilkat.JsonObject")
$bSuccess = $oJsonToken.LoadFile("qa_data/tokens/outlookContacts.json")
If ($bSuccess = False) Then
    ConsoleWrite($oJsonToken.LastErrorText & @CRLF)
    Exit
EndIf

$oHttp.AuthToken = $oJsonToken.StringOf("access_token")

; Send the following POST:

; POST https://graph.microsoft.com/v1.0/me/contacts
; Content-type: application/json
; 
; {
;   "givenName": "Pavel",
;   "surname": "Bansky",
;   "emailAddresses": [
;     {
;       "address": "pavelb@fabrikam.onmicrosoft.com",
;       "name": "Pavel Bansky"
;     }
;   ],
;   "businessPhones": [
;     "+1 732 555 0102"
;   ]
; }

; Build the JSON body of the POST.

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

$oJson = ObjCreate("Chilkat.JsonObject")
$oJson.UpdateString("givenName","Pavel")
$oJson.UpdateString("surname","Bansky")
$oJson.UpdateString("emailAddresses[0].address","pavelb@fabrikam.onmicrosoft.com")
$oJson.UpdateString("emailAddresses[0].name","Pavel Bansky")
$oJson.UpdateString("businessPhones[0]","+1 732 555 0102")

; Send the HTTP POST
$oResp = ObjCreate("Chilkat.HttpResponse")
$bSuccess = $oHttp.HttpJson("POST","https://graph.microsoft.com/v1.0/me/contacts",$oJson,"application/json",$oResp)
If ($bSuccess = False) Then
    ConsoleWrite($oHttp.LastErrorText & @CRLF)
    Exit
EndIf

ConsoleWrite("Response status code = " & $oResp.StatusCode & @CRLF)

$oJResp = ObjCreate("Chilkat.JsonObject")
$oJResp.Load($oResp.BodyStr)
$oJResp.EmitCompact = False
ConsoleWrite($oJResp.Emit() & @CRLF)

; The send succeeded if the response status code = 201.
If ($oResp.StatusCode <> 201) Then
    ConsoleWrite("Failed" & @CRLF)
    Exit
EndIf

; Sample JSON response:

; {
;   "@odata.context": "https://graph.microsoft.com/v1.0/$metadata#users('4ee732c3-322e-4a6b-b729-2fd1eb5c6004')/contacts/$entity",
;   "@odata.etag": "W/\"EQAAABYAAABUcG0qWqkmQYqWLHQataQxAAD0iYfT\"",
;   "id": "AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQBGAAAAAAAu7cUXL5YOTrdsUIw7-v8FBwBUcG0qWqkmQYqWLHQataQxAAAAAAEOAABUcG0qWqkmQYqWLHQataQxAAD0sxexAAA=",
;   "createdDateTime": "2021-06-29T16:32:05Z",
;   "lastModifiedDateTime": "2021-06-29T16:32:06Z",
;   "changeKey": "EQAAABYAAABUcG0qWqkmQYqWLHQataQxAAD0iYfT",
;   "categories": [
;   ],
;   "parentFolderId": "AAMkADYzZWE3YmZmLWU0YzgtNGNkZC04MGE1LWFiYTFlNTRlY2QwYQAuAAAAAAAu7cUXL5YOTrdsUIw7-v8FAQBUcG0qWqkmQYqWLHQataQxAAAAAAEOAAA=",
;   "birthday": null,
;   "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": {},
;   "businessAddress": {},
;   "otherAddress": {}
; }

ConsoleWrite("Contact created." & @CRLF)