Elasticsearch action steps
Elasticsearch actions are built-in steps that allow your workflows to interact directly with Elasticsearch APIs. You can search, index, update, and delete documents, manage indices, and perform any other operation supported by the Elasticsearch REST API.
All Elasticsearch actions are automatically authenticated using the permissions or API key of the user executing the workflow.
There are two ways to use Elasticsearch actions:
- Named actions: Structured actions that map directly to specific Elasticsearch API endpoints
- Generic request actions: Actions that provide full control over the HTTP request for advanced use cases
Named actions provide a structured way to call specific Elasticsearch endpoints. The action type maps directly to the Elasticsearch API.
To view the available named actions, click Actions menu and select Elasticsearch. For operations that are not available as a named action, use the generic request action.
The following table shows some examples:
| Action type | Elasticsearch operation |
|---|---|
elasticsearch.search |
POST /<index>/_search (Run a search) |
elasticsearch.delete |
DELETE /<index>/_doc/<id> (Delete a document) |
elasticsearch.indices.create |
PUT /<index> (Create an index) |
The parameters you provide in the with block are passed as the body or query parameters of the API request. The following examples demonstrate common use cases.
The elasticsearch.search action searches for documents in the specified index. The query parameter is passed directly to the Run a search API.
steps:
- name: search_for_alerts
type: elasticsearch.search
with:
index: ".alerts-security.attack.discovery*"
query:
bool:
filter:
- term:
kibana.alert.severity: "critical"
The elasticsearch.delete action deletes a single document by its ID. The index and id parameters are used to construct the API path.
steps:
- name: delete_a_doc
type: elasticsearch.delete
with:
index: "my-index"
id: "document_id_123"
The elasticsearch.bulk action performs multiple indexing or delete operations in a single request. The body parameter must be a string containing the bulk operations in newline-delimited JSON (NDJSON) format. Each operation requires an action/metadata line followed by an optional source document line.
steps:
- name: bulk_index_data
type: elasticsearch.bulk
with:
index: "national-parks-data"
body: |
{ "index": { "_id": "1" } }
{ "name": "Yellowstone National Park", "category": "geothermal" }
{ "index": { "_id": "2" } }
{ "name": "Grand Canyon National Park", "category": "canyon" }
- Action/metadata line: Specifies the action and document ID
- Source document line: The document data
For advanced use cases or for accessing Elasticsearch APIs that do not have a named action, use the generic elasticsearch.request type. This gives you full control over the HTTP request.
We recommend using named actions whenever possible. They are more readable and provide a stable interface for common operations.
Use the following parameters in the with block to configure the request:
| Parameter | Required | Description |
|---|---|---|
method |
No (defaults to GET) |
The HTTP method (GET, POST, PUT, or DELETE) |
path |
Yes | The API endpoint path (for example, /_search, /_cluster/health) |
body |
No | The JSON request body |
query |
No | An object representing URL query string parameters |
This example uses the generic request to call the GET /_cluster/health endpoint (Get cluster health).
steps:
- name: get_cluster_health
type: elasticsearch.request
with:
method: GET
path: /_cluster/health
This example uses the generic request to call the POST /<index>/_delete_by_query endpoint (Delete documents).
steps:
- name: delete_old_documents
type: elasticsearch.request
with:
method: POST
path: /my-index/_delete_by_query
body:
query:
range:
"@timestamp":
lt: "now-30d"
The following example demonstrates how to combine multiple Elasticsearch actions in a workflow. It searches for documents and then iterates over the results to delete each one.
name: Search and Delete Documents
triggers:
- type: manual
steps:
- name: search_for_docs
type: elasticsearch.search
with:
index: ".alerts-security.attack.discovery.alerts-default"
query:
term:
host.name: "compromised-host"
- name: delete_found_docs
type: foreach
# The search results are in steps.search_for_docs.output
foreach: steps.search_for_docs.output.hits.hits
steps:
- name: delete_each_doc
type: elasticsearch.delete
with:
# The 'item' variable holds the current document from the loop
index: "{{ item._index }}"
id: "{{ item._id }}"
Key concepts in this example:
- Data flow: The output of the
search_for_docsstep is available to subsequent steps atsteps.search_for_docs.output. - Foreach loop: The
foreachstep iterates over thehits.hitsarray from the search results. - Item variable: Inside the loop, the
itemvariable holds the current document being processed, allowing you to access its fields such asitem._indexanditem._id.