Shared API Capabilities
API Response Envelopes
All responses from APIs have the following outer envelope:
{
"data": ...,
"meta": {...},
"error": {...}
}
The data
and error
fields are mutually exclusive. Responses are either a data response or an error. The data
section represents the subject or output information of the client's request. The meta
section contains additional
information about the requested entity that may be useful to clients (e.g. pagination, sortable fields, etc.).
The error
section contains errors in the following format:
{
"code": "string constant error code",
"message": "string human readable value",
"cause": ... //[nested error|field error]
}
The cause
field can either be another nested error
or a field error
:
{
"field": "the name of the field",
"reason": "a message explaining the issue",
"value": ... //the provided value
}
Filtering, Sorting, & Pagination
API support rich filtering, sorting and pagination on queries that return lists/arrays of objects in the data
fields.
On list responses the meta
section contains a list of sortableFields
which can filtered and sorted upon.
All values are provided in the filter
URL query field.
Example: https://my-controller/edge/v1/management/identities?filter=<filterValue>
The value of filter
(denoted by <filterValue>
) is defined by the ZitiQl grammar definition.
Pagination
Data can be paginated through by providing a filter
value with skip
and/or limit
clauses. For example to show:
- the first page of 10 items:
filter=skip 0 limit 10
- the second page of 10 items:
filter=skip 10 limit 10
Sorting
Data can be sorted on fields by providing a sort by
clause:
- sort by name ascending:
filter=sort by name asc
-
- sort by name descending:
filter=sort by name dsc
- sort by name descending:
Filtering
Logical Operations
The following comparisons are allowed:
Operation | Example |
---|---|
= , != | name = "myName" , "isOnline" = true |
< , > , <= , >= | precident > 0 |
contains , not contains | name contains "hi" |
Logical Conjunctions
Conjunction | Example |
---|---|
and | firstName = "bob" and lastName = "builder" |
or | firstName = "bob" or firstName = "jim" |
Complex conjunction grouping and nesting is supported via (
and )
.
Example: firstName = "bob" or (firstName = "jim" and lastName = "john" or ("isOnline" = false))
Types
Type | Example |
---|---|
string | "this is a string" |
number | 1 , 1.555 , 2e5 |
bool | true , false |
date_time (RFC3339) ( | datetime(2019-10-12T07:20:50.52+07:00) |
array | ["str", "str"] , [1,2,3.5] , [datetime(...), datetime(...)] |