API search parameters¶
Filters and other search parameters can be used with API functions that returns a list of records.
Examples¶
PHP¶
<?php
$url = 'Lead';
$where = [
[
'type' => 'isNotNull',
'attribute' => 'assignedUserId',
],
[
'type' => 'or',
'value' => [
[
'type' => 'equals',
'attribute' => 'status',
'value' => 'New',
],
[
'type' => 'equals',
'attribute' => 'status',
'value' => 'Assigned',
],
],
],
];
$boolFilterList = [
// 'onlyMy',
// 'followed',
];
// the list of available primary filters can obtained in a select manager class
$primaryFilter = 'primaryFilter';
// every param is optional
$params = [
'offset' => 0,
'maxSize' => 20,
'where' => $where,
'primaryFilter' => $primaryFilter,
'boolFilterList' => $boolFilterList,
'select' => 'id,name,assignedUserId,status',
'orderBy' => 'createdAt',
'order' => 'desc',
];
$response = $client->request('GET', $url, $params);
Javascript (Nodejs)¶
// every param is optional
const params = {
maxSize: 5,
primaryFilter: 'open',
where: [
{
type: 'equals',
attribute: 'priority',
value: 'Urgent',
}
],
select: 'id,name,assignedUserId,assignedUserName',
};
client.request('GET', 'Case', params)
.then(response => console.log(response))
Python¶
params = {
"select": "id,phoneNumber",
"where": [
{
"type": "equals",
"attribute": "phoneNumber",
"value": '+1',
},
],
}
result = client.request('GET', 'Account', params)
Params¶
Parameters are passed as query parameters (in GET request).
It's also possible to pass all search parameters in JSON format in one query parameter searchParams
.
offset¶
Integer
An offset for pagination.
maxSize¶
Integer
How much records to return.
select¶
String (or Array of strings if search params passed in JSON)
What record attributes to return. Separated by comma. Whitespaces are not allowed. Specify only attributes that you need, it can improve performance.
Example: id,name,status,assignedUserId
.
Example in JSON: ["id", "name"]
.
Note
An alias GET parameter attributeSelect
can be used instead to prevent false positive firewall blocking. As of v9.0.
where¶
Array
Search criteria. Can contain nested arrays and objects. See more below more detail.
Note
An alias GET parameter whereGroup
can be used instead to prevent false positive firewall blocking. As of v9.0.
primaryFilter¶
String
A primary filter. Primary filters are usually defined in Select Manager class.
boolFilterList¶
Array
Bool filters. E.g. onlyMy, followed.
orderBy¶
String
An attribute to order by.
order¶
String
A direction of order: 'desc' or 'asc'.
Where items¶
A Where parameter is an array if items, that can contain nested items.
Examples below are given in JSON format.
equals, notEquals¶
{
"type": "equals",
"attribute": "status",
"value": "New"
}
greaterThan, lessThan, greaterThanOrEquals, lessThanOrEquals¶
{
"type": "greaterThan",
"attribute": "amountConverted",
"value": 1000.00
}
isNull, isNotNull¶
{
"type": "isNull",
"attribute": "assignedUserId"
}
isTrue, isFalse¶
{
"type": "isTrue",
"attribute": "someBoolField"
}
linkedWith, notLinkedWith¶
For link-multiple fields.
{
"type": "linkedWith",
"attribute": "teams",
"value": ["someTeamId"]
}
isLinked, isNotLinked¶
For link-multiple fields. Whether is linked or not linked with any record.
{
"type": "isLinked",
"attribute": "teams"
}
in, notIn¶
{
"type": "in",
"attribute": "status",
"value": ["New", "Assigned"]
}
contains, notContains, startsWith, endsWith, like, notLike¶
{
"type": "contains",
"attribute": "someTextOrVarcharField",
"value": "text"
}
or, and¶
{
"type": "or",
"value": [
{
"type": "equals",
"attribute": "status",
"value": "New"
},
{
"type": "equals",
"attribute": "status",
"value": "Assigned"
}
]
}
today, past, future, lastSevenDays, currentMonth, lastMonth, nextMonth, currentQuarter, lastQuarter, currentYear, lastYear, currentFiscalYear, lastFiscalYear, currentFiscalQuarter, lastFiscalQuarter¶
{
"type": "today",
"attribute": "someDateField"
}
For date-time fields:
{
"type": "today",
"attribute": "someDateTimeField",
"dateTime": true,
"timeZone": "Europe/Kyiv"
}
lastXDays, nextXDays, olderThanXDays, afterXDays,¶
{
"type": "lastXDays",
"attribute": "someDateField",
"value": 2
}
between¶
{
"type": "between",
"attribute": "someNumberOrDateField",
"value": [100, 200]
}
arrayAnyOf, arrayNoneOf, arrayAllOf¶
For array, multi-enum, checkbox fields.
{
"type": "arrayAnyOf",
"attribute": "fieldName",
"value": ["Value 1", "Value 2"]
}
arrayIsEmpty, arrayIsNotEmpty¶
For array, multi-enum, checkbox fields.
{
"type": "arrayIsEmpty",
"attribute": "fieldName"
}
Attribute names¶
Attribute names usually are same as a system field names. Fields are listed at Administration > Entity Manager > ... > Fields.
Attribute names should be in lowerCamelCase.
More info about attributes here.