Elasticsearch Connector
With this connector, Hasura allows you to instantly create a real-time GraphQL API on top of your documents in Elasticsearch. This connector supports Elasticsearch functionalities listed in the table below, allowing for efficient and scalable data operations. Additionally, you will benefit from all the powerful features of Hasura’s Data Delivery Network (DDN) platform, including query pushdown capabilities that delegate all query operations to the Elasticsearch, thereby enhancing query optimization and performance.
This connector is built using the Go Data Connector SDK and implements the Data Connector Spec.
- See the listing in the Hasura Hub
- Hasura DDN Documentation
- Hasura DDN Quickstart
- GraphQL on Elasticsearch
Docs for the Elasticsearch data connector:
Features
Below, you'll find a matrix of all supported features for the Elasticsearch connector:
Feature | Supported | Notes |
---|---|---|
Native Queries + Logical Models | ✅ | |
Simple Object Query | ✅ | |
Filter / Search | ✅ | |
Simple Aggregation | ✅ | |
Sort | ✅ | |
Paginate | ✅ | |
Nested Objects | ✅ | |
Nested Arrays | ✅ | |
Nested Filtering | ✅ | |
Nested Sorting | ❌ | |
Nested Relationships | ❌ |
Before you get Started
- Create a Hasura Cloud account
- Please ensure you have the DDN CLI and Docker installed
- Create a supergraph
- Create a subgraph
Using the Elasticsearch connector
Step 1: Authenticate your CLI session
ddn auth login
Step 2: Configure the connector
Once you have an initialized supergraph and subgraph, run the initialization command in interactive mode while providing a name for the connector in the prompt:
ddn connector init <connector-name> -i
Step 2.1: Choose hasura/elasticsearch
from the list
Step 2.2: Choose a port for the connector
The CLI will ask for a specific port to run the connector on. Choose a port that is not already in use or use the default suggested port.
Step 2.3: Provide the env vars required for the connector
To configure the connector, the following environment variables need to be set:
Environment Variable | Description | Required | Example Value |
---|---|---|---|
ELASTICSEARCH_URL | The comma-separated list of Elasticsearch host addresses for connection (Use local.hasura.dev instead of localhost if your connector is running on your local machine) | Yes | https://example.es.gcp.cloud.es.io:9200 |
ELASTICSEARCH_USERNAME | The username for authenticating to the Elasticsearch cluster | Yes | admin |
ELASTICSEARCH_PASSWORD | The password for the Elasticsearch user account | Yes | default |
ELASTICSEARCH_API_KEY | The Elasticsearch API key for authenticating to the Elasticsearch cluster | No |
|
ELASTICSEARCH_CA_CERT_PATH | The path to the Certificate Authority (CA) certificate for verifying the Elasticsearch server's SSL certificate | No | /etc/connector/cacert.pem |
ELASTICSEARCH_INDEX_PATTERN | The pattern for matching Elasticsearch indices, potentially including wildcards, used by the connector | No | hasura* |
Step 3: Introspect the connector
ddn connector introspect <connector-name>
This will generate a configuration.json
file that will have the schema of your Elasticsearch DB.
Step 4: Add your resources
ddn connector-link add-resources <connector-name>
This command will track all the indices in your Elasticsearch DB as Models.
Contributing
Check out our contributing guide for more details.
License
The Elasticsearch connector is available under the Apache License 2.0.