Skip to main content

satellite product browser

Project description

vresto logo

vresto

An elegant Python interface for discovering and retrieving Copernicus Sentinel data.

PyPI version PyPI Downloads Tests Docs - MkDocs Ruff Gitleaks


Demo

vresto Demo

Features

  • 🗺️ Interactive Map Interface - Visually search and filter satellite products
  • 🛰️ High-Resolution Tile Server - Instantly visualize full-resolution product bands on the map (via localtileserver)
  • 🔍 Smart Search - Filter by location, date range, cloud cover, and product type
  • 📦 Granular Download Management - Advanced Band-Resolution matrix for precise data selection and de-duplicated downloads
  • 🔌 Dual Backend Support - Flexible discovery via OData or STAC APIs
  • 🐍 Professional API - Clean Python API for programmatic access
  • 🔐 Secure - Handle S3 credentials safely with static key support
  • Efficient - Batch operations and smart caching

⚡ Quick Start with Docker 🐳

The fastest way to run vresto is by using Docker Compose 🚢

You only need Docker and Docker Compose installed on your machine. If you don't have them yet, you can find installation instructions on the Docker website and Docker Compose documentation.

Note: You need Copernicus credentials to use vresto. Get free access at https://dataspace.copernicus.eu/

Start vresto in just a few steps:

  1. Clone the repository and go to its main directory

    git clone https://github.com/kalfasyan/vresto.git && cd vresto
    
  2. Start the application with Docker Compose

    docker compose up -d
    

    ℹ️ That's it! The app will start and you can add credentials later via the UI, or provide them now:

    Option A: Add credentials now (Recommended if you have them)

    • Uncomment and fill the environment variables in docker-compose.yml, or
    • Create a .env file:
      cp .env.example .env
      # Edit .env with your credentials
      

    Option B: Add credentials later (via the app Settings menu)

    • Just run docker compose up -d without credentials (use docker compose up -d --build if you just cloned the repo)
    • The app will start at http://localhost:8610
    • Click the ☰ menu button in the top-left corner to open the Settings drawer
    • Add your Copernicus credentials through the Settings menu anytime
    • S3 credentials are optional—without them you'll get temporary credentials with usage limits (see Setup Guide for details)

Done! 🎉

Your vresto dashboard is now running at:
🌐 http://localhost:8610

Note: If you pulled recent changes and a feature isn't available, rebuild the Docker image:

docker compose up -d --build
🚀 Essential Docker & Docker Compose Commands
# Start the app in background (Docker Compose)
docker compose up -d
# View logs (Docker Compose)
docker compose logs -f
# Stop and remove services (Docker Compose)
docker compose down
# Rebuild and start (Docker Compose)
docker compose up -d --build
# Run the container directly (plain Docker)
docker run -d -p 8610:8610 \
  --name vresto-dashboard \
  vresto:latest
# View logs (plain Docker)
docker logs -f vresto-dashboard
# Stop and remove the container (plain Docker)
docker stop vresto-dashboard && docker rm vresto-dashboard

Quick Start

Note: You need Copernicus credentials to use vresto. Get free access at https://dataspace.copernicus.eu/

Installation

From PyPI (recommended for users):

pip install vresto

For development:

git clone https://github.com/kalfasyan/vresto.git
cd vresto
uv sync

Configuration

Configure your credentials (see Setup Guide for details):

export COPERNICUS_USERNAME="your_email@example.com"
export COPERNICUS_PASSWORD="your_password"

Or run the interactive setup helper which writes a .env in the project root:

python scripts/setup_credentials.py

Launch the App

Simply run:

vresto

Opens at http://localhost:8610

Alternative methods:

# Using make
make app

# Or directly with Python
python src/vresto/ui/app.py

Command-Line Interface (CLI):

Quick searches and downloads from the terminal:

# 🔍 Search for products
vresto-cli search-name "S2A_MSIL2A_20200612" --max-results 5

# 📸 Download quicklook (preview image)
vresto-cli download-quicklook "S2A_MSIL2A_20200612T023601_N0500_R089_T50NKJ_20230327T190018" --output ./quicklooks

# 📋 Download metadata
vresto-cli download-metadata "S2A_MSIL2A_20200612T023601_N0500_R089_T50NKJ_20230327T190018" --output ./metadata

# 🎨 Download specific bands
vresto-cli download-bands "S2A_MSIL2A_20200612T023601_N0500_R089_T50NKJ_20230327T190018" "B04,B03,B02" --resolution 10 --output ./data

For complete CLI documentation, see the CLI Guide.

API usage:

Get started with just a few lines of Python:

from vresto.api import CatalogSearch, CopernicusConfig
from vresto.products import ProductsManager

# Initialize
config = CopernicusConfig()
catalog = CatalogSearch(config=config)
manager = ProductsManager(config=config)

# 🔍 Search for a product by name
products = catalog.search_products_by_name("S2A_MSIL2A", max_results=5)

# 📸 Download quicklook and metadata
for product in products:
    quicklook = manager.get_quicklook(product)
    metadata = manager.get_metadata(product)
    if quicklook:
        quicklook.save_to_file(f"{product.name}.jpg")

# 🎨 Download specific bands for analysis/visualization
manager.download_product_bands(
    product=products[0].name,
    bands=["B04", "B03", "B02"],  # Red, Green, Blue
    resolution=10,
    dest_dir="./data"
)

For more examples, see the examples/ directory and API Guide.

For detailed setup and usage, see the documentation below.

Documentation

📖 Full Documentation - Hosted on GitHub Pages

Requirements

  • Python 3.11+
  • uv package manager (optional but recommended)

License

See LICENSE.txt

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vresto-0.2.7.tar.gz (80.4 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vresto-0.2.7-py3-none-any.whl (104.8 kB view details)

Uploaded Python 3

File details

Details for the file vresto-0.2.7.tar.gz.

File metadata

  • Download URL: vresto-0.2.7.tar.gz
  • Upload date:
  • Size: 80.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vresto-0.2.7.tar.gz
Algorithm Hash digest
SHA256 bf4ac68cbc2d6c408e150a2fa85039020b0ccc68e6ac56f8295ccf5c3f00d653
MD5 e86ec5c8294e0b4b2575e8f72f79dc21
BLAKE2b-256 c8e4f96f9f19b3d468b2350d1473b4fb0a8a9c1891f8dcd5c15d1c1e026f2a72

See more details on using hashes here.

Provenance

The following attestation bundles were made for vresto-0.2.7.tar.gz:

Publisher: publish.yml on kalfasyan/vresto

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vresto-0.2.7-py3-none-any.whl.

File metadata

  • Download URL: vresto-0.2.7-py3-none-any.whl
  • Upload date:
  • Size: 104.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for vresto-0.2.7-py3-none-any.whl
Algorithm Hash digest
SHA256 bd5edae84d8dc8cae5133d221ff252308233e01b8171465986f14dc4e56e0b3c
MD5 d89aed3c34f067e1f3ece9f55ef3c43f
BLAKE2b-256 dc446f7bf49a21c5e93d45e153ef52120c917826842194ca6df3399b72b14a2a

See more details on using hashes here.

Provenance

The following attestation bundles were made for vresto-0.2.7-py3-none-any.whl:

Publisher: publish.yml on kalfasyan/vresto

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page