Data Access Deployment Guide⚓︎
The Data Access Building Block provides feature-rich and reliable interfaces to geospatial data assets stored in the platform, addressing both human and machine users. This guide provides step-by-step instructions to deploy the Data Access BB in your Kubernetes cluster.
Introduction⚓︎
The Data Access Building Block provides STAC data discovery, OGC API Features and OGC API Tiles for vector and raster data access.
The building block offers:
- STAC API for data discovery
- Support for retrieval and visualisation of raster and vector data via standard OGC APIs
- Dynamic specification of which datasets should be delivered with which data access services
- Integration with other building blocks through shared databases (e.g. pgSTAC)
Components Overview⚓︎
The Data Access BB consists of the following main components:
- 
eoAPI: A set of microservices for geospatial data access, including: - stac: STAC API for accessing geospatial metadata.
- raster: Access to raster data via OGC APIs.
- vector: Access to vector data via OGC APIs.
 
- 
PostgreSQL with PostGIS and pgSTAC 
 Database for storing geospatial metadata and data managed by the Crunchy Data Postgres Operator (pgo).
- 
eoapi-support 
 Optional but recommended monitoring stack (Grafana, Prometheus, metrics server) to observe and manage the Data Access services.
Prerequisites⚓︎
Before deploying the Data Access Building Block, ensure you have the following:
| Component | Requirement | Documentation Link | 
|---|---|---|
| Kubernetes | Cluster (tested on v1.28) | Installation Guide | 
| Helm | Version 3.5 or newer | Installation Guide | 
| kubectl | Configured for cluster access | Installation Guide | 
| Ingress Controller | Properly installed | Installation Guide | 
| TLS Certificates | Managed via cert-manageror manually | TLS Certificate Management Guide | 
| Object Store | Accessible object store (i.e. MinIO) | MinIO Deployment Guide | 
Clone the Deployment Guide Repository:
Validate your environment:
Run the validation script to ensure all prerequisites are met:
Deployment Steps⚓︎
1. Run the Configuration Script⚓︎
The configuration script will prompt you for necessary configuration values, generate configuration files, and prepare for deployment.
Configuration Parameters
During the script execution, you will be prompted to provide:
- INGRESS_HOST: Base domain for ingress hosts.- Example: example.com
 
- Example: 
- CLUSTER_ISSUER(optional): Cert-manager Cluster Issuer for TLS certificates.- Example: letsencrypt-prod
 
- Example: 
- PERSISTENT_STORAGECLASS: Storage class for persistent volumes.- Example: standard
 
- Example: 
- S3_HOST: Host URL for MinIO or S3-compatible storage.- Example: minio.example.com
 
- Example: 
- S3_ACCESS_KEY: Access key for your S3 storage.
- S3_SECRET_KEY: Secret key for S3 storage.
2. Apply Secrets⚓︎
The script will create a Kubernetes secret for the S3 credentials. Ensure you have the S3_ACCESS_KEY and S3_SECRET_KEY set in your environment.
3. Deploy PostgreSQL Operator and eoAPI⚓︎
- Install the PostgreSQL Operator (pgo) from the Crunchy Data OCI registry:
helm upgrade -i pgo oci://registry.developers.crunchydata.com/crunchydata/pgo \
  --version 5.6.0 \
  --namespace data-access \
  --create-namespace \
  --values postgres/generated-values.yaml
- Install eoAPI:
helm repo add eoapi https://devseed.com/eoapi-k8s/
helm repo update eoapi
helm upgrade -i eoapi eoapi/eoapi \
  --version 0.6.0 \
  --namespace data-access \
  --values eoapi/generated-values.yaml
- Deploy STAC Admin Manager
Note: The STAC Manager may not deploy fully, if you see
CrashLoopBackOfferrors, this is expected. The STAC Manager is not required for the Data Access Building Block to function
helm repo add eoepca-dev https://eoepca.github.io/helm-charts-dev
helm repo update eoepca-dev
helm upgrade -i stac-manager eoepca-dev/stac-manager \
  --version 0.0.3 \
  --namespace data-access \
  --values stac-manager/generated-values.yaml
