CLI tools for managing stac-fastapi-elasticsearch-opensearch deployments.
pip install sfeos-tools[elasticsearch]Or for local development:
pip install -e sfeos_tools[elasticsearch]pip install sfeos-tools[opensearch]Or for local development:
pip install -e sfeos_tools[opensearch]To use the interactive Streamlit viewer:
pip install sfeos-tools[viewer]Or for local development:
pip install -e sfeos_tools[viewer]pip install sfeos-tools[dev]Or for local development:
pip install -e sfeos_tools[dev]After installation, the sfeos-tools command will be available:
# View available commands
sfeos-tools --help
# View version
sfeos-tools --versionAdds a bbox_shape field to existing collections for spatial search support. This migration is required for collections created before spatial search was added. Collections created or updated after this feature will automatically have the bbox_shape field.
sfeos-tools add-bbox-shape --backend [elasticsearch|opensearch] [options]Options:
--backend: Database backend to use (required, choices: elasticsearch, opensearch)--host: Database host (default: localhost or ES_HOST env var)--port: Database port (default: 9200 for ES, 9202 for OS, or ES_PORT env var)--use-ssl/--no-ssl: Use SSL connection (default: true or ES_USE_SSL env var)--user: Database username (default: ES_USER env var)--password: Database password (default: ES_PASS env var)
Reindexes all STAC indexes to the next version and updates aliases. This command performs the following actions:
- Creates/updates index templates
- Reindexes collections and item indexes to a new version
- Applies asset migration script for compatibility
- Switches aliases to the new indexes
sfeos-tools reindex --backend [elasticsearch|opensearch] [options]Options:
--backend: Database backend to use (required, choices: elasticsearch, opensearch)--host: Database host (default: localhost or ES_HOST env var)--port: Database port (default: 9200 for ES, 9202 for OS, or ES_PORT env var)--use-ssl/--no-ssl: Use SSL connection (default: true or ES_USE_SSL env var)--user: Database username (default: ES_USER env var)--password: Database password (default: ES_PASS env var)--yes: Skip confirmation prompt
Examples:
# Reindex Elasticsearch with custom host and no SSL
sfeos-tools reindex --backend elasticsearch --host localhost --port 9200 --no-ssl --yes
# Reindex OpenSearch with default settings
sfeos-tools reindex --backend opensearch --yesLoad STAC collections and items from local JSON files into a STAC API instance. This command is useful for:
- Populating a new STAC API deployment with test data
- Migrating data between STAC API instances
- Bulk loading STAC collections and items
sfeos-tools load-data --base-url <stac-api-url> [options]Options:
--base-url: Base URL of the STAC API (required)--collection-id: ID of the collection to create/update (default: test-collection)--data-dir: Directory containing collection.json and feature collection files (default: sample_data/)--use-bulk: Use bulk insert method for items (faster for large datasets)
Data Directory Structure:
Your data directory should contain:
collection.json: STAC collection definition- One or more
.jsonfiles: Feature collections with STAC items
Examples:
# Load data from default directory
sfeos-tools load-data --base-url http://localhost:8080
# Load with custom collection ID and bulk insert
sfeos-tools load-data \
--base-url http://localhost:8080 \
--collection-id my-collection \
--use-bulk
# Load from custom directory
sfeos-tools load-data \
--base-url http://localhost:8080 \
--data-dir /path/to/stac/data \
--collection-id production-dataLaunch an interactive Streamlit-based web viewer for exploring STAC collections and items. The viewer provides:
- Interactive map visualization of STAC items
- Collection browser and selector
- Item search and filtering
- Metadata inspection
- Asset preview and imagery display
- Support for thumbnails, images (JPEG, PNG, TIFF), and other asset types
sfeos-tools viewer [options]Options:
--stac-url: STAC API base URL (default: http://localhost:8080)--port: Port for the Streamlit viewer (default: 8501)
Requirements:
The viewer requires additional dependencies. Install with:
pip install sfeos-tools[viewer]Examples:
# Launch viewer with default settings (connects to http://localhost:8080)
sfeos-tools viewer
# Connect to a custom STAC API
sfeos-tools viewer --stac-url https://my-stac-api.com
# Use a different port
sfeos-tools viewer --port 8502
# Custom STAC API and port
sfeos-tools viewer --stac-url http://localhost:8080 --port 8502The viewer will automatically open in your default web browser. Press Ctrl+C in the terminal to stop the viewer.
To develop sfeos-tools locally:
# Install in editable mode with dev dependencies
pip install -e ./sfeos_tools[dev]
# Run the CLI
sfeos-tools --help
# Run tests
pytest
# Format code
pre-commit install
pre-commit run --all-filesThis project is licensed under the MIT License - see the LICENSE file for details.
