/GeoNature-citizen

Portail web d'inventaire citoyen de la biodiversité à destination du grand public

Primary LanguageTypeScriptGNU Affero General Public License v3.0AGPL-3.0

GeoNature-citizen

Portail d'inventaire participatif de la biodiversité à destination du grand public (Démo).

logo

‼️ Projet en cours de développement, actuellement en version beta

English:

GeoNature-citizen is a free and Open Source web solution for citizen science projects for biodiversity data collection. It is fully customizable. Your platform may be a single or a multiple program and be based on existing or adoc list of species.

The data collection is gamified to improve the user management using badges and scores. It can also be customized to accept new user to be created or not.

It is based on a fully open Source stack from PostgreSQL to Angular.

Francais:

GeoNature-citizen est une solution web gratuite et à code source ouvert pour les projets de science citoyenne destinés à la collecte de données sur la biodiversité. L'outil est entièrement personnalisable. Votre plateforme peut être constituée d'un programme unique ou de plusieurs programmes de collecte et être basée sur une liste d'espèces existante ou adoc.

La collecte de données est ludifiée pour améliorer la gestion des utilisateurs à l’aide de badges et de scores. Elle peut également être personnalisée pour accepter que de nouveaux utilisateurs soient créés ou non.

Documentation : https://geonature-citizen.readthedocs.io

Cas d'utilisation

Solutions logicielles

Backend (API)

  • Python 3
    • Flask (moteur de l'API)
    • flask-jwt-extended (pour l'authentification)
    • SQLAlchemy
  • PostgreSQL 10 / Postgis 2.4

Frontend

  • NodeJS 10
  • Angular 8
  • LeafletJS
  • Bootstrap 4.1

Dépendances

GeoNature-citizen s'appuie sur TaxHub pour la création des listes d'espèces utilisées dans les programmes.

Installation

  • Lancer le script install_app.sh pour installer l'application entière ainsi que ses dépendances (postgres, taxhub ...)
  • Au premier lancement le script créera un fichier settings.ini dans config
  • Remplacer toutes les variables par vos données de votre serveur
  • Relancer le script install_app.sh
    • Les fichiers de conf frontend et backend seront alors créés et configurés
    • Le serveur flask sera lancé via supervisor : api_geonature
    • Si vous avez choisi le mode Server side pour le frontend, il sera lancé via supervisor : geonature sur le port 4000

Mise à jour

  • Lancer le script update_app.sh
    • Le script récupérera les modifications depuis git
    • il va transpiler le front et redémarrer si besoin les services supervisor
    • [Warning] si des modifications SQL ont été faites, il faudra les faire manuellement

L'origine du projet

Ce projet est initialement développé pour répondre aux besoins de collectes participatives dans le cadre des démarches d'atlas de biodiversité communal/territorial (ABC/ABT). La première version de ce projet est le fruit d'une démarche mutualisée entre différents projects :

Il constitue l'une des briques du projet GeoNature, porté par les Parcs nationaux de France et bénéficie de l'appui technique du Parc national des Ecrins.