PADAS Engine REST Docs
Overview
HTTP verbs & CRUD
RESTful notes tries to adhere as closely as possible to standard HTTP and REST conventions in its use of HTTP verbs and related CRUD (Create, Read, Update, and Delete) operations.
Resource Endpoint | Verb | Usage |
---|---|---|
|
|
Used to retrieve all available resources (Read all) |
|
|
Used to retrieve a resource (Read one) |
|
|
Used to create a new resource (Create) |
|
|
Used to update an existing resource (Update one) |
|
|
Used to delete an existing resource (Delete one) |
Note: By default, Padas Engine listens on https://localhost:8999
HTTP status codes
RESTful notes tries to adhere as closely as possible to standard HTTP and REST conventions in its use of HTTP status codes.
Status code | Usage |
---|---|
|
The request completed successfully |
|
A new resource has been created successfully. The resource’s URI is available from the response’s
|
|
An update to an existing resource has been applied successfully |
|
The request was malformed. The response body will include an error providing further information |
|
The request lacks valid authentication credentials |
|
The request lacks valid authorization credentials (e.g. invalid tokens or role) |
|
The requested resource did not exist |
|
The request could not be completed due to a conflict with the current state of the resource |
ERROR Messages
401 Unauthorized
and 403 Forbidden
responses do NOT contain any error messages. For all others, response body contains error information.
Field Name | Description |
---|---|
|
Response status |
|
Resource related error message |
|
Endpoint specific message details for debugging |
Following table provides information on error message
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
Content-Length: 119
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Provided username does not exist"
}
REST Endpoints
Init
This REST endpoint provides status and initial user creation functionality.
Create: POST /api/init
Initialize with a new user. This can be only performed 1 time. Consecutive requests should result in error.
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
Password for this user |
|
|
An array of roles |
|
|
Name of the role. |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
An array of roles |
|
|
Id for role |
|
|
Name of the role. |
POST /api/init HTTP/1.1
Content-Type: application/json;charset=UTF-8
Content-Length: 156
Host: localhost:8999
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 201 Created
Location: https://localhost:8999/init
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 140
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"roles" : [ {
"id" : 7,
"name" : "user"
} ]
}
POST /api/init HTTP/1.1
Content-Type: application/json;charset=UTF-8
Content-Length: 156
Host: localhost:8999
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 129
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "API and users are already initialized."
}
Read: GET /api/init
Read initial status of the endpoints. true
means we have users initialized already.
Path | Type | Description |
---|---|---|
|
|
Shows status. Value is |
GET /api/init HTTP/1.1
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: text/plain;charset=UTF-8
Content-Length: 26
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"initialized" : true
}
GET /api/init HTTP/1.1
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: text/plain;charset=UTF-8
Content-Length: 27
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"initialized" : false
}
Authentication & Authorization
A username and password authentication scheme is provided by default. A POST
request is used to perform login action.
Important Note: Any request to a protected resource (i.e. /api/*
URLs), other than login (/api/login
), must have a valid access_token
within Authorization
header as a Bearer token. Example:
GET /api/some-resource-goes-here HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhZG1pbiIsInJvbGVzIjpbImFkbWluIl0sImlzcyI6Imh0dHA6Ly9sb2NhbGhvc3Q6ODA4MC9hcGkvbG9naW4iLCJleHAiOjE2NDc3OTk2MTZ9.yBxgcrvYzOLJK_tkQz0ItocRDBLntrVpSX6i3XMLN7w
...
Login: POST /api/login
Upon successful login tokens are generated: use access_token
for accessing any resource and refresh_token
when access_token
is no longer valid.
A failed login returns 401
response code.
Path | Type | Description |
---|---|---|
|
|
Username to login. |
|
|
Password for the user. |
Path | Type | Description |
---|---|---|
|
|
Authorization (JWT) token to access protected API resources. |
|
|
This token can be used to obtain additional access token when existing one expires. |
POST /api/login HTTP/1.1
Content-Type: application/json;charset=UTF-8
Content-Length: 57
Host: localhost:8999
{
"username" : "testadmin",
"password" : "password"
}
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 441
{
"access_token" : "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTUzMn0.2JH20dheeFj46EXT0_ESeEvOvOwUfnEUscNVOzTTMvs",
"refresh_token" : "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMjUzMn0.sAskR4bm9g6_dHXoYgTdgoRiSmZDG4XQ8LEmcTbk0uI"
}
POST /api/login HTTP/1.1
Content-Type: application/json;charset=UTF-8
Content-Length: 62
Host: localhost:8999
{
"username" : "testadmin",
"password" : "nosuchpassxxx"
}
HTTP/1.1 401 Unauthorized
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Refresh Token: GET /api/token/refresh
When access_token
is no longer valid (receiving 403
responses due to expiration) this endpoint can be utilized to obtain a new one.
A failed access attempt returns 403
response code.
Name | Description |
---|---|
|
Contains Bearer refresh token for getting a fresh access token. |
Path | Type | Description |
---|---|---|
|
|
Authorization (JWT) token to access protected API resources. |
|
|
This token can be used to obtain additional access token when existing one expires. |
GET /api/token/refresh HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMjU0Mn0.XPt4KBP2019ef6Pklb7GjgidJQHGWedCVwBXRZfobLc
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 452
{
"access_token" : "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS90b2tlbi9yZWZyZXNoIiwiZXhwIjoxNjg3MTA5NTQyfQ.A8_E9GvAbFPOVGhWKOvfj2XplkYTss222oiDhb3s6zM",
"refresh_token" : "eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMjU0Mn0.XPt4KBP2019ef6Pklb7GjgidJQHGWedCVwBXRZfobLc"
}
GET /api/token/refresh HTTP/1.1
Authorization: Bearer some_invalid_refresh_token
Host: localhost:8999
HTTP/1.1 401 Unauthorized
ERROR: JWT verification error.
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 49
{
"error_message" : "JWT verification error."
}
Engine
This REST endpoint provides functionality for reading state, stop, and start actions for stream engine.
State: GET /api/engine/state
Read current state based on https://docs.confluent.io/platform/current/streams/javadocs/javadoc/org/apache/kafka/streams/KafkaStreams.State.html
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Current list of states of the stream engine threads according to https://docs.confluent.io/platform/current/streams/javadocs/javadoc/org/apache/kafka/streams/KafkaStreams.State.html |
GET /api/engine/state HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMDI4MX0.OezbcFXQ4Hhu5qCaeSfFzsriQ2ABxc5-OiwVtR6vEyE
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 30
{
"states" : [ "RUNNING" ]
}
Stop: POST /api/engine/stop
Stop the engine. If it’s already stopped it should return the same result.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Current list of states of the stream engine threads according to https://docs.confluent.io/platform/current/streams/javadocs/javadoc/org/apache/kafka/streams/KafkaStreams.State.html |
POST /api/engine/stop HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMDI4MX0.OezbcFXQ4Hhu5qCaeSfFzsriQ2ABxc5-OiwVtR6vEyE
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 34
{
"states" : [ "NOT_RUNNING" ]
}
POST /api/engine/stop HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMDI4MX0.OezbcFXQ4Hhu5qCaeSfFzsriQ2ABxc5-OiwVtR6vEyE
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 34
{
"states" : [ "NOT_RUNNING" ]
}
Start: POST /api/engine/start
Start the engine. The engine must be in NOT_RUNNING
state.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Current list of states of the stream engine threads according to https://docs.confluent.io/platform/current/streams/javadocs/javadoc/org/apache/kafka/streams/KafkaStreams.State.html |
POST /api/engine/start HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzExMDI4MX0.OezbcFXQ4Hhu5qCaeSfFzsriQ2ABxc5-OiwVtR6vEyE
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 34
{
"states" : [ "REBALANCING" ]
}
Topics
This REST endpoint provides functionality for Create (once) and Read operations on topics resource.
Create: POST /api/topics
Create topics. Since the topics are created only once, this endpoint is provided as a convenience more than a necessity. It is best to consult your Kafka Administrator prior to creating these topics for optimal partition and replication counts.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Topic name |
|
|
Number of partitions for the topic. This can not be changed after creation. |
|
|
Number of data replicas for this topic |
|
|
|
Path | Type | Description |
---|---|---|
|
|
|
|
|
Topic name |
|
|
Error message |
POST /api/topics HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvYXBpL2xvZ2luIiwiZXhwIjoxNjQ3ODkxNTcyfQ.n_ML9TDv6ggpDELJreQmiMMzgzyqHtcIMyc-GqCcOTo
Content-Length: 156
Host: localhost:8080
[
{
"name": "padas_nodes",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_rules",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_tasks",
"numberOfPartitions": 2,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_pipelines",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_topologies",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
}
]
HTTP/1.1 201 Created
Location: http://localhost:8080/api/topics
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
[
{
"result": "success",
"name": "padas_nodes"
},
{
"result": "success",
"name": "padas_rules"
},
{
"result": "success",
"name": "padas_tasks"
},
{
"result": "success",
"name": "padas_pipelines"
},
{
"result": "failure",
"message": "org.apache.kafka.common.errors.TopicExistsException: Topic 'padas_topologies' already exists."
}
]
Read ALL: GET /api/topics
Read all topics.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Topic name |
|
|
Number of partitions for the topic. This can not be changed after creation. |
|
|
Number of data replicas for this topic |
|
|
|
GET /api/topics HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvYXBpL2xvZ2luIiwiZXhwIjoxNjQ3ODkxNTcyfQ.n_ML9TDv6ggpDELJreQmiMMzgzyqHtcIMyc-GqCcOTo
Host: localhost:8080
HTTP/1.1 200 OK
Location: http://localhost:8080/api/topics
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
[
{
"name": "padas_rules",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_nodes",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_tasks",
"numberOfPartitions": 2,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_pipelines",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
},
{
"name": "padas_topologies",
"numberOfPartitions": 1,
"replicationFactor": 1,
"compact": true
}
]
List ALL: GET /api/topics/list
Read all available topics from the Kafka cluster.
Name | Description |
---|---|
|
Contains Bearer access token. |
GET /api/topics/list HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwOi8vbG9jYWxob3N0OjgwODAvYXBpL2xvZ2luIiwiZXhwIjoxNjQ3ODkxNTcyfQ.n_ML9TDv6ggpDELJreQmiMMzgzyqHtcIMyc-GqCcOTo
Host: localhost:8080
HTTP/1.1 200 OK
Location: http://localhost:8080/api/topics/list
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
X-Frame-Options: DENY
["topic1","topic2","topic3"]
Users
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on users resource.
Create: POST /api/users
Create a new user.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
Password for this user |
|
|
An array of roles |
|
|
Name of the role. |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
An array of roles |
|
|
Id for role |
|
|
Name of the role. |
POST /api/users HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Content-Length: 156
Host: localhost:8999
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 201 Created
Location: https://localhost:8999/api/users
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 141
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"roles" : [ {
"id" : 21,
"name" : "user"
} ]
}
POST /api/users HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Content-Length: 156
Host: localhost:8999
{
"name" : "New User",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 172
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "User already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/users
Read all users.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
An array of users |
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
An array of roles |
|
|
Id for role |
|
|
Name of the role. |
GET /api/users HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 151
[ {
"name" : "Test Admin",
"username" : "testadmin",
"email" : "testadmin@padas.io",
"roles" : [ {
"id" : 2,
"name" : "admin"
} ]
} ]
Read: GET /api/users/{username}
Read one user information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
Username to fetch |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
An array of roles |
|
|
Id for role |
|
|
Name of the role. |
GET /api/users/testadmin HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 147
{
"name" : "Test Admin",
"username" : "testadmin",
"email" : "testadmin@padas.io",
"roles" : [ {
"id" : 2,
"name" : "admin"
} ]
}
GET /api/users/nosuchuserxxx HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 119
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Provided username does not exist"
}
Update: PUT /api/users/{username}
Update a specific user.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
Username to udpate |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
Password for this user, can be left empty to skip update |
|
|
An array of roles |
|
|
Name of the role. |
Path | Type | Description |
---|---|---|
|
|
Display name for user |
|
|
Unique user name |
|
|
Email address associated with this user |
|
|
An array of roles |
|
|
Id for role |
|
|
Name of the role. |
PUT /api/users/newuser HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Content-Length: 157
Host: localhost:8999
{
"name" : "New User2",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 142
{
"name" : "New User2",
"username" : "newuser",
"email" : "newuser@padas.io",
"roles" : [ {
"id" : 24,
"name" : "user"
} ]
}
PUT /api/users/newuser HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Content-Length: 157
Host: localhost:8999
{
"name" : "New User2",
"username" : "newuser",
"email" : "newuser@padas.io",
"password" : "password123",
"roles" : [ {
"name" : "user"
} ]
}
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 119
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Provided username does not exist"
}
Delete: DELETE /api/users/{username}
Delete a specific user.
Parameter | Description |
---|---|
|
Username to delete |
DELETE /api/users/newuser HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/users/testadmin HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc5Nn0.ZOzx83xm3kxdX6F0IDLNJMOK8TNILYgSahXk5pexzF8
Host: localhost:8999
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 148
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Authenticated user is not allowed to delete herself"
}
Nodes
This REST endpoint provides functionality for Read and Delete operations on nodes resource.
Read ALL: GET /api/nodes
Read all nodes.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
An array of nodes |
|
|
UUID of registered Padas Engine node |
|
|
Hostname of the node |
|
|
REST URL for the node |
|
|
Group name for this node in order to distribute certain topologies |
GET /api/nodes HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTcyMn0.Q1NoZWkAoSKq7tnG6X6ajw5sHO0IlCafAz1gsztpM-o
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 292
[ {
"uuid" : "45443803-c6f2-413e-b9fb-89f76b027b73",
"host" : "seynur.local",
"rest" : "https://seynur.local:8999",
"group" : "default"
}, {
"uuid" : "d7169eb8-7710-4085-aa36-1ab2c8267842",
"host" : "seynur.local",
"rest" : "https://seynur.local:8999",
"group" : "default"
} ]
Read: GET /api/nodes/{id}
Read one user information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
UUID of the node to fetch |
Path | Type | Description |
---|---|---|
|
|
UUID of registered Padas Engine node |
|
|
Hostname of the node |
|
|
REST URL for the node |
|
|
Group name for this node in order to distribute certain topologies |
GET /api/nodes/45443803-c6f2-413e-b9fb-89f76b027b73 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTcyMn0.Q1NoZWkAoSKq7tnG6X6ajw5sHO0IlCafAz1gsztpM-o
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 143
{
"uuid" : "45443803-c6f2-413e-b9fb-89f76b027b73",
"host" : "seynur.local",
"rest" : "https://seynur.local:8999",
"group" : "default"
}
GET /api/nodes/79262a62-156f-4dbb-9931-bf25bf26ece6 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTcyMn0.Q1NoZWkAoSKq7tnG6X6ajw5sHO0IlCafAz1gsztpM-o
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 116
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested node does not exist"
}
Delete: DELETE /api/nodes/{id}
Delete a specific node. The ID must match the UUID of the node that is receiving the request.
Parameter | Description |
---|---|
|
UUID of the node to fetch |
DELETE /api/nodes/45443803-c6f2-413e-b9fb-89f76b027b73 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTcyMn0.Q1NoZWkAoSKq7tnG6X6ajw5sHO0IlCafAz1gsztpM-o
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/nodes/ee9b1dda-0f75-4e8e-8d28-47a41b60cb87 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTcyMn0.Q1NoZWkAoSKq7tnG6X6ajw5sHO0IlCafAz1gsztpM-o
Host: localhost:8999
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 186
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Unable to remove node. In order to remove properly the node must match the provided UUID"
}
Tasks
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on tasks resource.
Create: POST /api/tasks
Create a new task.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
POST /api/tasks HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 200
Host: localhost:8999
{
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
HTTP/1.1 201 Created
Location: https://localhost:8999/api/tasks
Content-Type: application/json
Content-Length: 200
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
POST /api/tasks HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 200
Host: localhost:8999
{
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 172
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "Task already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/tasks
Read all tasks.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
GET /api/tasks HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 419
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
[ {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}, {
"id" : 102,
"name" : "MyTest name3",
"description" : "MyTest description text goes here",
"function" : "FILTER",
"definition" : {
"type" : "regex",
"value" : "dest",
"action" : "keep"
}
} ]
Read: GET /api/tasks/{id}
Read one task information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the task to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
GET /api/tasks/100 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 200
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
GET /api/tasks/109 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 116
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested task does not exist"
}
Update: PUT /api/tasks/{id}
Update a specific task.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the task to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
PUT /api/tasks/100 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 207
Host: localhost:8999
{
"id" : 100,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 207
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"id" : 100,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
PUT /api/tasks/109 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 200
Host: localhost:8999
{
"id" : 109,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 152
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Task to update does not exist. Please use create (POST) endpoint."
}
Delete: DELETE /api/tasks/{id}
Delete a specific task.
Parameter | Description |
---|---|
|
ID of the task to fetch |
DELETE /api/tasks/100 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/tasks/109 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 117
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Task to delete does not exist."
}
Bulk Update/Create: POST /api/bulk/tasks
Bulk update/create a list of tasks.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
Path | Type | Description |
---|---|---|
|
|
ID for this task |
|
|
Unique task name |
|
|
Description of this task |
|
|
Predefined functionality for the task, refer to schema definition |
|
|
JSON object representing function parameters |
POST /api/bulk/tasks HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 353
Host: localhost:8999
[ {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}, {
"id" : 101,
"name" : "MyTest name2",
"description" : "MyTest description text goes here",
"function" : "PARSE_KV",
"definition" : { }
} ]
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 568
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
[ {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}, {
"id" : 101,
"name" : "MyTest name2",
"description" : "MyTest description text goes here",
"function" : "PARSE_KV",
"definition" : { }
}, {
"id" : 102,
"name" : "MyTest name3",
"description" : "MyTest description text goes here",
"function" : "FILTER",
"definition" : {
"type" : "regex",
"value" : "dest",
"action" : "keep"
}
} ]
POST /api/bulk/tasks HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc1M30._cEo5zXdDtwupUbkUbFYrOyTRZgdu0xO-dGg-KyO2Wc
Content-Length: 412
Host: localhost:8999
[ {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"function" : "TIMESTAMP",
"definition" : {
"field" : "somefield",
"format" : "%H%M%S"
}
}, {
"id" : 101,
"name" : "MyTest name2",
"description" : "MyTest description text goes here",
"function" : "PARSE_KV",
"definition" : { }
}, {
"someInvalidSchema" : "field value",
"someId" : 4
} ]
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 146
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Unable to bulk update tasks due to invalid input."
}
Pipelines
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on pipelines resource.
Create: POST /api/pipelines
Create a new pipeline.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
POST /api/pipelines HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 120
Host: localhost:8999
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
HTTP/1.1 201 Created
Location: https://localhost:8999/api/pipelines
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 120
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
POST /api/pipelines HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 120
Host: localhost:8999
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 176
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "Pipeline already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/pipelines
Read all pipelines.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
GET /api/pipelines HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 249
[ {
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}, {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 101, 100 ]
} ]
Read: GET /api/pipelines/{id}
Read one pipeline information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the pipeline to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
GET /api/pipelines/1 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 120
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
GET /api/pipelines/109 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 120
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested pipeline does not exist"
}
Update: PUT /api/pipelines/{id}
Update a specific pipeline.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the pipeline to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
PUT /api/pipelines/1 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 127
Host: localhost:8999
{
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 127
{
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
PUT /api/pipelines/109 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 122
Host: localhost:8999
{
"id" : 109,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 156
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Pipeline to update does not exist. Please use create (POST) endpoint."
}
Delete: DELETE /api/pipelines/{id}
Delete a specific pipeline.
Parameter | Description |
---|---|
|
ID of the pipeline to fetch |
DELETE /api/pipelines/1 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/pipelines/109 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 121
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Pipeline to delete does not exist."
}
Bulk Update/Create: POST /api/bulk/pipelines
Bulk update/create a list of pipelines.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
Path | Type | Description |
---|---|---|
|
|
ID for this pipeline |
|
|
Unique pipeline name |
|
|
Description of this pipeline |
|
|
An array of ordered Task IDs |
POST /api/bulk/pipelines HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 245
Host: localhost:8999
[ {
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"tasks" : [ 1, 5 ]
} ]
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 370
[ {
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"tasks" : [ 1, 5 ]
}, {
"id" : 100,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 101, 100 ]
} ]
POST /api/bulk/pipelines HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTczMn0.kQ4hvMbK7R5D2ysPc7MDrq7_AnkLp-QXyfCM2oCaU1s
Content-Length: 304
Host: localhost:8999
[ {
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"tasks" : [ 1, 3, 5 ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"tasks" : [ 1, 5 ]
}, {
"someInvalidSchema" : "field value",
"someId" : 4
} ]
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 150
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Unable to bulk update pipelines due to invalid input."
}
Topologies
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on topologies resource.
Create: POST /api/topologies
Create a new topology.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
POST /api/topologies HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 225
Host: localhost:8999
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
HTTP/1.1 201 Created
Location: https://localhost:8999/api/topologies
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 225
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
POST /api/topologies HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 225
Host: localhost:8999
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 176
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "Topology already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/topologies
Read all topologies.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
GET /api/topologies HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 229
[ {
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
} ]
Read: GET /api/topologies/{id}
Read one topology information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the topology to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
GET /api/topologies/1 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 225
{
"id" : 1,
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
GET /api/topologies/222 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 120
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested topology does not exist"
}
Update: PUT /api/topologies/{id}
Update a specific topology.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the topology to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
PUT /api/topologies/1 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 232
Host: localhost:8999
{
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 232
{
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
PUT /api/topologies/222 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 234
Host: localhost:8999
{
"id" : 222,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 156
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Topology to update does not exist. Please use create (POST) endpoint."
}
Delete: DELETE /api/topologies/{id}
Delete a specific topology.
Parameter | Description |
---|---|
|
ID of the topology to fetch |
DELETE /api/topologies/1 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/topologies/222 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 121
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Topology to delete does not exist."
}
Bulk Update/Create: POST /api/bulk/topologies
Bulk update/create a list of topologies.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
Path | Type | Description |
---|---|---|
|
|
ID for this topology |
|
|
Unique topology name |
|
|
Description of this topology |
|
|
An array of ordered Pipeline IDs |
|
|
Determines whether this topology is enabled or not, default is |
|
|
Group determines the instances where this topology should run, default is “default” |
|
|
Input topic name for this topology |
|
|
An array of output topics where results will be sent |
POST /api/bulk/topologies HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 465
Host: localhost:8999
[ {
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
} ]
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 465
[ {
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
} ]
POST /api/bulk/topologies HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc4N30.iTGgbpk3DtbMNQv8PQTWTO2GaVFzxbjzN2zmSn1YLB8
Content-Length: 524
Host: localhost:8999
[ {
"id" : 1,
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}, {
"id" : 2,
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"pipelines" : [ 1, 3, 5 ],
"enabled" : true,
"group" : "default",
"input" : "test_input",
"output" : [ "test_output" ]
}, {
"someInvalidSchema" : "field value",
"someId" : 4
} ]
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 151
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Unable to bulk update topologies due to invalid input."
}
Rules
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on rules resource.
Create: POST /api/rules
Create a new rule.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
POST /api/rules HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 239
Host: localhost:8999
{
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
HTTP/1.1 201 Created
Location: https://localhost:8999/api/rules
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 239
{
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
POST /api/rules HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 239
Host: localhost:8999
{
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 172
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "Rule already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/rules
Read all rules.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
GET /api/rules HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 522
[ {
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}, {
"id" : "myrule10",
"name" : "myrule10 name",
"description" : "myrule10 description",
"datamodel" : "rules",
"pdl" : "temporal(ordered=true) [ field1?=\"value\" || field3=\"value3\" ] timespan=2m group_by field2",
"annotations" : [ "T1811" ],
"enabled" : false
} ]
Read: GET /api/rules/{id}
Read one rule information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the rule to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
GET /api/rules/100 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 239
{
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
GET /api/rules/x1099 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 116
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested rule does not exist"
}
Update: PUT /api/rules/{id}
Update a specific rule.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the rule to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
PUT /api/rules/100 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 246
Host: localhost:8999
{
"id" : "100",
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 246
{
"id" : "100",
"name" : "MyUpdatedTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
PUT /api/rules/x1099 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 241
Host: localhost:8999
{
"id" : "x1099",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 152
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Rule to update does not exist. Please use create (POST) endpoint."
}
Delete: DELETE /api/rules/{id}
Delete a specific rule.
Parameter | Description |
---|---|
|
ID of the rule to fetch |
DELETE /api/rules/100 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/rules/x1099 HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 117
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Rule to delete does not exist."
}
Bulk Update/Create: POST /api/bulk/rules
Bulk update/create a list of rules.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
Path | Type | Description |
---|---|---|
|
|
ID for this rule |
|
|
Unique rule name |
|
|
Description of this rule |
|
|
Datamodel where this rule will be applicable |
|
|
PDL query to match against events according to the Datamodel |
|
|
An array of annotations regarding this rule, such as MITRE ATT&CK Technique IDs |
|
|
Determines whether this rule is active |
POST /api/bulk/rules HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 488
Host: localhost:8999
[ {
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}, {
"id" : "1001",
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : false
} ]
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 767
[ {
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}, {
"id" : "1001",
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : false
}, {
"id" : "myrule10",
"name" : "myrule10 name",
"description" : "myrule10 description",
"datamodel" : "rules",
"pdl" : "temporal(ordered=true) [ field1?=\"value\" || field3=\"value3\" ] timespan=2m group_by field2",
"annotations" : [ "T1811" ],
"enabled" : false
} ]
POST /api/bulk/rules HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc0MX0.ldlmeS_iwKp3p_u4WZj_n33aS8ddX1wgdN9_KLXfn-0
Content-Length: 547
Host: localhost:8999
[ {
"id" : "100",
"name" : "MyTest name",
"description" : "MyTest description text goes here",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : true
}, {
"id" : "1001",
"name" : "MyTest name2",
"description" : "MyTest description text goes here2",
"datamodel" : "endpoint",
"pdl" : "src=mysource AND dest=some.dest.ip",
"annotations" : [ "T1001", "T1059.001" ],
"enabled" : false
}, {
"someInvalidSchema" : "field value",
"someId" : 4
} ]
HTTP/1.1 400 Bad Request
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 146
{
"status" : "BAD_REQUEST",
"message" : "Resource validation failed",
"debugMessage" : "Unable to bulk update rules due to invalid input."
}
Lookups
This REST endpoint provides functionality for CRUD (Create, Read, Update, and Delete) operations on Lookup resources.
Create: POST /api/lookups
Create a new lookup.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID for this lookup |
Part | Description |
---|---|
|
Multipart form data that holds the file to be uploaded. |
Path | Type | Description |
---|---|---|
|
|
ID for this lookup |
POST /api/lookups HTTP/1.1
Content-Type: multipart/form-data;charset=UTF-8; boundary=6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=id
test_id
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=file; filename=test_csv.csv
Content-Type: text/csv
field1,field2,field3
value1,5,value3
v1,3,v3
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm--
HTTP/1.1 201 Created
Location: https://localhost:8999/api/lookups
Content-Type: text/plain;charset=UTF-8
Content-Length: 22
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"id" : "test_id"
}
POST /api/lookups HTTP/1.1
Content-Type: multipart/form-data;charset=UTF-8; boundary=6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=id
test_id
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=file; filename=test_csv.csv
Content-Type: text/csv
field1,field2,field3
value1,5,value3
v1,3,v3
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm--
HTTP/1.1 409 Conflict
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 174
{
"status" : "CONFLICT",
"message" : "Resource already exists",
"debugMessage" : "Lookup already exists, can not create a new one. Please use update (PUT) endpoint."
}
Read ALL: GET /api/lookups
Read all lookups.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
ID for this lookup |
|
|
Contents of the lookup file as JSON array (CSV content is converted). |
GET /api/lookups HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 184
[ {
"id" : "test_id",
"content" : [ {
"field1" : "value1",
"field2" : 5,
"field3" : "value3"
}, {
"field1" : "v1",
"field2" : 3,
"field3" : "v3"
} ]
} ]
Read: GET /api/lookups/{id}
Read one lookup information.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the lookup to fetch |
Path | Type | Description |
---|---|---|
|
|
ID for this lookup |
|
|
Contents of the lookup file as JSON array (CSV content is converted). |
GET /api/lookups/test_id HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
HTTP/1.1 200 OK
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 180
{
"id" : "test_id",
"content" : [ {
"field1" : "value1",
"field2" : 5,
"field3" : "value3"
}, {
"field1" : "v1",
"field2" : 3,
"field3" : "v3"
} ]
}
GET /api/lookups/xxtest_id HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 118
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested lookup does not exist"
}
Update: POST /api/lookups/{id}
Update a specific lookup.
Name | Description |
---|---|
|
Contains Bearer access token. |
Parameter | Description |
---|---|
|
ID of the lookup to fetch |
Part | Description |
---|---|
|
Multipart form data that holds the file to be uploaded. |
Path | Type | Description |
---|---|---|
|
|
ID for this lookup |
POST /api/lookups/test_id HTTP/1.1
Content-Type: multipart/form-data;charset=UTF-8; boundary=6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=file; filename=test_json.json
Content-Type: text/json
[{"field1":"value1","field3":"value3","field2":5},{"field1":"v1","field3":"v3","field2":3}]
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm--
HTTP/1.1 200 OK
Content-Type: text/plain;charset=UTF-8
Content-Length: 22
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"id" : "test_id"
}
POST /api/lookups/xxtest_id HTTP/1.1
Content-Type: multipart/form-data;charset=UTF-8; boundary=6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm
Content-Disposition: form-data; name=file; filename=test_json.json
Content-Type: text/json
[{"field1":"value1","field3":"value3","field2":5},{"field1":"v1","field3":"v3","field2":3}]
--6o2knFse3p53ty9dmcQvWAIx1zInP11uCfbm--
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 154
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Lookup to update does not exist. Please use create (POST) endpoint."
}
Delete: DELETE /api/lookups/{id}
Delete a specific lookup.
Parameter | Description |
---|---|
|
ID of the lookup to fetch |
DELETE /api/lookups/test_id HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
HTTP/1.1 204 No Content
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
DELETE /api/lookups/xxtest_id HTTP/1.1
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTYyMn0.LT7dN5PptrkLJ5qc1-CJgrU_v9bnohbXXyto_b36DNc
Host: localhost:8999
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 119
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Lookup to delete does not exist."
}
Tests
This REST endpoint provides functionality for testing a rule, a task, or a pipeline. Request body contains the payload for the given test. For example, for a Rule test it must be JSON but depending on the task and/or pipeline it can be plain text (e.g. raw event data)
Testing a Rule: POST /api/test/rules/{id}
id
represents the rule to be tested for the given payload.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Result of this test as JSON value. It is set to either <code>true</code> or <code>false</code> for rule matching. |
POST /api/test/rules/myruleid1 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 68
Host: localhost:8999
{
"src" : "my_source",
"dest" : "10.20.30.40",
"bytes" : 456
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 93
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : {
"src" : "my_source",
"dest" : "10.20.30.40",
"bytes" : 456
}
}
POST /api/test/rules/myruleid1 HTTP/1.1
Content-Type: application/json;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 72
Host: localhost:8999
{
"src" : "no_such_value",
"dest" : "10.20.30.40",
"bytes" : 456
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 21
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : null
}
Testing a Task: POST /api/test/tasks/{id}
id
represents the task to be tested for the given payload.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Result of this test as JSON value. |
POST /api/test/tasks/100 HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 81
Host: localhost:8999
{
"mytime" : "20-05-2022 11:45:09",
"dest" : "10.20.30.40",
"bytes" : 456
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 135
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : {
"mytime" : "20-05-2022 11:45:09",
"dest" : "10.20.30.40",
"bytes" : 456,
"_time" : 1653047109000
}
}
POST /api/test/tasks/100 HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 88
Host: localhost:8999
{
"no_such_field" : "20-05-2022 11:45:09",
"dest" : "10.20.30.40",
"bytes" : 456
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 142
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : {
"no_such_field" : "20-05-2022 11:45:09",
"dest" : "10.20.30.40",
"bytes" : 456,
"_time" : 1687109177572
}
}
Testing a Pipeline: POST /api/test/pipelines/{id}
id
represents the pipeline to be tested for the given payload.
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Result of this test as JSON value. |
POST /api/test/pipelines/100 HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 57
Host: localhost:8999
mytime="20-05-2022 11:45:09", dest=10.20.30.40, bytes=456
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 213
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : {
"mytime" : "20-05-2022 11:45:09",
"dest" : "10.20.30.40",
"bytes" : "456",
"_raw" : "mytime=\"20-05-2022 11:45:09\", dest=10.20.30.40, bytes=456",
"_time" : 1653047109000
}
}
POST /api/test/pipelines/177 HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 57
Host: localhost:8999
mytime="20-05-2022 11:45:09", dest=10.20.30.40, bytes=456
HTTP/1.1 404 Not Found
Content-Type: application/json
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
Content-Length: 120
{
"status" : "NOT_FOUND",
"message" : "Resource not found",
"debugMessage" : "Requested pipeline does not exist"
}
Testing a PDL: POST /api/test/pdl
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Result of this test as JSON value. |
POST /api/test/pdl HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 83
Host: localhost:8999
{
"pdl" : "bytes > 400",
"data" : "{\"dest\":\"10.20.30.40\", \"bytes\":456}"
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 68
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : {
"dest" : "10.20.30.40",
"bytes" : 456
}
}
Testing a PDL Syntax: POST /api/test/pdl/syntax
Name | Description |
---|---|
|
Contains Bearer access token. |
Path | Type | Description |
---|---|---|
|
|
Result of this syntax test as JSON value. |
POST /api/test/pdl/syntax HTTP/1.1
Content-Type: text/plain;charset=UTF-8
Authorization: Bearer eyJ0eXAiOiJKV1QiLCJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJ0ZXN0YWRtaW4iLCJyb2xlcyI6WyJhZG1pbiJdLCJpc3MiOiJodHRwczovL2xvY2FsaG9zdDo4OTk5L2FwaS9sb2dpbiIsImV4cCI6MTY4NzEwOTc3N30.e0z4NDK_-kNFhFyLKMXtAmh5cDXyRSYrC6g_6vFPxbI
Content-Length: 55
Host: localhost:8999
{
"pdl" : "bytes > 400 AND field1=\"value string\""
}
HTTP/1.1 200 OK
Content-Type: application/json
Content-Length: 21
X-Content-Type-Options: nosniff
X-XSS-Protection: 1; mode=block
Cache-Control: no-cache, no-store, max-age=0, must-revalidate
Pragma: no-cache
Expires: 0
Strict-Transport-Security: max-age=31536000 ; includeSubDomains
X-Frame-Options: DENY
{
"result" : true
}
End
End of document