Skip to content

Latest commit

 

History

History
71 lines (53 loc) · 3.55 KB

README.md

File metadata and controls

71 lines (53 loc) · 3.55 KB

Weather Awareness Sortie Planner (WASP)

An application to help correlate weather data with when you should plan sorties

Problem Statement

Sorties are often planned without much data/insight as to how weather has historically affected launches. We propose a simple open platform that will ingest historical weather data, and show data along with a 'heatmap' of ideal timeframes for when to launch sorties to prevent interference from weather.

weathermap

Data Sources Used

https://climate.af.mil and the 14th weather squadron https://noaa.org

How to run

WARNING: You will need monthly_base_weather_data.csv and place it into /wasp/heatmap/ in order for the Sqllite databse to populate. (Create database function from /API/ is called to create the database). This is required before you can run the project and is also why the CI in the actions is failing.

You will also need to create a map box api token in order for theme changing to work. https://docs.mapbox.com/help/getting-started/access-tokens/

DOCKER From the root directory of the repository, run docker-compose up add --build if needed to rebuild the containers from scratch

LOCAL From the ./wasp directory python manage.py LOCAL TESTS python manage.py test

DJANGO TEST python manage.py wasp.django_tests

Access the GUI

Find the port used in mange.py or in the docker-compose.yml file. Example if docker compose was used: Go to browser and type http://localhost:8000/heatmap

Explanation of Folders/files

./wasp : houses the heatmap and wasp python applications

./wasp/wasp : houses the base python application, defining routes and other general structures

./wasp/heatmap : houses python application for the heatmap

./wasp/heatmap/plotly_app.py : houses most of the code for the heatmap page

./data : houses our example data that is used by our sqllite database

Considerations for Air Gapped Environments and Cloud Deployments

Docker compose will create a container image that you can use in Docker, K8s, or any other container hosting software. In projects without external dependencies (IE F12 -> network in browser doesn't show external network calls) you can just transfer a container image to air gapped environments and it generally will work. Currently our maps and graphs provider (Plotly) has external dependencies for map images and html elements. Plotly does have an enterprise solution which can be hosted in its own network, which would help consolidate dependencies for air gapped deployments, but this is a paid solution. All weather data and aircraft data used is publically available.

Future Ideas

  • Improvements to data storage. Our sqllite database solution worked for our hackathon but can be greatly expanded to be included in a docker deployment (postgres included in docker compose as example)'
  • Convert the project to NPM to help reduce the amount of remote libraries accessed by the application
  • Change maps provider to something that can be hosted locally to aid in air-gapped deployments
  • Formal REST APIs allowing for CRUD operations with the database.

Other Helpful Tips

Ensure that you use a python virtual environment to better manage libraries. Libraries used in application containers should be noted in requirements.txt

# install virtual env & set up env
apt install python3-virtualenv
virtualenv weatherHeatmap
source weatherHeatmap/bin/activate
# install dependencies
pip3 install django

Exec into docker container docker exec -it <container ID> sh