ecobalyse

Ecobalyse makes it possible to understand and calculate the ecological impacts of the products distributed in France.
https://github.com/mtes-mct/ecobalyse

Category: Industrial Ecology
Sub Category: Life Cycle Assessment

Keywords

carbon-emissions carbon-footprint environment environmental-footprint simulation

Keywords from Contributors

climate

Last synced: about 5 hours ago
JSON representation

Repository metadata

Accélerer la mise en place de l'affichage environnemental

README.md

Ecobalyse Build status

Accélerer la mise en place de l'affichage environnemental

L'application est accessible à cette adresse.

Note: le projet Ecobalyse s'appellait initialement Wikicarbone.

Socle technique et prérequis

Le frontend de cette application est écrite en Elm. Vous devez disposer d'un environnement NodeJS 14+ et npm. Pour le backend vous devez disposer d'un environnement python >=3.11, pipenv et gettext sur votre machine. Certains fichiers d’impacts détaillés nécessitent d’installer et de configurer transcrypt pour les lire en local.

Configuration

Les variables d'environnement suivantes doivent être définies :

  • BACKEND_ADMINS : la liste des emails des administrateurs initiaux, séparés par une virgule
  • DEFAULT_FROM_EMAIL : l'email utilisé comme origine pour les mails liés à l'authentification (par défaut ecobalyse@beta.gouv.fr)
  • DJANGO_DEBUG: la valeur du mode DEBUG de Django (par défaut True)
  • DJANGO_SECRET_KEY : la clé secrète de Django
  • EMAIL_SERVER_HOST: serveur SMTP (localhost permet de bénéficier d'une instance maildev)
  • EMAIL_SERVER_PASSWORD: le mot de passe du serveur SMTP
  • EMAIL_SERVER_PORT: Port su serveur SMTP (1025 permet de bénéficier d'une instance maildev)
  • EMAIL_SERVER_USER: Nom d'utilisateur SMTP
  • EMAIL_SERVER_USE_TLS: Utilisation de TLS (par defaut à True, positionner à False pour utiliser l'instance maildev)
  • ENABLE_FOOD_SECTION : affichage ou non de la section expérimentale dédiée à l'alimentaire (valeur True ou False, par défault False)
  • ENABLE_OBJECTS_SECTION : affichage ou non de la section expérimentale dédiée aux objets génériques (valeur True ou False, par défault False)
  • ENABLE_VELI_SECTION : affichage ou non de la section expérimentale dédiée aux véhicules intermédiaires (valeur True ou False, par défault False)
  • MATOMO_HOST: le domaine de l'instance Matomo permettant le suivi d'audience du produit (typiquement stats.beta.gouv.fr).
  • MATOMO_SITE_ID: l'identifiant du site Ecobalyse sur l'instance Matomo permettant le suivi d'audience du produit.
  • MATOMO_TOKEN: le token Matomo permettant le suivi d'audience du produit.
  • NODE_ENV: l'environnement d'exécution nodejs (par défaut, development)
  • PLAUSIBLE_HOST: Le domaine du serveur Plausible (optionnel)
  • RATELIMIT_MAX_RPM: le nombre de requêtes maximum par minute et par ip (par défaut: 5000)
  • RATELIMIT_WHITELIST: liste des adresses IP non soumises au rate-limiting, séparées par des virgules
  • SCALINGO_POSTGRESQL_URL : l'uri pour accéder à Postgresl (définie automatiquement par Scalingo). Si non défini sqlite3 est utilisé.
  • SECRET_KEY: le secret 32bits pour le backend; vous pouvez en générer une avec openssl rand -hex 32
  • SENTRY_DSN: le DSN Sentry à utiliser pour les rapports d'erreur.
  • TRANSCRYPT_KEY: la clé utilisée et autogénérée par transcrypt et disponible dans https://vaultwarden.incubateur.net.
  • ENCRYPTION_KEY : la clé utilisée par les scripts npm run encrypt et npm run decrypt pour chiffrer/déchiffrer les fichiers d’impacts détaillés inclus dans chaque archive de release. Pour générer une nouvelle clé, vous pouvez utiliser le script bin/generate-crypto-key.
  • VERSION_POLL_SECONDS: The number of seconds between two http polls to retrieve the current app version (/version.json, défault: 300)

En développement, copiez le fichier .env.sample, renommez-le .env, et mettez à jour les valeurs qu'il contient ; le serveur de développement node chargera les variables en conséquences.

Pour utiliser le PostgreSQL lancé avec docker, configurez la variable SCALINGO_POSTGRESQL_URL comme ceci :

SCALINGO_POSTGRESQL_URL=postgres://postgres:password@localhost:5433/ecobalyse_dev

Note: docker est également une dépendance requise pour lancer la suite de tests (npm test).

Installation

Frontend

  • Installation des dépendances

    npm ci --ignore-scripts
    
  • Déchiffrage du fichier des impacts détaillés. Attention, la variable d’environnement
    TRANSCRYPT_KEY documentée plus haut doit être renseignée et exportée auparavant.

    export TRANSCRYPT_KEY="<clé de déchiffrement>"
    ./bin/run-transcrypt.sh
    

Backend

pipenv install -d

Assurez-vous d'avoir un PostgreSQL >=16 qui tourne localement si vous souhaitez vous rapprocher de l'environnement de production. À défaut, sqlite sera utilisé.

Pour créer et lancer un PostgreSQL sur le port 5433 en local en utilisant docker :

# Création du volume pour persister les données
docker volume create ecobalyse_postgres_data

# Lancement du docker postgres 16
docker run --name ecobalyse-postgres -e POSTGRES_PASSWORD=password -d -p 5433:5432 -v ecobalyse_postgres_data:/var/lib/postgresql/data postgres:16

# Création de la base de données ecobalyse_dev
docker exec -it ecobalyse-postgres createdb -U postgres ecobalyse_dev

Vous devriez pouvoir y accéder via votre psql local avec la commande suivante :

psql -U postgres -p 5433 -h localhost ecobalyse_dev

Chargement des données par défaut

Pour initialiser la base de données (attention, toutes les données présentes, si il y en a, seront supprimées) :

pipenv run ./backend/update.sh

Développement

Environnement de développement local

Le serveur local de développement se lance au moyen des deux commandes suivantes :

npm start

Trois instances de développement sont alors accessibles :

  • localhost:8002 sert le backend django utilisé pour l'authentification, et sert aussi les fichiers statiques de elm. Sert aussi l'admin django
  • localhost:8001 sert l'API ;
  • localhost:1234 est l'URL à utiliser en développement pour tester l'intégration des trois composants (le front, l'API et le Django) car un proxy Parcel renvoie certaines requêtes vers le port 8001 ou 8002 (voir .proxyrc). Le frontend est servi en mode hot-reload, pour recharger! l'interface Web à chaque modification du code frontend.

ℹ️ Pour accéder à l'admin django, utilisez l'email foo@bar.baz. Le lien d'activation pour se connecter automatiquement à l'admin sera affiché dans votre terminal.

Auto-hébergement avec Docker

Vous trouverez dans ./docker des scripts permettant d’héberger une version publiée d’Ecobalyse en local en utilisant docker. Vous pouvez éditez le Dockerfile pour spécifier la version que vous souhaitez lancer, puis la lancer en utilisant docker compose :

docker compose -f docker/compose.yaml up --build

Un server express sera lancé sur http://localhost:8001. À noter qu’actuellement, vous ne pouvez pas avoir accès aux impacts détailés de cette façon.

Hooks Git avec pre-commit et Formatage de Code avec Prettier et Ruff

Ce projet utilise https://pre-commit.com/ pour gérer les hooks Git ainsi que Prettier et Ruff pour le formatage automatique du code.
Le build sur le CI échouera si les fichiers python, javascript et json ne sont pas proprement formattés.

Vérification Automatique avant chaque Commit

Pour installer les hooks pre-commit, exécutez la commande suivante :

pipenv run pre-commit install

Un hook de pre-commit sera alors configuré pour vérifier que le code est bien formaté avant de permettre le commit. Le hook corrigera les erreurs dans la mesure du possible. Il vous suffira alors d'ajouter les modifications à votre staging, git puis à refaire votre commit.

Il est possible de lancer la vérification du formatage à la main grâce à la commande suivante :

npm run lint:all

Si vous voulez lancer la correction automatique de tous les problèmes détectés, lancez :

npm run fix:all

Si vous ne souhaitez pas que la vérification se fasse de manière automatique, vous pouvez désinstaller pre-commit et les hooks associés :

pipenv run pre-commit uninstall

Débogage des emails

Une instance maildev est lancé en même temps que le serveur de développement, elle est accessible à l'adresse http://localhost:1081.

Compilation

Pour compiler la partie client de l'application :

npm run build

Les fichiers sont alors générés dans le répertoire build à la racine du projet, qui peut être servi de façon statique.

Déploiement

L'application est déployée automatiquement sur la plateforme Scalingo à chaque mise à jour de la branche master sur le dépôt.

Chaque Pull Request effectuée sur le dépôt est également automatiquement déployée sur une instance de revue spécifique, par exemple https://ecobalyse-pr44.osc-fr1.scalingo.io/ pour la pull request #44. Ces instances de recette restent actives 72 heures, puis sont automatiquement décommisionnées passé ce délai ou si la pull request correspondante est mergée.

Ajout d'une variable d'environnement

Pour ajouter une variable d'environnement sur une application, il est recommandé d'utiliser le CLI scalingo qui permet d'ajouter des valeurs qui contiennent plusieurs lignes (à la différence de l'interface graphique qui ne le permet pas) :

scalingo --app ecobalyse env-set "MY_VAR=$(cat fichier.key)"

Fichiers d’impacts détaillés

Les fichiers d’impacts détaillés sont chiffrés à l’aide de transcrypt sur le dépôt public Github. En revanche, la version locale est une version décryptée par transcrypt. Vous pouvez donc utiliser, localement, les commandes git habituelles pour voir les différences dans ces fichiers, par exemple :

git diff master HEAD public/data/textile/processes_impacts.json

Des commandes supplémentaires sont disponibles pour chiffrer et déchiffrer les fichiers manuellement au besoin (débogage par exemple). Notez que ces commandes requièrent la présence de la variable d’environnement ENCRYPTION_KEY pour fonctionner correctement :

npm run encrypt public/data/textile/processes_impacts.json dist/processes_impacts_textile.json.enc
npm run decrypt dist/processes_impacts.json.enc dist/processes_impacts_textile.json

Points d'attention

Lors du merge d'une PR, il est important de merger d'abord la PR correspondante sur ecobalyse-private, puis celle sur ecobalyse.

Serveur de production

Variables d'environnement

Les variables d'environnement doivent être positionnées via l'interface de configuration Scalingo (voir la section Configuration).

Lancement du serveur

Pour lancer le serveur applicatif complet (frontend + backend), par exemple depuis un environnement de production, la démarche est la suivante :

npm run build
npm run server:start

L'application est alors servie sur le port 1234.

Ecobalyse data

Le dépôt ecobalyse-data contient les scripts (principalement Python) utilisés pour
importer et exporter les données du projet Ecobalyse.

Versioning

Le versioning de l'application permet de revenir à des anciennes versions d'Ecobalyse. Pour que ce versioning puisse fonctionner, les anciennes versions (<= 2.0.0) doivent être patchées rétroactivement. Le script ./bin/build-specific-app-version.sh permet de générer une version spécifique de l'application et d'appliquer les patchs si nécessaire. Par exemple, pour générer la version 1.3.2 (le deuxième paramètre est le commit du répertoire https://github.com/MTE-extended/ecobalyse-private associé à cette version, si applicable) :

pipenv run ./bin/build-specific-app-version.sh v1.3.2 3531c73f23a1eb6f1fc6b9c256a5344742230fcf

Un fichier v1.3.2-dist.tar.gz sera disponible à la racine du projet et un répertoire v1.3.2 aura été créé dans versions/.

Le script python permettant de patcher les fichiers est disponible ici : ./bin/patch_files_for_versions_compat.py.

Toutes les versions disponibles dans les releases Github ont été patchées comme il se doit.


Owner metadata


GitHub Events

Total
Last Year

Committers metadata

Last synced: about 18 hours ago

Total Commits: 2,003
Total Committers: 17
Avg Commits per committer: 117.824
Development Distribution Score (DDS): 0.437

Commits in past year: 324
Committers in past year: 10
Avg Commits per committer in past year: 32.4
Development Distribution Score (DDS) in past year: 0.531

Name Email Commits
Nicolas Perriault n****s@p****t 1128
Christophe Combelles c****b@f****r 331
Mathieu Agopian m****u@a****o 226
paulboosz p****z@g****m 127
Vincent Jousse v****t@j****g 104
github-actions[bot] 4****] 30
Cedric Rossi c****i@b****r 16
Tristan Robert t****4@g****m 16
dependabot[bot] 4****] 13
Ingredient editor e****e@b****r 3
Alban Fournier a****x@g****m 3
Emile Rolley ⏚ 4****y 1
Julien Bouquillon j****n@b****m 1
Nicolas Dubois n****s@g****m 1
Nicolas Planchenault 1****l 1
PascalDagras 9****s 1
cerve c****e@g****m 1

Committer domains:


Issue and Pull Request metadata

Last synced: 2 days ago

Total issues: 242
Total pull requests: 1,478
Average time to close issues: 28 days
Average time to close pull requests: 8 days
Total issue authors: 14
Total pull request authors: 14
Average comments per issue: 0.68
Average comments per pull request: 0.52
Merged pull request: 1,049
Bot issues: 0
Bot pull requests: 107

Past year issues: 235
Past year pull requests: 493
Past year average time to close issues: 30 days
Past year average time to close pull requests: 6 days
Past year issue authors: 13
Past year pull request authors: 11
Past year average comments per issue: 0.67
Past year average comments per pull request: 0.45
Past year merged pull request: 306
Past year bot issues: 0
Past year bot pull requests: 37

More stats: https://issues.ecosyste.ms/repositories/lookup?url=https://github.com/mtes-mct/ecobalyse

Top Issue Authors

  • camcoq-start (164)
  • n1k0 (24)
  • vjousse (17)
  • paulboosz (14)
  • nicolaspkandeel (5)
  • cedricr (4)
  • ccomb (4)
  • pgredigui (4)
  • desoindx (1)
  • CodeByNico (1)
  • p-j (1)
  • antoineverger1 (1)
  • albanfournier (1)
  • guillaume-vizier-holis (1)

Top Pull Request Authors

  • n1k0 (525)
  • ccomb (295)
  • paulboosz (198)
  • vjousse (170)
  • magopian (85)
  • tristanrobert (79)
  • github-actions[bot] (58)
  • dependabot[bot] (49)
  • cedricr (8)
  • albanfournier (4)
  • wo0dyn (2)
  • revolunet (2)
  • EmileRolley (2)
  • p-j (1)

Top Issue Labels

  • product feature (35)
  • backoffice (30)
  • data (28)
  • objects (18)
  • bug (18)
  • textile (16)
  • tech-debt (14)
  • api (14)
  • vehicles (11)
  • ui (10)
  • enhancement (9)
  • intra emergency (7)
  • kpi (4)
  • auth/sso (3)
  • food (3)
  • good first issue (2)
  • veli (1)

Top Pull Request Labels

  • dependencies (49)
  • javascript (37)
  • pending-release (36)
  • automated (32)
  • python (12)
  • autorelease: pending (12)
  • autorelease: tagged (10)
  • automated pr (4)
  • ui (4)
  • data (2)
  • tech-debt (2)
  • intra emergency (1)
  • food (1)
  • api (1)
  • auth/sso (1)
  • backoffice (1)
  • bug (1)

Package metadata

proxy.golang.org: github.com/mtes-mct/ecobalyse

  • Homepage:
  • Documentation: https://pkg.go.dev/github.com/mtes-mct/ecobalyse#section-documentation
  • Licenses: mit
  • Latest release: v8.2.0+incompatible (published 16 days ago)
  • Last Synced: 2025-12-24T15:02:16.889Z (2 days ago)
  • Versions: 31
  • Dependent Packages: 0
  • Dependent Repositories: 0
  • Rankings:
    • Dependent packages count: 5.395%
    • Average: 5.576%
    • Dependent repos count: 5.758%
proxy.golang.org: github.com/MTES-MCT/ecobalyse

  • Homepage:
  • Documentation: https://pkg.go.dev/github.com/MTES-MCT/ecobalyse#section-documentation
  • Licenses: mit
  • Latest release: v8.2.0+incompatible (published 16 days ago)
  • Last Synced: 2025-12-24T15:02:16.650Z (2 days ago)
  • Versions: 31
  • Dependent Packages: 0
  • Dependent Repositories: 0
  • Rankings:
    • Dependent packages count: 5.395%
    • Average: 5.576%
    • Dependent repos count: 5.758%

Dependencies

.github/workflows/codeql-analysis.yml actions
  • actions/checkout v2 composite
  • github/codeql-action/analyze v1 composite
  • github/codeql-action/autobuild v1 composite
  • github/codeql-action/init v1 composite
.github/workflows/node.js.yml actions
  • actions/cache v2 composite
  • actions/checkout v2 composite
  • actions/setup-node v2 composite
package-lock.json npm
  • 718 dependencies
package.json npm
  • concurrently ^7.6.0 development
  • elm-format ^0.8.5 development
  • elm-review ^2.8.5 development
  • elm-test 0.19.1-revision11 development
  • jest ^29.3.1 development
  • nodemon ^2.0.20 development
  • process ^0.11.10 development
  • rimraf ^4.0.4 development
  • supertest ^6.3.3 development
  • @parcel/transformer-elm ^2.8.1
  • @parcel/transformer-image ^2.8.1
  • @parcel/transformer-sass ^2.8.1
  • @sentry/browser ^7.26.0
  • @sentry/node ^7.26.0
  • @sentry/tracing ^7.26.0
  • bootstrap ^5.2.3
  • cors ^2.8.5
  • elm ^0.19.1-5
  • express ^4.18.2
  • helmet ^6.0.1
  • highcharts ^10.3.2
  • js-yaml ^4.1.0
  • parcel ^2.8.1
  • piwik ^1.0.9
  • rapidoc ^9.3.3
.github/workflows/create_release_archive.yml actions
  • ./.github/actions/create-release * composite
  • ./.github/actions/transcrypt-cli * composite
  • actions/checkout v4 composite
  • actions/setup-node v4 composite
  • actions/upload-artifact v4 composite
.github/workflows/create_release.yml actions
  • ./.github/actions/create-release * composite
  • ./.github/actions/transcrypt-cli * composite
  • actions/checkout v4 composite
  • actions/setup-node v4 composite
  • orhun/git-cliff-action v4 composite
  • softprops/action-gh-release v2 composite
.github/workflows/export_json.yml actions
  • ./.github/actions/scalingo-cli * composite
  • actions/checkout v4 composite
  • actions/upload-artifact v4 composite
  • astral-sh/setup-uv v4 composite
  • shimataro/ssh-key-action v2 composite
.github/workflows/semantic-pr.yml actions
  • amannn/action-semantic-pull-request v5 composite
packages/python/ecobalyse/setup.py pypi
.github/actions/scalingo-cli/action.yml actions
docker/Dockerfile docker
  • node ${NODE_VERSION}-alpine build
pyproject.toml pypi
  • advanced-alchemy >=1.4.4
  • aiosmtplib >=4.0.0
  • aiosqlite >=0.21.0
  • asyncpg >=0.30.0
  • asyncstdlib >=3.13.1
  • check-jsonschema >=0.32.1
  • emails >=0.6
  • litestar [jwt,sqlalchemy,standard]>=2.16.0
  • msgspec >=0.19.0
  • orjson >=3.10.16
  • psycopg [binary,pool]>=3.2.6
  • pwdlib [argon2]>=0.2.1
  • pygithub >=2.6.1
  • pytest-databases [postgres]>=0.12.0
  • pytest-mock >=3.14.1
  • python-stdnum >=2.1
  • sentry-sdk [litestar]>=2.41
  • structlog >=25.2.0
  • typer >=0.16.0
.github/workflows/ecobalyse-data-sync.yml actions
  • actions/checkout v4 composite
.github/workflows/score_history.yml actions
  • ./.github/actions/scalingo-cli * composite
  • ./.github/actions/transcrypt-cli * composite
  • actions/cache v4 composite
  • actions/checkout v4 composite
  • actions/setup-node v4 composite
  • astral-sh/setup-uv v4 composite
  • shimataro/ssh-key-action v2 composite
.github/workflows/create_pr_for_changelog.yml actions
  • actions/checkout v4 composite
  • orhun/git-cliff-action v4 composite
  • peter-evans/create-pull-request v7 composite
.github/actions/create-release/action.yml actions
  • actions/cache v4 composite
docker-compose.yml docker
  • postgres 14
.github/actions/transcrypt-cli/action.yml actions
uv.lock pypi
  • 104 dependencies

Score: -Infinity