You are viewing an old version of this page. View the current version.
Compare with Current
View Page History
« Previous
Version 4
Next »
Overview
Check the list of available endpoints and methods in the Aggregation task API:
Endpoints and methods | Description |
---|
GET /aggrtasks/{domain} see below | Get detailed information about a model. |
GET /aggrtasks/{domain}/{aggrId} see below | Get information about a specific aggregation task. |
GET /aggrtasks/{domain}/{aggrId}/measures see below | Get the measures of an aggregation task. |
POST /aggrtasks/{domain} see below | Create a new aggregation task. |
PUT /aggrtasks/{domain}/{aggrId} see below | Update an aggregation task. |
PUT /aggrtasks/{domain}/{aggrId}/stop see below | Stop an aggregation task. |
PUT /aggrtasks/{domain}/{aggrId}/start see below | Start a task and add aggregated data from a specific date. |
PUT /aggrtasks/{domain}/{aggrId}/resume see below | Resume a stopped aggregation task. |
DELETE /aggrtasks/{domain}/{aggrId} see below | Delete an aggregation task. |
Endpoints and methods
GET /aggrtasks/{domain}
Get information about all the aggregation tasks in a domain.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation tasks you want to get information about. |
Query string parameters
Query string parameters are optionally added after the path parameters, preceded by a question mark (?
) and separated by an ampersand (&
)
Parameter | Type | Description |
---|
skipCache
| boolean
| If it is true , skips the cache that contains the status of the aggregation tasks and force the system to tell you where to find them. Default value is false . |
status
| string
| Execution status of the aggregation tasks. Available values are: RUNNING
STOPPED
DELETED
ERROR
PARTIAL_STOPPED
PENDING_CREATE
PENDING_START
PENDING_STOP
PENDING_UPDATE
PENDING_REBUILD
PENDING_DELETE
PENDING_RESUME
PENDING_EXTEND
|
id
| string
| If you want to get details about a specific aggregation task only, enter its ID here. |
fromDate
| integer
| Timestamp from when the aggregation tasks to be returned were created. Format is a timestamp in milliseconds, for example 1652400000000 |
name
| string
| If you want to get details about a specific aggregation task only, you can enter its name. |
ownerEmail
| string
| Email of the aggregation tasks' owner. |
negated
| boolean
| Set this to true to negate all other parameters. Default value is false . |
Example
Find below a request example in cURL language. In this case, we are requesting all the aggregation tasks with status STOPPED
created in the given domain. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X GET "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain?status=STOPPED"
Response
Code | Description |
---|
200 | Successful response. List of aggregation tasks retrieved.
[
{
"id": "cc_myDomain:nQEbd480",
"name": "test1",
"delay": 0,
"domainName": "myDomain",
"ownerEmail": "john.smith@devo.com",
"jobs": [
{
"grain": "1m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652432340000
},
{
"grain": "5m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652400000000
},
{
"grain": "1h",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652400000000
}
],
"creationDate": 1652432342000,
"updateDate": 1652432342000,
"status": "STOPPED",
"statusData": "INCOMPLETE",
"fromDate": 1652400000000
},
{
"id": "cc_myDomain:oYckc691",
"name": "test2",
"delay": 0,
"domainName": "myDomain",
"ownerEmail": "john.smith@devo.com",
"jobs": [
{
"grain": "1m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652436480000
},
{
"grain": "5m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652436300000
},
{
"grain": "1h",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652436000000
}
],
"creationDate": 1652436468000,
"updateDate": 1652436468000,
"status": "STOPPED",
"statusData": "INCOMPLETE",
"fromDate": 1652400000000
}
]
|
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
GET /aggrtasks/{domain}/{aggrId}
Get information about a specific aggregation task in a given domain.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation task you want to get information about. |
aggrId required
| string
| Enter the ID of the aggregation task you want to get information about. |
Query string parameters
Query string parameters are optionally added after the path parameters, preceded by a question mark (?
) and separated by an ampersand (&
)
Parameter | Type | Description |
---|
skipCache
| boolean
| If it is true , skips the cache that contains the status of the aggregation task and force the system to tell you where to find it. Default value is false . |
Example
Find below a request example in cURL language. In this case, we are requesting details about the aggregation task with ID cc_myDomain:abcDE123
created in the domain called myDomain
. Also, we want to skip the cache about its status. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X GET "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123?skipCache=true"
Response
Code | Description |
---|
200 | Successful response. aggregation task details retrieved.
{
"id": "cc_myDomain:abcDE123",
"name": "Test",
"table": "demo.ecommerce.data`1234`.`345`",
"wheres": [
"eq(client, \"myDomain\")"
],
"delay": 0,
"query": {
"linq": "from demo.ecommerce.data`1234`.`345` where eq(client, \"myDomain\") group every 60000 by level, type, message, client"
},
"domainName": "myDomain",
"ownerEmail": "john.smith@devo.com",
"jobs": [
{
"grain": "1m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652432040000
},
{
"grain": "5m",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652400000000
},
{
"grain": "1h",
"status": "STOPPED",
"from": 1652400000000,
"to": 1652400000000
}
],
"creationDate": 1652432055000,
"updateDate": 1652432055000,
"status": "STOPPED",
"statusData": "INCOMPLETE",
"fromDate": 1652400000000
}
|
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
GET /aggrtasks/{domain}/{aggrId}/measures
Get the measures of an aggregation task.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Parameter |
---|
domain required
| string
| Enter the domain of the aggregation task you want to get information about. |
aggrId required
| string
| Enter the ID of the aggregation task you want to get information about. |
Example
Find below a request example in cURL language. In this case, we are requesting the measures of the aggregation task with ID cc_myDomain:abcDE123
created in the domain called myDomain
. Also, we want to skip the cache about its status. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X GET "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123/measures"
Response
Code | Description |
---|
200 | Successful response. In this example, the task is calculating three aggregations: count()
avg(responseTime)
sum(responseTime)
{
"responseTime": [
"avg",
"sum"
],
"count": []
}
|
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
POST /aggrtasks/{domain}
Create a new aggregation task.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain where you want to create the aggregation task. |
Request body
The request JSON body must include an object with the following key-value pairs:
Parameter | Type | Description |
---|
name required
| string
| Aggregation task's name, which must be unique in the domain. |
query required
| object
| An object that contains three parameters: LINQ - Base query of the aggregation task, written in LINQ syntax.
timezone - Timezone of the aggregation task query, in the following format: Europe/Madrid
locale - Locale of the aggregation task query, in the following format: en
|
fromDate required
| string
| Date from which the aggregation task searches to calculate the aggregated data. Valid format is dd/mm/yyyy |
description
| string
| Brief description of the aggregation task. |
delay
| integer
| Maximum acceptable time difference between the current time and the last event displayed. You can indicate it in seconds (1s ), minutes (1m ), hours (1h ) and days (1d ). Default value is 0 |
minGrain
| string
| Minimum granularity of the aggregation task. Available values are: AUTO - Calculate best aggregation according to the given query.
1m - Aggregate every minute.
5m - Aggregate every 5 minutes.
30m - Aggregate every 30 minutes.
|
Example
Find below a request example in cURL language. In this case, we are creating a new aggregation task in the domain called myDomain
. Learn how to authorize your request in this article.
curl --location -g 'https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain' --header 'standAloneToken:YOUR_TOKEN' --header 'Content-Type: application/json' --data '{
"name": "MyNewAggTask",
"description": "This is a test aggregation task",
"fromDate": "06/02/2023",
"minGrain": "30m",
"query": {
"timeZone": "Europe/Madrid",
"locale": "es",
"linq": "from siem.logtrust.web.activity group every 5m by username every 5m select avg(responseTime) as responseTime"
}
}'
Response
Code | Description |
---|
200 | Successful response. Aggregation task created.
{
"id": "cc_myDomain:abcDE123",
"name": "MyNewAggTask",
"table": "siem.logtrust.web.activity",
"wheres": [
"eq(client, \"myDomain\")"
],
"delay": 0,
"query": {
"linq": "from siem.logtrust.web.activity where eq(client, \"integrations_factory\") group every 60000 by username, client select sumf(responseTime) as responseTime_sumf",
"timeZone": "Europe/Madrid",
"locale": "es"
},
"description": "my new aggregation task",
"domainName": "myDomain",
"ownerEmail": "john.smith@devo.com",
"creationDate": 1677087818714,
"updateDate": 1677087818714,
"status": "PENDING_CREATE",
"statusData": null,
"fromDate": 0
}
|
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
PUT /aggrtasks/{domain}/{aggrId}
Update a specific aggregation task.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation task that you want to update. |
aggrId required
| string
| Enter the ID of the aggregation task that you want to update. |
Request body
The request JSON body must include an object with the following key-value pairs:
Parameter | Type | Description |
---|
query
| object
| An object that contains three parameters: LINQ - Base query of the aggregation task, written in LINQ syntax.
timezone - Timezone of the aggregation task query, in the following format: Europe/Madrid
locale - Locale of the aggregation task query, in the following format: en
|
description
| string
| Brief description of the aggregation task. |
delay
| integer
| Maximum acceptable time difference between the current time and the last event displayed. You can indicate it in seconds (1s ), minutes (1m ), hours (1h ) and days (1d ). Default value is 0 |
minGrain
| string
| Minimum granularity of the aggregation task. Available values are: AUTO - Calculate best aggregation according to the given query.
1m - Aggregate every minute.
5m - Aggregate every 5 minutes.
30m - Aggregate every 30 minutes.
|
Example
Find below a request example in cURL language. In this case, we are updating an aggregation task with ID cc_myDomain:abcDE123
in the domain called myDomain
. Learn how to authorize your request in this article.
curl --location --request PUT 'https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123' --header 'standAloneToken:YOUR_TOKEN' --header 'Content-Type: application/json' --data '{
"description": "Aggregation task updated",
"minGrain": "5m",
"query": {
"timeZone": "Europe/Madrid",
"locale": "es",
"linq": "from siem.logtrust.web.activity group every 10m by username every 5m select avg(responseTime) as responseTime"
}
}'
Response
Code | Description |
---|
200 | Aggregation task successfully updated.
{
"id": "cc_myDomain:abcDE123",
"name": "MyNewAggTask",
"table": "siem.logtrust.web.activity",
"wheres": [
"eq(client, \"myDomain\")"
],
"delay": 0,
"query": {
"linq": "from siem.logtrust.web.activity where eq(client, \"integrations_factory\") group every 60000 by username, client select sumf(responseTime) as responseTime_sumf",
"timeZone": "Europe/Madrid",
"locale": "es"
},
"description": "Aggregation task updated",
"domainName": "myDomain",
"ownerEmail": "john.smith@devo.com",
"creationDate": 1677087818714,
"updateDate": 1677087818714,
"status": "PENDING_CREATE",
"statusData": null,
"fromDate": 0
}
|
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
PUT /aggrtasks/{domain}/{aggrId}/stop
Stop an aggregation task.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation task that you want to stop. |
aggrId required
| string
| Enter the ID of the aggregation task that you want to stop. |
Example
Find below a request example in cURL language. In this case, we want to stop the aggregation task with ID cc_myDomain:abcDE123
in the domain called myDomain
. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X PUT "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123/stop"
Response
Code | Description |
---|
200 | Aggregation task stopped. |
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
PUT /aggrtasks/{domain}/{aggrId}/start
Start a new task and add aggregated data from a specific date.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain where you want the aggregation task to be. |
aggrId required
| string
| Enter the ID of the aggregation task that you want to start. |
Query string parameters
Query string parameters are optionally added after the path parameters, preceded by a question mark (?
) and separated by an ampersand (&
)
Parameter | Type | Description |
---|
from required
| integer
| Timestamp from when the aggregation task will be started. Format is a timestamp in milliseconds, for example 1652400000000 |
Example
Find below a request example in cURL language. In this case, we want to start the aggregation task with ID cc_myDomain:abcDE123
in the domain called myDomain
from a specific date indicated in the timestamp added to the URL. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X PUT "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123/start?from=1652400000000"
Response
Code | Description |
---|
200 | Aggregation task started. |
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
PUT /aggrtasks/{domain}/{aggrId}/resume
Resume an aggregation task from the date it was stopped.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation task that you want to resume. |
aggrId required
| string
| Enter the ID of the aggregation task that you want to resume. |
Example
Find below a request example in cURL language. In this case, we want to resume the aggregation task with ID cc_myDomain:abcDE123
in the domain called myDomain
. Also, we want to skip the cache about its status. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X PUT "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123/resume"
Response
Code | Description |
---|
200 | Aggregation task resumed. |
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |
DELETE /aggrtasks/{domain}/{aggrId}
Delete an aggregation task. This will permanently remove all the tasks and associated metadata.
Request
Path parameters
Add the following path parameters as part of the endpoint:
Parameter | Type | Description |
---|
domain required
| string
| Enter the domain of the aggregation task that you want to delete. |
aggrId required
| string
| Enter the ID of the aggregation task that you want to delete. |
Find below a request example in cURL language. In this case, we want to delete the aggregation task with ID cc_myDomain:abcDE123
in the domain called myDomain
. Also, we want to skip the cache about its status. Learn how to authorize your request in this article.
curl -H "standAloneToken:YOUR_TOKEN" -X DELETE "https://api-us.devo.com/aggregations/v2/aggrtasks/myDomain/cc_myDomain:abcDE123"
Response
Code | Description |
---|
200 | Aggregation task deleted. |
400 | Error in request |
401 | Unauthorized error. |
403 | Forbidden request. |
404 | Not found. |
405 | Method not allowed. |
500 | Server error and Java exception. |