Data Listing and Query (DLQS) Search
The Data Listing & Query Service (DLQS) provides robust APIs for querying and summarizing data objects on an ElasticSearch cluster. This service empowers application developers with the capability to execute precise queries on data objects or entities residing on OS1.
DLQS includes two key API endpoints:
- SearchQuery: Enables detailed querying of data objects, allowing developers to execute specific searches tailored to their needs.
- AggregateQuery: Complements the search functionality by providing summarized data views. This API is useful for efficiently aggregating transactional data, such as counting documents with specific criteria or assessing the status of various entities.
Together, these APIs offer a comprehensive suite for data listing, searching, and aggregation, catering to a wide range of application development requirements in data analysis and management.
Developers can use the SearchQuery and AggregateQuery endpoints by setting up the App Role Config to enable an app with permissions. This configuration can be defined in either JSON or YAML format.
App Roles Configuration generally consist of the following sections:
- Resources:
- This should declare only App level resources. CoreOS resources are standard and need not be mentioned.
- Each resource should start with the keyword app:<app_short_name>:.
- This is a combination of the resource name and the allowed HTTP methods.
- Roles:
- This lists the roles and the associated permissions for each role. Note that roles, once defined, cannot be deprecated or removed from AAA.
In the example below, we’ll add the Platform:Role:platform:app:coreos:dlq-search permission for the tenant:operations:facility_supervisor role.
GET - /core/api/v1/dlqs/search/{domain}/{type}
Path Parameters
Parameter | Data Type | Description | Example |
domain | string | The domain of the index to search. Possible values are:
| containers |
type | string | The type parameter specifies the entity type to search for, in all lowercase. It's formulated by removing special characters and combining the appId and entityPluralName, also in lowercase. |
|
Parameter | Data Type | Description | Example |
limit | integer | The maximum number of search results to return. Default is 50. | limit=10 |
offset | integer | Specifies the number of records or entries to bypass before starting to return results. Default is 0. | offset=20 |
select | string | Specifies the list of attributes to be included in the response. If not specified, all attributes are included in the response. This needs to be passed as a comma-separated string of attribute names. | select=userName,userAge |
sortKey | string | The key to be used for sorting the result data. Sorting is allowed only on number and string type of values. | sortKey=userAge.keyword or sortKey=userAge |
sortBy | string | Key to specify if result data is to be fetched in ascending ("asc") or descending ("desc") order. Allowed values are "asc", "desc". Default is "desc". | sortBy=asc |
query | string | Key to pass filters on the result data. This should be URI encoded. | query=name%20EQ%20John Possible values:
|
GET - /core/api/v1/dlqs/aggregate/{domain}/{type}
Path Parameters
Parameter | Data Type | Description | Example |
domain | string | The domain of the index to search. Possible values are:
| containers |
type | string | The type parameter specifies the entity type to search for, in all lowercase. It's formulated by removing special characters and combining the appId and entityPluralName, also in lowercase. |
|
Query Parameters
Parameter | Data Type | Description | Example |
query | string | Key to pass filters on the result data. This should be URI encoded. | Possible values:
|
aggregateQuery | string | Query criteria | Possible values:
|