unicodeC / New FreshBooks / Edit Secondary Contact ID
Back to Collection Items
#include <C_CkHttpW.h>
#include <C_CkJsonObjectW.h>
#include <C_CkStringBuilderW.h>
#include <C_CkHttpResponseW.h>
void ChilkatSample(void)
{
HCkHttpW http;
BOOL success;
HCkJsonObjectW json;
HCkStringBuilderW sbRequestBody;
HCkHttpResponseW resp;
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http = CkHttpW_Create();
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "contact": {
// "email": "secondary@emailaddress.com",
// "fname": "FirstName",
// "lname": "LastName",
// "phone1": ""
// }
// }
json = CkJsonObjectW_Create();
CkJsonObjectW_UpdateString(json,L"contact.email",L"secondary@emailaddress.com");
CkJsonObjectW_UpdateString(json,L"contact.fname",L"FirstName");
CkJsonObjectW_UpdateString(json,L"contact.lname",L"LastName");
CkJsonObjectW_UpdateString(json,L"contact.phone1",L"");
// Adds the "Authorization: Bearer <access_token>" header.
CkHttpW_putAuthToken(http,L"<access_token>");
CkHttpW_SetRequestHeader(http,L"Content-Type",L"application/json");
sbRequestBody = CkStringBuilderW_Create();
CkJsonObjectW_EmitSb(json,sbRequestBody);
resp = CkHttpW_PTextSb(http,L"PUT",L"https://api.freshbooks.com/accounting/account/{{accountid}}/users/contacts/{{contactid}}",sbRequestBody,L"utf-8",L"application/json",FALSE,FALSE);
if (CkHttpW_getLastMethodSuccess(http) == FALSE) {
wprintf(L"%s\n",CkHttpW_lastErrorText(http));
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
return;
}
wprintf(L"%d\n",CkHttpResponseW_getStatusCode(resp));
wprintf(L"%s\n",CkHttpResponseW_bodyStr(resp));
CkHttpResponseW_Dispose(resp);
CkHttpW_Dispose(http);
CkJsonObjectW_Dispose(json);
CkStringBuilderW_Dispose(sbRequestBody);
}
Curl Command
curl -X PUT
-H "Authorization: Bearer <access_token>"
-H "Content-Type: application/json"
-d '{
"contact": {
"email": "secondary@emailaddress.com",
"fname": "FirstName",
"lname": "LastName",
"phone1": ""
}
}'
https://api.freshbooks.com/accounting/account/{{accountid}}/users/contacts/{{contactid}}
Postman Collection Item JSON
{
"name": "Edit Secondary Contact ID",
"request": {
"method": "PUT",
"header": [
{
"key": "Content-Type",
"name": "Content-Type",
"value": "application/json",
"type": "text"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"contact\": {\n \"email\": \"secondary@emailaddress.com\",\n \"fname\": \"FirstName\",\n \"lname\": \"LastName\",\n \"phone1\": \"\"\n }\n}"
},
"url": {
"raw": "https://api.freshbooks.com/accounting/account/{{accountid}}/users/contacts/{{contactid}}",
"protocol": "https",
"host": [
"api",
"freshbooks",
"com"
],
"path": [
"accounting",
"account",
"{{accountid}}",
"users",
"contacts",
"{{contactid}}"
]
},
"description": "Allows you to edit a specific secondary contact"
},
"response": [
]
}