❗ Click here for 🇬🇧 English
vogel-spotter is een webapplicatie die recente vogelwaarnemingen weergeeft vanuit een BirdWeather-station. De applicatie bestaat uit een FastAPI-backend en een frontend die wordt geserveerd door Nginx.
- 🪺 Doel
- 🐤 Functies
- 🐦⬛ Vereisten
- 🐣 Installatie
- 🦆 Projectstructuur
- 🐓 Frontend
- 🦉 Backend
- 🔒 HTTPS-Portal
- 🕊️ Inspiratie
- 🐦 Licentie
- 🐦🔥 To Do
- 🇬🇧 English
Het doel is om vogelliefhebbers een eenvoudig platform te bieden om vogelactiviteit van een BirdWeather-station te volgen.
- Weergave van recente vogelwaarnemingen van het afgelopen uur.
- Weergave van top 25 meest waargenomen vogelsoorten op dit BirdWeather-station.
- Responsief ontwerp geschikt voor verschillende schermformaten.
- Ondersteuning voor dark mode voor gebruik in omgevingen met weinig licht.
- Bevat een refresh-knop voor snelle updates.
- Ondersteuning voor zowel Engels als Nederlands.
- Docker: Zorg dat Docker op je systeem is geïnstalleerd.
- Docker Compose: Vereist om meerdere containers tegelijk te beheren.
Het is mogelijk om de applicatie te implementeren op Vercel. Vercel is een platform voor frontend-hosting en serverloze functies. Klik op de onderstaande knop om de implementatie te starten:
Vergeet niet om de omgevingsvariabele toe te voegen aan de setup. Raadpleeg de Vercel documentatie voor meer informatie.
-
Clone de repository:
git clone https://github.com/iMartzen/vogel-spotter.git cd vogel-spotter
-
Start de applicatie en volg de instructies:
./run.sh
Als het script geen uitvoerrechten heeft:
chmod +x run.sh
-
Open je browser en ga naar:
https://$HOSTNAME.local
-
Stop de applicatie
./stop.sh
Als het script geen uitvoerrechten heeft:
chmod +x stop.sh
Gebruik het Ansible-playbook om de applicatie te implementeren op een server. Raadpleeg de README.md voor vereisten en installatie-instructies.
STATION_ID=1
src/
: Bevat de broncode van de FastAPI-backend en de frontend.ansible/
: Bevat de code voor het Ansible playbookdocker-compose.yml
: Docker Compose-configuratiebestand.Dockerfile
: Dockerfile voor het bouwen van de FastAPI-backend.
De frontend is een single-page applicatie (SPA) gebouwd met vanilla JavaScript. De frontend haalt gegevens op via de API en toont deze dynamisch in de interface.
De backend is gebouwd met FastAPI en biedt de API-endpoints. Deze backend haalt gegevens op van de BirdWeather-API, verwerkt deze en levert ze aan de frontend.
/api/detections
: Geeft recente vogelwaarnemingen van het afgelopen uur terug./api/top25
: Retourneert de top 25 van meest waargenomen vogelsoorten op dit BirdWeather-station.
De setup maakt gebruik van https-portal in de Docker Compose-setup. HTTPS-Portal is een volledig geautomatiseerde HTTPS-server, aangedreven door Nginx, Let's Encrypt en Docker. Het vereenvoudigt het verkrijgen en vernieuwen van SSL-certificaten voor je applicatie.
Dit project is geïnspireerd door het luistervink.nl project, dat zich richt op het monitoren en analyseren van vogelgeluiden. vogel-spotter bouwt voort op dat idee door waarnemingen van BirdWeather-stations te integreren in een gebruiksvriendelijke webapplicatie.
Dit project is gelicentieerd onder de MIT-licentie. Zie het bestand LICENSE voor meer details.
- Dagelijkse top 10: Voeg een lijst toe met de 10 meest waargenomen vogels van vandaag.
- Maandelijkse statistieken: Toon het aantal waarnemingen per vogelsoort gedurende een maand.
vogel-spotter is a web application that displays recent bird sightings from a BirdWeather station. The application consists of a FastAPI backend and a frontend served by Nginx.
- 🪺 Purpose
- 🐤 Features
- 🐦⬛ Requirements
- 🐣 Installation
- 🦆 Project Structure
- 🦚 Frontend
- 🦢 Backend
- 🔒 HTTPS-Portal
- 🕊️ Inspiration
- 🐦 License
- 🦤 To Do
The goal is to provide bird enthusiasts with a simple platform to track bird activity from a BirdWeather station.
- Display recent bird sightings from the past hour.
- Display of the top 25 most observed bird species at this BirdWeather station.
- Responsive design suitable for various screen sizes.
- Support for dark mode for use in low-light environments.
- Includes a refresh button for quick updates.
- Support for both English and Dutch.
- Docker: Ensure Docker is installed on your system.
- Docker Compose: Required to manage multiple containers simultaneously.
It is also possible to deploy the application on Vercel. Vercel is a platform for frontend hosting and serverless functions. Click the button below to start the deployment:
Don't forget to add the environment variable to the setup. Refer to the Vercel documentation for more information.
-
Clone the repository:
git clone https://github.com/iMartzen/vogel-spotter.git cd vogel-spotter
-
Run the application and follow the instructions:
./run.sh
If the script does not have execution permissions:
chmod +x run.sh
-
Open your browser and navigate to:
https://$HOSTNAME.local
-
Stop the application
./stop.sh
If the script does not have execution permissions:
chmod +x stop.sh
Use the Ansible-playbook to deploy the application on a server. Refer to the README.md for requirements and detailed installation instructions.
STATION_ID=1
src/
: Contains the source code for the FastAPI backend and the frontend.ansible/
: Containts the code for the Ansible playbookdocker-compose.yml
: Docker Compose configuration file.Dockerfile
: Dockerfile for building the FastAPI backend.
The frontend is a single-page application (SPA) built with vanilla JavaScript. The frontend fetches data via the API and dynamically displays it in the interface.
The backend is built with FastAPI and provides the API endpoints. This backend fetches data from the BirdWeather API, processes it, and delivers it to the frontend.
/api/detections
: Returns recent bird sightings from the past hour./api/top25
: Returns the top 25 most observed bird species at this BirdWeather station.
The setup uses https-portal in the Docker Compose setup. HTTPS-Portal is a fully automated HTTPS server powered by Nginx, Let's Encrypt, and Docker. It simplifies the process of obtaining and renewing SSL certificates for your application.
This project is inspired by the luistervink.nl project, which focuses on monitoring and analyzing bird sounds. vogel-spotter builds on that idea by integrating observations from BirdWeather stations into a user-friendly web application.
This project is licensed under the MIT license. See the LICENSE file for more details.
- Daily Top 10: Add a list of the 10 most observed birds of today.
- Monthly Statistics: Show the number of observations per bird species over a month.