PowerShell
PowerShell
GetHarvest - Get Client Contacts
See more GetHarvest Examples
Returns a list of your contacts.Chilkat PowerShell Downloads
Add-Type -Path "C:\chilkat\ChilkatDotNet47-x64\ChilkatDotNet47.dll"
$success = $false
# This example assumes the Chilkat API to have been previously unlocked.
# See Global Unlock Sample for sample code.
$http = New-Object Chilkat.Http
# Implements the following CURL command:
# curl "https://api.harvestapp.com/v2/contacts" \
# -H "Authorization: Bearer ACCESS_TOKEN" \
# -H "Harvest-Account-Id: ACCOUNT_ID" \
# -H "User-Agent: MyApp (yourname@example.com)"
$http.SetRequestHeader("User-Agent","MyApp (yourname@example.com)")
$http.SetRequestHeader("Authorization","Bearer ACCESS_TOKEN")
$http.SetRequestHeader("Harvest-Account-Id","ACCOUNT_ID")
$sbResponseBody = New-Object Chilkat.StringBuilder
$success = $http.QuickGetSb("https://api.harvestapp.com/v2/contacts",$sbResponseBody)
if ($success -eq $false) {
$($http.LastErrorText)
exit
}
$jResp = New-Object Chilkat.JsonObject
$jResp.LoadSb($sbResponseBody)
$jResp.EmitCompact = $false
$("Response Body:")
$($jResp.Emit())
$respStatusCode = $http.LastStatus
$("Response Status Code = " + $respStatusCode)
if ($respStatusCode -ge 400) {
$("Response Header:")
$($http.LastHeader)
$("Failed.")
exit
}
# Sample JSON response:
# {
# "contacts": [
# {
# "id": 4706479,
# "title": "Owner",
# "first_name": "Jane",
# "last_name": "Doe",
# "email": "janedoe@example.com",
# "phone_office": "(203) 697-8885",
# "phone_mobile": "(203) 697-8886",
# "fax": "(203) 697-8887",
# "created_at": "2017-06-26T21:20:07Z",
# "updated_at": "2017-06-26T21:27:07Z",
# "client": {
# "id": 5735774,
# "name": "ABC Corp"
# }
# },
# {
# "id": 4706453,
# "title": "Manager",
# "first_name": "Richard",
# "last_name": "Roe",
# "email": "richardroe@example.com",
# "phone_office": "(318) 515-5905",
# "phone_mobile": "(318) 515-5906",
# "fax": "(318) 515-5907",
# "created_at": "2017-06-26T21:06:55Z",
# "updated_at": "2017-06-26T21:27:20Z",
# "client": {
# "id": 5735776,
# "name": "123 Industries"
# }
# }
# ],
# "per_page": 100,
# "total_pages": 1,
# "total_entries": 2,
# "next_page": null,
# "previous_page": null,
# "page": 1,
# "links": {
# "first": "https://api.harvestapp.com/v2/contacts?page=1&per_page=100",
# "next": null,
# "previous": null,
# "last": "https://api.harvestapp.com/v2/contacts?page=1&per_page=100"
# }
# }
# Sample code for parsing the JSON response...
# Use the following online tool to generate parsing code from sample JSON:
# Generate Parsing Code from JSON
$per_page = $jResp.IntOf("per_page")
$total_pages = $jResp.IntOf("total_pages")
$total_entries = $jResp.IntOf("total_entries")
$next_page = $jResp.StringOf("next_page")
$previous_page = $jResp.StringOf("previous_page")
$page = $jResp.IntOf("page")
$linksFirst = $jResp.StringOf("links.first")
$linksNext = $jResp.StringOf("links.next")
$linksPrevious = $jResp.StringOf("links.previous")
$linksLast = $jResp.StringOf("links.last")
$i = 0
$count_i = $jResp.SizeOfArray("contacts")
while ($i -lt $count_i) {
$jResp.I = $i
$id = $jResp.IntOf("contacts[i].id")
$title = $jResp.StringOf("contacts[i].title")
$first_name = $jResp.StringOf("contacts[i].first_name")
$last_name = $jResp.StringOf("contacts[i].last_name")
$email = $jResp.StringOf("contacts[i].email")
$phone_office = $jResp.StringOf("contacts[i].phone_office")
$phone_mobile = $jResp.StringOf("contacts[i].phone_mobile")
$fax = $jResp.StringOf("contacts[i].fax")
$created_at = $jResp.StringOf("contacts[i].created_at")
$updated_at = $jResp.StringOf("contacts[i].updated_at")
$clientId = $jResp.IntOf("contacts[i].client.id")
$clientName = $jResp.StringOf("contacts[i].client.name")
$i = $i + 1
}