Skip to content

[This is a read-only mirror] API server for Où ça ? - An app for naturalists to manage and view their wildlife observations

License

Notifications You must be signed in to change notification settings

alexandresoro/ouca-backend

Repository files navigation

Où ça ? - Base Naturaliste

About the project

The aim of the Où ça ? project is to provide naturalists with an application where they can record and visualize their wildlife observations.

This project provides an API to interact with these observations - add new elements, edit them and so on. This API is structured as a stateless microservice. It exposes a REST API and is agnostic of the integrator.

Prerequisites

  • Node.js 22 or later
  • pnpm 9 or later
  • PostgreSQL 17 or newer to store the data.
  • A Redis instance used as temporary cache.
  • An OIDC provider to provide authentication services.

Most of the app is independent of the OIDC provider as it follows standard claims except for roles that may be handled differently depending on the provider. Hence, currently only Zitadel is supported, but additional providers can be easily added.

API structure

Application is exposed via a REST API available under /v1/. Specification is exposed at /documentation.

The application exposes a static path at /download/:id, that is to be used for downloading export files. The exact path is returned by the corresponding generate export endpoints.

Authentication

The API require users to be authenticated.

Authentication is done using a separate OIDC provider.

On server side, a valid access token is expected in header Authorization: Bearer xyzabc.

The access token does not need to be a JWT token and can be an opaque one as introspection is performed server-side to validate the access token.

Options

The following environment variables are available to configure the application:

Option Type Default Description
OUCA_SERVER_HOST string localhost The address where the server listen to. See Fastify docs for accepted values
OUCA_SERVER_PORT number (port) 4000 The port used by the server
OUCA_LOG_LEVEL string warn The log level of the server. Uses Pino logging levels
OUCA_LOG_PRETTY boolean false If true the logs will be displayed in a human friendly format
DATABASE_URL string postgresql://basenaturaliste:[email protected]:5432/basenaturaliste The URL of the database to connect to
REDIS_URL string redis://localhost:6379/0 The URL of the Redis instance to connect to.
OUCA_DATABASE_RUN_MIGRATIONS boolean false To enable or disable database migration scripts at startup. Default is false as it is expected to run migrations separately
OUCA_DATABASE_MIGRATION_SCHEMA string public The name of the schema where to store the database migrations info
OUCA_DATABASE_MIGRATION_TABLE string base_naturaliste_umzug_migrations The name of the table where to store the database migrations info
OUCA_DATABASE_MIGRATIONS_PATH string Default migration folder path The path where the migration scripts are stored. Normally this should not need to be changed
OIDC_PROVIDER* string none Only zitadel is supported for the moment
OIDC_ISSUER* string none The URL of the OIDC provider.
OIDC_INTROSPECTION_PATH string /oauth/v2/introspect The path for introspection endpoint.
OIDC_CLIENT_ID* string none Client ID to connect to OIDC.
OIDC_CLIENT_SECRET* string none Client secret to connect to OIDC. The app implements the Client Credentials flow with Basic auth.
SENTRY_DSN string none A Sentry DSN used for error reporting
SENTRY_TRACES_SAMPLE_RATE number 1.0 Sentry traces sample rate ratio

Values with * are required and must be provided.

Structure of an observation

An observation is materialized by the following characteristics:

  • An observer and potential associate observers.
  • The observation date with an optional time and duration.
  • A location for the observation. It is structured with a "locality" that belongs to a "town" which itself belongs to a "department".
  • An optional temperature and weather characteristics.

The characteristics above are considered to be an inventory. An observation belongs to a single inventory, but an inventory can contain several observation, which represents a real use case where several observations can be made during the same session.

  • A species and its related species class.
  • An estimate on the number of species encountered.
  • An estimate on the distance between the observer and the species observed.
  • The age of the species encountered.
  • The sex of the species encountered.
  • An optional list of behaviors describing the state of the species.
  • An optional list of environments surrounding the species.
  • An optional comment on the observation.

About

[This is a read-only mirror] API server for Où ça ? - An app for naturalists to manage and view their wildlife observations

Topics

Resources

License

Stars

Watchers

Forks

Contributors 4

  •  
  •  
  •  
  •