Skip to main content

Web GUI for Leeway simulations with OpenDrift

Project description

GitHub Workflow Status Pylint PyPi License Code style: black

About

This is a little Django web application that does an OpenDrift Leeway simulation with a set of provided parameters via a web form. The result is sent to a user via e-mail.

This is an experimental tool to help Search and Rescue operations. An experimental service is available at leeway.tuerantuer.org.

Sample output from the leeway tool (100 points, 1km radius, south of Lampedusa):

Example leeway output

Usage

Django users have to be created in the CRUD backend, available at https://leeway.example.com/admin. E-mail addresses should be added for users as they receive the result via e-mail.

The program regularly fetches incoming mails via IMAP and starts simulations from key-value-pairs in the mail subject or text body. The sender of the mail needs to have an associated account. Allowed keys via e-mail are: longitude, latitude, object_type, radius, duration, start_time. The separator between key and value is =. Key-value-pairs are separated by ; in the subject and by new lines in the text body. The date format for start date is YYYY-MM-DD HH:MM:SS.

API usage

API documentation can be found at: https://leeway.tuerantuer.org/api/docs/

Authentication can be provided in two ways:

  1. Via your session cookie, obtained from the normal login
  2. Via an authentication token, can be obtained via /api/auth/login/

Installation

Prerequisite: Python 3.8 or later is required.

  1. Clone this repository and change into the new directory:
    git clone git@github.com:digitalfabrik/opendrift-leeway-webgui.git leeway
    cd leeway
    
  2. Create a virtual environment outside of the project directory and activate it:
    python3 -m venv ~/.venv
    source ~/.venv/bin/activate
    
  3. Install the dependencies:
    pip install -e .[dev]
    
  4. Create minimal config file /etc/opendrift-leeway-webgui.ini to enable DEBUG mode:
    [base]
    DEBUG = True
    
  5. Initialize the database:
    cd opendrift_leeway_webgui
    python3 manage.py migrate
    python3 manage.py createsuperuser
    
  6. Build the enhanced Docker container:
    cd opendrift
    docker build -t opendrift-leeway-custom .
    

Development Server

  1. Switch into the cloned project and then into the opendrift_leeway_webgui subdirectory.
  2. Open two terminals:
    1. In the first terminal run:
      source ../.venv/bin/activate
      python3 manage.py runserver
      
    2. In the second terminal run:
      source ../.venv/bin/activate
      celery -A leeway worker -l INFO
      

Releasing

Run bumpver update to perform the following tasks with one command:

  1. Bump the version in pyproject.toml
  2. Create a version bump commit
  3. Create a new version tag
  4. Push the commit and tag
  5. Create a new release on PyPI via GitHub Actions

Production Server

This details the installation on Debian with Apache2 and mod_wsgi.

  1. Create target directory on the production system:
    sudo mkdir /opt/iopendrift-leeway-webgui
    sudo chown www-data:www-data /opt/opendrift-leeway-webgui
    
  2. Create the virtual environment:
    sudo -u www-data bash
    python3 -m venv .venv
    source .venv/bin/activate
    
  3. Install the application into the virtual environment:
    pip install opendrift-leeway-webgui
    
  4. Copy the example config file to /etc/opendrift-leeway-webgui.ini and fill in the template
  5. Install Docker and add the docker group to the www-data user.
  6. Create symlink to facilitate the Apache configuration:
    ln -s $(python -c "from opendrift_leeway_webgui.core import wsgi; print(wsgi.__file__)") .
    
  7. Configure Apache2 according to the example.
  8. Set up Celery worker with leeway-celery.service and start the service.

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

opendrift_leeway_webgui-2026.3.0.tar.gz (216.8 kB view details)

Uploaded Source

Built Distribution

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

opendrift_leeway_webgui-2026.3.0-py3-none-any.whl (230.0 kB view details)

Uploaded Python 3

File details

Details for the file opendrift_leeway_webgui-2026.3.0.tar.gz.

File metadata

File hashes

Hashes for opendrift_leeway_webgui-2026.3.0.tar.gz
Algorithm Hash digest
SHA256 ae3ebbdb535a38e421d48adef7af7e5764e7ca885dfe72c67d741ddef0fa41d3
MD5 3c8c5b627b4104ebf15d12e3f9307744
BLAKE2b-256 d22d70f9cf569a3faf74b0c5348262f8e59c42a81f3d861899d334235c9e0aab

See more details on using hashes here.

File details

Details for the file opendrift_leeway_webgui-2026.3.0-py3-none-any.whl.

File metadata

File hashes

Hashes for opendrift_leeway_webgui-2026.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2efe54239528b7216ffc882c220281c95c263ae2ccd88ab83ee2d6b662a3b055
MD5 6d6c52166b37471a37a3c394d3b721c3
BLAKE2b-256 5d7de19e15b49178b952099997ee35f89c6c303805cab2076ab6f6885626e845

See more details on using hashes here.

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