POST | 3/contacts |
GET | 3/surveys/{SurveyId}/panelists/{ContactId} |
GET | 3/contacts/{ContactId} |
This example will show you the possibilities to add a new contact. This contact will immediately be added to a survey. We will return a ContactCreateResult which indicates if the request was successful and the contact id or failure message. With the contact id you can retrieve the panelist information.
You can find an overview of all available properties for a new contact.
curl -X POST "https://api-eu.agileresearch.medallia.com/3/contacts?SurveyId={SurveyId}" -H "X-Master-Key: {MasterKey}" -H "X-Key: {Key}" -H "Content-type: application/json" -d "{'FirstName': 'John', 'LastName': 'Doe', 'Email': 'john.doe@mail.com'}"
{"Meta":{"Status":200,"Timestamp":"2025-01-22T07:58:51.8553991Z"},"Data":{"Succeeded":true,"ContactId":20921043}}
System.Net.Http.HttpClient client = new System.Net.Http.HttpClient(); client.BaseAddress = new Uri("https://api-eu.agileresearch.medallia.com/"); client.DefaultRequestHeaders.Add("X-Master-Key", "{MasterKey}"); client.DefaultRequestHeaders.Add("X-Key", "{Key}"); client.DefaultRequestHeaders.Add("Content-type", "application/json"); string requestUri = string.Format("3/contacts?SurveyId={0}", "{SurveyId}"); var jsonObject = new { FirstName = "John", LastName = "Doe", Email = "john.doe@mail.com" }; System.Net.Http.HttpResponseMessage response = client.PostAsJsonAsync(requestUri, jsonObject).Result;
{"Meta":{"Status":200,"Timestamp":"2025-01-22T07:58:51.8553991Z"},"Data":{"Succeeded":true,"ContactId":20921043}}
In order to avoid a 403 Forbidden response, please make sure you have the required roles as indicated in the API Reference.
Afer creating a contact, you can check the resulting data by using the ContactCreateResult.
First you should check if the Succeeded
is true. Otherwise the request failed. You can find the failure reason in the FailureMessage
, which can be one of the following:
If the request wa successsful, the ContactId
will be available. This contact id can be used to retrieve the contact information with the request below.
curl -X GET "https://api-eu.agileresearch.medallia.com/3/contacts/{ContactId}" -H "X-Master-Key: {MasterKey}" -H "X-Key: {Key}" -H "Content-type: application/json"
{"Meta":{"Status":200,"Timestamp":"2025-01-22T07:58:51.8553991Z"},"Data":{"ContactId":20960745,"FirstName":"Jane","Email":"john.doe@mail.com","Gender":"F"}}
System.Net.Http.HttpClient client = new System.Net.Http.HttpClient(); client.BaseAddress = new Uri("https://api-eu.agileresearch.medallia.com/"); client.DefaultRequestHeaders.Add("X-Master-Key", "{MasterKey}"); client.DefaultRequestHeaders.Add("X-Key", "{Key}"); client.DefaultRequestHeaders.Accept.Add(new System.Net.Http.Headers.MediaTypeWithQualityHeaderValue("application/json")); string requestUri = string.Format("3/contacts/{0}", "{ContactId}"); System.Net.Http.HttpResponseMessage response = client.GetAsync(requestUri).Result;
{"Meta":{"Status":200,"Timestamp":"2025-01-22T07:58:51.8553991Z"},"Data":{"ContactId":20960745,"FirstName":"Jane","Email":"john.doe@mail.com","Gender":"F"}}
Or retrieve the contact from the survey and immediately get the survey urls.
curl -X "https://api-eu.agileresearch.medallia.com/3/surveys/{SurveyId}/panelists/{ContactId}" -H "X-Master-Key: {MasterKey}" -H "X-Key: {Key}" -H "Content-type: application/json"
{ "Meta" : { "Status" : 200, "Timestamp" : "2025-01-22T07:58:51.8553991Z" }, "Data" : { "PreviewUrl" : "https://s.chkmkt.com/?e={SurveyId}&l=&c=20960745&h=6F00B98B3738C94&v=1&m=PREVIEW", "LiveUrl" : "https://s.chkmkt.com/?e={SurveyId}&l=&c=20960745&h=6F00B98B3738C94", "PanelistStatusId" : 1, "DateAdded" : "2025-01-22T07:58:51.8553991Z", "Password" : "F628D3", "ContactId" : 20960745, "FirstName" : "Jane", "Email" : "john.doe@mail.com" } }
System.Net.Http.HttpClient client = new System.Net.Http.HttpClient(); client.BaseAddress = new Uri("https://api-eu.agileresearch.medallia.com/"); client.DefaultRequestHeaders.Add("X-Master-Key", "{MasterKey}"); client.DefaultRequestHeaders.Add("X-Key", "{Key}"); client.DefaultRequestHeaders.Add("Content-type", "application/json"); string requestUri = string.Format("3/surveys/{0}/panelists/{1}", "{SurveyId}", "{ContactId}"); System.Net.Http.HttpResponseMessage response = client.GetAsync(requestUri).Result;
{ "Meta" : { "Status" : 200, "Timestamp" : "2025-01-22T07:58:51.8553991Z" }, "Data" : { "PreviewUrl" : "https://s.chkmkt.com/?e={SurveyId}&l=&c=20960745&h=6F00B98B3738C94&v=1&m=PREVIEW", "LiveUrl" : "https://s.chkmkt.com/?e={SurveyId}&l=&c=20960745&h=6F00B98B3738C94", "PanelistStatusId" : 1, "DateAdded" : "2025-01-22T07:58:51.8553991Z", "Password" : "F628D3", "ContactId" : 20960745, "FirstName" : "Jane", "Email" : "john.doe@mail.com" } }
We have used the following methods in this example. You can find all details regarding each request in the API Reference.
POST | 3/contacts |
GET | 3/surveys/{SurveyId}/panelists/{ContactId} |
GET | 3/contacts/{ContactId} |