Skip to main content

How to get a list of Customers

This document is designed to help you understand how you can fetch a list of Customers with search parameters customizations. The endpoint enables user to get a list of customers that contains a particular string ({{searchTerm}}) in multiple fields({{fieldsToBeSearched}}) like ID, firstName, communications etc. and one can control to combine the results from the searchTerm being present in different fieldsToBeSearched by AND or OR. The list contains an array of objects which contains a sub-object named customer which contains all the customer information and a sub-object named vehicles which contains all the vehicles owned by the customer.
To get a customer list, you first need your credentials. If you don't already have one, head over to the Authentication and Authorization page to see how you can request for credentials from us. The endpoint mentioned below can help you with getting a customer list and customize the search parameters :-

Parameters Used

Path parameters

Parameter NameValueDescriptionRequired
departmentUUIDStringUnique identifier of dealer departmentYes

Request parameters

Parameter NameDescriptionRequiredDefault Value
{{fieldsToBeSearched}}Fields in which {{searchTerm}} will be searched for and matching customers will be fetched . set of fields are fname, lname, company, customerKey, communications.commValue,vehicles.vin .Multiple values must be passed as comma separated example : fname,lname,vehicles.vin . It is recommended to search by customerKey or vehicles.vin.No---
{{maxResults}}Size of customer list that will be returned. Could be any number from 1 to 100No100
{{searchTerm}}Term to search within {{fieldsToBeSearched}}. Maximum length of this search term is 30.Yes---

Authorization

Parameter NameDescriptionRequired
{{basic_auth_token}}Authorization: Base64 encoded string using Service Subscriber Username and passwordYes

Scope

This request requires the following authorization scopes:

ScopeLevelDescription
customer.searchDealerDepartmentAuthorises client to fetch customers provided dealer department

Endpoint

curl -X GET "https://api.mykaarma.com/customer/v2/department/{{departmentUUID}}/customer/listMinimal?fieldsToBeSearched={{fieldsToBeSearched}}&maxResults={{maxResults}}&searchTerm={{searchterm}}"
-H "accept: application/json"
-H "Authorization: {{basic_auth_token}}"

Response

{
"errors": [
{
"errorCode": 0,
"errorTitle": "string",
"errorMessage": "string"
}
],
"warnings": [
{
"warningCode": 0,
"warningTitle": "string",
"warningMessage": "string"
}
],
"matchingCustomers": [
{
"id": 0,
"fname": "string",
"lname": "string",
"customerKey": "string",
"uuid": "string",
"company": "string",
"dealerId": 0,
"communications": [
{
"commValue": "string",
"commType": "string",
"commLabel": "string",
"preferred": true,
"id": 0
}
],
"vehicles": [
{
"model": "string",
"year": "string",
"make": "string",
"engine": "string",
"bodyStyle": "string",
"trim": "string",
"vin": "string",
"id": 0,
"isValid": true,
"uuid": "string",
"vehicleKey": "string",
"imageUrl": "string"
}
],
"secondaryCustomerData": [
{
"fname": "string",
"lname": "string",
"customerKey": "string",
"guid": "string",
"customerId": 0
}
]
}
]
}

Quick summary of getCustomer response fields

Parameter NameDescription
idUnique identifier used by mykaarma to uniquely identify each customer in mykaarma databases. This value should not be used by vendor and in near future would always be null
fnamefirstName of the customer
lnamelastName of the customer
customerKeyUnique identifier used by DMS to uniquely identify each customer, used by mykaarma to lookup customers in DMS databases for various purposes like update, delete, book appointment
uuidUnique identifier used by mykaarma used for uniquely identifying customers over API calls(for read, write, update, delete purposes)
companycompany name of the customer provided if the customer is a BUSINESS customer
dealerIdUnique identifier used by mykaarma to uniquely identify each dealer in mykaarma databases This value should not be used by and vendor and in near future would always be null
communications.commValueThe value of customer communciation can be a phone number or an email address
communications.commLabelIt tells the type of phone or email example cell, home, work etc.
communications.preferredIt is a boolean value which tells which phone and which email is preferred for use by a customer, only one phone and one email can have isPreferred true for a customer
communications.idUnique identifier used by mykaarma to uniquely identify each customer communication in mykaarma databases. This value should not be used by and vendor and in near future would always be null
communications.commTypedescribes the type of communciation P for Phone and E for email
vehicles.idUnique identifier used by mykaarma to uniquely identify each vehicle in mykaarma databases. This value should not be used by and vendor and in near future would always be null
vehicles.vehicleKeyUnique identifier used by DMS to uniquely identify each vehicle, used by mykaarma to lookup vehicles in DMS databases for various purposes like updation, deletion, booking appointment etc.
vehicles.vehicleUuidUnique identifier used by mykaarma in addition to vehicles.id, used for uniquely identifying vehicles over API calls(for read, write, update, delete purposes) without revealing their database id that is vehicles.id
vehicles.yearthe year when the vehicle was manufactured
vehicles.makethe brand of the vehicle
vehicles.engineengine description of the vehicle
vehicles.trimtrim description of the vehicle
vehicles.modelmodel of the vehicle
vehicles.vinVIN of the vehicle
vehicles.isValidIndicates whether the customer currently owns the vehicle.
secondaryCustomerDataField used internally by mykaarma . Not to be used by any vendor.