Skip to content

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.

License

Notifications You must be signed in to change notification settings

iMartzen/vogel-spotter

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

56 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

🦜 vogel-spotter

❗ 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.

πŸ“‘ Inhoudsopgave

πŸͺΊ Doel

Het doel is om vogelliefhebbers een eenvoudig platform te bieden om vogelactiviteit van een BirdWeather-station te volgen.

🐀 Functies

  • Weergave van recente vogelwaarnemingen van het afgelopen uur.
  • Geeft de status van het BirdWeather-station weer (online/offline).
  • 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.

πŸ¦β€β¬› Vereisten

  • Docker: Zorg dat Docker op je systeem is geΓ―nstalleerd.
  • Docker Compose: Vereist om meerdere containers tegelijk te beheren.

🐣 Installatie

β–² Vercel

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:

Deploy to Vercel

Vergeet niet om de omgevingsvariabele toe te voegen aan de setup. Raadpleeg de Vercel documentatie voor meer informatie.

πŸ’» Lokaal

  1. Clone de repository:

    git clone https://github.com/iMartzen/vogel-spotter.git
    cd vogel-spotter
  2. Start de applicatie en volg de instructies:

    ./run.sh

    Als het script geen uitvoerrechten heeft: chmod +x run.sh

  3. Open je browser en ga naar:

    https://$HOSTNAME.local
  4. Stop de applicatie

    ./stop.sh

    Als het script geen uitvoerrechten heeft: chmod +x stop.sh

🌐 Server

Gebruik het Ansible-playbook om de applicatie te implementeren op een server. Raadpleeg de README.md voor vereisten en installatie-instructies.

πŸͺΉ Voorbeeld .env bestand

STATION_ID=1

πŸ¦† Projectstructuur

  • src/: Bevat de broncode van de FastAPI-backend en de frontend.
  • ansible/: Bevat de code voor het Ansible playbook
  • docker-compose.yml: Docker Compose-configuratiebestand.
  • Dockerfile: Dockerfile voor het bouwen van de FastAPI-backend.

πŸ“ Frontend

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.

πŸ¦‰ Backend

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 Endpoints

  • /api/detections: Geeft recente vogelwaarnemingen van het afgelopen uur terug.
  • /api/status: Geeft de status van het BirdWeather-station terug (online/offline).

πŸ”’ HTTPS-Portal

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.

πŸ•ŠοΈ Inspiratie

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.

🐦 Licentie

Dit project is gelicentieerd onder de MIT-licentie. Zie het bestand LICENSE voor meer details.

πŸ¦β€πŸ”₯ To Do

Mogelijke uitbreidingen

  • 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.
  • Top 25 aller tijden: Voeg een overzicht toe van de 25 meest gespotte vogels sinds het begin van de registratie.

πŸ‡¬πŸ‡§ English

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.

πŸ“‘ Table of Contents

πŸͺΊ Purpose

The goal is to provide bird enthusiasts with a simple platform to track bird activity from a BirdWeather station.

🐀 Features

  • Display recent bird sightings from the past hour.
  • Show the status of the BirdWeather station (online/offline).
  • 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.

πŸ¦β€β¬› Requirements

  • Docker: Ensure Docker is installed on your system.
  • Docker Compose: Required to manage multiple containers simultaneously.

🐣 Installation

β–² Vercel

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:

Deploy to Vercel

Don't forget to add the environment variable to the setup. Refer to the Vercel documentation for more information.

πŸ’» Locally

  1. Clone the repository:

    git clone https://github.com/iMartzen/vogel-spotter.git
    cd vogel-spotter
  2. Run the application and follow the instructions:

    ./run.sh

    If the script does not have execution permissions: chmod +x run.sh

  3. Open your browser and navigate to:

    https://$HOSTNAME.local
  4. Stop the application

    ./stop.sh

    If the script does not have execution permissions: chmod +x stop.sh

🌐 Server

Use the Ansible-playbook to deploy the application on a server. Refer to the README.md for requirements and detailed installation instructions.

πŸͺΉ Example .env file

STATION_ID=1

πŸ¦† Project Structure

  • src/: Contains the source code for the FastAPI backend and the frontend.
  • ansible/: Containts the code for the Ansible playbook
  • docker-compose.yml: Docker Compose configuration file.
  • Dockerfile: Dockerfile for building the FastAPI backend.

🦚 Frontend

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.

🦒 Backend

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 Endpoints

  • /api/detections: Returns recent bird sightings from the past hour.
  • /api/status: Returns the status of the BirdWeather station (online/offline).

πŸ”’ HTTPS-Portal

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.

πŸ•ŠοΈ Inspiration

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.

🐦 License

This project is licensed under the MIT license. See the LICENSE file for more details.

🦀 To Do

Possible Extensions

  • 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.
  • Top 25 All Time: Add an overview of the 25 most spotted birds since the start of the registration.

About

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.

Topics

Resources

License

Stars

Watchers

Forks