delphiAx / DocuSign eSignature REST API / Imports multiple new contacts into the contacts collection from CSV, JSON, or XML (based on content type).
Back to Collection Items
var
http: TChilkatHttp;
success: Integer;
json: TChilkatJsonObject;
resp: IChilkatHttpResponse;
begin
// This example assumes the Chilkat API to have been previously unlocked.
// See Global Unlock Sample for sample code.
http := TChilkatHttp.Create(Self);
// Use this online tool to generate code from sample JSON: Generate Code to Create JSON
// The following JSON is sent in the request body.
// {
// "contacts": [
// {
// "signingGroupUsers": [
// {
// "userName": "sample string 1",
// "userId": "sample string 2",
// "email": "sample string 3",
// "userType": "sample string 4",
// "userStatus": "sample string 5",
// "uri": "sample string 6",
// "loginStatus": "sample string 7",
// "sendActivationEmail": "sample string 8",
// "activationAccessCode": "sample string 9"
// }
// ],
// "contactId": "sample string 1",
// "name": "sample string 2",
// "emails": [
// "sample string 1"
// ],
// "organization": "sample string 3",
// "shared": "sample string 4",
// "contactUri": "sample string 5",
// "signingGroup": "sample string 6",
// "signingGroupName": "sample string 7",
// "contactPhoneNumbers": [
// {
// "phoneNumber": "sample string 1",
// "phoneType": "sample string 2"
// }
// ]
// }
// ]
// }
json := TChilkatJsonObject.Create(Self);
json.UpdateString('contacts[0].signingGroupUsers[0].userName','sample string 1');
json.UpdateString('contacts[0].signingGroupUsers[0].userId','sample string 2');
json.UpdateString('contacts[0].signingGroupUsers[0].email','sample string 3');
json.UpdateString('contacts[0].signingGroupUsers[0].userType','sample string 4');
json.UpdateString('contacts[0].signingGroupUsers[0].userStatus','sample string 5');
json.UpdateString('contacts[0].signingGroupUsers[0].uri','sample string 6');
json.UpdateString('contacts[0].signingGroupUsers[0].loginStatus','sample string 7');
json.UpdateString('contacts[0].signingGroupUsers[0].sendActivationEmail','sample string 8');
json.UpdateString('contacts[0].signingGroupUsers[0].activationAccessCode','sample string 9');
json.UpdateString('contacts[0].contactId','sample string 1');
json.UpdateString('contacts[0].name','sample string 2');
json.UpdateString('contacts[0].emails[0]','sample string 1');
json.UpdateString('contacts[0].organization','sample string 3');
json.UpdateString('contacts[0].shared','sample string 4');
json.UpdateString('contacts[0].contactUri','sample string 5');
json.UpdateString('contacts[0].signingGroup','sample string 6');
json.UpdateString('contacts[0].signingGroupName','sample string 7');
json.UpdateString('contacts[0].contactPhoneNumbers[0].phoneNumber','sample string 1');
json.UpdateString('contacts[0].contactPhoneNumbers[0].phoneType','sample string 2');
// Adds the "Authorization: Bearer {{accessToken}}" header.
http.AuthToken := '{{accessToken}}';
http.SetRequestHeader('Accept','application/json');
resp := http.PostJson3('https://domain.com/v2.1/accounts/{{accountId}}/contacts','application/json',json.ControlInterface);
if (http.LastMethodSuccess = 0) then
begin
Memo1.Lines.Add(http.LastErrorText);
Exit;
end;
Memo1.Lines.Add(IntToStr(resp.StatusCode));
Memo1.Lines.Add(resp.BodyStr);
Curl Command
curl -X POST
-H "Accept: application/json"
-H "Authorization: Bearer {{accessToken}}"
-d '{
"contacts": [
{
"signingGroupUsers": [
{
"userName": "sample string 1",
"userId": "sample string 2",
"email": "sample string 3",
"userType": "sample string 4",
"userStatus": "sample string 5",
"uri": "sample string 6",
"loginStatus": "sample string 7",
"sendActivationEmail": "sample string 8",
"activationAccessCode": "sample string 9"
}
],
"contactId": "sample string 1",
"name": "sample string 2",
"emails": [
"sample string 1"
],
"organization": "sample string 3",
"shared": "sample string 4",
"contactUri": "sample string 5",
"signingGroup": "sample string 6",
"signingGroupName": "sample string 7",
"contactPhoneNumbers": [
{
"phoneNumber": "sample string 1",
"phoneType": "sample string 2"
}
]
}
]
}'
https://domain.com/v2.1/accounts/{{accountId}}/contacts
Postman Collection Item JSON
{
"name": "Imports multiple new contacts into the contacts collection from CSV, JSON, or XML (based on content type).",
"request": {
"method": "POST",
"header": [
{
"key": "Accept",
"value": "application/json"
},
{
"key": "Authorization",
"value": "Bearer {{accessToken}}"
}
],
"body": {
"mode": "raw",
"raw": "{\n \"contacts\": [\n {\n \"signingGroupUsers\": [\n {\n \"userName\": \"sample string 1\",\n \"userId\": \"sample string 2\",\n \"email\": \"sample string 3\",\n \"userType\": \"sample string 4\",\n \"userStatus\": \"sample string 5\",\n \"uri\": \"sample string 6\",\n \"loginStatus\": \"sample string 7\",\n \"sendActivationEmail\": \"sample string 8\",\n \"activationAccessCode\": \"sample string 9\"\n }\n ],\n \"contactId\": \"sample string 1\",\n \"name\": \"sample string 2\",\n \"emails\": [\n \"sample string 1\"\n ],\n \"organization\": \"sample string 3\",\n \"shared\": \"sample string 4\",\n \"contactUri\": \"sample string 5\",\n \"signingGroup\": \"sample string 6\",\n \"signingGroupName\": \"sample string 7\",\n \"contactPhoneNumbers\": [\n {\n \"phoneNumber\": \"sample string 1\",\n \"phoneType\": \"sample string 2\"\n }\n ]\n }\n ]\n}"
},
"url": {
"raw": "{{baseUrl}}/v2.1/accounts/{{accountId}}/contacts",
"host": [
"{{baseUrl}}"
],
"path": [
"v2.1",
"accounts",
"{{accountId}}",
"contacts"
],
"variable": [
{
"key": "accountId",
"value": "{{accountId}}",
"type": "string"
}
]
}
},
"response": [
]
}