Search Scope Documentation
Search criteria are specified as a json object.
Valid parameters for the search field(s): field
, fields
.
Valid parameters for the search value(s): value
, values
.
{ "search":[ { "fields":"<db-field>", "values":"<value of which you're searching for>", "operator":"<by which operator you seek>" } ] }
Possible combinations of search criteria: OR-Search, AND-Search and combination of both.
To combine the search fields and/or the search values via the OR operator, they must be provided as a comma separated list:
{ "search":[ { "fields":"<db-field>, <db-field>, <db-field>", "values":"<value>, <value of which you're searching for>", "operator":"<by which operator you seek>" } ] }
The AND combination would be:
{ "search":[ { "fields":"<db-field>, <db-field>", "values":"<value>", "operator":"<by which operator you seek>" }, { "fields":"<db-field>", "values":"<value>, <value>", "operator":"<by which operator you seek>" } ] }
Example: Find all people who live in the area with postal code starting with 530 or 531.
{ "search":[ { "field":"isAccount", "value":"false", "operator":"equals" }, { "field":"postcode1", "value":"530, 531", "operator":"startswith" } ] }
And here is the whole request:
curl -X POST "https://appload.scopevisio.com/rest/contacts" -H "accept: application/json" -H "Authorization: Bearer [TOKEN]" -H "content-type: application/json" -d "search : [{\"fields\" : \"isAccount\",\"values\" : \"true\",\"operator\": \"equals\" }, {\"fields\" : \"postcode1,\"values\" : \"530, 531\",\"operator\": \"startswith\"}]"
Search Operators
Available operators for string values:startswith
– if the string starts with your value, it will matchendswith
– if the string ends with your value, it will matchcontains
– if your value is somewhere in the string, it will matchicontains
– if your value is somewhere in the string, it will match in case-insensitive mannernotequal
– if your value does not equal, it will matchequal
– if your value equals, it will matchis null
– if the field is null, it will matchis not null
– if the field is not null, it will match
Available operators for numbers:equal
– if your value equals, it will matchnotequal
– if your value does not equal, it will matchless
– if your value is less than, itll matchgreater
– if your value is greater than, it will matchlessorequal
- if your value is less than or equals, it will matchgreaterorequal
- if your value is grater than or equals, it will matchis null
– if the field is null, it will matchis not null
– if the field is not null, it will match
Available operators for boolean values:equal
– if your value equals, it will matchnotequal
– if your value does not equal, it will matchis null
– if the field is null, it will matchis not null
– if the field is not null, it will match
"is null" search
It is also possible to use the is null
operator in combination with all other operators. The result is an OR-search combination. When the is null
is used alone, without combining with another operator, the values
parameter can be skipped.
In this example the contacts having no postal code at all are returned:
{ "search":[ { "field":"postalcode1", "operator":"is null" } ] }
In this example the contacts having postal code starting with "53" or having no postal code at all are returned:
{ "search":[ { "field":"postalcode1", "value":"53", "operator":"is null, sartswith" } ] }
"is not null" search
It is also possible to use the is not null
. This operator however cannot be combined with other operators. When the is not null
operator is used the values
parameter can be skipped.
In this example only the contacts with a non-null postal code are returned:
{ "search":[ { "field":"postalcode1", "operator":"is not null" } ] }
Paging, fields, ordering and formatting
Retrieving data may result in a high number of items. Therefore, results may be returned over a number of pages.
The number of the first page
is 0 which is also the page default. A value smaller than 0 will be replaced with 0.
The pageSize
default is 100. It can be set to a maximum value of 1000. A value greater than 1000 will be replaced with 1000.
Which fields should the result contain can be specified by the fields
element.
Certain value types are by default formatted in a specific manner. All value formatting can be disabled by setting the "formatValues" attribute to false. This attribute affects the output only when at least one field is specified.
Here is an example:
{ "page":2, "pageSize":250, "fields":[ "id", "firstname", "lastname", "postcode1" ], "formatValues": false }
curl -s -d '{ "page": 2, "pageSize": 250, "fields": ["id", "firstname", "lastname", "postcode1" ]}' -H "Content-Type: application/json" -H "Authorization: Bearer [TOKEN]" https://appload.scopevisio.com/rest/contacts
A combination of search criteria and paging or formatting is also possible:
{ "page":2, "pageSize":250, "fields":[ "id", "lastname", "firstname", "postcode1" ], "search":[ { "field":"isAccount", "value":"false", "operator":"equals" }, { "field":"postcode1", "value":"53", "operator":"startswith" } ] }
To order the returned records the array element order
is used. This list contains elements using the format "<db-field>=<sortOrder>"
with possble values asc
and desc
for sortOrder
.
For example the ordering of the contacts from the previous example by name descending and then by firstname ascending would look like:
{ "page":2, "pageSize":250, "fields":[ "id", "lastname", "firstname", "postcode1" ], "search":[ { "field":"isAccount", "value":"false", "operator":"equals" }, { "field":"postcode1", "value":"53", "operator":"startswith" } ], "order" : ["lastname = desc", "firstname = asc"] }
Count
It is also possible to retrieve only the record count of the result by using the count
element. Count retrieves the number of objects depending on the search
. If search
is given the count of elements fulfilling the search criteria is returned, if not - the total count elements is retrieved.
Example: A total of 20 contacts exist in a Scopevisio Organisation. Eight of the contacts are personal, the others are company contacts. The following count combined with search criteria should return eight - the number of personal contacts.
{ "count": true, "search":[ { "field":"isAccount", "value":"false", "operator":"equals" } ] }
The following example should return the total count of contacts in the organisation which is 20.
{ "count": true }
All other search criteria, page
, pageSize
, fields
, order
are ignored when using the count
element.
Special searches
Some webservices allow also some special search or filter criteria, depending on the context.
Journal, personal journal and statistics journal
For /journal, /personaljournal and /statisticspostings the following filter criteria are available:
createdSince
- postings created (Erstellungsdatum) since the given datecreatedBefore
postings created (Erstellungsdatum) before the given datepostingDateSince
- postings with posting date (Buchungsdatum) since the given datepostingDateBefore
- postings with posting date (Buchungsdatum) before the given dateexternalDocumentDateSince
- postings with externalDocumentDate (Externes Belegdatum) since the given date
The date must be provided as milliseconds since the UNIX epoch (1970-01-01T00:00:00.000Z).
The following example returns all postings with creation date from 01.01.2018 to 31.12.2018 containing the word "Rabatt".
{ "createdSince": 1514764800000, "createdBefore": 1546300799000, "search": [ { "field": "postingText", "operator": "contains", "value": "Rabatt" } ] }
Statisticspostings
For /statisticspostings the following filter criteria are available:
createdSince
- postings created (Erstellungsdatum) since the given datecreatedBefore
postings created (Erstellungsdatum) before the given datepostingDateSince
- postings with posting date (Buchungsdatum) since the given datepostingDateBefore
- postings with posting date (Buchungsdatum) before the given dateaccountNumber
- filter on the statistics accountnumber
Availability of human resources
For /humanresourcesAvailability the following filter criteria are available:
validFrom
- human resources available since this point in timevalidTill
- human resources available until this point in time
For /humanresourcesavailability/v2 the following filter criteria are available:
Note, that the values must be formatted as yyyy-MM
validFrom
- human resources available since this monthvalidTill
- human resources available until this month