- Deploy the Ingress (APISIX Only):
If you are using nginx then you can skip this step as the ingress will be deployed as part of the eoapi chart.
- Deploy EOAPI Maps Plugin
helm upgrade -i eoapi-maps-plugin eoepca-dev/eoapi-maps-plugin \
  --version 0.0.21 \
  --namespace data-access \
  --values eoapi-maps-plugin/generated-values.yaml
- (Optional) Install eoapi-supportfor Grafana, Prometheus, and the metrics server:
helm upgrade -i eoapi-support eoapi/eoapi-support \
  --version 0.1.7 \
  --namespace data-access \
  --values eoapi-support/generated-values.yaml
Note: If you prefer to monitor Data Access with your own monitoring solution, you can skip this step.
4. Monitoring the Deployment⚓︎
After deploying, you can monitor the status of the deployments:
Check that all pods are in the Running state and that services/ingresses are properly exposed.
5. Accessing the Data Access Services⚓︎
Once the deployment is complete and all pods are running, you can access the services:
- 
eoAPI STAC API: 
 https://eoapi.${INGRESS_HOST}/stac/
- 
Grafana (if eoapi-supportis installed and ingress is enabled):
 https://eoapisupport.${INGRESS_HOST}/
- 
eoAPI Maps Plugin: 
 https://maps.${INGRESS_HOST}/
Load Sample Collection⚓︎
The following steps load a sample Sentinel2-L2A-Iceland collection into eoAPI.
Check the loaded collection via STAC Browser…
source ~/.eoepca/state
xdg-open https://radiantearth.github.io/stac-browser/#/external/eoapi.${INGRESS_HOST}/stac/collections/sentinel-2-iceland
Testing and Validation⚓︎
Below are some quick ways to test and validate the Data Access services.
1. Access the Swagger UI⚓︎
The Data Access Building Block provides Swagger UI documentation for its APIs, allowing you to interact with the APIs directly from your browser.
- 
eoAPI STAC API Swagger UI: 
 https://eoapi.${INGRESS_HOST}/stac/api.html
- 
eoAPI Raster API Swagger UI: 
 https://eoapi.${INGRESS_HOST}/raster/api.html
- 
eoAPI Vector API Swagger UI: 
 https://eoapi.${INGRESS_HOST}/vector/api.html
Replace ${INGRESS_HOST} with your actual ingress host domain.
2. Access the STAC Manager UI⚓︎
3. Run Demo Jupyter Notebooks⚓︎
The EOEPCA/demo Jupyter Notebooks showcase how to interact with the Data Access services programmatically, including examples for data discovery, visualization, and data download using the Data Access APIs. See the 04 Data Access Notebook for usage examples.
- 
Before running the notebooks, ensure that sample data is registered into the Data Access component. Follow the Resource Registration Guide. 
- 
In the notebooks, set the base_domainvariable to reflect your endpoint:
For more information on how to run the demo Jupyter Notebooks, please visit the EOEPCA/demo Readme.
3. Perform Basic API Tests⚓︎
You can perform basic tests using tools like curl or directly through the Swagger UI.
Example: Retrieve STAC API Landing Page
source ~/.eoepca/state
curl -X GET "https://eoapi.${INGRESS_HOST}/stac/" -H "accept: application/json"
Example: Search STAC Items
source ~/.eoepca/state
curl -X POST "https://eoapi.${INGRESS_HOST}/stac/search" \
  -H "Content-Type: application/json" \
  -d '{
    "bbox": [-10, 35, 0, 45],
    "datetime": "2021-01-01T00:00:00Z/2021-12-31T23:59:59Z",
    "limit": 10
  }'
4. Test Suite Execution⚓︎
Run the Data Access tests from the system test suite.
The test results are summarised to the file test-report.xml.
Uninstallation⚓︎
To uninstall the Data Access Building Block and clean up associated resources:
helm uninstall eoapi -n data-access
helm uninstall eoapi-maps-plugin -n data-access
helm uninstall stac-manager -n data-access
helm uninstall pgo -n data-access
kubectl delete namespace data-access